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 ? :
}
)
}