mirror of
				https://github.com/labring/FastGPT.git
				synced 2025-10-20 18:54:09 +00:00 
			
		
		
		
	 3a4b4a866b
			
		
	
	3a4b4a866b
	
	
	
		
			
			* feat(member-group): Team (#2616) * feat: member-group schema define * feat(fe): create group * feat: add group edit modal * feat(fe): add avatar group component * feat: edit group fix: permission select menu style * feat: bio-mode support for select-member component * fix: avatar group key unique * feat: group manage * feat: divide member into group and clbs * feat: finish team permission * chore: adjust * fix: get clbs * perf: groups code * pref: member group for team (#2706) * chore: fe adjust fix: remove the member from groups when removing from team feat: change the groups avatar when updating the team's avatar * chore: DefaultGroupName as a constant string '' * fix: create default group when create team for root * feat: comment * feat: 4811 init * pref: member group for team (#2732) * chore: default group name * feat: get default group when get by tmbid * feat(fe): adjust * member ui * fix: delete group (#2736) * perf: init4811 * pref: member group (#2818) * fix: update clb per then refetch clb list * fix: calculate group permission * feat(fe): group tag * refactor(fe): team and group manage * feat: manage group member * feat: add group transfer owner modal * feat: group manage member * chore: adjust the file structure * pref: member group * chore: adjust fe style * fix: ts error * chore: fe adjust * chore: fe adjust * chore: adjust * chore: adjust the code * perf: i18n and schema name * pref: member-group (#2862) * feat: group list ordered by updateTime * fix: transfer ownership of group when deleting member * fix: i18n fix * feat: can not set member as admin/owner when user is not active * fix: GroupInfoModal hover input do not change color * fix(fe): searchinput do not scroll * perf: team group ui * doc * remove enum --------- Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import React from 'react';
 | |
| import Avatar from '.';
 | |
| import { Box, Flex } from '@chakra-ui/react';
 | |
| 
 | |
| /**
 | |
|  * AvatarGroup
 | |
|  *
 | |
|  * @param avatars - avatars array
 | |
|  * @param max - max avatars to show
 | |
|  * @param [groupId] - group id to make the key unique
 | |
|  * @returns
 | |
|  */
 | |
| function AvatarGroup({
 | |
|   avatars,
 | |
|   max = 3,
 | |
|   groupId
 | |
| }: {
 | |
|   max?: number;
 | |
|   avatars: string[];
 | |
|   groupId?: string;
 | |
| }) {
 | |
|   return (
 | |
|     <Flex position="relative">
 | |
|       {avatars.slice(0, max).map((avatar, index) => (
 | |
|         <Avatar
 | |
|           key={avatar + groupId}
 | |
|           src={avatar}
 | |
|           position={index > 0 ? 'absolute' : 'relative'}
 | |
|           left={index > 0 ? `${index * 15}px` : 0}
 | |
|           zIndex={index > 0 ? index + 1 : 0}
 | |
|           w={'24px'}
 | |
|           borderRadius={'50%'}
 | |
|         />
 | |
|       ))}
 | |
|       {avatars.length > max && (
 | |
|         <Box
 | |
|           position="relative"
 | |
|           left={`${(max - 1) * 15}px`}
 | |
|           w={'24px'}
 | |
|           h={'24px'}
 | |
|           borderRadius="50%"
 | |
|           display="flex"
 | |
|           alignItems="center"
 | |
|           justifyContent="center"
 | |
|           fontSize="sm"
 | |
|           color="myGray.500"
 | |
|         >
 | |
|           +{avatars.length - max}
 | |
|         </Box>
 | |
|       )}
 | |
|     </Flex>
 | |
|   );
 | |
| }
 | |
| 
 | |
| export default AvatarGroup;
 |