<template>
  <q-page
    padding
    class="fit row  justify-center items-center content-center"
  >
    <q-card class="col-xs-11 col-sm-8 col-md-6 col-lg-4 justify-center items-center content-center">
      <q-toolbar class="bg-primary text-white">
        <q-toolbar-title>
          Login
        </q-toolbar-title>
      </q-toolbar>

      <q-card-section>
        <q-form
          ref="LoginForm"
          @submit="doLogin"
          class="q-gutter-md"
        >
          <q-input
            filled
            v-model="userid"
            label="Benutzername oder E-Mail"
            :rules="rules"
          />
          <q-input
            filled
            v-model="password"
            type="password"
            label="Password"
            :rules="rules"
          />
          <div class="row justify-end">
            <q-btn
              label="Login"
              type="submit"
              color="primary"
            />
          </div>
        </q-form>
      </q-card-section>
    </q-card>
  </q-page>
</template>

<script lang="ts">
import { defineComponent, ref } from '@vue/composition-api';
import { Loading, Notify } from 'quasar';

export default defineComponent({
  // name: 'PageName'
  setup(_, { root }) {
    const mainRoute = { name: 'dashboard' };

    /* Stuff for the real login page */
    const userid = ref('');
    const password = ref('');
    const rules = [
      (val: string) => (val && val.length > 0) || 'Feld darf nicht leer sein!',
    ];

    function doLogin() {
      Loading.show({
        message: 'Du wirst angemeldet',
      });
      root.$store
        .dispatch('session/login', {
          userid: userid.value,
          password: password.value,
        })
        .then(() => {
          const x = root.$route.query['redirect'];
          void root.$router.push(
            typeof x === 'string' ? { path: x } : mainRoute
          );
        })
        .catch((error: { status: number } | undefined) => {
          if (error && error.status === 401) {
            password.value = '';
            Notify.create({
              group: false,
              type: 'negative',
              message: 'Benutzername oder Passwort sind falsch.',
              timeout: 10000,
              progress: true,
              actions: [{ icon: 'mdi-close', color: 'white' }],
            });
          }
        })
        .finally(() => {
          Loading.hide();
        });
    }

    return { userid, password, doLogin, rules };
  },
});
</script>