mirror of
				https://github.com/labring/FastGPT.git
				synced 2025-10-20 10:45:52 +00:00 
			
		
		
		
	V4.6.9-first commit (#899)
* perf: insert mongo dataset data session * perf: dataset data index * remove delay * rename bill schema * rename bill record * perf: bill table * perf: prompt * perf: sub plan * change the usage count * feat: usage bill * publish usages * doc * 新增团队聊天功能 (#20) * perf: doc * feat 添加标签部分 feat 信息团队标签配置 feat 新增团队同步管理 feat team分享页面 feat 完成team分享页面 feat 实现模糊搜索 style 格式化 fix 修复迷糊匹配 style 样式修改 fix 团队标签功能修复 * fix 修复鉴权功能 * merge 合并代码 * fix 修复引用错误 * fix 修复pr问题 * fix 修复ts格式问题 --------- Co-authored-by: archer <545436317@qq.com> Co-authored-by: liuxingwan <liuxingwan.lxw@alibaba-inc.com> * update extra plan * fix: ts * format * perf: bill field * feat: standard plan * fix: ts * feat 个人账号页面修改 (#22) * feat 添加标签部分 feat 信息团队标签配置 feat 新增团队同步管理 feat team分享页面 feat 完成team分享页面 feat 实现模糊搜索 style 格式化 fix 修复迷糊匹配 style 样式修改 fix 团队标签功能修复 * fix 修复鉴权功能 * merge 合并代码 * fix 修复引用错误 * fix 修复pr问题 * fix 修复ts格式问题 * feat 修改个人账号页 --------- Co-authored-by: liuxingwan <liuxingwan.lxw@alibaba-inc.com> * sub plan page (#23) * fix chunk index; error page text * feat: dataset process Integral prediction * feat: stand plan field * feat: sub plan limit * perf: index * query extension * perf: share link push app name * perf: plan point unit * perf: get sub plan * perf: account page * feat 新增套餐详情弹窗代码 (#24) * merge 合并代码 * fix 新增套餐详情弹框 * fix 修复pr问题 * feat: change http node input to prompt editor (#21) * feat: change http node input to prompt editor * fix * split PromptEditor to HttpInput * Team plans (#25) * perf: pay check * perf: team plan test * plan limit check * replace sensitive text * perf: fix some null * collection null check * perf: plans modal * perf: http module * pacakge (#26) * individuation page and pay modal amount (#27) * feat: individuation page * team chat config * pay modal * plan count and replace invalid chars (#29) * fix: user oneapi * fix: training queue * fix: qa queue * perf: remove space chars * replace invalid chars * change httpinput dropdown menu (#28) * perf: http * reseet free plan * perf: plan code to packages * remove llm config to package * perf: code * perf: faq * fix: get team plan --------- Co-authored-by: yst <77910600+yu-and-liu@users.noreply.github.com> Co-authored-by: liuxingwan <liuxingwan.lxw@alibaba-inc.com> Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
This commit is contained in:
		| @@ -0,0 +1,89 @@ | ||||
| import { Box, Flex } from '@chakra-ui/react'; | ||||
| import { EditorVariablePickerType } from '../../type'; | ||||
| import MyIcon from '../../../../Icon'; | ||||
| import React, { useCallback, useEffect } from 'react'; | ||||
|  | ||||
| export default function DropDownMenu({ | ||||
|   variables, | ||||
|   setDropdownValue | ||||
| }: { | ||||
|   variables: EditorVariablePickerType[]; | ||||
|   setDropdownValue?: (value: string) => void; | ||||
| }) { | ||||
|   const [highlightedIndex, setHighlightedIndex] = React.useState(0); | ||||
|  | ||||
|   const handleKeyDown = useCallback( | ||||
|     (event: any) => { | ||||
|       if (event.keyCode === 38) { | ||||
|         setHighlightedIndex((prevIndex) => Math.max(prevIndex - 1, 0)); | ||||
|       } else if (event.keyCode === 40) { | ||||
|         setHighlightedIndex((prevIndex) => Math.min(prevIndex + 1, variables.length - 1)); | ||||
|       } else if (event.keyCode === 13 && variables[highlightedIndex]?.key) { | ||||
|         setDropdownValue?.(variables[highlightedIndex].key); | ||||
|       } | ||||
|     }, | ||||
|     [highlightedIndex, variables] | ||||
|   ); | ||||
|  | ||||
|   useEffect(() => { | ||||
|     document.addEventListener('keydown', handleKeyDown); | ||||
|  | ||||
|     return () => { | ||||
|       document.removeEventListener('keydown', handleKeyDown); | ||||
|     }; | ||||
|   }, [handleKeyDown]); | ||||
|  | ||||
|   return variables.length ? ( | ||||
|     <Box | ||||
|       bg={'white'} | ||||
|       boxShadow={'lg'} | ||||
|       borderWidth={'1px'} | ||||
|       borderColor={'borderColor.base'} | ||||
|       p={2} | ||||
|       borderRadius={'md'} | ||||
|       position={'fixed'} | ||||
|       w={'auto'} | ||||
|       zIndex={99999} | ||||
|     > | ||||
|       {variables.map((item, index) => ( | ||||
|         <Flex | ||||
|           alignItems={'center'} | ||||
|           as={'li'} | ||||
|           key={item.key} | ||||
|           px={4} | ||||
|           py={2} | ||||
|           borderRadius={'sm'} | ||||
|           cursor={'pointer'} | ||||
|           maxH={'300px'} | ||||
|           overflow={'auto'} | ||||
|           _notLast={{ | ||||
|             mb: 2 | ||||
|           }} | ||||
|           {...(highlightedIndex === index | ||||
|             ? { | ||||
|                 bg: 'primary.50', | ||||
|                 color: 'primary.600' | ||||
|               } | ||||
|             : { | ||||
|                 bg: 'white', | ||||
|                 color: 'myGray.600' | ||||
|               })} | ||||
|           onMouseDown={(e) => { | ||||
|             e.preventDefault(); | ||||
|  | ||||
|             setDropdownValue?.(item.key); | ||||
|           }} | ||||
|           onMouseEnter={() => { | ||||
|             setHighlightedIndex(index); | ||||
|           }} | ||||
|         > | ||||
|           <MyIcon name={(item.icon as any) || 'core/modules/variable'} w={'14px'} /> | ||||
|           <Box ml={2} fontSize={'sm'}> | ||||
|             {item.key} | ||||
|             {item.key !== item.label && `(${item.label})`} | ||||
|           </Box> | ||||
|         </Flex> | ||||
|       ))} | ||||
|     </Box> | ||||
|   ) : null; | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Archer
					Archer