You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

index.tsx 4.2KB

Feat/parent child retrieval (#12086) Signed-off-by: yihong0618 <zouzou0208@gmail.com> Signed-off-by: -LAN- <laipz8200@outlook.com> Co-authored-by: AkaraChen <akarachen@outlook.com> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Warren Chen <warren.chen830@gmail.com> Co-authored-by: crazywoola <427733928@qq.com> Co-authored-by: Yi Xiao <54782454+YIXIAO0@users.noreply.github.com> Co-authored-by: yihong <zouzou0208@gmail.com> Co-authored-by: -LAN- <laipz8200@outlook.com> Co-authored-by: KVOJJJin <jzongcode@gmail.com> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: JzoNgKVO <27049666+JzoNgKVO@users.noreply.github.com> Co-authored-by: Charlie.Wei <luowei@cvte.com> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: huayaoyue6 <huayaoyue@163.com> Co-authored-by: kurokobo <kuro664@gmail.com> Co-authored-by: Matsuda <yiyth.fcb6@gmail.com> Co-authored-by: shirochan <s.yusuke0711@gmail.com> Co-authored-by: Jyong <76649700+JohnJyong@users.noreply.github.com> Co-authored-by: Huỳnh Gia Bôi <boihuynh147@gmail.com> Co-authored-by: Julian Huynh <julian.huynh@immersio.io> Co-authored-by: Hash Brown <hi@xzd.me> Co-authored-by: 非法操作 <hjlarry@163.com> Co-authored-by: Kazuki Takamatsu <kazuki.takamatsu@chowagiken.co.jp> Co-authored-by: Trey Dong <1346650911@qq.com> Co-authored-by: VoidIsVoid <343750470@qq.com> Co-authored-by: Gimling <huangjl@ruyi.ai> Co-authored-by: xiandan-erizo <xiandan.erizo@gmail.com> Co-authored-by: Muneyuki Noguchi <nogu.dev@gmail.com> Co-authored-by: zhaobingshuang <1475195565@qq.com> Co-authored-by: zhaobs <zhaobs@cailian.net> Co-authored-by: suzuki.sh <s2terminal@users.noreply.github.com> Co-authored-by: Yingchun Lai <laiyingchun@apache.org> Co-authored-by: huanshare <huanshare@live.com> Co-authored-by: huanshare <liuhuan101@longfor.com> Co-authored-by: orangeclk <orangeclk@users.noreply.github.com> Co-authored-by: 문정현 <120004247+JungHyunMoon@users.noreply.github.com> Co-authored-by: barabicu <kztk533@gmail.com> Co-authored-by: Wei Mingzhi <whistler_wmz@users.sf.net> Co-authored-by: Paul van Oorschot <20116814+pvoo@users.noreply.github.com> Co-authored-by: zkyTech <zhangkunyuan@hotmail.com> Co-authored-by: zhangkunyuan <zhangkunyuan@cmhi.chinamobile.com> Co-authored-by: Tommy <34446820+Asterovim@users.noreply.github.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: Novice <857526207@qq.com> Co-authored-by: Novice Lee <novicelee@NovicedeMacBook-Pro.local> Co-authored-by: Novice Lee <novicelee@NoviPro.local> Co-authored-by: zxhlyh <16177003+zxhlyh@users.noreply.github.com> Co-authored-by: liuzhenghua <1090179900@qq.com> Co-authored-by: Jiang <65766008+AlwaysBluer@users.noreply.github.com> Co-authored-by: jiangzhijie <jiangzhijie.jzj@alibaba-inc.com> Co-authored-by: Joe <79627742+ZhouhaoJiang@users.noreply.github.com> Co-authored-by: Alok Shrivastwa <alok.shrivastwa@gmail.com> Co-authored-by: Alok Shrivastwa <Alok.Shrivastwa@microland.com> Co-authored-by: JasonVV <jasonwangiii@outlook.com> Co-authored-by: Hiroshi Fujita <fujita-h@users.noreply.github.com> Co-authored-by: Kevin9703 <51311316+Kevin9703@users.noreply.github.com> Co-authored-by: NFish <douxc512@gmail.com> Co-authored-by: Junyan Qin <1010553892@qq.com> Co-authored-by: IWAI, Masaharu <iwaim.sub@gmail.com> Co-authored-by: IWAI, Masaharu <iwai_masaharu@funkit.co.jp> Co-authored-by: Bowen Liang <liangbowen@gf.com.cn> Co-authored-by: luckylhb90 <luckylhb90@gmail.com> Co-authored-by: hobo.l <hobo.l@binance.com> Co-authored-by: douxc <7553076+douxc@users.noreply.github.com>
10 months ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. 'use client'
  2. import type { FC } from 'react'
  3. import React, { useCallback, useState } from 'react'
  4. import { useBoolean } from 'ahooks'
  5. import { RiArrowDownSLine } from '@remixicon/react'
  6. import { useTranslation } from 'react-i18next'
  7. import FileIcon from '../document-file-icon'
  8. import DocumentList from './document-list'
  9. import type { DocumentItem, ParentMode, SimpleDocumentDetail } from '@/models/datasets'
  10. import { ProcessMode } from '@/models/datasets'
  11. import {
  12. PortalToFollowElem,
  13. PortalToFollowElemContent,
  14. PortalToFollowElemTrigger,
  15. } from '@/app/components/base/portal-to-follow-elem'
  16. import cn from '@/utils/classnames'
  17. import SearchInput from '@/app/components/base/search-input'
  18. import { GeneralType, ParentChildType } from '@/app/components/base/icons/src/public/knowledge'
  19. import { useDocumentList } from '@/service/knowledge/use-document'
  20. import Loading from '@/app/components/base/loading'
  21. type Props = {
  22. datasetId: string
  23. value: {
  24. name?: string
  25. extension?: string
  26. processMode?: ProcessMode
  27. parentMode?: ParentMode
  28. }
  29. onChange: (value: SimpleDocumentDetail) => void
  30. }
  31. const DocumentPicker: FC<Props> = ({
  32. datasetId,
  33. value,
  34. onChange,
  35. }) => {
  36. const { t } = useTranslation()
  37. const {
  38. name,
  39. extension,
  40. processMode,
  41. parentMode,
  42. } = value
  43. const [query, setQuery] = useState('')
  44. const { data } = useDocumentList({
  45. datasetId,
  46. query: {
  47. keyword: query,
  48. page: 1,
  49. limit: 20,
  50. },
  51. })
  52. const documentsList = data?.data
  53. const isParentChild = processMode === ProcessMode.parentChild
  54. const TypeIcon = isParentChild ? ParentChildType : GeneralType
  55. const [open, {
  56. set: setOpen,
  57. toggle: togglePopup,
  58. }] = useBoolean(false)
  59. const ArrowIcon = RiArrowDownSLine
  60. const handleChange = useCallback(({ id }: DocumentItem) => {
  61. onChange(documentsList?.find(item => item.id === id) as SimpleDocumentDetail)
  62. setOpen(false)
  63. }, [documentsList, onChange, setOpen])
  64. return (
  65. <PortalToFollowElem
  66. open={open}
  67. onOpenChange={setOpen}
  68. placement='bottom-start'
  69. >
  70. <PortalToFollowElemTrigger onClick={togglePopup}>
  71. <div className={cn('flex items-center ml-1 px-2 py-0.5 rounded-lg hover:bg-state-base-hover select-none cursor-pointer', open && 'bg-state-base-hover')}>
  72. <FileIcon name={name} extension={extension} size='lg' />
  73. <div className='flex flex-col items-start ml-1 mr-0.5'>
  74. <div className='flex items-center space-x-0.5'>
  75. <span className={cn('system-md-semibold')}> {name || '--'}</span>
  76. <ArrowIcon className={'h-4 w-4 text-text-primary'} />
  77. </div>
  78. <div className='flex items-center h-3 text-text-tertiary space-x-0.5'>
  79. <TypeIcon className='w-3 h-3' />
  80. <span className={cn('system-2xs-medium-uppercase', isParentChild && 'mt-0.5' /* to icon problem cause not ver align */)}>
  81. {isParentChild ? t('dataset.chunkingMode.parentChild') : t('dataset.chunkingMode.general')}
  82. {isParentChild && ` · ${!parentMode ? '--' : parentMode === 'paragraph' ? t('dataset.parentMode.paragraph') : t('dataset.parentMode.fullDoc')}`}
  83. </span>
  84. </div>
  85. </div>
  86. </div>
  87. </PortalToFollowElemTrigger>
  88. <PortalToFollowElemContent className='z-[11]'>
  89. <div className='w-[360px] p-1 pt-2 rounded-xl border-[0.5px] border-components-panel-border bg-components-panel-bg-blur shadow-lg backdrop-blur-[5px]'>
  90. <SearchInput value={query} onChange={setQuery} className='mx-1' />
  91. {documentsList
  92. ? (
  93. <DocumentList
  94. className='mt-2'
  95. list={documentsList.map(d => ({
  96. id: d.id,
  97. name: d.name,
  98. extension: d.data_source_detail_dict?.upload_file?.extension || '',
  99. }))}
  100. onChange={handleChange}
  101. />
  102. )
  103. : (<div className='mt-2 flex items-center justify-center w-[360px] h-[100px]'>
  104. <Loading />
  105. </div>)}
  106. </div>
  107. </PortalToFollowElemContent>
  108. </PortalToFollowElem>
  109. )
  110. }
  111. export default React.memo(DocumentPicker)