import React, { useEffect, useState, useCallback } from 'react'; import { Switch, Route, useParams, useRouteMatch } from 'react-router-dom'; import * as BS from 'react-bootstrap' import 'reactjs-popup/dist/index.css'; import ProfileCard from './ProfileCard.js' import ProfilePages from './ProfilePages.js' import Loading from "./Loading.js"; import API_URL from "../Constants/constants.js"; export default function Memberlist() { const { path } = useRouteMatch(); const { sysID } = useParams(); const [isLoading, setIsLoading ] = useState(false); const [isError, setIsError ] = useState(false); const [currentPage, setCurrentPage] = useState(1); const [membersPerPage, setMembersPerPage] = useState(25); const [members, setMembers ] = useState([]); const [memberData, setMemberData ] = useState([]); const [filteredMembers, setFilteredMembers ] = useState([]); const [sortedMembers, setSortedMembers ] = useState([]); const [searchBy, setSearchBy] = useState('name') const [sortBy, setSortBy] = useState('name') const [value, setValue] = useState(''); const fetchMembers = useCallback( () => { setIsLoading(true); setIsError(false); setMembersPerPage(25); fetch(`${API_URL}s/${sysID}/members`,{ method: 'GET', }).then ( res => res.json() ).then (data => { setMembers(data) setIsLoading(false); }) .catch (error => { console.log(error); setIsError(true); setIsLoading(false); }) }, [sysID]) useEffect(() => { fetchMembers(); }, [fetchMembers]) useEffect(() => { 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)"} }) setMemberData(Members1); }, [members]) const indexOfLastMember = currentPage * membersPerPage; const indexOfFirstMember = indexOfLastMember - membersPerPage; useEffect(() => { searchMembers(); }, [value, memberData, searchBy]) function searchMembers() { const currentMembers = memberData.filter(member => { if (!value) return true; 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; }) setFilteredMembers(currentMembers); } useEffect (() => { if (sortBy === 'name') { const sortMembers = filteredMembers.sort((a, b) => a.name.localeCompare(b.name)).slice(indexOfFirstMember, indexOfLastMember); setSortedMembers(sortMembers); } else if (sortBy === 'display name') { const sortMembers = filteredMembers.sort((a, b) => a.displayName.localeCompare(b.displayName)).slice(indexOfFirstMember, indexOfLastMember); setSortedMembers(sortMembers); } else if (sortBy === 'ID') { const sortMembers = filteredMembers.sort((a, b) => a.id.localeCompare(b.id)).slice(indexOfFirstMember, indexOfLastMember); setSortedMembers(sortMembers); } }, [sortBy, filteredMembers, indexOfFirstMember, indexOfLastMember]) const active = currentPage; const pageAmount = Math.ceil(filteredMembers.length / membersPerPage); const memberList = sortedMembers.map((member) => ); return ( <> { setMembersPerPage(e.target.value); setCurrentPage(1); }}> { setSearchBy(e.target.value) }}> { setSortBy(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 > 1 ? setCurrentPage(currentPage - 1)}>{currentPage - 1} : "" } setCurrentPage(currentPage)} active={currentPage === active}>{currentPage} { currentPage < pageAmount ? setCurrentPage(currentPage + 1)}>{currentPage + 1} : "" } { currentPage > pageAmount - 3 ? "" : } { currentPage > pageAmount - 2 ? "" : setCurrentPage(pageAmount)} active={pageAmount === active}>{pageAmount}} { currentPage === pageAmount ? : setCurrentPage(currentPage + 1)} />} { isLoading ? : isError ? Error fetching members. : <> {memberList} } { isLoading ? : } ) }