penisularhr-ui / src / routes / app / user / manage / +page.server.ts
+page.server.ts
Raw
/* eslint-disable @typescript-eslint/no-explicit-any */
import { PUBLIC_BASE_API_URL } from '$env/static/public';
import { fail } from '@sveltejs/kit';

export async function load({ cookies }) {
	return {
		accessToken: cookies.get('accessToken')
	};
}

export const actions = {
	create: async ({ cookies, request, getClientAddress }) => {
		const data = await request.formData();
		const name = data.get('name');
		const username = data.get('username');
		const password = data.get('password');

		const reqBody = JSON.stringify({
			name,
			username,
			password
		});

		const response = await fetch(`${PUBLIC_BASE_API_URL}/auth/register`, {
			body: reqBody,
			headers: {
				'Content-Type': 'application/json',
				Authorization: `Bearer ${cookies.get('accessToken')}`,
				'x-forwarded-for': getClientAddress(),
				'x-real-ip': getClientAddress()
			},
			method: 'POST'
		});

		const responseData = await response.json();

		if (responseData.statusCode === 409) {
			return fail(responseData.statusCode, {
				id: 'inputData',
				message: 'Duplicate name or username'
			});
		}

		if (responseData.statusCode) {
			return fail(responseData.statusCode, {
				id: 'inputData',
				message: JSON.stringify(responseData.message)
			});
		}

		return {
			id: 'inputData',
			message: 'Created'
		};
	},

	update: async ({ cookies, request, getClientAddress }) => {
		const data = await request.formData();
		const id = data.get('id');
		const role = data.get('role');

		const reqBody = JSON.stringify({
			role
		});

		const response = await fetch(`${PUBLIC_BASE_API_URL}/auth/update-role/${id}`, {
			body: reqBody,
			headers: {
				'Content-Type': 'application/json',
				Authorization: `Bearer ${cookies.get('accessToken')}`,
				'x-forwarded-for': getClientAddress(),
				'x-real-ip': getClientAddress()
			},
			method: 'POST'
		});

		const responseData = await response.json();

		if (responseData.statusCode) {
			return fail(responseData.statusCode, {
				id: 'inputData',
				message: JSON.stringify(responseData.message)
			});
		}

		return {
			id: 'inputData',
			message: 'Updated'
		};
	},

	getTableData: async ({ cookies, request, getClientAddress }) => {
		const data = await request.formData();
		const page = data.get('page');

		const query = `?take=10&page=${page}`;

		try {
			const res = await fetch(`${PUBLIC_BASE_API_URL}/users${query}`, {
				headers: {
					'Content-Type': 'application/json',
					Authorization: `Bearer ${cookies.get('accessToken')}`,
					'x-forwarded-for': getClientAddress(),
					'x-real-ip': getClientAddress()
				}
			});
			const resData = await res.json();

			if (resData.meta.itemCount === 0) {
				return fail(404, { id: 'tableData', message: 'No items available' });
			}
			const pageCount = resData.meta.pageCount;
			const hasNextPage = resData.meta.hasNextPage;
			const hasPreviousPage = resData.meta.hasPreviousPage;

			const returnData = resData.data.map((el: any) => ({
				...el,
				createdAt: new Date(el.createdAt).toISOString().split('T')[0],
				updatedAt: new Date(el.updatedAt).toISOString().split('T')[0]
			}));

			return { returnData, pageCount, hasNextPage, hasPreviousPage, id: 'tableData' };
		} catch (err: any) {
			return err.message;
		}
	}
};