카테고리 목록에서 파일 목록을 재귀적으로 표시할 수 있는 기능 구현

This commit is contained in:
static
2025-01-22 22:24:44 +09:00
parent 8f8bad6d10
commit f34764ffe0
9 changed files with 98 additions and 41 deletions

View File

@@ -22,6 +22,8 @@
let info: Writable<CategoryInfo | null> | undefined = $state();
let selectedSubCategory: SelectedCategory | undefined = $state();
let isFileRecursive = $state(false);
let isCreateCategoryModalOpen = $state(false);
let isSubCategoryMenuBottomSheetOpen = $state(false);
let isRenameCategoryModalOpen = $state(false);
@@ -49,6 +51,7 @@
<div class="flex-grow bg-gray-100 pb-[5.5em]">
{#if $info}
<Category
bind:isFileRecursive
info={$info}
onFileClick={({ id }) => goto(`/file/${id}`)}
onFileRemoveClick={({ id }) => {

View File

@@ -5,13 +5,23 @@ import { categoryFileListResponse, type CategoryFileListResponse } from "$lib/se
import { getCategoryFiles } from "$lib/server/services/category";
import type { RequestHandler } from "./$types";
export const GET: RequestHandler = async ({ locals, params }) => {
export const GET: RequestHandler = async ({ locals, url, params }) => {
const { userId } = await authorize(locals, "activeClient");
const zodRes = z.object({ id: z.coerce.number().int().positive() }).safeParse(params);
if (!zodRes.success) error(400, "Invalid path parameters");
const { id } = zodRes.data;
const paramsZodRes = z.object({ id: z.coerce.number().int().positive() }).safeParse(params);
if (!paramsZodRes.success) error(400, "Invalid path parameters");
const { id } = paramsZodRes.data;
const { files } = await getCategoryFiles(userId, id);
return json(categoryFileListResponse.parse({ files }) as CategoryFileListResponse);
const queryZodRes = z
.object({ recursive: z.coerce.boolean().nullable() })
.safeParse({ recursive: url.searchParams.get("recursive") });
if (!queryZodRes.success) error(400, "Invalid query parameters");
const { recursive } = queryZodRes.data;
const { files } = await getCategoryFiles(userId, id, recursive ?? false);
return json(
categoryFileListResponse.parse({
files: files.map(({ id, isRecursive }) => ({ file: id, isRecursive })),
}) as CategoryFileListResponse,
);
};