DatasetCard.tsx 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. 'use client'
  2. import { useContext, useContextSelector } from 'use-context-selector'
  3. import Link from 'next/link'
  4. import useSWR from 'swr'
  5. import type { MouseEventHandler } from 'react'
  6. import { useCallback, useState } from 'react'
  7. import { useTranslation } from 'react-i18next'
  8. import style from '../list.module.css'
  9. import type { App } from '@/types/app'
  10. import Confirm from '@/app/components/base/confirm'
  11. import { ToastContext } from '@/app/components/base/toast'
  12. import { deleteDataset, fetchDatasets } from '@/service/datasets'
  13. import AppIcon from '@/app/components/base/app-icon'
  14. import AppsContext from '@/context/app-context'
  15. import { DataSet } from '@/models/datasets'
  16. import classNames from 'classnames'
  17. export type DatasetCardProps = {
  18. dataset: DataSet
  19. onDelete?: () => void
  20. }
  21. const DatasetCard = ({
  22. dataset,
  23. onDelete
  24. }: DatasetCardProps) => {
  25. const { t } = useTranslation()
  26. const { notify } = useContext(ToastContext)
  27. const [showConfirmDelete, setShowConfirmDelete] = useState(false)
  28. const onDeleteClick: MouseEventHandler = useCallback((e) => {
  29. e.preventDefault()
  30. setShowConfirmDelete(true)
  31. }, [])
  32. const onConfirmDelete = useCallback(async () => {
  33. try {
  34. await deleteDataset(dataset.id)
  35. notify({ type: 'success', message: t('dataset.datasetDeleted') })
  36. if (onDelete)
  37. onDelete()
  38. }
  39. catch (e: any) {
  40. notify({ type: 'error', message: `${t('dataset.datasetDeleteFailed')}${'message' in e ? `: ${e.message}` : ''}` })
  41. }
  42. setShowConfirmDelete(false)
  43. }, [dataset.id])
  44. return (
  45. <>
  46. <Link href={`/datasets/${dataset.id}/documents`} className={style.listItem}>
  47. <div className={style.listItemTitle}>
  48. <AppIcon size='small' />
  49. <div className={style.listItemHeading}>
  50. <div className={style.listItemHeadingContent}>{dataset.name}</div>
  51. </div>
  52. <span className={style.deleteAppIcon} onClick={onDeleteClick} />
  53. </div>
  54. <div className={style.listItemDescription}>{dataset.description}</div>
  55. <div className={classNames(style.listItemFooter, style.datasetCardFooter)}>
  56. <span className={style.listItemStats}>
  57. <span className={classNames(style.listItemFooterIcon, style.docIcon)} />
  58. {dataset.document_count}{t('dataset.documentCount')}
  59. </span>
  60. <span className={style.listItemStats}>
  61. <span className={classNames(style.listItemFooterIcon, style.textIcon)} />
  62. {Math.round(dataset.word_count / 1000)}{t('dataset.wordCount')}
  63. </span>
  64. <span className={style.listItemStats}>
  65. <span className={classNames(style.listItemFooterIcon, style.applicationIcon)} />
  66. {dataset.app_count}{t('dataset.appCount')}
  67. </span>
  68. </div>
  69. {showConfirmDelete && (
  70. <Confirm
  71. title={t('dataset.deleteDatasetConfirmTitle')}
  72. content={t('dataset.deleteDatasetConfirmContent')}
  73. isShow={showConfirmDelete}
  74. onClose={() => setShowConfirmDelete(false)}
  75. onConfirm={onConfirmDelete}
  76. onCancel={() => setShowConfirmDelete(false)}
  77. />
  78. )}
  79. </Link>
  80. </>
  81. )
  82. }
  83. export default DatasetCard