From f07f507fe6a8bb0f30efb62281606781682738ba Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Wed, 3 Aug 2022 09:58:41 +0100 Subject: [PATCH] Make user assignment picker readonly and prevent adding same user multiple times --- .../_components/AssignmentModal.svelte | 68 +++++++++++-------- 1 file changed, 40 insertions(+), 28 deletions(-) diff --git a/packages/builder/src/pages/builder/portal/overview/_components/AssignmentModal.svelte b/packages/builder/src/pages/builder/portal/overview/_components/AssignmentModal.svelte index 47de0f8f24..e0497b4600 100644 --- a/packages/builder/src/pages/builder/portal/overview/_components/AssignmentModal.svelte +++ b/packages/builder/src/pages/builder/portal/overview/_components/AssignmentModal.svelte @@ -18,9 +18,48 @@ let prevSearch = undefined, search = undefined let pageInfo = createPaginationStore() + let appData = [{ id: "", role: "" }] $: page = $pageInfo.page $: fetchUsers(page, search) + $: availableUsers = getAvailableUsers($users, appUsers, appData) + $: filteredGroups = $groups.filter(group => { + return !group.apps.find(appId => { + return appId === app.appId + }) + }) + + $: optionSections = { + ...($auth.groupsEnabled && + filteredGroups.length && { + groups: { + data: filteredGroups, + getLabel: group => group.name, + getValue: group => group._id, + getIcon: group => group.icon, + getColour: group => group.color, + }, + }), + users: { + data: availableUsers, + getLabel: user => user.email, + getValue: user => user._id, + getIcon: user => user.icon, + getColour: user => user.color, + }, + } + + const getAvailableUsers = (allUsers, appUsers, newUsers) => { + return (allUsers.data || []).filter(user => { + // Filter out assigned users + if (appUsers.find(x => x._id === user._id)) { + return false + } + + // Filter out new users which are going to be assigned + return !newUsers.find(x => x.id === user._id) + }) + } async function fetchUsers(page, search) { if ($pageInfo.loading) { @@ -41,34 +80,6 @@ } } - $: filteredGroups = $groups.filter(group => { - return !group.apps.find(appId => { - return appId === app.appId - }) - }) - - $: optionSections = { - ...($auth.groupsEnabled && - filteredGroups.length && { - groups: { - data: filteredGroups, - getLabel: group => group.name, - getValue: group => group._id, - getIcon: group => group.icon, - getColour: group => group.color, - }, - }), - users: { - data: $users.data.filter(u => !appUsers.find(x => x._id === u._id)), - getLabel: user => user.email, - getValue: user => user._id, - getIcon: user => user.icon, - getColour: user => user.color, - }, - } - - $: appData = [{ id: "", role: "" }] - function addNewInput() { appData = [...appData, { id: "", role: "" }] } @@ -86,6 +97,7 @@ {#each appData as input, index}