generated from pascalmartineau/wp-skeleton
minor: rename onLoginSubmit / onLoginClick
All checks were successful
Deploy WordPress and Nuxt / deploy (push) Successful in 1m2s
All checks were successful
Deploy WordPress and Nuxt / deploy (push) Successful in 1m2s
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
const { loginFields, onLoginSubmit } = useAuth();
|
const { loginFields, login } = useAuth();
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
@@ -10,6 +10,6 @@ const { loginFields, onLoginSubmit } = useAuth();
|
|||||||
description="Veuillez vous identifier."
|
description="Veuillez vous identifier."
|
||||||
icon="i-lucide-user"
|
icon="i-lucide-user"
|
||||||
loading-auto
|
loading-auto
|
||||||
@submit="onLoginSubmit"
|
@submit="login"
|
||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
const { onLogoutClick } = useAuth();
|
const { logout } = useAuth();
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
@@ -18,7 +18,7 @@ const { onLogoutClick } = useAuth();
|
|||||||
loading-auto
|
loading-auto
|
||||||
to="/auth"
|
to="/auth"
|
||||||
label="Déconnexion"
|
label="Déconnexion"
|
||||||
@click="onLogoutClick"
|
@click="logout"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
@@ -1,12 +1,16 @@
|
|||||||
import type { FormSubmitEvent } from "@nuxt/ui";
|
import type { FormSubmitEvent } from "@nuxt/ui";
|
||||||
|
|
||||||
export function useAuth() {
|
export function useAuth() {
|
||||||
|
const { loggedIn, session } = useUserSession();
|
||||||
const toast = useToast();
|
const toast = useToast();
|
||||||
const redirect = useRoute().query.redirect as string || "/";
|
const redirect = useRoute().query.redirect as string || "/";
|
||||||
const router = useRouter();
|
const router = useRouter();
|
||||||
const { fetch: refreshUserSession } = useUserSession();
|
const { fetch: refreshUserSession } = useUserSession();
|
||||||
|
|
||||||
// Login form
|
const isLoggedIn = loggedIn;
|
||||||
|
const isSwitchedTo = computed(() => Boolean(session.value?.isSwitchedTo));
|
||||||
|
|
||||||
|
// Login
|
||||||
const loginFields = [
|
const loginFields = [
|
||||||
{
|
{
|
||||||
name: "email",
|
name: "email",
|
||||||
@@ -22,7 +26,7 @@ export function useAuth() {
|
|||||||
required: true,
|
required: true,
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
async function onLoginSubmit({ data: args }: FormSubmitEvent<LoginOutput>) {
|
async function login({ data: args }: FormSubmitEvent<LoginOutput>) {
|
||||||
try {
|
try {
|
||||||
const { data, errors } = await useGraphqlMutation("login", args);
|
const { data, errors } = await useGraphqlMutation("login", args);
|
||||||
if (errors.length || !data.login) {
|
if (errors.length || !data.login) {
|
||||||
@@ -38,8 +42,8 @@ export function useAuth() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Logout action
|
// Logout
|
||||||
async function onLogoutClick() {
|
async function logout() {
|
||||||
try {
|
try {
|
||||||
const result = await $fetch("/api/logout", { method: "POST" });
|
const result = await $fetch("/api/logout", { method: "POST" });
|
||||||
if (!result.success) {
|
if (!result.success) {
|
||||||
@@ -54,5 +58,35 @@ export function useAuth() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return { loginFields, onLoginSubmit, onLogoutClick };
|
// Switch to
|
||||||
|
async function switchTo(userId: string | number) {
|
||||||
|
try {
|
||||||
|
const { data, errors } = await useGraphqlMutation("switchTo", { userId });
|
||||||
|
if (errors.length || !data.switchTo) {
|
||||||
|
throw new Error("Une erreur est survenue");
|
||||||
|
}
|
||||||
|
await refreshUserSession();
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
const message = error instanceof Error ? error.message : "Une erreur est survenue";
|
||||||
|
toast.add({ title: "Échec du changement d'utilisateur", description: message, color: "error" });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Switch back
|
||||||
|
async function switchBack() {
|
||||||
|
try {
|
||||||
|
const result = await $fetch("/api/switch-back", { method: "POST" });
|
||||||
|
if (!result.success) {
|
||||||
|
throw new Error("Une erreur est survenue.");
|
||||||
|
}
|
||||||
|
await refreshUserSession();
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
const message = error instanceof Error ? error.message : "Une erreur est survenue";
|
||||||
|
toast.add({ title: "Échec du changement d'utilisateur", description: message, color: "error" });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return { isLoggedIn, isSwitchedTo, loginFields, login, logout, switchTo, switchBack };
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,37 +0,0 @@
|
|||||||
export function useUserSwitching() {
|
|
||||||
const toast = useToast();
|
|
||||||
const { fetch: refreshUserSession } = useUserSession();
|
|
||||||
const { session } = useUserSession();
|
|
||||||
|
|
||||||
const isUserSwitched = computed(() => Boolean(session.value?.isSwitchedTo));
|
|
||||||
|
|
||||||
async function userSwitchTo(userId: string | number) {
|
|
||||||
try {
|
|
||||||
const { data, errors } = await useGraphqlMutation("switchTo", { userId });
|
|
||||||
if (errors.length || !data.switchTo) {
|
|
||||||
throw new Error("Une erreur est survenue");
|
|
||||||
}
|
|
||||||
await refreshUserSession();
|
|
||||||
}
|
|
||||||
catch (error) {
|
|
||||||
const message = error instanceof Error ? error.message : "Une erreur est survenue";
|
|
||||||
toast.add({ title: "Échec du changement d'utilisateur", description: message, color: "error" });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async function userSwitchBack() {
|
|
||||||
try {
|
|
||||||
const result = await $fetch("/api/switch-back", { method: "POST" });
|
|
||||||
if (!result.success) {
|
|
||||||
throw new Error("Une erreur est survenue.");
|
|
||||||
}
|
|
||||||
await refreshUserSession();
|
|
||||||
}
|
|
||||||
catch (error) {
|
|
||||||
const message = error instanceof Error ? error.message : "Une erreur est survenue";
|
|
||||||
toast.add({ title: "Échec du changement d'utilisateur", description: message, color: "error" });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return { isUserSwitched, userSwitchTo, userSwitchBack };
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user