diff --git a/packages/builder/src/components/automation/SetupPanel/AutomationBlockSetup.svelte b/packages/builder/src/components/automation/SetupPanel/AutomationBlockSetup.svelte index b16533c2ca..b901d21a6d 100644 --- a/packages/builder/src/components/automation/SetupPanel/AutomationBlockSetup.svelte +++ b/packages/builder/src/components/automation/SetupPanel/AutomationBlockSetup.svelte @@ -114,7 +114,7 @@ $: schemaFields = search.getFields( $tables.list, Object.values(schema || {}), - { allowLinks: true } + { allowLinks: false } ) $: queryLimit = tableId?.includes("datasource") ? "∞" : "1000" $: isTrigger = $memoBlock?.type === AutomationStepType.TRIGGER diff --git a/packages/builder/src/dataBinding.js b/packages/builder/src/dataBinding.js index 8adc27ee59..c89221f163 100644 --- a/packages/builder/src/dataBinding.js +++ b/packages/builder/src/dataBinding.js @@ -1141,10 +1141,11 @@ export const buildFormSchema = (component, asset) => { const fieldSetting = settings.find( setting => setting.key === "field" && setting.type.startsWith("field/") ) - if (fieldSetting && component.field) { + if (fieldSetting) { const type = fieldSetting.type.split("field/")[1] - if (type) { - schema[component.field] = { type } + const key = component.field || component._instanceName + if (type && key) { + schema[key] = { type } } } component._children?.forEach(child => { diff --git a/packages/builder/src/stores/builder/automations.js b/packages/builder/src/stores/builder/automations.js index 8f54f85ef5..b7d55ee2d4 100644 --- a/packages/builder/src/stores/builder/automations.js +++ b/packages/builder/src/stores/builder/automations.js @@ -16,6 +16,7 @@ import { AutomationTriggerStepId, AutomationEventType, AutomationStepType, + AutomationActionStepId, } from "@budibase/types" import { ActionStepID } from "constants/backend/automations" import { FIELDS } from "constants/backend" @@ -466,9 +467,13 @@ const automationActions = store => ({ .getPathSteps(block.pathTo, automation) .slice(0, -1) + // Current step will always be the last step of the path + const currentBlock = store.actions + .getPathSteps(block.pathTo, automation) + .at(-1) + // Extract all outputs from all previous steps as available bindingsx§x let bindings = [] - const addBinding = (name, value, icon, idx, isLoopBlock, bindingName) => { if (!name) return const runtimeBinding = determineRuntimeBinding( @@ -519,9 +524,24 @@ const automationActions = store => ({ runtimeName = `loop.${name}` } else if (idx === 0) { runtimeName = `trigger.${name}` + } else if ( + currentBlock?.stepId === AutomationActionStepId.EXECUTE_SCRIPT + ) { + const stepId = pathSteps[idx].id + if (!stepId) { + notifications.error("Error generating binding: Step ID not found.") + return null + } + runtimeName = `steps["${stepId}"].${name}` } else { - runtimeName = `steps.${pathSteps[idx]?.id}.${name}` + const stepId = pathSteps[idx].id + if (!stepId) { + notifications.error("Error generating binding: Step ID not found.") + return null + } + runtimeName = `steps.${stepId}.${name}` } + return runtimeName } @@ -637,7 +657,6 @@ const automationActions = store => ({ console.error("Loop block missing.") } } - Object.entries(schema).forEach(([name, value]) => { addBinding(name, value, icon, blockIdx, isLoopBlock, bindingName) }) diff --git a/packages/client/manifest.json b/packages/client/manifest.json index 393c08a282..6dd1b71b75 100644 --- a/packages/client/manifest.json +++ b/packages/client/manifest.json @@ -3096,7 +3096,6 @@ "name": "Text Field", "icon": "Text", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -3106,8 +3105,7 @@ { "type": "field/string", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -3226,13 +3224,22 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "string" + } + ] + } }, "numberfield": { "name": "Number Field", "icon": "123", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -3242,8 +3249,7 @@ { "type": "field/number", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -3328,13 +3334,22 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "number" + } + ] + } }, "bigintfield": { "name": "BigInt Field", "icon": "TagBold", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -3344,8 +3359,7 @@ { "type": "field/bigint", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -3414,13 +3428,22 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "number" + } + ] + } }, "passwordfield": { "name": "Password Field", "icon": "LockClosed", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -3430,8 +3453,7 @@ { "type": "field/string", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -3500,13 +3522,22 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "string" + } + ] + } }, "optionsfield": { "name": "Options Picker", "icon": "Menu", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -3516,8 +3547,7 @@ { "type": "field/options", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -3714,13 +3744,22 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "string" + } + ] + } }, "multifieldselect": { "name": "Multi-select Picker", "icon": "ViewList", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -3730,8 +3769,7 @@ { "type": "field/array", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -3922,13 +3960,22 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "array" + } + ] + } }, "booleanfield": { "name": "Checkbox", "icon": "SelectBox", "editable": true, - "requiredAncestors": ["form"], "size": { "width": 400, "height": 60 @@ -3937,8 +3984,7 @@ { "type": "field/boolean", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -4047,13 +4093,22 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "boolean" + } + ] + } }, "longformfield": { "name": "Long Form Field", "icon": "TextAlignLeft", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -4063,8 +4118,7 @@ { "type": "field/longform", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -4171,13 +4225,22 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "string" + } + ] + } }, "datetimefield": { "name": "Date Picker", "icon": "Date", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -4187,8 +4250,7 @@ { "type": "field/datetime", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -4291,7 +4353,17 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "datetime" + } + ] + } }, "codescanner": { "name": "Barcode/QR Scanner", @@ -4305,8 +4377,7 @@ { "type": "field/barcodeqr", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -4451,7 +4522,17 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "string" + } + ] + } }, "signaturesinglefield": { "name": "Signature", @@ -4924,7 +5005,6 @@ "icon": "Brackets", "styles": ["size"], "editable": true, - "requiredAncestors": ["form"], "size": { "width": 400, "height": 100 @@ -4933,8 +5013,7 @@ { "type": "field/json", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -5014,7 +5093,17 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "string" + } + ] + } }, "s3upload": { "name": "S3 File Upload", @@ -5029,8 +5118,7 @@ { "type": "field/s3", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -5075,7 +5163,17 @@ "label": "Validation", "key": "validation" } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "array" + } + ] + } }, "dataprovider": { "name": "Data Provider", @@ -7643,7 +7741,6 @@ "name": "User List Field", "icon": "UserGroup", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -7653,8 +7750,7 @@ { "type": "field/bb_reference", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -7744,14 +7840,23 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "array" + } + ] + } }, "bbreferencesinglefield": { "devComment": "As bb reference is only used for user subtype for now, we are using user for icon and labels", "name": "User Field", "icon": "User", "styles": ["size"], - "requiredAncestors": ["form"], "editable": true, "size": { "width": 400, @@ -7761,8 +7866,7 @@ { "type": "field/bb_reference_single", "label": "Field", - "key": "field", - "required": true + "key": "field" }, { "type": "text", @@ -7852,6 +7956,16 @@ } ] } - ] + ], + "context": { + "type": "static", + "values": [ + { + "label": "Value", + "key": "value", + "type": "string" + } + ] + } } } diff --git a/packages/client/src/components/app/forms/Field.svelte b/packages/client/src/components/app/forms/Field.svelte index 9210b6ea8f..5fccb5d881 100644 --- a/packages/client/src/components/app/forms/Field.svelte +++ b/packages/client/src/components/app/forms/Field.svelte @@ -1,7 +1,10 @@ -