70 lines
1.4 KiB
TypeScript
70 lines
1.4 KiB
TypeScript
import { DashboardFolder } from '.prisma/client'
|
|
import useSWR from 'swr'
|
|
import { fetcher, sendRequest } from './utils'
|
|
|
|
export const useFolders = ({
|
|
parentId,
|
|
onError,
|
|
}: {
|
|
parentId?: string
|
|
onError: (error: Error) => void
|
|
}) => {
|
|
const params = new URLSearchParams(
|
|
parentId ? { parentId: parentId.toString() } : undefined
|
|
)
|
|
const { data, error, mutate } = useSWR<{ folders: DashboardFolder[] }, Error>(
|
|
`/api/folders?${params}`,
|
|
fetcher
|
|
)
|
|
if (error) onError(error)
|
|
return {
|
|
folders: data?.folders,
|
|
isLoading: !error && !data,
|
|
mutate,
|
|
}
|
|
}
|
|
|
|
export const useFolderContent = ({
|
|
folderId,
|
|
onError,
|
|
}: {
|
|
folderId?: string
|
|
onError: (error: Error) => void
|
|
}) => {
|
|
const { data, error, mutate } = useSWR<{ folder: DashboardFolder }, Error>(
|
|
`/api/folders/${folderId}`,
|
|
fetcher
|
|
)
|
|
if (error) onError(error)
|
|
return {
|
|
folder: data?.folder,
|
|
isLoading: !error && !data,
|
|
mutate,
|
|
}
|
|
}
|
|
|
|
export const createFolder = async (
|
|
folder: Pick<DashboardFolder, 'parentFolderId'>
|
|
) =>
|
|
sendRequest<DashboardFolder>({
|
|
url: `/api/folders`,
|
|
method: 'POST',
|
|
body: folder,
|
|
})
|
|
|
|
export const deleteFolder = async (id: string) =>
|
|
sendRequest({
|
|
url: `/api/folders/${id}`,
|
|
method: 'DELETE',
|
|
})
|
|
|
|
export const updateFolder = async (
|
|
id: string,
|
|
folder: Partial<DashboardFolder>
|
|
) =>
|
|
sendRequest({
|
|
url: `/api/folders/${id}`,
|
|
method: 'PATCH',
|
|
body: folder,
|
|
})
|