add / edit / delete user warrens

This commit is contained in:
2025-07-21 19:27:41 +02:00
parent 50e066f794
commit 2c26002507
86 changed files with 2197 additions and 300 deletions

View File

@@ -0,0 +1,48 @@
import type { ApiResponse } from '~/shared/types/api';
import type { UserWarren } from '~/shared/types/warrens';
import { getApiHeaders } from '..';
import { toast } from 'vue-sonner';
export async function createUserWarren(
userWarren: UserWarren
): Promise<{ success: true; data: UserWarren } | { success: false }> {
const { data, error } = await useFetch<ApiResponse<UserWarren>>(
getApiUrl('admin/user-warrens'),
{
method: 'POST',
headers: getApiHeaders(),
body: JSON.stringify(userWarren),
responseType: 'json',
}
);
if (data.value == null) {
toast.error('Create user warren', {
description: error.value?.data ?? 'Failed to create user warren',
});
return {
success: false,
};
}
const keys = ['admin-resources'];
const session = useAuthSession();
if (
session.value != null &&
data.value.data.userId === session.value.user.id
) {
keys.push('warrens');
}
await refreshNuxtData(keys);
toast.success('Create user warren', {
description: 'Successfully created user warren',
});
return {
success: true,
data: data.value.data,
};
}

View File

@@ -32,7 +32,7 @@ export async function deleteUser(
await refreshNuxtData('admin-resources');
toast.success('Delete user', {
description: 'Successfully delete user',
description: 'Successfully deleted user',
});
return {

View File

@@ -0,0 +1,52 @@
import type { UserWarren } from '~/shared/types/warrens';
import { getApiHeaders } from '..';
import { toast } from 'vue-sonner';
import type { ApiResponse } from '~/shared/types/api';
export async function deleteUserWarren(
userId: string,
warrenId: string
): Promise<{ success: true; data: UserWarren } | { success: false }> {
const { data, error } = await useFetch<ApiResponse<UserWarren>>(
getApiUrl('admin/user-warrens'),
{
method: 'DELETE',
headers: getApiHeaders(),
body: JSON.stringify({
userId: userId,
warrenId: warrenId,
}),
responseType: 'json',
}
);
if (data.value == null) {
toast.error('Delete user warren', {
description: error.value?.data ?? 'Failed to delete user warren',
});
return {
success: false,
};
}
const keys = ['admin-resources'];
const session = useAuthSession();
if (
session.value != null &&
data.value.data.userId === session.value.user.id
) {
keys.push('warrens');
}
await refreshNuxtData(keys);
toast.success('Delete user warren', {
description: 'Successfully deleted user warren',
});
return {
success: true,
data: data.value.data,
};
}

View File

@@ -33,7 +33,14 @@ export async function editUser(
};
}
await refreshNuxtData('admin-resources');
const session = useAuthSession();
if (session.value != null && data.value.data.id === session.value.user.id) {
reloadNuxtApp({
ttl: 2000,
});
} else {
await refreshNuxtData('admin-resources');
}
toast.success('Edit user', {
description: 'Successfully edited user',

View File

@@ -0,0 +1,30 @@
import type { UserWarren } from '~/shared/types/warrens';
import { getApiHeaders } from '..';
import type { ApiResponse } from '~/shared/types/api';
export async function editUserWarren(
userWarren: UserWarren
): Promise<{ success: true; data: UserWarren } | { success: false }> {
const { data } = await useFetch<ApiResponse<UserWarren>>(
getApiUrl('admin/user-warrens'),
{
method: 'PATCH',
headers: getApiHeaders(),
body: JSON.stringify(userWarren),
responseType: 'json',
}
);
if (data.value == null) {
return {
success: false,
};
}
await refreshNuxtData('admin-resources');
return {
success: true,
data: data.value.data,
};
}

View File

@@ -1,5 +1,5 @@
import type { ApiResponse } from '~/shared/types/api';
import type { UserWarren, Warren } from '~/shared/types/warrens';
import type { AdminWarrenData, UserWarren } from '~/shared/types/warrens';
import { getApiHeaders } from '..';
import type { AdminResources, AuthUserWithWarrens } from '~/shared/types/admin';
import type { AuthUser } from '~/shared/types/auth';
@@ -15,7 +15,7 @@ export async function fetchAllAdminResources(): Promise<
ApiResponse<{
users: AuthUser[];
userWarrens: UserWarren[];
warrens: Warren[];
warrens: AdminWarrenData[];
}>
>(getApiUrl('admin/all'), {
method: 'GET',
@@ -36,7 +36,7 @@ export async function fetchAllAdminResources(): Promise<
warrens: [],
}))
.reduce((acc, u) => ({ ...acc, [u.id]: u }), {});
const warrens: Record<string, Warren> = {};
const warrens: Record<string, AdminWarrenData> = {};
for (const warren of data.value.data.warrens) {
warrens[warren.id] = warren;