feat: adding member(s) to group(s)!
This commit is contained in:
parent
ff2a6d038d
commit
c286aaa0b8
@ -1,7 +1,7 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import type Group from "../../api/group";
|
import type Group from "../../api/group";
|
||||||
import type Member from "../../api/member";
|
import type Member from "../../api/member";
|
||||||
import { Row, Col, Button, Alert, ListGroup, ListGroupItem } from 'sveltestrap';
|
import { Row, Col, Button, Alert, ListGroup, ListGroupItem, Spinner } from 'sveltestrap';
|
||||||
import { createEventDispatcher } from 'svelte';
|
import { createEventDispatcher } from 'svelte';
|
||||||
import PKAPI from '../../api';
|
import PKAPI from '../../api';
|
||||||
import ListPagination from "../ListPagination.svelte";
|
import ListPagination from "../ListPagination.svelte";
|
||||||
@ -12,6 +12,7 @@
|
|||||||
import Svelecte, { addFormatter } from 'svelecte';
|
import Svelecte, { addFormatter } from 'svelecte';
|
||||||
|
|
||||||
let loading: boolean = false;
|
let loading: boolean = false;
|
||||||
|
let err: string;
|
||||||
export let group: Group;
|
export let group: Group;
|
||||||
export let memberMode: boolean = true;
|
export let memberMode: boolean = true;
|
||||||
export let members: Member[];
|
export let members: Member[];
|
||||||
@ -28,7 +29,7 @@
|
|||||||
|
|
||||||
let smallPages = true;
|
let smallPages = true;
|
||||||
|
|
||||||
if (group.members) {
|
$: if (group.members) {
|
||||||
membersInGroup = members.filter(member => group.members.includes(member.uuid));
|
membersInGroup = members.filter(member => group.members.includes(member.uuid));
|
||||||
membersInGroup = membersInGroup.sort((a, b) => a.name.localeCompare(b.name));
|
membersInGroup = membersInGroup.sort((a, b) => a.name.localeCompare(b.name));
|
||||||
|
|
||||||
@ -61,8 +62,52 @@ function memberListRenderer(item: any) {
|
|||||||
'member-list': memberListRenderer
|
'member-list': memberListRenderer
|
||||||
});
|
});
|
||||||
|
|
||||||
</script>
|
const dispatch = createEventDispatcher();
|
||||||
|
|
||||||
|
function update() {
|
||||||
|
dispatch("update", group)
|
||||||
|
}
|
||||||
|
|
||||||
|
const api = new PKAPI();
|
||||||
|
|
||||||
|
async function submitAdd() {
|
||||||
|
let data = membersToBeAdded;
|
||||||
|
try {
|
||||||
|
loading = true;
|
||||||
|
await api.postGroupMembers({token: localStorage.getItem("pk-token"), id: group.id, data: data, removing: false});
|
||||||
|
data.forEach(member => group.members.push(member));
|
||||||
|
update();
|
||||||
|
err = null;
|
||||||
|
membersToBeAdded = [];
|
||||||
|
loading = false;
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
err = error.message;
|
||||||
|
loading = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function submitRemove() {
|
||||||
|
let data = membersToBeRemoved;
|
||||||
|
try {
|
||||||
|
loading = true;
|
||||||
|
await api.postGroupMembers({token: localStorage.getItem("pk-token"), id: group.id, data: data, removing: true});
|
||||||
|
group.members = group.members.filter(m => !data.includes(m));
|
||||||
|
update();
|
||||||
|
err = null;
|
||||||
|
membersToBeRemoved = [];
|
||||||
|
loading = false;
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
err = error.message;
|
||||||
|
loading = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
</script>
|
||||||
|
{#if err}
|
||||||
|
<Alert color="danger">{err}</Alert>
|
||||||
|
{/if}
|
||||||
<Row>
|
<Row>
|
||||||
<Col xs={12} lg={6} class="text-center mb-3">
|
<Col xs={12} lg={6} class="text-center mb-3">
|
||||||
<h5><div class="icon d-inline-block">
|
<h5><div class="icon d-inline-block">
|
||||||
@ -85,13 +130,19 @@ function memberListRenderer(item: any) {
|
|||||||
<FaUserPlus />
|
<FaUserPlus />
|
||||||
</div>Add Members</h5>
|
</div>Add Members</h5>
|
||||||
<Svelecte renderer="member-list" disableHighlight bind:value={membersToBeAdded} options={membersNotInGroupSelection} multiple/>
|
<Svelecte renderer="member-list" disableHighlight bind:value={membersToBeAdded} options={membersNotInGroupSelection} multiple/>
|
||||||
<p>(this is nonfunctional at the moment)</p>
|
{#if !loading && membersToBeAdded && membersToBeAdded.length > 0}
|
||||||
|
<Button class="w-100 mt-2" color="primary" on:click={submitAdd}>Add</Button>{:else}
|
||||||
|
<Button class="w-100 mt-2" color="primary" disabled>{#if loading}<Spinner size="sm" />{:else}Add{/if}</Button>
|
||||||
|
{/if}
|
||||||
<hr/>
|
<hr/>
|
||||||
<h5><div class="icon d-inline-block">
|
<h5><div class="icon d-inline-block">
|
||||||
<FaUserMinus />
|
<FaUserMinus />
|
||||||
</div>Remove Members</h5>
|
</div>Remove Members</h5>
|
||||||
<Svelecte renderer="member-list" disableHighlight bind:value={membersToBeRemoved} options={membersInGroupSelection} multiple/>
|
<Svelecte renderer="member-list" disableHighlight bind:value={membersToBeRemoved} options={membersInGroupSelection} multiple/>
|
||||||
<p>(this is ALSO nonfunctional)</p>
|
{#if !loading && membersToBeRemoved && membersToBeRemoved.length > 0}
|
||||||
|
<Button class="w-100 mt-2" color="primary" on:click={submitRemove}>Remove</Button>{:else}
|
||||||
|
<Button class="w-100 mt-2" color="primary" disabled>{#if loading}<Spinner size="sm" />{:else}Remove{/if}</Button>
|
||||||
|
{/if}
|
||||||
</Col>
|
</Col>
|
||||||
</Row>
|
</Row>
|
||||||
<Button style="flex: 0" color="secondary" on:click={() => memberMode = false}>Back</Button>
|
<Button style="flex: 0" color="secondary" on:click={() => memberMode = false}>Back</Button>
|
@ -131,6 +131,6 @@
|
|||||||
{:else if editMode}
|
{:else if editMode}
|
||||||
<Edit on:update bind:member bind:editMode />
|
<Edit on:update bind:member bind:editMode />
|
||||||
{:else if groupMode}
|
{:else if groupMode}
|
||||||
<GroupEdit on:update bind:member bind:groups bind:groupMode />
|
<GroupEdit on:updateGroups bind:member bind:groups bind:groupMode />
|
||||||
{/if}
|
{/if}
|
||||||
</CardBody>
|
</CardBody>
|
@ -1,7 +1,7 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import type Group from "../../api/group";
|
import type Group from "../../api/group";
|
||||||
import type Member from "../../api/member";
|
import type Member from "../../api/member";
|
||||||
import { Row, Col, Button, Alert, ListGroup, ListGroupItem } from 'sveltestrap';
|
import { Row, Col, Button, Alert, ListGroup, ListGroupItem, Spinner } from 'sveltestrap';
|
||||||
import { createEventDispatcher } from 'svelte';
|
import { createEventDispatcher } from 'svelte';
|
||||||
import PKAPI from '../../api';
|
import PKAPI from '../../api';
|
||||||
import ListPagination from "../ListPagination.svelte";
|
import ListPagination from "../ListPagination.svelte";
|
||||||
@ -16,6 +16,7 @@
|
|||||||
export let member: Member;
|
export let member: Member;
|
||||||
export let groups: Group[] = [];
|
export let groups: Group[] = [];
|
||||||
let loading: boolean = false;
|
let loading: boolean = false;
|
||||||
|
let err: string;
|
||||||
export let groupMode: boolean = true;
|
export let groupMode: boolean = true;
|
||||||
|
|
||||||
let groupsWithMember: Group[];
|
let groupsWithMember: Group[];
|
||||||
@ -29,7 +30,7 @@
|
|||||||
let currentPage = 1;
|
let currentPage = 1;
|
||||||
let smallPages = true;
|
let smallPages = true;
|
||||||
|
|
||||||
if (groups) {
|
$: if (groups) {
|
||||||
groupsWithMember = groups.filter(group => group.members.includes(member.uuid));
|
groupsWithMember = groups.filter(group => group.members.includes(member.uuid));
|
||||||
groupsWithMember.sort((a, b) => a.name.localeCompare(b.name));
|
groupsWithMember.sort((a, b) => a.name.localeCompare(b.name));
|
||||||
|
|
||||||
@ -62,8 +63,52 @@
|
|||||||
'member-list': groupListRenderer
|
'member-list': groupListRenderer
|
||||||
});
|
});
|
||||||
|
|
||||||
</script>
|
const dispatch = createEventDispatcher();
|
||||||
|
|
||||||
|
function updateGroups() {
|
||||||
|
dispatch("updateGroups", groups);
|
||||||
|
}
|
||||||
|
|
||||||
|
const api = new PKAPI();
|
||||||
|
|
||||||
|
async function submitAdd() {
|
||||||
|
let data = groupsToBeAdded;
|
||||||
|
try {
|
||||||
|
loading = true;
|
||||||
|
await api.postMemberGroups({token: localStorage.getItem("pk-token"), id: member.id, data: data, removing: false});
|
||||||
|
groups.forEach(group => data.includes(group.uuid) && group.members.push(member.uuid));
|
||||||
|
updateGroups();
|
||||||
|
err = null;
|
||||||
|
groupsToBeAdded = [];
|
||||||
|
loading = false;
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
err = error.message;
|
||||||
|
loading = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function submitRemove() {
|
||||||
|
let data = groupsToBeRemoved;
|
||||||
|
try {
|
||||||
|
loading = true;
|
||||||
|
await api.postMemberGroups({token: localStorage.getItem("pk-token"), id: member.id, data: data, removing: true});
|
||||||
|
groups.forEach(group => {if (data.includes(group.uuid)) group.members = group.members.filter(m => m !== member.uuid)});
|
||||||
|
updateGroups();
|
||||||
|
err = null;
|
||||||
|
groupsToBeRemoved = [];
|
||||||
|
loading = false;
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
err = error.message;
|
||||||
|
loading = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
</script>
|
||||||
|
{#if err}
|
||||||
|
<Alert color="danger">{err}</Alert>
|
||||||
|
{/if}
|
||||||
<Row>
|
<Row>
|
||||||
<Col xs={12} lg={6} class="text-center mb-3">
|
<Col xs={12} lg={6} class="text-center mb-3">
|
||||||
<h5><div class="icon d-inline-block">
|
<h5><div class="icon d-inline-block">
|
||||||
@ -86,13 +131,19 @@
|
|||||||
<FaFolderPlus />
|
<FaFolderPlus />
|
||||||
</div>Add to Groups</h5>
|
</div>Add to Groups</h5>
|
||||||
<Svelecte renderer="member-list" disableHighlight bind:value={groupsToBeAdded} options={groupsWithoutMemberSelection} multiple/>
|
<Svelecte renderer="member-list" disableHighlight bind:value={groupsToBeAdded} options={groupsWithoutMemberSelection} multiple/>
|
||||||
<p>(this is nonfunctional at the moment)</p>
|
{#if !loading && groupsToBeAdded && groupsToBeAdded.length > 0}
|
||||||
|
<Button class="w-100 mt-2" color="primary" on:click={submitAdd}>Add</Button>{:else}
|
||||||
|
<Button class="w-100 mt-2" color="primary" disabled>{#if loading}<Spinner size="sm" />{:else}Add{/if}</Button>
|
||||||
|
{/if}
|
||||||
<hr/>
|
<hr/>
|
||||||
<h5><div class="icon d-inline-block">
|
<h5><div class="icon d-inline-block">
|
||||||
<FaFolderMinus />
|
<FaFolderMinus />
|
||||||
</div>Remove from Groups</h5>
|
</div>Remove from Groups</h5>
|
||||||
<Svelecte renderer="member-list" disableHighlight bind:value={groupsToBeRemoved} options={groupsWithMemberSelection} multiple/>
|
<Svelecte renderer="member-list" disableHighlight bind:value={groupsToBeRemoved} options={groupsWithMemberSelection} multiple/>
|
||||||
<p>(this is ALSO nonfunctional)</p>
|
{#if !loading && groupsToBeRemoved && groupsToBeRemoved.length > 0}
|
||||||
|
<Button class="w-100 mt-2" color="primary" on:click={submitRemove}>Remove</Button>{:else}
|
||||||
|
<Button class="w-100 mt-2" color="primary" disabled>{#if loading}<Spinner size="sm" />{:else}Remove{/if}</Button>
|
||||||
|
{/if}
|
||||||
</Col>
|
</Col>
|
||||||
</Row>
|
</Row>
|
||||||
<Button style="flex: 0" color="secondary" on:click={() => groupMode = false}>Back</Button>
|
<Button style="flex: 0" color="secondary" on:click={() => groupMode = false}>Back</Button>
|
Loading…
Reference in New Issue
Block a user