2025-09-10 23:29:27 +03:00
|
|
|
<script setup>
|
2025-09-14 17:44:32 +03:00
|
|
|
import { reactive, ref } from 'vue'
|
2025-09-14 14:22:15 +03:00
|
|
|
import { useAuthStore } from '@/stores/authStore.js'
|
2025-09-14 17:44:32 +03:00
|
|
|
import { storeToRefs } from 'pinia'
|
2025-09-09 23:19:17 +03:00
|
|
|
|
2025-09-12 23:50:21 +03:00
|
|
|
const store = useAuthStore()
|
2025-09-09 23:19:17 +03:00
|
|
|
|
2025-09-14 17:44:32 +03:00
|
|
|
const { activeTab } = storeToRefs(store)
|
|
|
|
|
|
|
|
|
|
const signInEmail = ref('')
|
|
|
|
|
const signInPassword = ref('')
|
2025-09-09 23:19:17 +03:00
|
|
|
|
2025-09-14 14:22:15 +03:00
|
|
|
const onSignIn = () => {
|
2025-09-14 17:44:32 +03:00
|
|
|
store.login(signInEmail.value, signInPassword.value)
|
2025-09-12 23:50:21 +03:00
|
|
|
}
|
2025-09-14 14:22:15 +03:00
|
|
|
|
2025-09-14 17:44:32 +03:00
|
|
|
const signUp = reactive({
|
|
|
|
|
email: '',
|
|
|
|
|
password: '',
|
|
|
|
|
reenterPassword: '',
|
|
|
|
|
})
|
|
|
|
|
|
2025-09-14 14:22:15 +03:00
|
|
|
const onSignUp = () => {
|
2025-09-14 17:44:32 +03:00
|
|
|
store.register(signUp.email, signUp.password)
|
2025-09-14 14:22:15 +03:00
|
|
|
}
|
2025-09-09 23:19:17 +03:00
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<template>
|
2025-09-12 23:50:21 +03:00
|
|
|
<n-card class="my-card">
|
|
|
|
|
<n-tabs
|
2025-09-14 17:44:32 +03:00
|
|
|
v-model:value="activeTab"
|
2025-09-12 23:50:21 +03:00
|
|
|
class="card-tabs"
|
|
|
|
|
size="large"
|
|
|
|
|
animated
|
|
|
|
|
pane-wrapper-style="margin: 0 -4px"
|
|
|
|
|
pane-style="padding-left: 4px; padding-right: 4px; box-sizing: border-box;"
|
|
|
|
|
>
|
|
|
|
|
<n-tab-pane name="signin" tab="Sign in">
|
2025-09-14 14:22:15 +03:00
|
|
|
<n-form @submit.prevent="onSignIn">
|
2025-09-12 23:50:21 +03:00
|
|
|
<n-form-item-row label="Email">
|
2025-09-14 17:44:32 +03:00
|
|
|
<n-input v-model:value="signInEmail"/>
|
2025-09-12 23:50:21 +03:00
|
|
|
</n-form-item-row>
|
|
|
|
|
<n-form-item-row label="Password">
|
2025-09-14 17:44:32 +03:00
|
|
|
<n-input v-model:value="signInPassword" type="password" show-password-on="click" />
|
2025-09-12 23:50:21 +03:00
|
|
|
</n-form-item-row>
|
|
|
|
|
</n-form>
|
2025-09-14 14:22:15 +03:00
|
|
|
<n-button type="primary" block secondary strong @click="onSignIn"> Sign In</n-button>
|
2025-09-12 23:50:21 +03:00
|
|
|
</n-tab-pane>
|
|
|
|
|
|
|
|
|
|
<n-tab-pane name="signup" tab="Sign up">
|
2025-09-14 17:44:32 +03:00
|
|
|
<n-form @submit.prevent="onSignUp">
|
|
|
|
|
<n-form-item-row label="Email" >
|
|
|
|
|
<n-input v-model:value="signUp.email"/>
|
2025-09-12 23:50:21 +03:00
|
|
|
</n-form-item-row>
|
|
|
|
|
<n-form-item-row label="Password">
|
2025-09-14 17:44:32 +03:00
|
|
|
<n-input type="password" v-model:value="signUp.password" show-password-on="click" />
|
2025-09-12 23:50:21 +03:00
|
|
|
</n-form-item-row>
|
|
|
|
|
<n-form-item-row label="Reenter Password">
|
2025-09-14 17:44:32 +03:00
|
|
|
<n-input type="password" v-model:value="signUp.reenterPassword" show-password-on="click" />
|
2025-09-12 23:50:21 +03:00
|
|
|
</n-form-item-row>
|
|
|
|
|
</n-form>
|
2025-09-14 14:22:15 +03:00
|
|
|
<n-button type="primary" block secondary strong @click="onSignUp">Sign up</n-button>
|
2025-09-12 23:50:21 +03:00
|
|
|
</n-tab-pane>
|
|
|
|
|
</n-tabs>
|
|
|
|
|
</n-card>
|
2025-09-09 23:19:17 +03:00
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
2025-09-12 23:50:21 +03:00
|
|
|
.card-tabs .n-tabs-nav--bar-type {
|
|
|
|
|
padding-left: 4px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.my-card {
|
|
|
|
|
max-width: 500px;
|
|
|
|
|
width: 90%;
|
2025-09-14 17:44:32 +03:00
|
|
|
margin: auto;
|
2025-09-10 23:29:27 +03:00
|
|
|
}
|
2025-09-09 23:19:17 +03:00
|
|
|
</style>
|