use-document.ts 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. import {
  2. useMutation,
  3. useQuery,
  4. } from '@tanstack/react-query'
  5. import { del, get, patch } from '../base'
  6. import { useInvalid } from '../use-base'
  7. import type { MetadataType, SortType } from '../datasets'
  8. import type { DocumentDetailResponse, DocumentListResponse, UpdateDocumentBatchParams } from '@/models/datasets'
  9. import { DocumentActionType } from '@/models/datasets'
  10. import type { CommonResponse } from '@/models/common'
  11. const NAME_SPACE = 'knowledge/document'
  12. export const useDocumentListKey = [NAME_SPACE, 'documentList']
  13. export const useDocumentList = (payload: {
  14. datasetId: string
  15. query: {
  16. keyword: string
  17. page: number
  18. limit: number
  19. sort?: SortType
  20. status: any
  21. },
  22. refetchInterval?: number | false
  23. }) => {
  24. const { query, datasetId, refetchInterval } = payload
  25. const { keyword, page, limit, sort, status } = query
  26. return useQuery<DocumentListResponse>({
  27. queryKey: [...useDocumentListKey, datasetId, keyword, page, limit, sort, status],
  28. queryFn: () => get<DocumentListResponse>(`/datasets/${datasetId}/documents`, {
  29. params: query,
  30. }),
  31. refetchInterval,
  32. })
  33. }
  34. export const useInvalidDocumentList = (datasetId?: string) => {
  35. return useInvalid(datasetId ? [...useDocumentListKey, datasetId] : useDocumentListKey)
  36. }
  37. const useAutoDisabledDocumentKey = [NAME_SPACE, 'autoDisabledDocument']
  38. export const useAutoDisabledDocuments = (datasetId: string) => {
  39. return useQuery({
  40. queryKey: [...useAutoDisabledDocumentKey, datasetId],
  41. queryFn: () => get<{ document_ids: string[] }>(`/datasets/${datasetId}/auto-disable-logs`),
  42. })
  43. }
  44. export const useInvalidDisabledDocument = () => {
  45. return useInvalid(useAutoDisabledDocumentKey)
  46. }
  47. const toBatchDocumentsIdParams = (documentIds: string[] | string) => {
  48. const ids = Array.isArray(documentIds) ? documentIds : [documentIds]
  49. return ids.map(id => `document_id=${id}`).join('&')
  50. }
  51. export const useDocumentBatchAction = (action: DocumentActionType) => {
  52. return useMutation({
  53. mutationFn: ({ datasetId, documentIds, documentId }: UpdateDocumentBatchParams) => {
  54. return patch<CommonResponse>(`/datasets/${datasetId}/documents/status/${action}/batch?${toBatchDocumentsIdParams(documentId || documentIds!)}`)
  55. },
  56. })
  57. }
  58. export const useDocumentEnable = () => {
  59. return useDocumentBatchAction(DocumentActionType.enable)
  60. }
  61. export const useDocumentDisable = () => {
  62. return useDocumentBatchAction(DocumentActionType.disable)
  63. }
  64. export const useDocumentArchive = () => {
  65. return useDocumentBatchAction(DocumentActionType.archive)
  66. }
  67. export const useDocumentUnArchive = () => {
  68. return useDocumentBatchAction(DocumentActionType.unArchive)
  69. }
  70. export const useDocumentDelete = () => {
  71. return useMutation({
  72. mutationFn: ({ datasetId, documentIds, documentId }: UpdateDocumentBatchParams) => {
  73. return del<CommonResponse>(`/datasets/${datasetId}/documents?${toBatchDocumentsIdParams(documentId || documentIds!)}`)
  74. },
  75. })
  76. }
  77. export const useSyncDocument = () => {
  78. return useMutation({
  79. mutationFn: ({ datasetId, documentId }: UpdateDocumentBatchParams) => {
  80. return get<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/notion/sync`)
  81. },
  82. })
  83. }
  84. export const useSyncWebsite = () => {
  85. return useMutation({
  86. mutationFn: ({ datasetId, documentId }: UpdateDocumentBatchParams) => {
  87. return get<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/website-sync`)
  88. },
  89. })
  90. }
  91. const useDocumentDetailKey = [NAME_SPACE, 'documentDetail', 'withoutMetaData']
  92. export const useDocumentDetail = (payload: {
  93. datasetId: string
  94. documentId: string
  95. params: { metadata: MetadataType }
  96. }) => {
  97. const { datasetId, documentId, params } = payload
  98. return useQuery<DocumentDetailResponse>({
  99. queryKey: [...useDocumentDetailKey, 'withoutMetaData', datasetId, documentId],
  100. queryFn: () => get<DocumentDetailResponse>(`/datasets/${datasetId}/documents/${documentId}`, { params }),
  101. })
  102. }
  103. export const useDocumentMetadata = (payload: {
  104. datasetId: string
  105. documentId: string
  106. params: { metadata: MetadataType }
  107. }) => {
  108. const { datasetId, documentId, params } = payload
  109. return useQuery<DocumentDetailResponse>({
  110. queryKey: [...useDocumentDetailKey, 'onlyMetaData', datasetId, documentId],
  111. queryFn: () => get<DocumentDetailResponse>(`/datasets/${datasetId}/documents/${documentId}`, { params }),
  112. })
  113. }
  114. export const useInvalidDocumentDetailKey = () => {
  115. return useInvalid(useDocumentDetailKey)
  116. }