code tidy up

This commit is contained in:
Peter Clement 2023-08-29 21:54:15 +01:00
parent f456210224
commit ac34f1129c
2 changed files with 54 additions and 46 deletions

View File

@ -48,7 +48,7 @@
{
_id: CreatorID,
name: "Creator",
tag: !$licensing.perAppBuildersEnabled && "Business",
tag: !$licensing.perAppBuildersEnabled && Constants.PlanType.BUSINESS,
},
...newRoles,
]
@ -108,13 +108,8 @@
getOptionValue={role => role._id}
getOptionColour={getColor}
getOptionIcon={getIcon}
isOptionEnabled={option => {
if (option._id == CreatorID && !$licensing.perAppBuildersEnabled) {
return false
} else {
return true
}
}}
isOptionEnabled={option =>
option._id !== CreatorID || $licensing.perAppBuildersEnabled}
{placeholder}
{error}
/>
@ -132,13 +127,8 @@
getOptionValue={role => role._id}
getOptionColour={getColor}
getOptionIcon={getIcon}
isOptionEnabled={option => {
if (option._id == CreatorID && !$licensing.perAppBuildersEnabled) {
return false
} else {
return true
}
}}
isOptionEnabled={option =>
option._id !== CreatorID || $licensing.perAppBuildersEnabled}
{placeholder}
{error}
/>

View File

@ -80,16 +80,18 @@
if (!filterByAppAccess && !query) {
filteredInvites =
appInvites.length > 100 ? appInvites.slice(0, 100) : [...appInvites]
filteredInvites.sort(sortInviteRoles)
return
}
filteredInvites = appInvites.filter(invite => {
filteredInvites = appInvites
.filter(invite => {
const inviteInfo = invite.info?.apps
if (!query && inviteInfo && prodAppId) {
return Object.keys(inviteInfo).includes(prodAppId)
}
return invite.email.includes(query)
})
.sort(sortInviteRoles)
}
$: filterByAppAccess, prodAppId, filterInvites(query)
@ -150,6 +152,19 @@
.sort(sortRoles)
}
const sortInviteRoles = (a, b) => {
const aIsEmpty = !a.info.apps || Object.keys(a.info.apps).length === 0
const bIsEmpty = !b.info.apps || Object.keys(b.info.apps).length === 0
return aIsEmpty
? bIsEmpty
? 0
: 1 // Put items with empty "apps" at the bottom
: bIsEmpty
? -1
: 0 // Put items with non-empty "apps" above the empty ones
}
const sortRoles = (a, b) => {
const roleA = a.role
const roleB = b.role
@ -357,10 +372,8 @@
const payload = [
{
email: newUserEmail,
builder:
creationRoleType === Constants.BudibaseRoles.Admin ? true : false,
admin:
creationRoleType === Constants.BudibaseRoles.Admin ? true : false,
builder: !!creationRoleType === Constants.BudibaseRoles.Admin,
admin: !!creationRoleType === Constants.BudibaseRoles.Admin,
},
]
@ -387,6 +400,7 @@
}
const onInviteUser = async () => {
form.validate()
userOnboardResponse = await inviteUser()
const originalQuery = query + ""
query = null
@ -563,20 +577,13 @@
<div class="invite-header">
<Heading size="XS">No user found</Heading>
<div class="invite-directions">
Add a valid email to invite a new user
</div>
</div>
<div class="invite-form">
<span>{query || ""}</span>
<ActionButton
icon="UserAdd"
disabled={!queryIsEmail || inviting}
Try searching a different email or <span
class="underlined"
on:click={$licensing.userLimitReached
? userLimitReachedModal.show
: openInviteFlow}
: openInviteFlow}>invite a new user</span
>
Add user
</ActionButton>
</div>
</div>
</Layout>
{/if}
@ -752,6 +759,7 @@
value={query}
on:change={e => {
email = e.detail
query = e.detail
}}
validate={() => {
if (!email) {
@ -770,7 +778,7 @@
)}
label="Role"
/>
{#if creationRoleType !== Constants.Roles.ADMIN}
{#if creationRoleType !== Constants.BudibaseRoles.Admin}
<RoleSelect
placeholder={false}
bind:value={creationAccessType}
@ -783,14 +791,19 @@
/>
{/if}
</FancyForm>
{#if creationRoleType === Constants.Roles.ADMIN}
{#if creationRoleType === Constants.BudibaseRoles.Admin}
<div class="admin-info">
<Icon name="Info" />
Admins will get full access to all apps and settings
</div>
{/if}
<span class="add-user">
<Button newStyles cta on:click={onInviteUser}>Add user</Button>
<Button
newStyles
cta
disabled={!query.length && !email?.length}
on:click={onInviteUser}>Add user</Button
>
</span>
</div>
</Layout>
@ -818,15 +831,20 @@
}
.admin-info {
padding: var(--spacing-l) var(--spacing-l) var(--spacing-xs)
var(--spacing-l);
margin-top: var(--spacing-xl);
padding: var(--spacing-l) var(--spacing-l) var(--spacing-l) var(--spacing-l);
display: flex;
align-items: center;
gap: var(--spacing-xl);
height: 50px;
height: 30px;
background-color: var(--background-alt);
}
.underlined {
text-decoration: underline;
cursor: pointer;
}
.search-input {
flex: 1;
}