<template>
<div class="_panel" v-if="$store.getters.isSignedIn && fetching">
	<mk-loading/>
</div>
<div v-else-if="$store.getters.isSignedIn">
	<x-form
		class="form"
		ref="form"
		v-if="state == 'waiting'"
		:session="session"
		@denied="state = 'denied'"
		@accepted="accepted"
	/>
	<div class="denied _panel" v-if="state == 'denied'">
		<h1>{{ $t('_auth.denied') }}</h1>
	</div>
	<div class="accepted _panel" v-if="state == 'accepted'">
		<h1>{{ session.app.isAuthorized ? this.$t('already-authorized') : this.$t('allowed') }}</h1>
		<p v-if="session.app.callbackUrl">{{ $t('_auth.callback') }}<mk-ellipsis/></p>
		<p v-if="!session.app.callbackUrl">{{ $t('_auth.pleaseGoBack') }}</p>
	</div>
	<div class="error _panel" v-if="state == 'fetch-session-error'">
		<p>{{ $t('error') }}</p>
	</div>
</div>
<div class="signin" v-else>
	<mk-signin @login="onLogin"/>
</div>
</template>

<script lang="ts">
import Vue from 'vue';
import XForm from './auth.form.vue';
import MkSignin from '../components/signin.vue';

export default Vue.extend({
	components: {
		XForm,
		MkSignin,
	},
	data() {
		return {
			state: null,
			session: null,
			fetching: true
		};
	},
	computed: {
		token(): string {
			return this.$route.params.token;
		}
	},
	mounted() {
		if (!this.$store.getters.isSignedIn) return;

		// Fetch session
		this.$root.api('auth/session/show', {
			token: this.token
		}).then(session => {
			this.session = session;
			this.fetching = false;

			// 既に連携していた場合
			if (this.session.app.isAuthorized) {
				this.$root.api('auth/accept', {
					token: this.session.token
				}).then(() => {
					this.accepted();
				});
			} else {
				this.state = 'waiting';
			}
		}).catch(error => {
			this.state = 'fetch-session-error';
			this.fetching = false;
		});
	},
	methods: {
		accepted() {
			this.state = 'accepted';
			if (this.session.app.callbackUrl) {
				location.href = `${this.session.app.callbackUrl}?token=${this.session.token}`;
			}
		}, onLogin(res) {
			localStorage.setItem('i', res.i);
			location.reload();
		}
	}
});
</script>

<style lang="scss" scoped>

</style>