diff --git a/charts/budibase/templates/app-service-deployment.yaml b/charts/budibase/templates/app-service-deployment.yaml
index 2b2589406a..e47dc0bb58 100644
--- a/charts/budibase/templates/app-service-deployment.yaml
+++ b/charts/budibase/templates/app-service-deployment.yaml
@@ -201,25 +201,24 @@ spec:
image: budibase/apps:{{ .Values.globals.appVersion | default .Chart.AppVersion }}
imagePullPolicy: Always
+ {{- if .Values.services.apps.startupProbe }}
+ {{- with .Values.services.apps.startupProbe }}
+ startupProbe:
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
+ {{- if .Values.services.apps.livenessProbe }}
+ {{- with .Values.services.apps.livenessProbe }}
livenessProbe:
- httpGet:
- path: /health
- port: {{ .Values.services.apps.port }}
- initialDelaySeconds: 10
- periodSeconds: 5
- successThreshold: 1
- failureThreshold: 3
- timeoutSeconds: 3
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
+ {{- if .Values.services.apps.readinessProbe }}
+ {{- with .Values.services.apps.readinessProbe }}
readinessProbe:
- httpGet:
- path: /health
- port: {{ .Values.services.apps.port }}
- initialDelaySeconds: 5
- periodSeconds: 5
- successThreshold: 1
- failureThreshold: 3
- timeoutSeconds: 3
-
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
name: bbapps
ports:
- containerPort: {{ .Values.services.apps.port }}
diff --git a/charts/budibase/templates/proxy-service-deployment.yaml b/charts/budibase/templates/proxy-service-deployment.yaml
index c087627100..53bba6232d 100644
--- a/charts/budibase/templates/proxy-service-deployment.yaml
+++ b/charts/budibase/templates/proxy-service-deployment.yaml
@@ -40,24 +40,24 @@ spec:
- image: budibase/proxy:{{ .Values.globals.appVersion | default .Chart.AppVersion }}
imagePullPolicy: Always
name: proxy-service
+ {{- if .Values.services.proxy.startupProbe }}
+ {{- with .Values.services.proxy.startupProbe }}
+ startupProbe:
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
+ {{- if .Values.services.proxy.livenessProbe }}
+ {{- with .Values.services.proxy.livenessProbe }}
livenessProbe:
- httpGet:
- path: /health
- port: {{ .Values.services.proxy.port }}
- initialDelaySeconds: 0
- periodSeconds: 5
- successThreshold: 1
- failureThreshold: 2
- timeoutSeconds: 3
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
+ {{- if .Values.services.proxy.readinessProbe }}
+ {{- with .Values.services.proxy.readinessProbe }}
readinessProbe:
- httpGet:
- path: /health
- port: {{ .Values.services.proxy.port }}
- initialDelaySeconds: 0
- periodSeconds: 5
- successThreshold: 1
- failureThreshold: 2
- timeoutSeconds: 3
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
ports:
- containerPort: {{ .Values.services.proxy.port }}
env:
diff --git a/charts/budibase/templates/worker-service-deployment.yaml b/charts/budibase/templates/worker-service-deployment.yaml
index 5fed80b355..124c667807 100644
--- a/charts/budibase/templates/worker-service-deployment.yaml
+++ b/charts/budibase/templates/worker-service-deployment.yaml
@@ -190,24 +190,24 @@ spec:
{{ end }}
image: budibase/worker:{{ .Values.globals.appVersion | default .Chart.AppVersion }}
imagePullPolicy: Always
+ {{- if .Values.services.worker.startupProbe }}
+ {{- with .Values.services.worker.startupProbe }}
+ startupProbe:
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
+ {{- if .Values.services.worker.livenessProbe }}
+ {{- with .Values.services.worker.livenessProbe }}
livenessProbe:
- httpGet:
- path: /health
- port: {{ .Values.services.worker.port }}
- initialDelaySeconds: 10
- periodSeconds: 5
- successThreshold: 1
- failureThreshold: 3
- timeoutSeconds: 3
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
+ {{- if .Values.services.worker.readinessProbe }}
+ {{- with .Values.services.worker.readinessProbe }}
readinessProbe:
- httpGet:
- path: /health
- port: {{ .Values.services.worker.port }}
- initialDelaySeconds: 5
- periodSeconds: 5
- successThreshold: 1
- failureThreshold: 3
- timeoutSeconds: 3
+ {{- toYaml . | nindent 10 }}
+ {{- end }}
+ {{- end }}
name: bbworker
ports:
- containerPort: {{ .Values.services.worker.port }}
diff --git a/charts/budibase/values.yaml b/charts/budibase/values.yaml
index 74e4c52654..12e21a8e9c 100644
--- a/charts/budibase/values.yaml
+++ b/charts/budibase/values.yaml
@@ -119,15 +119,37 @@ services:
port: 10000
replicaCount: 1
upstreams:
- apps: 'http://app-service.{{ .Release.Namespace }}.svc.{{ .Values.services.dns }}:{{ .Values.services.apps.port }}'
- worker: 'http://worker-service.{{ .Release.Namespace }}.svc.{{ .Values.services.dns }}:{{ .Values.services.worker.port }}'
- minio: 'http://minio-service.{{ .Release.Namespace }}.svc.{{ .Values.services.dns }}:{{ .Values.services.objectStore.port }}'
- couchdb: 'http://{{ .Release.Name }}-svc-couchdb:{{ .Values.services.couchdb.port }}'
+ apps: "http://app-service.{{ .Release.Namespace }}.svc.{{ .Values.services.dns }}:{{ .Values.services.apps.port }}"
+ worker: "http://worker-service.{{ .Release.Namespace }}.svc.{{ .Values.services.dns }}:{{ .Values.services.worker.port }}"
+ minio: "http://minio-service.{{ .Release.Namespace }}.svc.{{ .Values.services.dns }}:{{ .Values.services.objectStore.port }}"
+ couchdb: "http://{{ .Release.Name }}-svc-couchdb:{{ .Values.services.couchdb.port }}"
resources: {}
-# annotations:
-# co.elastic.logs/module: nginx
-# co.elastic.logs/fileset.stdout: access
-# co.elastic.logs/fileset.stderr: error
+ startupProbe:
+ httpGet:
+ path: /health
+ port: 10000
+ scheme: HTTP
+ failureThreshold: 30
+ periodSeconds: 3
+ readinessProbe:
+ httpGet:
+ path: /health
+ port: 10000
+ scheme: HTTP
+ enabled: true
+ periodSeconds: 3
+ failureThreshold: 1
+ livenessProbe:
+ httpGet:
+ path: /health
+ port: 10000
+ scheme: HTTP
+ failureThreshold: 3
+ periodSeconds: 5
+ # annotations:
+ # co.elastic.logs/module: nginx
+ # co.elastic.logs/fileset.stdout: access
+ # co.elastic.logs/fileset.stderr: error
apps:
port: 4002
@@ -135,23 +157,67 @@ services:
logLevel: info
httpLogging: 1
resources: {}
-# nodeDebug: "" # set the value of NODE_DEBUG
-# annotations:
-# co.elastic.logs/multiline.type: pattern
-# co.elastic.logs/multiline.pattern: '^[[:space:]]'
-# co.elastic.logs/multiline.negate: false
-# co.elastic.logs/multiline.match: after
+ startupProbe:
+ httpGet:
+ path: /health
+ port: 4002
+ scheme: HTTP
+ failureThreshold: 30
+ periodSeconds: 3
+ readinessProbe:
+ httpGet:
+ path: /health
+ port: 4002
+ scheme: HTTP
+ enabled: true
+ periodSeconds: 3
+ failureThreshold: 1
+ livenessProbe:
+ httpGet:
+ path: /health
+ port: 4002
+ scheme: HTTP
+ failureThreshold: 3
+ periodSeconds: 5
+ # nodeDebug: "" # set the value of NODE_DEBUG
+ # annotations:
+ # co.elastic.logs/multiline.type: pattern
+ # co.elastic.logs/multiline.pattern: '^[[:space:]]'
+ # co.elastic.logs/multiline.negate: false
+ # co.elastic.logs/multiline.match: after
worker:
port: 4003
replicaCount: 1
logLevel: info
httpLogging: 1
resources: {}
-# annotations:
-# co.elastic.logs/multiline.type: pattern
-# co.elastic.logs/multiline.pattern: '^[[:space:]]'
-# co.elastic.logs/multiline.negate: false
-# co.elastic.logs/multiline.match: after
+ startupProbe:
+ httpGet:
+ path: /health
+ port: 4003
+ scheme: HTTP
+ failureThreshold: 30
+ periodSeconds: 3
+ readinessProbe:
+ httpGet:
+ path: /health
+ port: 4003
+ scheme: HTTP
+ enabled: true
+ periodSeconds: 3
+ failureThreshold: 1
+ livenessProbe:
+ httpGet:
+ path: /health
+ port: 4003
+ scheme: HTTP
+ failureThreshold: 3
+ periodSeconds: 5
+ # annotations:
+ # co.elastic.logs/multiline.type: pattern
+ # co.elastic.logs/multiline.pattern: '^[[:space:]]'
+ # co.elastic.logs/multiline.negate: false
+ # co.elastic.logs/multiline.match: after
couchdb:
enabled: true
diff --git a/lerna.json b/lerna.json
index fb1b966db4..457fef141c 100644
--- a/lerna.json
+++ b/lerna.json
@@ -1,5 +1,5 @@
{
- "version": "2.8.29-alpha.3",
+ "version": "2.8.29-alpha.7",
"npmClient": "yarn",
"packages": [
"packages/*"
diff --git a/packages/bbui/package.json b/packages/bbui/package.json
index 4d39f6330b..e5d0ad6b57 100644
--- a/packages/bbui/package.json
+++ b/packages/bbui/package.json
@@ -85,7 +85,8 @@
"dayjs": "^1.10.4",
"easymde": "^2.16.1",
"svelte-flatpickr": "3.2.3",
- "svelte-portal": "^1.0.0"
+ "svelte-portal": "^1.0.0",
+ "svelte-dnd-action": "^0.9.8"
},
"resolutions": {
"loader-utils": "1.4.1"
diff --git a/packages/bbui/src/IconPicker/IconPicker.svelte b/packages/bbui/src/IconPicker/IconPicker.svelte
index 2b42da61b1..b3cc72daa3 100644
--- a/packages/bbui/src/IconPicker/IconPicker.svelte
+++ b/packages/bbui/src/IconPicker/IconPicker.svelte
@@ -1,5 +1,4 @@
+
+
+
+ {#each options as option, idx (option.id)}
+
+
+
+
+
+
openColorPickerPopover(idx, e.target)}
+ >
+
+
+ {#each colorsArray as color}
+
handleColorChange(option.name, color, idx)}
+ style="--color:{color};"
+ class="circle circle-hover"
+ />
+ {/each}
+
+
+
+
+
+ handleNameChange(option.name, idx, e.target.value)}
+ value={option.name}
+ placeholder="Option name"
+ />
+
+
+
+
+
+ {/each}
+
+
+
+
+
diff --git a/packages/bbui/src/Popover/Popover.svelte b/packages/bbui/src/Popover/Popover.svelte
index 9f951a6a7e..6706bf7a8b 100644
--- a/packages/bbui/src/Popover/Popover.svelte
+++ b/packages/bbui/src/Popover/Popover.svelte
@@ -21,6 +21,7 @@
export let offset = 5
export let customHeight
export let animate = true
+ export let customZindex
$: target = portalTarget || getContext(Context.PopoverRoot) || ".spectrum"
@@ -77,8 +78,9 @@
}}
on:keydown={handleEscape}
class="spectrum-Popover is-open"
+ class:customZindex
role="presentation"
- style="height: {customHeight}"
+ style="height: {customHeight}; --customZindex: {customZindex};"
transition:fly|local={{ y: -20, duration: animate ? 200 : 0 }}
>
@@ -92,4 +94,8 @@
border-color: var(--spectrum-global-color-gray-300);
overflow: auto;
}
+
+ .customZindex {
+ z-index: var(--customZindex) !important;
+ }
diff --git a/packages/bbui/src/index.js b/packages/bbui/src/index.js
index 97762d2b3a..cda6b5acbf 100644
--- a/packages/bbui/src/index.js
+++ b/packages/bbui/src/index.js
@@ -84,7 +84,7 @@ export { default as IconSideNavItem } from "./IconSideNav/IconSideNavItem.svelte
export { default as Slider } from "./Form/Slider.svelte"
export { default as Accordion } from "./Accordion/Accordion.svelte"
export { default as File } from "./Form/File.svelte"
-
+export { default as OptionSelectDnD } from "./OptionSelectDnD/OptionSelectDnD.svelte"
// Renderers
export { default as BoldRenderer } from "./Table/BoldRenderer.svelte"
export { default as CodeRenderer } from "./Table/CodeRenderer.svelte"
diff --git a/packages/builder/src/components/backend/DataTable/TableDataTable.svelte b/packages/builder/src/components/backend/DataTable/TableDataTable.svelte
index 7ef779d300..33175b336d 100644
--- a/packages/builder/src/components/backend/DataTable/TableDataTable.svelte
+++ b/packages/builder/src/components/backend/DataTable/TableDataTable.svelte
@@ -66,6 +66,13 @@
+
+
+
+
+
+
+
{#if isInternal}
@@ -79,9 +86,8 @@
{:else}
{/if}
+
-
-
{#if isUsersTable}
{:else}
diff --git a/packages/builder/src/components/backend/DataTable/modals/CreateEditColumn.svelte b/packages/builder/src/components/backend/DataTable/modals/CreateEditColumn.svelte
index 4761ccee02..7c3e13f39a 100644
--- a/packages/builder/src/components/backend/DataTable/modals/CreateEditColumn.svelte
+++ b/packages/builder/src/components/backend/DataTable/modals/CreateEditColumn.svelte
@@ -7,12 +7,12 @@
Toggle,
RadioGroup,
DatePicker,
- ModalContent,
- Context,
Modal,
notifications,
+ OptionSelectDnD,
+ Layout,
} from "@budibase/bbui"
- import { createEventDispatcher } from "svelte"
+ import { createEventDispatcher, getContext } from "svelte"
import { cloneDeep } from "lodash/fp"
import { tables, datasources } from "stores/backend"
import { TableNames, UNEDITABLE_USER_FIELDS } from "constants"
@@ -26,12 +26,10 @@
SWITCHABLE_TYPES,
} from "constants/backend"
import { getAutoColumnInformation, buildAutoColumn } from "builderStore/utils"
- import ValuesList from "components/common/ValuesList.svelte"
import ConfirmDialog from "components/common/ConfirmDialog.svelte"
import { truncate } from "lodash"
import ModalBindableInput from "components/common/bindings/ModalBindableInput.svelte"
import { getBindings } from "components/backend/DataTable/formula"
- import { getContext } from "svelte"
import JSONSchemaModal from "./JSONSchemaModal.svelte"
import { ValidColumnNameRegex } from "@budibase/shared-core"
@@ -45,11 +43,11 @@
const dispatch = createEventDispatcher()
const PROHIBITED_COLUMN_NAMES = ["type", "_id", "_rev", "tableId"]
- const { hide } = getContext(Context.Modal)
- let fieldDefinitions = cloneDeep(FIELDS)
+ const { dispatch: gridDispatch } = getContext("grid")
export let field
+ let fieldDefinitions = cloneDeep(FIELDS)
let originalName
let linkEditDisabled
let primaryDisplay
@@ -61,11 +59,10 @@
let savingColumn
let deleteColName
let jsonSchemaModal
-
+ let allowedTypes = []
let editableColumn = {
type: "string",
constraints: fieldDefinitions.STRING.constraints,
-
// Initial value for column name in other table for linked records
fieldName: $tables.selected.name,
}
@@ -83,7 +80,23 @@
primaryDisplay =
$tables.selected.primaryDisplay == null ||
$tables.selected.primaryDisplay === editableColumn.name
+ } else if (!savingColumn) {
+ let highestNumber = 0
+ Object.keys(table.schema).forEach(columnName => {
+ const columnNumber = extractColumnNumber(columnName)
+ if (columnNumber > highestNumber) {
+ highestNumber = columnNumber
+ }
+ return highestNumber
+ })
+
+ if (highestNumber >= 1) {
+ editableColumn.name = `Column 0${highestNumber + 1}`
+ } else {
+ editableColumn.name = "Column 01"
+ }
}
+ allowedTypes = getAllowedTypes()
}
$: initialiseField(field, savingColumn)
@@ -182,6 +195,8 @@
indexes,
})
dispatch("updatecolumns")
+ gridDispatch("close-edit-column")
+
if (
saveColumn.type === LINK_TYPE &&
saveColumn.relationshipType === RelationshipType.MANY_TO_MANY
@@ -203,6 +218,7 @@
function cancelEdit() {
editableColumn.name = originalName
+ gridDispatch("close-edit-column")
}
async function deleteColumn() {
@@ -214,8 +230,8 @@
await tables.deleteField(editableColumn)
notifications.success(`Column ${editableColumn.name} deleted`)
confirmDeleteDialog.hide()
- hide()
dispatch("updatecolumns")
+ gridDispatch("close-edit-column")
}
} catch (error) {
notifications.error(`Error deleting column: ${error.message}`)
@@ -251,14 +267,6 @@
required = req
}
- function onChangePrimaryDisplay(e) {
- const isPrimary = e.detail
- // primary display is always required
- if (isPrimary) {
- editableColumn.constraints.presence = { allowEmpty: false }
- }
- }
-
function openJsonSchemaEditor() {
jsonSchemaModal.show()
}
@@ -272,6 +280,11 @@
deleteColName = ""
}
+ function extractColumnNumber(columnName) {
+ const match = columnName.match(/Column (\d+)/)
+ return match ? parseInt(match[1]) : 0
+ }
+
function getRelationshipOptions(field) {
if (!field || !field.tableId) {
return null
@@ -402,15 +415,8 @@
}
-
+
field.name}
getOptionValue={field => field.type}
+ getOptionIcon={field => field.icon}
isOptionEnabled={option => {
if (option.type == AUTO_TYPE) {
return availableAutoColumnKeys?.length > 0
@@ -433,28 +439,6 @@
}}
/>
- {#if canBeRequired || canBeDisplay}
-
- {#if canBeRequired}
-
- {/if}
- {#if canBeDisplay}
-
- {/if}
-
- {/if}
-
{#if editableColumn.type === "string"}
{:else if editableColumn.type === "options"}
-
{:else if editableColumn.type === "longform"}
@@ -480,19 +464,28 @@
/>
{:else if editableColumn.type === "array"}
-
{:else if editableColumn.type === "datetime" && !editableColumn.autocolumn}
-
-
+
+
+
{#if datasource?.source !== "ORACLE" && datasource?.source !== "SQL_SERVER"}