fix not being able to update roles twice
This commit is contained in:
parent
e12ba0fa38
commit
be543d6e3b
|
@ -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
|
// 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 => ({
|
$: appList = $apps.map(app => ({
|
||||||
...app,
|
...app,
|
||||||
role: $request?.data?.roles?.[app._id],
|
role: $roleFetch?.data?.roles?.[app._id],
|
||||||
}))
|
}))
|
||||||
let selectedApp
|
let selectedApp
|
||||||
|
|
||||||
const request = fetchData(`/api/admin/users/${userId}`)
|
const roleFetch = fetchData(`/api/admin/users/${userId}`)
|
||||||
|
|
||||||
async function deleteUser() {
|
async function deleteUser() {
|
||||||
const res = await users.del(userId)
|
const res = await users.del(userId)
|
||||||
if (res.message) {
|
if (res.message) {
|
||||||
notifications.success(`User ${$request?.data?.email} deleted.`)
|
notifications.success(`User ${$roleFetch?.data?.email} deleted.`)
|
||||||
$goto("./")
|
$goto("./")
|
||||||
} else {
|
} else {
|
||||||
notifications.error("Failed to delete user.")
|
notifications.error("Failed to delete user.")
|
||||||
|
@ -61,7 +61,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="heading">
|
<div class="heading">
|
||||||
<Layout noPadding gap="XS">
|
<Layout noPadding gap="XS">
|
||||||
<Heading>User: {$request?.data?.email}</Heading>
|
<Heading>User: {$roleFetch?.data?.email}</Heading>
|
||||||
<Body
|
<Body
|
||||||
>Lorem ipsum dolor sit amet consectetur adipisicing elit. Debitis porro
|
>Lorem ipsum dolor sit amet consectetur adipisicing elit. Debitis porro
|
||||||
ut nesciunt ipsam perspiciatis aliquam et hic minus alias beatae. Odit
|
ut nesciunt ipsam perspiciatis aliquam et hic minus alias beatae. Odit
|
||||||
|
@ -76,7 +76,7 @@
|
||||||
<div class="fields">
|
<div class="fields">
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<Label size="L">Email</Label>
|
<Label size="L">Email</Label>
|
||||||
<Input disabled thin value={$request?.data?.email} />
|
<Input disabled thin value={$roleFetch?.data?.email} />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="regenerate">
|
<div class="regenerate">
|
||||||
|
@ -119,13 +119,17 @@
|
||||||
showCloseIcon={false}
|
showCloseIcon={false}
|
||||||
>
|
>
|
||||||
<Body
|
<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
|
></Body
|
||||||
>
|
>
|
||||||
</ModalContent>
|
</ModalContent>
|
||||||
</Modal>
|
</Modal>
|
||||||
<Modal bind:this={editRolesModal}>
|
<Modal bind:this={editRolesModal}>
|
||||||
<UpdateRolesModal app={selectedApp} user={$request.data} />
|
<UpdateRolesModal
|
||||||
|
app={selectedApp}
|
||||||
|
user={$roleFetch.data}
|
||||||
|
on:update={roleFetch.refresh}
|
||||||
|
/>
|
||||||
</Modal>
|
</Modal>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
<script>
|
<script>
|
||||||
|
import { createEventDispatcher } from "svelte"
|
||||||
import { Body, Select, ModalContent, notifications } from "@budibase/bbui"
|
import { Body, Select, ModalContent, notifications } from "@budibase/bbui"
|
||||||
import { fetchData } from "helpers"
|
import { fetchData } from "helpers"
|
||||||
import { users } from "stores/portal"
|
import { users } from "stores/portal"
|
||||||
|
@ -6,19 +7,26 @@
|
||||||
export let app
|
export let app
|
||||||
export let user
|
export let user
|
||||||
|
|
||||||
|
const dispatch = createEventDispatcher()
|
||||||
|
|
||||||
const roles = fetchData(`/api/admin/roles/${app._id}`)
|
const roles = fetchData(`/api/admin/roles/${app._id}`)
|
||||||
$: options = $roles?.data?.roles?.map(role => role._id)
|
$: options = $roles?.data?.roles?.map(role => role._id)
|
||||||
let selectedRole
|
let selectedRole
|
||||||
|
|
||||||
function updateUserRoles() {
|
async function updateUserRoles() {
|
||||||
users.updateRoles({
|
const res = await users.updateRoles({
|
||||||
...user,
|
...user,
|
||||||
roles: {
|
roles: {
|
||||||
...user.roles,
|
...user.roles,
|
||||||
[app._id]: selectedRole,
|
[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>
|
</script>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue