import React, { useEffect, useState, useCallback } from 'react'; import { useRouteMatch, Switch, Route } from "react-router-dom"; import * as BS from 'react-bootstrap' import Popup from 'reactjs-popup'; import 'reactjs-popup/dist/index.css'; import { useForm } from "react-hook-form"; import MemberCard from './MemberCard.js' import MemberPages from '../../Pages/MemberPages.js' import Loading from "../Loading.js"; import API_URL from "../../Constants/constants.js"; import { FaPlus } from "react-icons/fa"; export default function Memberlist() { const { path } = useRouteMatch(); const user = JSON.parse(localStorage.getItem('user')); const userId = user.id; const [isLoading, setIsLoading ] = useState(false); const [isError, setIsError ] = useState(false); const [errorAlert, setErrorAlert ] = useState(false); const [proxyView, setProxyView] = useState(false); const [privacyView, setPrivacyView] = useState(false); const [currentPage, setCurrentPage] = useState(1); const [membersPerPage, setMembersPerPage] = useState(25); const [open, setOpen] = useState(false); const closeModal = () => setOpen(false); const [members, setMembers ] = useState([]); const [searchBy, setSearchBy] = useState('name') const [privacyFilter, setPrivacyFilter] = useState('all') const [sortBy, setSortBy] = useState('name') const [sortOrder, setSortOrder] = useState('ascending') const [value, setValue] = useState(''); const [proxyTags, setProxyTags] = useState([{ prefix: "", suffix: "" }]); const {register, handleSubmit, setValue: setTemplate} = useForm(); const fetchMembers = useCallback( () => { setIsLoading(true); setIsError(false); setMembersPerPage(localStorage.getItem("expandcards") ? 10 : 25); fetch(`${API_URL}s/${userId}/members`,{ method: 'GET', headers: { 'Authorization': localStorage.getItem("token") }}).then ( res => res.json() ).then (data => { setMembers(data) setIsLoading(false); }) .catch (error => { console.log(error); setIsError(true); setIsLoading(false); }) }, [userId]) useEffect(() => { fetchMembers(); }, [fetchMembers]) const indexOfLastMember = currentPage * membersPerPage; const indexOfFirstMember = indexOfLastMember - membersPerPage; let Members = members.map(member => { if (member.display_name) { return {...member, displayName: member.display_name} } return {...member, displayName: member.name} }) let Members1 = Members.map(member => { if (member.description) { return {...member, desc: member.description} } return {...member, desc: "(no description)"} }) const currentMembers = Members1.filter(member => { if (!value & privacyFilter === 'all') return true; if (privacyFilter === 'private') { if (member.visibility !== 'private') { return false; } } else if (privacyFilter === 'public') { if (member.visibility !== 'public') { return false; } } if (searchBy === 'name') { if (member.name.toLowerCase().includes(value.toLowerCase())) { return true; } return false; } else if (searchBy === 'display name') { if (member.displayName.toLowerCase().includes(value.toLowerCase())) { return true; } return false } else if (searchBy === 'description') { if (member.desc.toLowerCase().includes(value.toLowerCase())) { return true; } return false; } else if (searchBy === 'ID') { if (member.id.toLowerCase().includes(value.toLowerCase())) { return true; } return false; } return false; }) const active = currentPage; const pageAmount = Math.ceil(currentMembers.length / membersPerPage); var sortMembers = currentMembers; if (sortBy === 'name') { if (sortOrder === 'descending') { sortMembers = currentMembers.sort((a, b) => a.name.localeCompare(b.name)).reverse().slice(indexOfFirstMember, indexOfLastMember); } else sortMembers = currentMembers.sort((a, b) => a.name.localeCompare(b.name)).slice(indexOfFirstMember, indexOfLastMember); } else if (sortBy === 'display name') { if (sortOrder === 'descending') { sortMembers = currentMembers.sort((a, b) => a.displayName.localeCompare(b.displayName)).reverse().slice(indexOfFirstMember, indexOfLastMember); } else sortMembers = currentMembers.sort((a, b) => a.displayName.localeCompare(b.displayName)).slice(indexOfFirstMember, indexOfLastMember); } else if (sortBy === 'ID') { if (sortOrder === 'descending') { sortMembers = currentMembers.sort((a, b) => a.id.localeCompare(b.id)).reverse().slice(indexOfFirstMember, indexOfLastMember); } else sortMembers = currentMembers.sort((a, b) => a.id.localeCompare(b.id)).slice(indexOfFirstMember, indexOfLastMember); } else if (sortBy === 'date created') { if (sortOrder === 'descending') { sortMembers = currentMembers.sort((a, b) => a.created.localeCompare(b.created)).reverse().slice(indexOfFirstMember, indexOfLastMember); } else sortMembers = currentMembers.sort((a, b) => a.created.localeCompare(b.created)).slice(indexOfFirstMember, indexOfLastMember); } const memberList = sortMembers.map((member) => setMembers(members.map(member => member.id === memberEdit.id ? Object.assign(member, memberEdit) : member))} /> ); function addProxyField() { setProxyTags(oldTags => [...oldTags, {prefix: '', suffix: ''}] ) } const submitMember = data => { setIsLoading(true); const newdata = data.proxy_tags ? {...data, proxy_tags: data.proxy_tags.filter(tag => !(tag.prefix === "" && tag.suffix === ""))} : data fetch(`${API_URL}m/`,{ method: 'POST', body: JSON.stringify(newdata), headers: { 'Content-Type': 'application/json', 'Authorization': localStorage.getItem("token") }}).then (res => res.json() ).then (data => { setErrorAlert(false); closeModal(); fetchMembers(); } ).catch (error => { console.error(error); setErrorAlert(true); }); } return ( <> { setMembersPerPage(e.target.value); setCurrentPage(1); }}> { setSearchBy(e.target.value) }}> { setSortBy(e.target.value) }}> { setSortOrder(e.target.value) }}> { setPrivacyFilter(e.target.value) }}> {setValue(e.target.value); setCurrentPage(1);}} placeholder={`Search by ${searchBy}`}/> fetchMembers()}>Refresh { currentPage === 1 ? : setCurrentPage(currentPage - 1)} />} { currentPage < 3 ? "" : setCurrentPage(1)} active={1 === active}>{1}} { currentPage < 4 ? "" : currentPage < 5 ? setCurrentPage(2)} active={2 === active}>{2} : } { currentPage > 1 ? setCurrentPage(currentPage - 1)}>{currentPage - 1} : "" } setCurrentPage(currentPage)} active={currentPage === active}>{currentPage} { currentPage < pageAmount ? setCurrentPage(currentPage + 1)}>{currentPage + 1} : "" } { currentPage > pageAmount - 3 ? "" : currentPage === pageAmount - 3 ? setCurrentPage(pageAmount - 1)} active={pageAmount - 1 === active}>{pageAmount - 1} : } { currentPage > pageAmount - 2 ? "" : setCurrentPage(pageAmount)} active={pageAmount === active}>{pageAmount}} { currentPage === pageAmount ? : setCurrentPage(currentPage + 1)} />} { isLoading ? : isError ? Error fetching members. : <> setOpen(o => !o)}>Add Member
Add member
{ errorAlert ? Something went wrong, please try logging in and out again. : "" } Name: Display name: Birthday: (YYYY-MM-DD) Pronouns: Avatar url: Banner url: Color: (hexcode) Proxy tags: setProxyView(view => !view)}> { proxyView ? "Hide" : "Show" } Privacy settings: setPrivacyView(view => !view)}> { privacyView ? "Hide" : "Show" }
{ proxyView ? <>
Proxy Tags
{ proxyTags.map((item, index) => ( ))} addProxyField()}>Add new
: "" } { privacyView ? <>
privacy settings
Visibility: Name: Description: Birthday: Pronouns: Meta:
: "" } Description:
{ localStorage.getItem('template1') ? setTemplate('description', localStorage.getItem('template1'))}>Template 1 : ""} { localStorage.getItem('template2') ? setTemplate('description', localStorage.getItem('template2'))}>Template 2 : ""} { localStorage.getItem('template3') ? setTemplate('description', localStorage.getItem('template3'))}>Template 3 : ""}
Submit Cancel
{memberList} { currentPage === 1 ? : setCurrentPage(currentPage - 1)} />} { currentPage < 3 ? "" : setCurrentPage(1)} active={1 === active}>{1}} { currentPage < 4 ? "" : currentPage < 5 ? setCurrentPage(2)} active={2 === active}>{2} : } { currentPage > 1 ? setCurrentPage(currentPage - 1)}>{currentPage - 1} : "" } setCurrentPage(currentPage)} active={currentPage === active}>{currentPage} { currentPage < pageAmount ? setCurrentPage(currentPage + 1)}>{currentPage + 1} : "" } { currentPage > pageAmount - 3 ? "" : currentPage === pageAmount - 3 ? setCurrentPage(pageAmount - 1)} active={pageAmount - 1 === active}>{pageAmount - 1} : } { currentPage > pageAmount - 2 ? "" : setCurrentPage(pageAmount)} active={pageAmount === active}>{pageAmount}} { currentPage === pageAmount ? : setCurrentPage(currentPage + 1)} />} }
{ isLoading ? : setMembers(members.map(member => member.id === memberEdit.id ? Object.assign(member, memberEdit) : member))}/>}
) }