user screen update

This commit is contained in:
Peter Clement 2022-07-05 15:40:12 +01:00
parent a84b36cc54
commit 51f09377b8
5 changed files with 61 additions and 48 deletions

View File

@ -27,11 +27,9 @@
import { users, auth, groups, apps } from "stores/portal" import { users, auth, groups, apps } from "stores/portal"
import { roles } from "stores/backend" import { roles } from "stores/backend"
import { Constants } from "@budibase/frontend-core" import { Constants } from "@budibase/frontend-core"
import ForceResetPasswordModal from "./_components/ForceResetPasswordModal.svelte" import ForceResetPasswordModal from "./_components/ForceResetPasswordModal.svelte"
import { RoleUtils } from "@budibase/frontend-core" import { RoleUtils } from "@budibase/frontend-core"
import UserGroupPicker from "components/settings/UserGroupPicker.svelte" import UserGroupPicker from "components/settings/UserGroupPicker.svelte"
export let userId export let userId
let deleteUserModal let deleteUserModal
let resetPasswordModal let resetPasswordModal
@ -40,9 +38,7 @@
let popover let popover
let selectedGroups = [] let selectedGroups = []
let allAppList = [] let allAppList = []
$: console.log($apps) let toggleDisabled = false
$: console.log($userFetch.data)
$: allAppList = $apps $: allAppList = $apps
.filter(x => { .filter(x => {
if ($userFetch.data?.roles) { if ($userFetch.data?.roles) {
@ -52,15 +48,18 @@
} }
}) })
.map(app => { .map(app => {
let roles = Object.keys($userFetch.data.roles).filter(id => { let roles = Object.fromEntries(
return id === app.appId Object.entries($userFetch.data.roles).filter(
}) ([key]) => key === app.appId
)
)
return { return {
...app, name: app.name,
devId: app.devId,
icon: app.icon,
roles, roles,
} }
}) })
$: console.log(allAppList)
// Used for searching through groups in the add group popover // Used for searching through groups in the add group popover
$: filteredGroups = $groups.filter( $: filteredGroups = $groups.filter(
group => group =>
@ -74,6 +73,12 @@
}) })
}) })
$: globalRole = $userFetch?.data?.admin?.global
? "admin"
: $userFetch?.data?.builder?.global
? "developer"
: "appUser"
const userFetch = fetchData(`/api/global/users/${userId}`) const userFetch = fetchData(`/api/global/users/${userId}`)
async function deleteUser() { async function deleteUser() {
try { try {
@ -88,10 +93,10 @@
function getHighestRole(roles) { function getHighestRole(roles) {
let highestRole let highestRole
let highestRoleNumber = 0 let highestRoleNumber = 0
roles.forEach(role => { Object.keys(roles).forEach(role => {
let roleNumber = RoleUtils.getRolePriority(role._id) let roleNumber = RoleUtils.getRolePriority(roles[role])
if (roleNumber > highestRoleNumber) { if (roleNumber > highestRoleNumber) {
highestRole = role highestRole = roles[role]
} }
}) })
return highestRole return highestRole
@ -121,8 +126,14 @@
} }
} }
async function updateUserRole() { async function updateUserRole({ detail }) {
return if (detail === "developer") {
toggleFlags({ admin: { global: false }, builder: { global: true } })
} else if (detail === "admin") {
toggleFlags({ admin: { global: true }, builder: { global: false } })
} else if (detail === "appUser") {
toggleFlags({ admin: { global: false }, builder: { global: false } })
}
} }
async function addGroup(groupId) { async function addGroup(groupId) {
@ -142,21 +153,14 @@
await groups.actions.save(group) await groups.actions.save(group)
} }
function addAll() {} async function toggleFlags(detail) {
/*
async function toggleFlag(flagName, detail) {
toggleDisabled = true
try { try {
await users.save({ ...$userFetch?.data, [flagName]: { global: detail } }) await users.save({ ...$userFetch?.data, ...detail })
await userFetch.refresh() await userFetch.refresh()
} catch (error) { } catch (error) {
notifications.error("Error updating user") notifications.error("Error updating user")
} }
toggleDisabled = false
} }
async function toggleBuilderAccess({ detail }) { async function toggleBuilderAccess({ detail }) {
return toggleFlag("builder", detail) return toggleFlag("builder", detail)
} }
@ -169,7 +173,8 @@
selectedApp = detail selectedApp = detail
editRolesModal.show() editRolesModal.show()
} }
*/
function addAll() {}
onMount(async () => { onMount(async () => {
try { try {
await groups.actions.init() await groups.actions.init()
@ -240,7 +245,11 @@
{#if userId !== $auth.user._id} {#if userId !== $auth.user._id}
<div class="field"> <div class="field">
<Label size="L">Role</Label> <Label size="L">Role</Label>
<Select options={Constants.BbRoles} on:blur={updateUserRole} /> <Select
value={globalRole}
options={Constants.BbRoles}
on:change={updateUserRole}
/>
</div> </div>
{/if} {/if}
</div> </div>
@ -304,16 +313,20 @@
<List> <List>
{#if allAppList.length} {#if allAppList.length}
{#each allAppList as app} {#each allAppList as app}
<div on:click={$goto(`../../overview/${app.devId}`)}> <div class="pointer" on:click={$goto(`../../overview/${app.devId}`)}>
<ListItem <ListItem
title={app.name} title={app.name}
iconBackground={app?.icon?.color || ""} iconBackground={app?.icon?.color || ""}
icon={app?.icon?.name || "Apps"} icon={app?.icon?.name || "Apps"}
> >
<div class="title "> <div class="title ">
<StatusLight /> <StatusLight
color={RoleUtils.getRoleColour(getHighestRole(app.roles))}
/>
<div style="margin-left: var(--spacing-s);"> <div style="margin-left: var(--spacing-s);">
<Body size="XS">d</Body> <Body size="XS"
>{Constants.Roles[getHighestRole(app.roles)]}</Body
>
</div> </div>
</div> </div>
</ListItem> </ListItem>
@ -348,6 +361,9 @@
</Modal> </Modal>
<style> <style>
.pointer {
cursor: pointer;
}
.fields { .fields {
display: grid; display: grid;
grid-gap: var(--spacing-m); grid-gap: var(--spacing-m);

View File

@ -1,21 +1,14 @@
<script> <script>
import { Icon } from "@budibase/bbui" import { Icon } from "@budibase/bbui"
export let value export let value
$: console.log(value)
</script> </script>
<div class="align"> <div class="align">
<div class="spacing"> <div class="spacing">
<Icon name="Apps" /> <Icon name="WebPage" />
</div> </div>
{#if value?.apps?.length === 0} {parseInt(value?.length) || 0}
<div>
<div>No groups</div>
</div>
{:else if value?.apps?.length === 1}
{value?.groups[0]?.name}
{:else}
{parseInt(value?.apps?.length) || 0}
{/if}
</div> </div>
<style> <style>

View File

@ -5,16 +5,18 @@
<div class="align"> <div class="align">
<div class="spacing"> <div class="spacing">
<Icon name="User" /> <Icon name="UserGroup" />
</div> </div>
{#if value.length === 0} {#if value.length === 0}
<div>0</div> <div class="opacity">0</div>
{:else if value.length === 1} {:else if value.length === 1}
<div class="opacity"> <div class="opacity">
<Body size="S">{value[0].name}</Body> <Body size="S">{value[0].name}</Body>
</div> </div>
{:else} {:else}
{parseInt(value.length) || 0} groups <div class="opacity">
{parseInt(value.length) || 0} groups
</div>
{/if} {/if}
</div> </div>
@ -25,7 +27,7 @@
} }
.opacity { .opacity {
opacity: 0.7; opacity: 0.8;
} }
.spacing { .spacing {

View File

@ -25,7 +25,6 @@
import PasswordModal from "./_components/PasswordModal.svelte" import PasswordModal from "./_components/PasswordModal.svelte"
import ImportUsersModal from "./_components/ImportUsersModal.svelte" import ImportUsersModal from "./_components/ImportUsersModal.svelte"
import analytics, { Events } from "analytics" import analytics, { Events } from "analytics"
import TriggerAutomation from "../../../../../components/design/PropertiesPanel/PropertyControls/ButtonActionEditor/actions/TriggerAutomation.svelte"
const schema = { const schema = {
name: {}, name: {},
@ -35,10 +34,10 @@
sortable: false, sortable: false,
}, },
userGroups: { sortable: false, displayName: "User groups" }, userGroups: { sortable: false, displayName: "User groups" },
apps: {}, apps: { width: "120px" },
settings: { settings: {
sortable: false, sortable: false,
width: "50px", width: "60px",
displayName: "", displayName: "",
align: "Right", align: "Right",
}, },
@ -81,11 +80,13 @@
$: enrichedUsers = $users.map(user => { $: enrichedUsers = $users.map(user => {
let userGroups = [] let userGroups = []
let userApps = []
$groups.forEach(group => { $groups.forEach(group => {
if (group.users) { if (group.users) {
group.users?.forEach(y => { group.users?.forEach(y => {
if (y._id === user._id) { if (y._id === user._id) {
userGroups.push(group) userGroups.push(group)
userApps = group.apps
} }
}) })
} }
@ -94,6 +95,7 @@
...user, ...user,
name: user.firstName ? user.firstName + " " + user.lastName : "", name: user.firstName ? user.firstName + " " + user.lastName : "",
userGroups, userGroups,
apps: [...new Set(Object.keys(user.roles))],
} }
}) })

View File

@ -22,7 +22,7 @@
let appUsers = [] let appUsers = []
$: appUsers = $users.filter(x => { $: appUsers = $users.filter(x => {
return Object.keys(x.roles).some(y => { return Object.keys(x.roles).find(y => {
return extractAppId(y) === extractAppId(app.appId) return extractAppId(y) === extractAppId(app.appId)
}) })
}) })
@ -54,7 +54,7 @@
let newUser = { let newUser = {
...matchedUser, ...matchedUser,
roles: { [app.appId]: data.role }, roles: { [app.appId]: data.role, ...matchedUser.roles },
} }
await users.save(newUser) await users.save(newUser)