arch: move web folder into api & move api to top level
This commit is contained in:
73
frontend/src/shared/components/MemberManager/index.tsx
Normal file
73
frontend/src/shared/components/MemberManager/index.tsx
Normal file
@ -0,0 +1,73 @@
|
||||
import React, { useState } from 'react';
|
||||
|
||||
import {
|
||||
MemberName,
|
||||
ProfileIcon,
|
||||
MemberManagerWrapper,
|
||||
MemberManagerSearchWrapper,
|
||||
MemberManagerSearch,
|
||||
BoardMembersLabel,
|
||||
BoardMembersList,
|
||||
BoardMembersListItem,
|
||||
BoardMemberListItemContent,
|
||||
ActiveIconWrapper,
|
||||
} from './Styles';
|
||||
import { Checkmark } from 'shared/icons';
|
||||
|
||||
type MemberManagerProps = {
|
||||
availableMembers: Array<TaskUser>;
|
||||
activeMembers: Array<TaskUser>;
|
||||
onMemberChange: (member: TaskUser, isActive: boolean) => void;
|
||||
};
|
||||
const MemberManager: React.FC<MemberManagerProps> = ({
|
||||
availableMembers,
|
||||
activeMembers: initialActiveMembers,
|
||||
onMemberChange,
|
||||
}) => {
|
||||
const [activeMembers, setActiveMembers] = useState(initialActiveMembers);
|
||||
const [currentSearch, setCurrentSearch] = useState('');
|
||||
return (
|
||||
<MemberManagerWrapper>
|
||||
<MemberManagerSearchWrapper>
|
||||
<MemberManagerSearch
|
||||
onChange={(e: React.ChangeEvent<HTMLTextAreaElement>) => {
|
||||
setCurrentSearch(e.currentTarget.value);
|
||||
}}
|
||||
/>
|
||||
</MemberManagerSearchWrapper>
|
||||
<BoardMembersLabel>Board Members</BoardMembersLabel>
|
||||
<BoardMembersList>
|
||||
{availableMembers
|
||||
.filter(
|
||||
member => currentSearch === '' || member.fullName.toLowerCase().startsWith(currentSearch.toLowerCase()),
|
||||
)
|
||||
.map(member => {
|
||||
return (
|
||||
<BoardMembersListItem key={member.id}>
|
||||
<BoardMemberListItemContent
|
||||
onClick={() => {
|
||||
const isActive = activeMembers.findIndex(m => m.id === member.id) !== -1;
|
||||
if (isActive) {
|
||||
setActiveMembers(activeMembers.filter(m => m.id !== member.id));
|
||||
} else {
|
||||
setActiveMembers([...activeMembers, member]);
|
||||
}
|
||||
onMemberChange(member, !isActive);
|
||||
}}
|
||||
>
|
||||
<ProfileIcon>JK</ProfileIcon>
|
||||
<MemberName>{member.fullName}</MemberName>
|
||||
{activeMembers.findIndex(m => m.id === member.id) !== -1 && (
|
||||
<ActiveIconWrapper>
|
||||
<Checkmark width={16} height={16} />
|
||||
</ActiveIconWrapper>
|
||||
)}
|
||||
</BoardMemberListItemContent>
|
||||
</BoardMembersListItem>
|
||||
);
|
||||
})}
|
||||
</BoardMembersList>
|
||||
</MemberManagerWrapper>
|
||||
);
|
||||
};
|
||||
export default MemberManager;
|
Reference in New Issue
Block a user