feat: member list in groups

This commit is contained in:
Spectralitree 2021-12-21 00:20:55 +01:00
parent 8a6c26696f
commit af9380365d
2 changed files with 107 additions and 4 deletions

View File

@ -6,12 +6,16 @@
import Edit from './Edit.svelte'; import Edit from './Edit.svelte';
import twemoji from 'twemoji'; import twemoji from 'twemoji';
import Privacy from './Privacy.svelte'; import Privacy from './Privacy.svelte';
import type Member from 'src/api/member';
import MemberEdit from './MemberEdit.svelte';
export let group: Group; export let group: Group;
let editMode: boolean; let editMode: boolean = false;
let memberMode: boolean = false;
export let isPublic: boolean; export let isPublic: boolean;
export let loading: boolean = false; export let loading: boolean = false;
let privacyLoading = false; let privacyLoading = false;
export let members: Member[];
let htmlDescription: string; let htmlDescription: string;
$: if (group.description) { $: if (group.description) {
@ -42,7 +46,7 @@
</script> </script>
<CardBody style="border-left: 4px solid #{group.color}; margin: -1rem -1.25rem"> <CardBody style="border-left: 4px solid #{group.color}; margin: -1rem -1.25rem">
{#if !editMode } {#if !editMode && !memberMode}
<Row> <Row>
{#if group.id} {#if group.id}
<Col xs={12} lg={4} class="mb-2"> <Col xs={12} lg={4} class="mb-2">
@ -101,9 +105,11 @@
<img src={group.banner} alt="your system banner" class="w-100 mb-3 rounded" style="max-height: 12em; object-fit: cover"/> <img src={group.banner} alt="your system banner" class="w-100 mb-3 rounded" style="max-height: 12em; object-fit: cover"/>
{/if} {/if}
{#if !isPublic} {#if !isPublic}
<Button style="flex: 0" color="primary" on:click={() => editMode = true}>Edit</Button> <Button style="flex: 0" color="primary" on:click={() => editMode = true}>Edit</Button> <Button style="flex: 0" color="secondary" on:click={() => memberMode = true}>Members</Button>
{/if} {/if}
{:else} {:else if editMode}
<Edit on:update bind:loading bind:group bind:editMode /> <Edit on:update bind:loading bind:group bind:editMode />
{:else if memberMode}
<MemberEdit on:update bind:loading bind:group bind:memberMode bind:members />
{/if} {/if}
</CardBody> </CardBody>

View File

@ -0,0 +1,97 @@
<script lang="ts">
import type Group from "../../api/group";
import type Member from "../../api/member";
import { Row, Col, Input, Button, Label, Alert, ListGroup, ListGroupItem } from 'sveltestrap';
import { createEventDispatcher, onDestroy } from 'svelte';
import PKAPI from '../../api';
import ListPagination from "../ListPagination.svelte";
import twemoji from "twemoji";
import FaUserPlus from 'svelte-icons/fa/FaUserPlus.svelte'
import FaUserFriends from 'svelte-icons/fa/FaUserFriends.svelte'
import FaUserMinus from 'svelte-icons/fa/FaUserMinus.svelte'
import Svelecte, { addFormatter } from 'svelecte';
export let loading: boolean;
export let group: Group;
export let memberMode: boolean = true;
export let members: Member[];
let membersInGroup: Member[];
let membersNotInGroup: Member[];
let membersInGroupSelection: any[];
let membersNotInGroupSelection: any[];
let membersToBeAdded: any[];
let membersToBeRemoved: any[];
let currentPage: number = 1;
let smallPages = true;
if (group.members) {
membersInGroup = members.filter(member => group.members.includes(member.uuid));
membersInGroup = membersInGroup.sort((a, b) => a.name.localeCompare(b.name));
membersNotInGroup = members.filter(member => !group.members.includes(member.uuid));
membersNotInGroup = membersNotInGroup.sort((a, b) => a.name.localeCompare(b.name));
membersInGroupSelection = membersInGroup.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));
membersNotInGroupSelection = membersNotInGroup.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));
}
$: indexOfLastItem = currentPage * 10;
$: indexOfFirstItem = indexOfLastItem - 10;
$: pageAmount = Math.ceil(membersInGroup.length / 10);
$: finalMemberList = membersInGroup.slice(indexOfFirstItem, indexOfLastItem);
let settings = JSON.parse(localStorage.getItem('pk-settings'));
let listGroupElements: any[] = [];
$: if (settings && settings.appearance.twemoji) {
if (listGroupElements && listGroupElements.length > 0) {
listGroupElements.forEach(element => element && twemoji.parse(element));
};
}
function memberListRenderer(item: any) {
return `${item.name} (<code>${item.shortid}</code>)`;
}
addFormatter({
'member-list': memberListRenderer
});
</script>
<Row>
<Col xs={12} lg={6} class="text-center mb-3">
<h5><div class="icon d-inline-block">
<FaUserFriends />
</div>Current Members</h5>
<ListPagination bind:currentPage bind:pageAmount bind:smallPages/>
{#if finalMemberList.length > 0}
<ListGroup>
{#each finalMemberList as member, index (member.id)}
<ListGroupItem><span bind:this={listGroupElements[index]}><b>{member.name}</b> (<code>{member.id}</code>) {member.display_name ? `${member.display_name}` : ""}</span></ListGroupItem>
{/each}
</ListGroup>
{:else}
<p>There are no members in this group yet.</p>
<p>You can add some in this menu!</p>
{/if}
</Col>
<Col xs={12} lg={6} class="text-center mb-3">
<h5><div class="icon d-inline-block">
<FaUserPlus />
</div>Add Members</h5>
<Svelecte renderer="member-list" disableHighlight bind:value={membersToBeAdded} options={membersNotInGroupSelection} multiple/>
<p>(this is nonfunctional at the moment)</p>
<hr/>
<h5><div class="icon d-inline-block">
<FaUserMinus />
</div>Remove Members</h5>
<Svelecte renderer="member-list" disableHighlight bind:value={membersToBeRemoved} options={membersInGroupSelection} multiple/>
<p>(this is ALSO nonfunctional)</p>
</Col>
</Row>
<Button style="flex: 0" color="secondary" on:click={() => memberMode = false}>Back</Button>