2022-06-23 20:24:29 +00:00
< script lang = "ts" >
import { Card , CardHeader , CardBody , CardTitle , Alert , Accordion , AccordionItem , InputGroupText , InputGroup , Input , Row , Col , Spinner , Button , Tooltip , Label } from 'sveltestrap';
import { onMount } from 'svelte';
import { Link , useParams } from 'svelte-navigator';
import FaLock from 'svelte-icons/fa/FaLock.svelte';
import FaUserCircle from 'svelte-icons/fa/FaUserCircle.svelte';
import FaUsers from 'svelte-icons/fa/FaUsers.svelte'
import MemberBody from '../member/Body.svelte';
import GroupBody from '../group/Body.svelte';
import NewMember from '../member/NewMember.svelte';
import NewGroup from '../group/NewGroup.svelte';
import CardsHeader from '../CardsHeader.svelte';
import ListPagination from '../ListPagination.svelte';
import ListControl from './ListControl.svelte';
import ListSearch from './ListSearch.svelte';
import { Member , Group } from '../../api/types';
import api from '../../api';
export let members: Member[] = [];
export let groups: Group[] = [];
let list: Member[] | Group[] = [];
let processedList: Member[] | Group[] = [];
$: groupList = groups && groups.map(function(group) { return { name : group.name , shortid : group.id , id : group.uuid , members : group.members , display_name : group.display_name }; } ).sort((a, b) => a.name.localeCompare(b.name));
$: memberList = members && members.map(function(member) { return { name : member.name , shortid : member.id , id : member.uuid , display_name : member.display_name }; } ).sort((a, b) => a.name.localeCompare(b.name));
let token = localStorage.getItem("pk-token");
let listLoading = true;
let err: string;
let settings = JSON.parse(localStorage.getItem("pk-settings"));
let pageAmount: number;
let currentPage: number = 1;
let itemsPerPageValue = settings & & settings.accessibility & & settings.accessibility.expandedcards ? "10" : "25";
$: itemsPerPage = parseInt(itemsPerPageValue);
$: indexOfLastItem = currentPage * itemsPerPage;
$: indexOfFirstItem = indexOfLastItem - itemsPerPage;
$: pageAmount = Math.ceil(processedList.length / itemsPerPage);
$: slicedList = processedList.slice(indexOfFirstItem, indexOfLastItem);
export let isPublic: boolean;
export let isMainDash = true;
export let itemType: string;
let searchValue: string = "";
let searchBy: string = "";
let params = useParams();
$: id = $params.id;
onMount(() => {
if (token || isPublic) fetchList();
});
async function fetchList() {
err = "";
listLoading = true;
try {
if (itemType === "member") {
const res: Member[] = await api().systems(isPublic ? id : "@me").members.get({ auth : ! isPublic } );
members = res;
list = res;
}
else if (itemType === "group") {
const res: Group[] = await api().systems(isPublic ? id : "@me").groups.get({ auth : ! isPublic , query : { with_members : ! isPublic } } );
groups = res;
list = res;
}
else throw new Error(`Unknown list type ${ itemType } `);
} catch (error) {
console.log(error);
err = error.message;
}
listLoading = false;
}
function addItemToList(event: any) {
if (itemType === "member") {
members.push(event.detail);
2022-06-25 20:31:23 +00:00
list = members;
2022-06-23 20:24:29 +00:00
} else if (itemType === "group") {
2022-06-25 20:31:23 +00:00
groups.push(event.detail);
list = groups;
2022-06-23 20:24:29 +00:00
}
}
/* function updateList(event: any) {
list = list.map(member => member.id !== event.detail.id ? member : event.detail);
} */
/* function updateGroups(event: any) {
groups = event.detail;
} */
function updateDelete(event: any) {
2022-06-25 20:31:53 +00:00
if (itemType === "member") {
members = members.filter(m => m.id !== event.detail);
list = members;
} else if (itemType === "group") {
groups = groups.filter(g => g.id !== event.detail);
list = groups;
}
2022-06-23 20:24:29 +00:00
}
function getItemLink(item: Member | Group): string {
let url: string;
if (isMainDash) url = "/dash/";
else url = "/profile/";
if (itemType === "member") url += "m/";
else if (itemType === "group") url += "g/";
url += item.id;
return url;
}
< / script >
2022-06-24 05:59:51 +00:00
< ListControl { itemType } { isPublic } { memberList } { groups } { groupList } { list } bind:finalList = { processedList } bind:searchValue bind:searchBy bind:itemsPerPageValue bind:currentPage />
2022-06-23 20:24:29 +00:00
{ #if listLoading && ! err }
< div class = "mx-auto text-center" >
< Spinner class = "d-inline-block" / >
< / div >
{ :else if err }
< Row >
< Col xs = { 12 } lg= { 10 } >
< Alert color = "danger" > { err } </ Alert >
< / Col >
< Col xs = { 12 } lg= { 2 } >
< Button class = "w-100 mb-3" color = "primary" on:click = { fetchList } aria-label="refresh member list " > Refresh</ Button >
< / Col >
< / Row >
{ : else }
< ListSearch bind:searchBy bind:searchValue on:refresh = { fetchList } / >
2022-06-24 05:58:36 +00:00
< ListPagination bind:currentPage { pageAmount } />
2022-06-23 20:24:29 +00:00
{ #if ! err && ! isPublic }
{ #if itemType === "member" }
< NewMember on:create = { addItemToList } / >
{ :else if itemType === "group" }
< NewGroup on:create = { addItemToList } / >
{ /if }
{ /if }
2022-06-24 05:58:21 +00:00
2022-06-23 20:24:29 +00:00
{ #if settings && settings . accessibility ? ( ! settings . accessibility . expandedcards && ! settings . accessibility . pagelinks ) : true }
< Accordion class = "my-3" stayOpen >
2022-06-24 05:56:16 +00:00
{ #each slicedList as item , index ( item . id )}
2022-06-23 20:24:29 +00:00
< AccordionItem >
< CardsHeader { item } slot = "header" >
< div slot = "icon" >
{ #if isPublic || item . privacy . visibility === "public" }
{ #if itemType === "member" }
< FaUserCircle / >
{ :else if itemType === "group" }
< FaUsers / >
{ /if }
{ : else }
< FaLock / >
{ /if }
< / div >
< / CardsHeader >
{ #if itemType === "member" }
< MemberBody on:deletion = { updateDelete } bind:isPublic bind:groups bind:member = { item } / >
{ :else if itemType === "group" }
< GroupBody on:deletion = { updateDelete } { isPublic } { members } bind:group= { item } />
{ /if }
< / AccordionItem >
{ /each }
< / Accordion >
{ :else if settings . accessibility . expandedcards }
2022-06-24 05:56:16 +00:00
{ #each slicedList as item , index ( item . id )}
2022-06-23 20:24:29 +00:00
< Card class = "mb-3" >
< CardHeader >
2022-06-24 05:57:28 +00:00
< CardsHeader { item } >
2022-06-23 20:24:29 +00:00
< div slot = "icon" >
{ #if isPublic || item . privacy . visibility === "public" }
{ #if itemType === "member" }
< FaUserCircle / >
{ :else if itemType === "group" }
< FaUsers / >
{ /if }
{ : else }
< FaLock / >
{ /if }
< / div >
< / CardsHeader >
< / CardHeader >
< CardBody >
{ #if itemType === "member" }
< MemberBody on:deletion = { updateDelete } bind:isPublic bind:groups bind:member = { item } / >
{ :else if itemType === "group" }
< GroupBody on:deletion = { updateDelete } { isPublic } { members } bind:group= { item } />
{ /if }
< / CardBody >
< / Card >
{ /each }
{ : else }
< div class = "my-3" >
2022-06-24 05:56:16 +00:00
{ #each slicedList as item , index ( item . id )}
2022-06-23 20:24:29 +00:00
< Card >
< Link class = "accordion-button collapsed" style = "text-decoration: none;" to = { getItemLink ( item )} >
2022-06-24 05:57:28 +00:00
< CardsHeader { item } >
2022-06-23 20:24:29 +00:00
< div slot = "icon" >
{ #if isPublic || item . privacy . visibility === "public" }
{ #if itemType === "member" }
< FaUserCircle / >
{ :else if itemType === "group" }
< FaUsers / >
{ /if }
{ : else }
< FaLock / >
{ /if }
< / div >
< / CardsHeader >
< / Link >
< / Card >
{ /each }
< / div >
{ /if }
< ListPagination bind:currentPage { pageAmount } />
{ /if }