mirror of
				https://github.com/labring/FastGPT.git
				synced 2025-10-20 10:45:52 +00:00 
			
		
		
		
	 bfac393ab1
			
		
	
	bfac393ab1
	
	
	
		
			
			* feat:Prompt task (#3337) * feat:猜你想问自定义功能 * 修改用户输入框部分,去除冗余代码 * 删除不必要的属性 * 删除多余内容 * 修正了格式问题,并实现获取调试和app最新参数 * 修正了几行代码 * feat:Prompt task (#3337) * feat:猜你想问自定义功能 * 修改用户输入框部分,去除冗余代码 * 删除不必要的属性 * 删除多余内容 * 修正了格式问题,并实现获取调试和app最新参数 * 修正了几行代码 * perf: question gudide code * fix: i18n * hunyuan logo * fix: cq templates * perf: create question guide code * udpate svg --------- Co-authored-by: Jiangween <145003935+Jiangween@users.noreply.github.com>
		
			
				
	
	
		
			159 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {
 | |
|   Box,
 | |
|   Button,
 | |
|   Flex,
 | |
|   Textarea,
 | |
|   ModalFooter,
 | |
|   HStack,
 | |
|   Icon,
 | |
|   ModalBody
 | |
| } from '@chakra-ui/react';
 | |
| import MyIcon from '../../Icon/index';
 | |
| 
 | |
| import React, { useCallback, useEffect, useRef, useState } from 'react';
 | |
| import { useTranslation } from 'next-i18next';
 | |
| import MyModal from '../../MyModal';
 | |
| 
 | |
| const CustomLightTip = () => {
 | |
|   const { t } = useTranslation();
 | |
| 
 | |
|   return (
 | |
|     <HStack px="3" py="2" bgColor="primary.50" borderRadius="md" fontSize={'sm'}>
 | |
|       <Icon name="common/info" w="1rem" color={'primary.600'} />
 | |
|       <Box color="primary.600">
 | |
|         {t('common:core.app.QG.Custom prompt tip1')}
 | |
|         <Box as="span" color={'yellow.500'} fontWeight="500" display="inline">
 | |
|           {t('common:core.app.QG.Custom prompt tip2')}
 | |
|         </Box>
 | |
|         {t('common:core.app.QG.Custom prompt tip3')}
 | |
|       </Box>
 | |
|     </HStack>
 | |
|   );
 | |
| };
 | |
| 
 | |
| const FixBox = ({ children }: { children: React.ReactNode }) => {
 | |
|   return (
 | |
|     <Box>
 | |
|       <Box
 | |
|         bg="yellow.100"
 | |
|         as="span" // 改为 inline 元素
 | |
|         display="inline" // 确保是行内显示
 | |
|       >
 | |
|         {children}
 | |
|       </Box>
 | |
|     </Box>
 | |
|   );
 | |
| };
 | |
| 
 | |
| const CustomPromptEditor = ({
 | |
|   defaultValue = '',
 | |
|   defaultPrompt,
 | |
|   footerPrompt,
 | |
|   onChange,
 | |
|   onClose
 | |
| }: {
 | |
|   defaultValue?: string;
 | |
|   defaultPrompt: string;
 | |
|   footerPrompt?: string;
 | |
|   onChange: (e: string) => void;
 | |
|   onClose: () => void;
 | |
| }) => {
 | |
|   const ref = useRef<HTMLTextAreaElement>(null);
 | |
|   const { t } = useTranslation();
 | |
|   const [value, setValue] = useState(defaultValue || defaultPrompt);
 | |
| 
 | |
|   const adjustHeight = useCallback(() => {
 | |
|     const textarea = ref.current;
 | |
|     if (!textarea) return;
 | |
| 
 | |
|     textarea.style.height = '22px';
 | |
|     textarea.style.height = `${textarea.scrollHeight}px`;
 | |
|   }, []);
 | |
| 
 | |
|   useEffect(() => {
 | |
|     adjustHeight();
 | |
|     const timer = setTimeout(adjustHeight, 0);
 | |
|     return () => clearTimeout(timer);
 | |
|   }, [value, adjustHeight]);
 | |
| 
 | |
|   return (
 | |
|     <MyModal
 | |
|       isOpen
 | |
|       onClose={onClose}
 | |
|       iconSrc="modal/edit"
 | |
|       title={t('app:core.dataset.import.Custom prompt')}
 | |
|       w={'100%'}
 | |
|       h={'85vh'}
 | |
|       isCentered
 | |
|     >
 | |
|       <ModalBody flex={'1 0 0'} display={'flex'} flexDirection={'column'}>
 | |
|         <CustomLightTip />
 | |
| 
 | |
|         <HStack my={3} justifyContent={'space-between'}>
 | |
|           <Box fontWeight={'bold'} color={'myGray.600'}>
 | |
|             {t('common:core.ai.Prompt')}
 | |
|           </Box>
 | |
| 
 | |
|           <Button
 | |
|             variant={'grayGhost'}
 | |
|             size={'sm'}
 | |
|             leftIcon={<MyIcon name={'common/retryLight'} w={'14px'} />}
 | |
|             px={2}
 | |
|             onClick={() => setValue(defaultPrompt)}
 | |
|           >
 | |
|             {t('common:common.Reset')}
 | |
|           </Button>
 | |
|         </HStack>
 | |
| 
 | |
|         <Box
 | |
|           flex={'1 0 0'}
 | |
|           overflow={'auto'}
 | |
|           border="1px solid"
 | |
|           borderColor="borderColor.base"
 | |
|           borderRadius="md"
 | |
|           bg={'myGray.50'}
 | |
|           whiteSpace="pre-wrap"
 | |
|           fontSize="sm"
 | |
|           p={3}
 | |
|         >
 | |
|           <Textarea
 | |
|             ref={ref}
 | |
|             value={value}
 | |
|             placeholder={t('common:prompt_input_placeholder')}
 | |
|             onChange={(e) => setValue(e.target.value)}
 | |
|             resize="none"
 | |
|             bg="transparent"
 | |
|             border="none"
 | |
|             p={0}
 | |
|             mb={2}
 | |
|             _focus={{
 | |
|               border: 'none',
 | |
|               boxShadow: 'none'
 | |
|             }}
 | |
|           />
 | |
|           {footerPrompt && <FixBox>{footerPrompt}</FixBox>}
 | |
|         </Box>
 | |
|       </ModalBody>
 | |
|       <ModalFooter>
 | |
|         <Flex gap={3}>
 | |
|           <Button variant={'whiteBase'} fontWeight={'medium'} onClick={onClose} w={20}>
 | |
|             {t('common:common.Close')}
 | |
|           </Button>
 | |
|           <Button
 | |
|             fontWeight={'medium'}
 | |
|             onClick={() => {
 | |
|               onChange(value.replace(defaultValue, ''));
 | |
|               onClose();
 | |
|             }}
 | |
|             w={20}
 | |
|           >
 | |
|             {t('common:common.Confirm')}
 | |
|           </Button>
 | |
|         </Flex>
 | |
|       </ModalFooter>
 | |
|     </MyModal>
 | |
|   );
 | |
| };
 | |
| 
 | |
| export default CustomPromptEditor;
 |