refactor login/register UI+Logic

This commit is contained in:
Hayden 2022-09-24 17:57:15 -08:00
parent 2cb0f75220
commit 945e968090

View file

@ -1,7 +1,4 @@
<script setup lang="ts"> <script setup lang="ts">
import TextField from "@/components/Form/TextField.vue";
import { useNotifier } from "@/composables/use-notifier";
import { usePublicApi } from "@/composables/use-api";
import { useAuthStore } from "~~/stores/auth"; import { useAuthStore } from "~~/stores/auth";
useHead({ useHead({
title: "Homebox | Organize and Tag Your Stuff", title: "Homebox | Organize and Tag Your Stuff",
@ -11,49 +8,29 @@
layout: "empty", layout: "empty",
}); });
const api = usePublicApi();
const toast = useNotifier();
const authStore = useAuthStore(); const authStore = useAuthStore();
if (!authStore.isTokenExpired) { if (!authStore.isTokenExpired) {
navigateTo("/home"); navigateTo("/home");
} }
const registerFields = [ const username = ref("");
{ const email = ref("");
label: "What's your name?", const groupName = ref("");
value: "", const password = ref("");
}, const canRegister = ref(false);
{
label: "What's your email?",
value: "",
},
{
label: "Name your group",
value: "",
},
{
label: "Set your password",
value: "",
type: "password",
},
{
label: "Confirm your password",
value: "",
type: "password",
},
];
const api = usePublicApi();
async function registerUser() { async function registerUser() {
loading.value = true; loading.value = true;
// Print Values of registerFields
const { error } = await api.register({ const { error } = await api.register({
user: { user: {
name: registerFields[0].value, name: username.value,
email: registerFields[1].value, email: email.value,
password: registerFields[3].value, password: password.value,
}, },
groupName: registerFields[2].value, groupName: groupName.value,
}); });
if (error) { if (error) {
@ -64,48 +41,34 @@
toast.success("User registered"); toast.success("User registered");
loading.value = false; loading.value = false;
loginFields[0].value = registerFields[1].value;
registerForm.value = false; registerForm.value = false;
} }
const loginFields = [
{
label: "Email",
value: "",
},
{
label: "Password",
value: "",
type: "password",
},
];
const toast = useNotifier();
const loading = ref(false); const loading = ref(false);
const loginPassword = ref("");
async function login() { async function login() {
loading.value = true; loading.value = true;
const { data, error } = await api.login(loginFields[0].value, loginFields[1].value); const { data, error } = await api.login(email.value, loginPassword.value);
if (error) { if (error) {
toast.error("Invalid email or password"); toast.error("Invalid email or password");
} else { loading.value = false;
toast.success("Logged in successfully"); return;
authStore.$patch({
token: data.token,
expires: data.expiresAt,
});
navigateTo("/home");
} }
toast.success("Logged in successfully");
authStore.$patch({
token: data.token,
expires: data.expiresAt,
});
navigateTo("/home");
loading.value = false; loading.value = false;
} }
const registerForm = ref(false); const [registerForm, toggleLogin] = useToggle();
function toggleLogin() {
registerForm.value = !registerForm.value;
}
</script> </script>
<template> <template>
@ -159,19 +122,17 @@
<Icon name="heroicons-user" class="mr-1 w-7 h-7" /> <Icon name="heroicons-user" class="mr-1 w-7 h-7" />
Register Register
</h2> </h2>
<TextField <FormTextField v-model="email" label="Set your email?" />
v-for="field in registerFields" <FormTextField v-model="username" label="What's your name?" />
:key="field.label" <FormTextField v-model="groupName" label="Name your group" />
v-model="field.value" <FormTextField v-model="password" label="Set your password" type="password" />
:label="field.label" <PasswordScore v-model:valid="canRegister" :password="password" />
:type="field.type"
/>
<div class="card-actions justify-end"> <div class="card-actions justify-end">
<button <button
type="submit" type="submit"
class="btn btn-primary mt-2" class="btn btn-primary mt-2"
:class="loading ? 'loading' : ''" :class="loading ? 'loading' : ''"
:disabled="loading" :disabled="loading || !canRegister"
> >
Register Register
</button> </button>
@ -186,13 +147,8 @@
<Icon name="heroicons-user" class="mr-1 w-7 h-7" /> <Icon name="heroicons-user" class="mr-1 w-7 h-7" />
Login Login
</h2> </h2>
<TextField <FormTextField v-model="email" label="Email" />
v-for="field in loginFields" <FormTextField v-model="loginPassword" label="Password" type="password" />
:key="field.label"
v-model="field.value"
:label="field.label"
:type="field.type"
/>
<div class="card-actions justify-end mt-2"> <div class="card-actions justify-end mt-2">
<button type="submit" class="btn btn-primary" :class="loading ? 'loading' : ''" :disabled="loading"> <button type="submit" class="btn btn-primary" :class="loading ? 'loading' : ''" :disabled="loading">
Login Login
@ -205,7 +161,7 @@
<div class="text-center mt-6"> <div class="text-center mt-6">
<button <button
class="text-base-content text-lg hover:bg-primary hover:text-primary-content px-3 py-1 rounded-xl transition-colors duration-200" class="text-base-content text-lg hover:bg-primary hover:text-primary-content px-3 py-1 rounded-xl transition-colors duration-200"
@click="toggleLogin" @click="() => toggleLogin()"
> >
{{ registerForm ? "Already a User? Login" : "Not a User? Register" }} {{ registerForm ? "Already a User? Login" : "Not a User? Register" }}
</button> </button>
@ -227,4 +183,8 @@
transform: translateX(20px); transform: translateX(20px);
opacity: 0; opacity: 0;
} }
progress[value]::-webkit-progress-value {
transition: width 0.5s;
}
</style> </style>