Skip to content

Commit

Permalink
Merge pull request #12006 from Budibase/user-metadata-changes
Browse files Browse the repository at this point in the history
Allow user table changes in existing apps again
  • Loading branch information
aptkingston authored Oct 10, 2023
2 parents f8759a4 + 89e6a69 commit fed6bff
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 9 deletions.
1 change: 1 addition & 0 deletions packages/builder/src/builderStore/store/frontend.js
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ const INITIAL_FRONTEND_STATE = {
},
features: {
componentValidation: false,
disableUserMetadata: false,
},
errors: [],
hasAppPackage: false,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import { TableNames } from "constants"
import { Grid } from "@budibase/frontend-core"
import { API } from "api"
import { store } from "builderStore"
import GridAddColumnModal from "components/backend/DataTable/modals/grid/GridCreateColumnModal.svelte"
import GridCreateEditRowModal from "components/backend/DataTable/modals/grid/GridCreateEditRowModal.svelte"
import GridEditUserModal from "components/backend/DataTable/modals/grid/GridEditUserModal.svelte"
Expand All @@ -17,11 +18,11 @@
import GridUsersTableButton from "components/backend/DataTable/modals/grid/GridUsersTableButton.svelte"
const userSchemaOverrides = {
firstName: { displayName: "First name" },
lastName: { displayName: "Last name" },
email: { displayName: "Email" },
roleId: { displayName: "Role" },
status: { displayName: "Status" },
firstName: { displayName: "First name", disabled: true },
lastName: { displayName: "Last name", disabled: true },
email: { displayName: "Email", disabled: true },
roleId: { displayName: "Role", disabled: true },
status: { displayName: "Status", disabled: true },
}
$: id = $tables.selected?._id
Expand Down Expand Up @@ -60,14 +61,14 @@
datasource={gridDatasource}
canAddRows={!isUsersTable}
canDeleteRows={!isUsersTable}
canEditRows={!isUsersTable}
canEditColumns={!isUsersTable}
canEditRows={!isUsersTable || !$store.features.disableUserMetadata}
canEditColumns={!isUsersTable || !$store.features.disableUserMetadata}
schemaOverrides={isUsersTable ? userSchemaOverrides : null}
showAvatars={false}
on:updatedatasource={handleGridTableUpdate}
>
<svelte:fragment slot="filter">
{#if isUsersTable}
{#if isUsersTable && $store.features.disableUserMetadata}
<GridUsersTableButton />
{/if}
<GridFilterButton />
Expand Down
6 changes: 5 additions & 1 deletion packages/server/src/api/controllers/application.ts
Original file line number Diff line number Diff line change
Expand Up @@ -289,6 +289,7 @@ async function performAppCreate(ctx: UserCtx) {
},
features: {
componentValidation: true,
disableUserMetadata: true,
},
}

Expand All @@ -310,10 +311,13 @@ async function performAppCreate(ctx: UserCtx) {
}
})

// Keep existing validation setting
// Keep existing feature flags
if (!existing.features?.componentValidation) {
newApplication.features!.componentValidation = false
}
if (!existing.features?.disableUserMetadata) {
newApplication.features!.disableUserMetadata = false
}

// Migrate navigation settings and screens if required
if (existing) {
Expand Down
1 change: 1 addition & 0 deletions packages/types/src/documents/app/app.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,4 +66,5 @@ export interface AppIcon {

export interface AppFeatures {
componentValidation?: boolean
disableUserMetadata?: boolean
}

0 comments on commit fed6bff

Please sign in to comment.