fix not being able to update roles twice

This commit is contained in:
Keviin Åberg Kultalahti 2021-05-17 13:23:19 +02:00
parent e12ba0fa38
commit be543d6e3b
2 changed files with 22 additions and 10 deletions

View File

@ -31,16 +31,16 @@
// Here we need to merge the Apps list and the roles response to get something that makes sense for the table
$: appList = $apps.map(app => ({
...app,
role: $request?.data?.roles?.[app._id],
role: $roleFetch?.data?.roles?.[app._id],
}))
let selectedApp
const request = fetchData(`/api/admin/users/${userId}`)
const roleFetch = fetchData(`/api/admin/users/${userId}`)
async function deleteUser() {
const res = await users.del(userId)
if (res.message) {
notifications.success(`User ${$request?.data?.email} deleted.`)
notifications.success(`User ${$roleFetch?.data?.email} deleted.`)
$goto("./")
} else {
notifications.error("Failed to delete user.")
@ -61,7 +61,7 @@
</div>
<div class="heading">
<Layout noPadding gap="XS">
<Heading>User: {$request?.data?.email}</Heading>
<Heading>User: {$roleFetch?.data?.email}</Heading>
<Body
>Lorem ipsum dolor sit amet consectetur adipisicing elit. Debitis porro
ut nesciunt ipsam perspiciatis aliquam et hic minus alias beatae. Odit
@ -76,7 +76,7 @@
<div class="fields">
<div class="field">
<Label size="L">Email</Label>
<Input disabled thin value={$request?.data?.email} />
<Input disabled thin value={$roleFetch?.data?.email} />
</div>
</div>
<div class="regenerate">
@ -119,13 +119,17 @@
showCloseIcon={false}
>
<Body
>Are you sure you want to delete <strong>{$request?.data?.email}</strong
>Are you sure you want to delete <strong>{$roleFetch?.data?.email}</strong
></Body
>
</ModalContent>
</Modal>
<Modal bind:this={editRolesModal}>
<UpdateRolesModal app={selectedApp} user={$request.data} />
<UpdateRolesModal
app={selectedApp}
user={$roleFetch.data}
on:update={roleFetch.refresh}
/>
</Modal>
<style>

View File

@ -1,4 +1,5 @@
<script>
import { createEventDispatcher } from "svelte"
import { Body, Select, ModalContent, notifications } from "@budibase/bbui"
import { fetchData } from "helpers"
import { users } from "stores/portal"
@ -6,19 +7,26 @@
export let app
export let user
const dispatch = createEventDispatcher()
const roles = fetchData(`/api/admin/roles/${app._id}`)
$: options = $roles?.data?.roles?.map(role => role._id)
let selectedRole
function updateUserRoles() {
users.updateRoles({
async function updateUserRoles() {
const res = await users.updateRoles({
...user,
roles: {
...user.roles,
[app._id]: selectedRole,
},
})
notifications.success("Roles updated")
if (res.status === 400) {
notifications.error("Failed to update role.")
} else {
notifications.success("Roles updated")
dispatch("update")
}
}
</script>