ui: Perform logout
This commit is contained in:
parent
5541a62c92
commit
547e8f1249
2 changed files with 32 additions and 2 deletions
|
@ -19,6 +19,14 @@ export async function authUser(form: LoginForm): Promise<any> {
|
||||||
return await handleApiResponse(res);
|
return await handleApiResponse(res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export async function logout(): Promise<any> {
|
||||||
|
const res = await fetch('api/auth/logout', {
|
||||||
|
method: 'POST',
|
||||||
|
headers: {'Accept': 'application/json'},
|
||||||
|
});
|
||||||
|
return await handleApiResponse(res);
|
||||||
|
}
|
||||||
|
|
||||||
export async function specialUserOperations(email: string, kind: "recovery"|"validation"): Promise<any> {
|
export async function specialUserOperations(email: string, kind: "recovery"|"validation"): Promise<any> {
|
||||||
const res = await fetch('api/users', {
|
const res = await fetch('api/users', {
|
||||||
method: 'PATCH',
|
method: 'PATCH',
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
|
import { goto } from '$app/navigation';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
Button,
|
Button,
|
||||||
Dropdown,
|
Dropdown,
|
||||||
|
@ -11,14 +13,34 @@
|
||||||
Nav,
|
Nav,
|
||||||
} from 'sveltestrap';
|
} from 'sveltestrap';
|
||||||
|
|
||||||
|
import { logout as APILogout } from '$lib/api/user';
|
||||||
import Logo from '$lib/components/Logo.svelte';
|
import Logo from '$lib/components/Logo.svelte';
|
||||||
import { userSession } from '$lib/stores/usersession';
|
import { userSession, refreshUserSession } from '$lib/stores/usersession';
|
||||||
import { config as tsConfig, t, locales, locale } from '$lib/translations';
|
import { config as tsConfig, t, locales, locale } from '$lib/translations';
|
||||||
|
|
||||||
export { className as class };
|
export { className as class };
|
||||||
let className = '';
|
let className = '';
|
||||||
</script>
|
|
||||||
|
|
||||||
|
function logout() {
|
||||||
|
APILogout().then(
|
||||||
|
() => {
|
||||||
|
refreshUserSession().then(
|
||||||
|
() => { },
|
||||||
|
() => {
|
||||||
|
goto('/');
|
||||||
|
}
|
||||||
|
)
|
||||||
|
},
|
||||||
|
(error) => {
|
||||||
|
toasts.addErrorToast({
|
||||||
|
title: $t('errors.logout'),
|
||||||
|
message: error,
|
||||||
|
timeout: 20000,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
<Navbar
|
<Navbar
|
||||||
class="{className} {$userSession?'p-0':''}"
|
class="{className} {$userSession?'p-0':''}"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue