mirror of
				https://github.com/labring/FastGPT.git
				synced 2025-10-20 18:54:09 +00:00 
			
		
		
		
	 439c819ff1
			
		
	
	439c819ff1
	
	
	
		
			
			* Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * perf: workflow ux * system config * Newflow (#89) * docs: Add doc for Xinference (#1266) Signed-off-by: Carson Yang <yangchuansheng33@gmail.com> * Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * perf: workflow ux * system config * Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * Revert "lafAccount add pat & re request when token invalid (#76)" (#77) This reverts commit 83d85dfe37adcaef4833385ea52ee79fd84720be. * rename code * move code * update flow * input type selector * perf: workflow runtime * feat: node adapt newflow * feat: adapt plugin * feat: 360 connection * check workflow * perf: flow 性能 * change plugin input type (#81) * change plugin input type * plugin label mode * perf: nodecard * debug * perf: debug ui * connection ui * change workflow ui (#82) * feat: workflow debug * adapt openAPI for new workflow (#83) * adapt openAPI for new workflow * i18n * perf: plugin debug * plugin input ui * delete * perf: global variable select * fix rebase * perf: workflow performance * feat: input render type icon * input icon * adapt flow (#84) * adapt newflow * temp * temp * fix * feat: app schedule trigger * feat: app schedule trigger * perf: schedule ui * feat: ioslatevm run js code * perf: workflow varialbe table ui * feat: adapt simple mode * feat: adapt input params * output * feat: adapt tamplate * fix: ts * add if-else module (#86) * perf: worker * if else node * perf: tiktoken worker * fix: ts * perf: tiktoken * fix if-else node (#87) * fix if-else node * type * fix * perf: audio render * perf: Parallel worker * log * perf: if else node * adapt plugin * prompt * perf: reference ui * reference ui * handle ux * template ui and plugin tool * adapt v1 workflow * adapt v1 workflow completions * perf: time variables * feat: workflow keyboard shortcuts * adapt v1 workflow * update workflow example doc (#88) * fix: simple mode select tool --------- Signed-off-by: Carson Yang <yangchuansheng33@gmail.com> Co-authored-by: Carson Yang <yangchuansheng33@gmail.com> Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com> * doc * perf: extract node * extra node field * update plugin version * doc * variable * change doc & fix prompt editor (#90) * fold workflow code * value type label --------- Signed-off-by: Carson Yang <yangchuansheng33@gmail.com> Co-authored-by: Carson Yang <yangchuansheng33@gmail.com> Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
		
			
				
	
	
		
			148 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import React, { useRef, forwardRef, useMemo } from 'react';
 | |
| import {
 | |
|   Menu,
 | |
|   MenuList,
 | |
|   MenuItem,
 | |
|   Button,
 | |
|   useDisclosure,
 | |
|   MenuButton,
 | |
|   Box,
 | |
|   css,
 | |
|   Flex
 | |
| } from '@chakra-ui/react';
 | |
| import type { ButtonProps, MenuItemProps } from '@chakra-ui/react';
 | |
| import { ChevronDownIcon } from '@chakra-ui/icons';
 | |
| import { useLoading } from '../../../hooks/useLoading';
 | |
| import MyIcon from '../Icon';
 | |
| 
 | |
| export type SelectProps = ButtonProps & {
 | |
|   value?: string;
 | |
|   placeholder?: string;
 | |
|   list: {
 | |
|     alias?: string;
 | |
|     label: string | React.ReactNode;
 | |
|     value: string;
 | |
|   }[];
 | |
|   isLoading?: boolean;
 | |
|   onchange?: (val: any) => void;
 | |
| };
 | |
| 
 | |
| const MySelect = (
 | |
|   {
 | |
|     placeholder,
 | |
|     value,
 | |
|     width = '100%',
 | |
|     list = [],
 | |
|     onchange,
 | |
|     isLoading = false,
 | |
|     ...props
 | |
|   }: SelectProps,
 | |
|   selectRef: any
 | |
| ) => {
 | |
|   const ref = useRef<HTMLButtonElement>(null);
 | |
|   const { Loading } = useLoading();
 | |
|   const menuItemStyles: MenuItemProps = {
 | |
|     borderRadius: 'sm',
 | |
|     py: 2,
 | |
|     display: 'flex',
 | |
|     alignItems: 'center',
 | |
|     _hover: {
 | |
|       backgroundColor: 'myWhite.600'
 | |
|     },
 | |
|     _notLast: {
 | |
|       mb: 2
 | |
|     }
 | |
|   };
 | |
|   const { isOpen, onOpen, onClose } = useDisclosure();
 | |
|   const selectItem = useMemo(() => list.find((item) => item.value === value), [list, value]);
 | |
| 
 | |
|   return (
 | |
|     <Box
 | |
|       css={css({
 | |
|         '& div': {
 | |
|           width: 'auto !important'
 | |
|         }
 | |
|       })}
 | |
|     >
 | |
|       <Menu
 | |
|         autoSelect={false}
 | |
|         isOpen={isOpen}
 | |
|         onOpen={onOpen}
 | |
|         onClose={onClose}
 | |
|         strategy={'fixed'}
 | |
|         matchWidth
 | |
|       >
 | |
|         <MenuButton
 | |
|           as={Button}
 | |
|           ref={ref}
 | |
|           width={width}
 | |
|           px={3}
 | |
|           rightIcon={<ChevronDownIcon />}
 | |
|           variant={'whitePrimary'}
 | |
|           textAlign={'left'}
 | |
|           _active={{
 | |
|             transform: 'none'
 | |
|           }}
 | |
|           {...(isOpen
 | |
|             ? {
 | |
|                 boxShadow: '0px 0px 4px #A8DBFF',
 | |
|                 borderColor: 'primary.500'
 | |
|               }
 | |
|             : {})}
 | |
|           {...props}
 | |
|         >
 | |
|           <Flex alignItems={'center'}>
 | |
|             {isLoading && <MyIcon mr={2} name={'common/loading'} w={'16px'} />}
 | |
|             {selectItem?.alias || selectItem?.label || placeholder}
 | |
|           </Flex>
 | |
|         </MenuButton>
 | |
| 
 | |
|         <MenuList
 | |
|           minW={(() => {
 | |
|             const w = ref.current?.clientWidth;
 | |
|             if (w) {
 | |
|               return `${w}px !important`;
 | |
|             }
 | |
|             return Array.isArray(width)
 | |
|               ? width.map((item) => `${item} !important`)
 | |
|               : `${width} !important`;
 | |
|           })()}
 | |
|           w={'auto'}
 | |
|           px={'6px'}
 | |
|           py={'6px'}
 | |
|           border={'1px solid #fff'}
 | |
|           boxShadow={
 | |
|             '0px 2px 4px rgba(161, 167, 179, 0.25), 0px 0px 1px rgba(121, 141, 159, 0.25);'
 | |
|           }
 | |
|           zIndex={99}
 | |
|           maxH={'40vh'}
 | |
|           overflowY={'auto'}
 | |
|         >
 | |
|           {list.map((item) => (
 | |
|             <MenuItem
 | |
|               key={item.value}
 | |
|               {...menuItemStyles}
 | |
|               {...(value === item.value
 | |
|                 ? {
 | |
|                     color: 'primary.500',
 | |
|                     bg: 'myWhite.300'
 | |
|                   }
 | |
|                 : {})}
 | |
|               onClick={() => {
 | |
|                 if (onchange && value !== item.value) {
 | |
|                   onchange(item.value);
 | |
|                 }
 | |
|               }}
 | |
|               whiteSpace={'pre-wrap'}
 | |
|             >
 | |
|               {item.label}
 | |
|             </MenuItem>
 | |
|           ))}
 | |
|         </MenuList>
 | |
|       </Menu>
 | |
|     </Box>
 | |
|   );
 | |
| };
 | |
| 
 | |
| export default React.memo(forwardRef(MySelect));
 |