From 9b6b540dc5a00dca8bd1da518f9bc109c66abf50 Mon Sep 17 00:00:00 2001 From: Travis Tidwell Date: Mon, 2 Oct 2023 02:49:46 -0500 Subject: [PATCH 01/22] Fixing issue where content component would not save in the form. (#5352) --- src/components/content/Content.js | 1 + 1 file changed, 1 insertion(+) diff --git a/src/components/content/Content.js b/src/components/content/Content.js index 37e8dbb6c9..8ca7273481 100644 --- a/src/components/content/Content.js +++ b/src/components/content/Content.js @@ -18,6 +18,7 @@ export default class ContentComponent extends Component { group: 'layout', icon: 'html5', preview: false, + showPreview: false, documentation: '/userguide/form-building/layout-components#content', weight: 5, schema: ContentComponent.schema() From 7350cc8aa7a09c7be3ca2c460c9c54cec03c10f4 Mon Sep 17 00:00:00 2001 From: TanyaGashtold <61136841+TanyaGashtold@users.noreply.github.com> Date: Mon, 2 Oct 2023 10:50:52 +0300 Subject: [PATCH 02/22] Update Changelog.md --- Changelog.md | 1 + 1 file changed, 1 insertion(+) diff --git a/Changelog.md b/Changelog.md index 243974918f..5e263b84e9 100644 --- a/Changelog.md +++ b/Changelog.md @@ -16,6 +16,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/). - FIO-4816: fixed email submission: data display issues - [Snyk] Upgrade core-js from 3.32.0 to 3.32.1 - [Snyk] Upgrade vanilla-picker from 2.12.1 to 2.12.2 + - Fixed issue where content component would not save in the form. ## 5.0.0-rc.26 ### Changed From a2f2a8ab6f644556d948163fee33905489d6be62 Mon Sep 17 00:00:00 2001 From: alexandraRamanenka <60643585+alexandraRamanenka@users.noreply.github.com> Date: Tue, 3 Oct 2023 11:49:22 +0300 Subject: [PATCH 03/22] FIO-7206: Fixes an issue where removed components keys stay in the DataGrid defaultValue property (#5321) --- src/WebformBuilder.js | 7 +++++-- src/WebformBuilder.unit.js | 39 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 44 insertions(+), 2 deletions(-) diff --git a/src/WebformBuilder.js b/src/WebformBuilder.js index 6975e500b2..c38c374e28 100644 --- a/src/WebformBuilder.js +++ b/src/WebformBuilder.js @@ -417,7 +417,7 @@ export default class WebformBuilder extends Component { this.attachTooltip(component.refs.removeComponent, this.t('Remove')); component.addEventListener(component.refs.removeComponent, 'click', () => - this.removeComponent(component.schema, parent, component.component)); + this.removeComponent(component.schema, parent, component.component, component)); } return element; @@ -1081,7 +1081,7 @@ export default class WebformBuilder extends Component { } } - removeComponent(component, parent, original) { + removeComponent(component, parent, original, componentInstance) { if (!parent) { return; } @@ -1110,6 +1110,9 @@ export default class WebformBuilder extends Component { else if (parent.formioComponent && parent.formioComponent.removeChildComponent) { parent.formioComponent.removeChildComponent(component); } + if (component.input && componentInstance && componentInstance.parent) { + _.unset(componentInstance._data, componentInstance.key); + } const rebuild = parent.formioComponent.rebuild() || Promise.resolve(); rebuild.then(() => { this.emit('removeComponent', component, parent.formioComponent.schema, path, index); diff --git a/src/WebformBuilder.unit.js b/src/WebformBuilder.unit.js index 9311556ee4..7832c7799e 100644 --- a/src/WebformBuilder.unit.js +++ b/src/WebformBuilder.unit.js @@ -206,4 +206,43 @@ describe('WebformBuilder tests', function() { done(); }).catch(done); }); + + it('Should remove deletec components keys from default value', (done) => { + const builder = Harness.getBuilder(); + builder.setForm({}).then(() => { + Harness.buildComponent('datagrid'); + + setTimeout(() => { + const dataGridDefaultValue = builder.editForm.getComponent('defaultValue'); + dataGridDefaultValue.removeRow(0); + + setTimeout(() => { + Harness.saveComponent(); + setTimeout(() => { + const dataGridContainer = builder.webform.element.querySelector('[ref="dataGrid-container"]'); + Harness.buildComponent('textfield', dataGridContainer); + + setTimeout(() => { + Harness.saveComponent(); + + setTimeout(() => { + const textField = builder.webform.getComponent(['dataGrid', 'textField'])[0]; + textField.refs.removeComponent.dispatchEvent( new MouseEvent('click', { + view: window, + bubbles: true, + cancelable: true + })); + + setTimeout(() => { + const dataGrid = builder.webform.getComponent(['dataGrid']); + assert.deepEqual(dataGrid.schema.defaultValue, [{}], 'Should remove TextField key'); + done(); + }, 300); + }); + }, 300); + }, 300); + }, 350); + }, 350); + }).catch(done); + }); }); From 27da460cb74fd6816617a4cff3899d237c5e3d2d Mon Sep 17 00:00:00 2001 From: antonSoftensity <61691723+antonSoftensity@users.noreply.github.com> Date: Tue, 3 Oct 2023 11:50:23 +0300 Subject: [PATCH 04/22] FIO-7207 Changed tooltip and removed 'Hide label' option from the list of layout components (#5335) --- .../columns/editForm/Columns.edit.display.js | 18 ++++++++++++++++++ .../table/editForm/Table.edit.display.js | 18 ++++++++++++++++++ .../tabs/editForm/Tabs.edit.display.js | 18 ++++++++++++++++++ .../well/editForm/Well.edit.display.js | 18 ++++++++++++++++++ 4 files changed, 72 insertions(+) diff --git a/src/components/columns/editForm/Columns.edit.display.js b/src/components/columns/editForm/Columns.edit.display.js index edc92838e1..bf6973b583 100644 --- a/src/components/columns/editForm/Columns.edit.display.js +++ b/src/components/columns/editForm/Columns.edit.display.js @@ -31,6 +31,24 @@ export default [ key: 'tableView', ignore: true }, + { + key: 'hideLabel', + ignore: true + }, + { + weight: 0, + type: 'textfield', + input: true, + key: 'label', + label: 'Label', + placeholder: 'Field Label', + tooltip: 'The label for this field.', + validate: { + required: true + }, + autofocus: true, + overrideEditForm: true + }, { weight: 150, type: 'datagrid', diff --git a/src/components/table/editForm/Table.edit.display.js b/src/components/table/editForm/Table.edit.display.js index b1e2b18a6a..31282d7e5e 100644 --- a/src/components/table/editForm/Table.edit.display.js +++ b/src/components/table/editForm/Table.edit.display.js @@ -31,6 +31,24 @@ export default [ key: 'tableView', ignore: true }, + { + key: 'hideLabel', + ignore: true + }, + { + weight: 0, + type: 'textfield', + input: true, + key: 'label', + label: 'Label', + placeholder: 'Field Label', + tooltip: 'The label for this field.', + validate: { + required: true + }, + autofocus: true, + overrideEditForm: true + }, { type: 'number', label: 'Number of Rows', diff --git a/src/components/tabs/editForm/Tabs.edit.display.js b/src/components/tabs/editForm/Tabs.edit.display.js index 5328daf944..7a9615763d 100644 --- a/src/components/tabs/editForm/Tabs.edit.display.js +++ b/src/components/tabs/editForm/Tabs.edit.display.js @@ -31,6 +31,24 @@ export default [ key: 'tableView', ignore: true }, + { + key: 'hideLabel', + ignore: true + }, + { + weight: 0, + type: 'textfield', + input: true, + key: 'label', + label: 'Label', + placeholder: 'Field Label', + tooltip: 'The label for this field.', + validate: { + required: true + }, + autofocus: true, + overrideEditForm: true + }, { key: 'components', type: 'datagrid', diff --git a/src/components/well/editForm/Well.edit.display.js b/src/components/well/editForm/Well.edit.display.js index 61d3e0aa9c..ec0e46dba3 100644 --- a/src/components/well/editForm/Well.edit.display.js +++ b/src/components/well/editForm/Well.edit.display.js @@ -27,4 +27,22 @@ export default [ key: 'tableView', ignore: true }, + { + key: 'hideLabel', + ignore: true + }, + { + weight: 0, + type: 'textfield', + input: true, + key: 'label', + label: 'Label', + placeholder: 'Field Label', + tooltip: 'The label for this field.', + validate: { + required: true + }, + autofocus: true, + overrideEditForm: true + }, ]; From 47d9ff34de705747447dc4a839b587e5f00a3160 Mon Sep 17 00:00:00 2001 From: alexandraRamanenka <60643585+alexandraRamanenka@users.noreply.github.com> Date: Tue, 3 Oct 2023 11:50:40 +0300 Subject: [PATCH 05/22] Fio 7074 setting submission on wizard does not update data (#5351) * FIO-7074: Fixes an issue where setting submission to the Wizard from the form controller will not set values for all the pages * Fixed failing formio tests --------- Co-authored-by: Travis Tidwell --- src/Wizard.js | 25 ++++++++++++++----------- src/Wizard.unit.js | 2 +- 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/src/Wizard.js b/src/Wizard.js index 7e258dd26a..0fccb8d3fd 100644 --- a/src/Wizard.js +++ b/src/Wizard.js @@ -895,27 +895,30 @@ export default class Wizard extends Webform { } setValue(submission, flags = {}, ignoreEstablishment) { - this._submission = submission; - if ( - (flags && flags.fromSubmission && (this.options.readOnly || this.editMode) && !this.isHtmlRenderMode()) || + const changed = this.getPages({ all: true }).reduce((changed, page) => { + return this.setNestedValue(page, submission.data, flags, changed) || changed; + }, false); + + if (!flags.sanitize || (flags && flags.fromSubmission && (this.prefixComps.length || this.suffixComps.length) && submission._id) || (this.options.server && (this.prefixComps.length || this.suffixComps.length)) ) { - this._data = submission.data; + this.mergeData(this.data, submission.data); } - if (!ignoreEstablishment) { - this.establishPages(submission.data); - } - const changed = this.getPages({ all: true }).reduce((changed, page) => { - return this.setNestedValue(page, submission.data, flags, changed) || changed; - }, false); - if (changed) { this.pageFieldLogic(this.page); } + this.setEditMode(submission); + submission.data = this.data; + this._submission = submission; + + if (!ignoreEstablishment) { + this.establishPages(submission.data); + } + return changed; } diff --git a/src/Wizard.unit.js b/src/Wizard.unit.js index 549dfcaf10..1956a789d1 100644 --- a/src/Wizard.unit.js +++ b/src/Wizard.unit.js @@ -161,7 +161,7 @@ describe('Wizard tests', () => { }, 'Should contain correct submission data'); done(); - }, 200); + }, 500); }, 200); }, 200); }, 200); From c7641840c8fe8389ef235bce22770546eed5a2b2 Mon Sep 17 00:00:00 2001 From: alexandraRamanenka <60643585+alexandraRamanenka@users.noreply.github.com> Date: Tue, 3 Oct 2023 12:04:24 +0300 Subject: [PATCH 06/22] FIO-7309: Fixed an issue where min/maxDate settings for Day component are getting evaluated in Form Builder (#5339) Co-authored-by: TanyaGashtold <61136841+TanyaGashtold@users.noreply.github.com> --- src/WebformBuilder.unit.js | 25 ++++++++++++++++++++++++- src/components/day/Day.js | 4 ++-- 2 files changed, 26 insertions(+), 3 deletions(-) diff --git a/src/WebformBuilder.unit.js b/src/WebformBuilder.unit.js index 7832c7799e..5b3979ac16 100644 --- a/src/WebformBuilder.unit.js +++ b/src/WebformBuilder.unit.js @@ -207,7 +207,30 @@ describe('WebformBuilder tests', function() { }).catch(done); }); - it('Should remove deletec components keys from default value', (done) => { + it('Should keep min/max date validation settings with moment.js function', (done) => { + const builder = Harness.getBuilder(); + builder.setForm(columnsForm).then(() => { + const column1 = builder.webform.element.querySelector('[ref="columns-container"]'); + Harness.buildComponent('day', column1); + + setTimeout(() => { + const maxDateComp = builder.editForm.getComponent('maxDate'); + maxDateComp.setValue('moment().add(10, \'days\')'); + + setTimeout(() => { + Harness.saveComponent(); + + setTimeout(() => { + const dayComp = builder.webform.getComponent(['day']); + assert.equal(dayComp.component.maxDate, 'moment().add(10, \'days\')'); + done(); + }, 200); + }, 200); + }, 150); + }).catch(done); + }); + + it('Should remove deleted components keys from default value', (done) => { const builder = Harness.getBuilder(); builder.setForm({}).then(() => { Harness.buildComponent('datagrid'); diff --git a/src/components/day/Day.js b/src/components/day/Day.js index 26f133c4d3..add4bb960d 100644 --- a/src/components/day/Day.js +++ b/src/components/day/Day.js @@ -54,10 +54,10 @@ export default class DayComponent extends Field { } constructor(component, options, data) { - if (component.maxDate) { + if (component.maxDate && component.maxDate.indexOf('moment(') === -1) { component.maxDate = moment(component.maxDate, 'YYYY-MM-DD').toISOString(); } - if (component.minDate) { + if (component.minDate && component.minDate.indexOf('moment(') === -1) { component.minDate = moment(component.minDate, 'YYYY-MM-DD').toISOString(); } super(component, options, data); From 6802e5afeb1b6371075107c7a54c3df11d368bea Mon Sep 17 00:00:00 2001 From: TanyaGashtold <61136841+TanyaGashtold@users.noreply.github.com> Date: Tue, 3 Oct 2023 12:07:45 +0300 Subject: [PATCH 07/22] Update Changelog.md --- Changelog.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Changelog.md b/Changelog.md index 5e263b84e9..b087784d8f 100644 --- a/Changelog.md +++ b/Changelog.md @@ -17,6 +17,10 @@ and this project adheres to [Semantic Versioning](http://semver.org/). - [Snyk] Upgrade core-js from 3.32.0 to 3.32.1 - [Snyk] Upgrade vanilla-picker from 2.12.1 to 2.12.2 - Fixed issue where content component would not save in the form. + - FIO-7206: fixed an issue where removed components keys stay in the DataGrid defaultValue property + - FIO-7309: fixed an issue where min/maxDate settings for Day component are getting evaluated in Form Builder + - FIO-7207: changed tooltip and removed 'Hide label' option from the list of layout components + - FIO-7074: fixed an issue where setting submission on wizard does not update data ## 5.0.0-rc.26 ### Changed From 656a5d6c1a9acce599510825f851dd9980c82092 Mon Sep 17 00:00:00 2001 From: alexandraRamanenka <60643585+alexandraRamanenka@users.noreply.github.com> Date: Tue, 3 Oct 2023 17:25:46 +0300 Subject: [PATCH 08/22] FIO-7082: Moved Wizard Breadcrumbs Type to form settings (#5331) * FIO-7082: Moved Wizard Breadcrumbs Type to form settings * Fixed tests * Refactoring --- src/WebformBuilder.js | 6 +++++- src/Wizard.js | 4 +++- src/components/panel/Panel.unit.js | 1 - .../panel/editForm/Panel.edit.display.js | 19 +++---------------- 4 files changed, 11 insertions(+), 19 deletions(-) diff --git a/src/WebformBuilder.js b/src/WebformBuilder.js index c38c374e28..052a63bc45 100644 --- a/src/WebformBuilder.js +++ b/src/WebformBuilder.js @@ -1454,7 +1454,11 @@ export default class WebformBuilder extends Component { { ..._.omit(this.options, ['hooks', 'builder', 'events', 'attachMode', 'skipInit']), language: this.options.language, - ...editFormOptions + ...editFormOptions, + evalContext: { + ...(editFormOptions?.evalContext || this.options?.evalContext || {}), + buildingForm: this.form, + }, } ); diff --git a/src/Wizard.js b/src/Wizard.js index 0fccb8d3fd..da8bd99609 100644 --- a/src/Wizard.js +++ b/src/Wizard.js @@ -211,7 +211,9 @@ export default class Wizard extends Webform { } prepareHeaderSettings(ctx, headerType) { - if (this.currentPanel && this.currentPanel.breadcrumb === 'none' || ctx.isSubForm) { + const shouldHideBreadcrumbs = this.currentPanel?.breadcrumb === 'none' || + _.get(this.form, 'settings.wizardBreadcrumbsType', '') === 'none'; + if (shouldHideBreadcrumbs || ctx.isSubForm) { return null; } return this.renderTemplate(headerType, ctx); diff --git a/src/components/panel/Panel.unit.js b/src/components/panel/Panel.unit.js index 8a09760151..ba416b8115 100644 --- a/src/components/panel/Panel.unit.js +++ b/src/components/panel/Panel.unit.js @@ -64,7 +64,6 @@ describe('Panel Component', () => { const components = flattenComponents(panelEditForm().components); const keys = Object.keys(components).map(path => components[path].key); const settings = [ - 'breadcrumb', 'breadcrumbClickable' ]; diff --git a/src/components/panel/editForm/Panel.edit.display.js b/src/components/panel/editForm/Panel.edit.display.js index ce97999c7c..72076c705d 100644 --- a/src/components/panel/editForm/Panel.edit.display.js +++ b/src/components/panel/editForm/Panel.edit.display.js @@ -75,28 +75,15 @@ export default [ type: 'fieldset', input: false, components: [ - { - type: 'select', - input: true, - label: 'Breadcrumb Type', - key: 'breadcrumb', - dataSrc: 'values', - data: { - values: [ - { label: 'Default', value: 'default' }, - { label: 'Condensed', value: 'condensed' }, - { label: 'Hidden', value: 'none' }, - ] - } - }, { input: true, type: 'checkbox', label: 'Allow click on Breadcrumb', key: 'breadcrumbClickable', defaultValue: true, - conditional: { - json: { '!==': [{ var: 'data.breadcrumb' }, 'none'] } + customConditional({ data = {}, buildingForm = {} }) { + const formSettings = buildingForm.settings || {}; + return ![data.breadcrumb, formSettings.wizardBreadcrumbsType].includes('none'); } }, { From 04b1971f5435e58bc4a6b81b6c69e2587b7ab8ae Mon Sep 17 00:00:00 2001 From: lane-formio Date: Tue, 3 Oct 2023 09:26:15 -0500 Subject: [PATCH 09/22] Update Changelog.md --- Changelog.md | 1 + 1 file changed, 1 insertion(+) diff --git a/Changelog.md b/Changelog.md index b087784d8f..1217765d59 100644 --- a/Changelog.md +++ b/Changelog.md @@ -21,6 +21,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/). - FIO-7309: fixed an issue where min/maxDate settings for Day component are getting evaluated in Form Builder - FIO-7207: changed tooltip and removed 'Hide label' option from the list of layout components - FIO-7074: fixed an issue where setting submission on wizard does not update data + - FIO-7082: Moved Wizard Breadcrumbs Type to form settings ## 5.0.0-rc.26 ### Changed From 93dd00bfb3f7f72a33d08a03a6a5b1e3639a04c2 Mon Sep 17 00:00:00 2001 From: Clayton Gulick Date: Wed, 4 Oct 2023 09:53:20 -0500 Subject: [PATCH 10/22] only generate key when it doesn't exist for custom group (#4753) --- src/WebformBuilder.js | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/WebformBuilder.js b/src/WebformBuilder.js index 052a63bc45..8ccc2cecef 100644 --- a/src/WebformBuilder.js +++ b/src/WebformBuilder.js @@ -849,6 +849,10 @@ export default class WebformBuilder extends Component { } if (info) { + //if this is a custom component that was already assigned a key, don't stomp on it + if ((group === 'custom') && info.key) { + return info; + } info.key = this.generateKey(info); } From c420fa7df69b40b7828ae11b0dd9d969bc84f916 Mon Sep 17 00:00:00 2001 From: Travis Tidwell Date: Wed, 4 Oct 2023 09:54:41 -0500 Subject: [PATCH 11/22] Ensure we do not clobber the key of custom components. --- src/WebformBuilder.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/WebformBuilder.js b/src/WebformBuilder.js index 8ccc2cecef..b7df181d86 100644 --- a/src/WebformBuilder.js +++ b/src/WebformBuilder.js @@ -850,7 +850,7 @@ export default class WebformBuilder extends Component { if (info) { //if this is a custom component that was already assigned a key, don't stomp on it - if ((group === 'custom') && info.key) { + if (!Components.components.hasOwnProperty(info.type) && info.key) { return info; } info.key = this.generateKey(info); From 71e19e5e80e17f468d9ad47c7ff99502cede5539 Mon Sep 17 00:00:00 2001 From: Travis Tidwell Date: Wed, 4 Oct 2023 10:08:29 -0500 Subject: [PATCH 12/22] Adding shadow dom for lib inclusion (#5319) --- src/Embed.js | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/src/Embed.js b/src/Embed.js index ad25434a47..97908a1f34 100644 --- a/src/Embed.js +++ b/src/Embed.js @@ -142,7 +142,7 @@ export class Formio { } // eslint-disable-next-line max-statements - static async init(element, builder = false) { + static async init(element, options = {}, builder = false) { Formio.cdn = new CDN(Formio.config.cdn); Formio.config.libs = Formio.config.libs || { uswds: { @@ -160,10 +160,19 @@ export class Formio { const id = Formio.config.id || `formio-${Math.random().toString(36).substring(7)}`; // Create a new wrapper and add the element inside of a new wrapper. - const wrapper = Formio.createElement('div', { + let wrapper = Formio.createElement('div', { 'id': `"${id}-wrapper"` }); element.parentNode.insertBefore(wrapper, element); + + // If we include the libraries, then we will attempt to run this in shadow dom. + if (Formio.config.includeLibs && (typeof wrapper.attachShadow === 'function') && !Formio.config.premium) { + wrapper = wrapper.attachShadow({ + mode: 'open' + }); + options.shadowRoot = wrapper; + } + element.parentNode.removeChild(element); wrapper.appendChild(element); @@ -246,7 +255,7 @@ export class Formio { } static async createForm(element, form, options) { - const wrapper = await Formio.init(element); + const wrapper = await Formio.init(element, options); return Formio.FormioClass.createForm(element, form, { ...options, ...{ noLoader: true } @@ -278,7 +287,7 @@ export class Formio { } static async builder(element, form, options) { - const wrapper = await Formio.init(element, true); + const wrapper = await Formio.init(element, options, true); return Formio.FormioClass.builder(element, form, options).then((instance) => { Formio.debug('Builder created', instance); Formio.debug('Removing loader'); From 934cd6d6a5773568ef6b7d49fb8fe3904598efdd Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 4 Oct 2023 10:08:51 -0500 Subject: [PATCH 13/22] Bump get-func-name from 2.0.0 to 2.0.2 (#5354) Bumps [get-func-name](https://github.com/chaijs/get-func-name) from 2.0.0 to 2.0.2. - [Release notes](https://github.com/chaijs/get-func-name/releases) - [Commits](https://github.com/chaijs/get-func-name/commits/v2.0.2) --- updated-dependencies: - dependency-name: get-func-name dependency-type: indirect ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- yarn.lock | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/yarn.lock b/yarn.lock index 8229110dac..d3822a5834 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2033,11 +2033,16 @@ core-js@^2.0.0, core-js@^2.4.0: resolved "https://registry.npmjs.org/core-js/-/core-js-2.6.12.tgz#d9333dfa7b065e347cc5682219d6f690859cc2ec" integrity sha512-Kb2wC0fvsWfQrgk8HU5lW6U/Lcs8+9aaYcy4ZFc6DDlo4nZ7n70dEgE5rtR0oG6ufKDUnrwfWL1mXR5ljDatrQ== -core-js@^3.0.0, core-js@^3.21.1, core-js@^3.30.2, core-js@^3.31.0: +core-js@^3.0.0, core-js@^3.21.1, core-js@^3.30.2: version "3.32.0" resolved "https://registry.npmjs.org/core-js/-/core-js-3.32.0.tgz#7643d353d899747ab1f8b03d2803b0312a0fb3b6" integrity sha512-rd4rYZNlF3WuoYuRIDEmbR/ga9CeuWX9U05umAvgrrZoHY4Z++cp/xwPQMvUpBB4Ag6J8KfD80G0zwCyaSxDww== +core-js@^3.32.1: + version "3.32.2" + resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.32.2.tgz#172fb5949ef468f93b4be7841af6ab1f21992db7" + integrity sha512-pxXSw1mYZPDGvTQqEc5vgIb83jGQKFGYWY76z4a7weZXUolw3G+OvpZqSRcfYOoOVUQJYEPsWeQK8pKEnUtWxQ== + core-util-is@1.0.2: version "1.0.2" resolved "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" @@ -3687,9 +3692,9 @@ get-caller-file@^2.0.5: integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== get-func-name@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz#ead774abee72e20409433a066366023dd6887a41" - integrity sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig== + version "2.0.2" + resolved "https://registry.yarnpkg.com/get-func-name/-/get-func-name-2.0.2.tgz#0d7cf20cd13fda808669ffa88f4ffc7a3943fc41" + integrity sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ== get-intrinsic@^1.0.2, get-intrinsic@^1.1.1, get-intrinsic@^1.1.3, get-intrinsic@^1.2.0, get-intrinsic@^1.2.1: version "1.2.1" @@ -8148,10 +8153,10 @@ value-or-function@^3.0.0: resolved "https://registry.npmjs.org/value-or-function/-/value-or-function-3.0.0.tgz#1c243a50b595c1be54a754bfece8563b9ff8d813" integrity sha512-jdBB2FrWvQC/pnPtIqcLsMaQgjhdb6B7tk1MMyTKapox+tQZbdRP4uLxu/JY0t7fbfDCUMnuelzEYv5GsxHhdg== -vanilla-picker@^2.12.1: - version "2.12.1" - resolved "https://registry.npmjs.org/vanilla-picker/-/vanilla-picker-2.12.1.tgz#6e619eecf553891b8d2d042b745a23c91f19f34c" - integrity sha512-2qrEP9VYylKXbyzXKsbu2dferBTvqnlsr29XjHwFE+/MEp0VNj6oEUESLDtKZ7DWzGdSv1x/+ujqFZF+KsO3cg== +vanilla-picker@^2.12.2: + version "2.12.2" + resolved "https://registry.yarnpkg.com/vanilla-picker/-/vanilla-picker-2.12.2.tgz#b4c6a3f4015dbd208080265fe7edd311709aa251" + integrity sha512-dk0gNeNL9fQFGd1VEhNDQfFlbCqAiksRh1H2tVPlavkH88n/a/y30rXi9PPKrYPTK5kEfPO4xcldt4ts/1wIAg== dependencies: "@sphinxxxx/color-conversion" "^2.2.2" From dfd1002a5d14a40c3e03eb672f01c90c5b06a3a9 Mon Sep 17 00:00:00 2001 From: antonSoftensity <61691723+antonSoftensity@users.noreply.github.com> Date: Wed, 4 Oct 2023 18:11:40 +0300 Subject: [PATCH 14/22] FIO-7224 Fixed issues with layout components when Condensed mode is enabled (#5355) --- src/components/_classes/component/Component.js | 2 +- src/components/columns/Columns.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/_classes/component/Component.js b/src/components/_classes/component/Component.js index 3fa7232550..c64abaa4eb 100644 --- a/src/components/_classes/component/Component.js +++ b/src/components/_classes/component/Component.js @@ -768,7 +768,7 @@ export default class Component extends Element { let contentMargin = ''; if (this.component.hideLabel) { - const margin = this.labelWidth + this.labelMargin; + const margin = isCondensed ? 0 : this.labelWidth + this.labelMargin; contentMargin = isRightPosition ? `margin-right: ${margin}%` : ''; contentMargin = isLeftPosition ? `margin-left: ${margin}%` : ''; } diff --git a/src/components/columns/Columns.js b/src/components/columns/Columns.js index cb21879754..c18ab5da6b 100644 --- a/src/components/columns/Columns.js +++ b/src/components/columns/Columns.js @@ -74,7 +74,7 @@ export default class ColumnsComponent extends NestedComponent { if (!column.size) { column.size = 'md'; } - column.currentWidth = column.width || 0; + column.currentWidth = this.options.condensedMode ? this.gridSize : column.width || 0; // Ensure there is a components array. if (!Array.isArray(column.components)) { column.components = []; From 45fda912ef76bbed199826369474ef09589e35f2 Mon Sep 17 00:00:00 2001 From: alexandraRamanenka <60643585+alexandraRamanenka@users.noreply.github.com> Date: Wed, 4 Oct 2023 18:12:22 +0300 Subject: [PATCH 15/22] FIO-4833: Removes Hide Label setting from Well, Columns, Tabs and Table components since they do not render a label (#4973) Co-authored-by: Travis Tidwell --- src/components/columns/editForm/Columns.edit.display.js | 6 +++++- src/components/table/editForm/Table.edit.display.js | 4 ++++ src/components/tabs/editForm/Tabs.edit.display.js | 4 ++++ 3 files changed, 13 insertions(+), 1 deletion(-) diff --git a/src/components/columns/editForm/Columns.edit.display.js b/src/components/columns/editForm/Columns.edit.display.js index bf6973b583..a19b1151c1 100644 --- a/src/components/columns/editForm/Columns.edit.display.js +++ b/src/components/columns/editForm/Columns.edit.display.js @@ -112,5 +112,9 @@ export default [ tooltip: 'Will automatically adjust columns based on if nested components are hidden.', key: 'autoAdjust', input: true - } + }, + { + key: 'hideLabel', + ignore: true + }, ]; diff --git a/src/components/table/editForm/Table.edit.display.js b/src/components/table/editForm/Table.edit.display.js index 31282d7e5e..634e000e4b 100644 --- a/src/components/table/editForm/Table.edit.display.js +++ b/src/components/table/editForm/Table.edit.display.js @@ -124,4 +124,8 @@ export default [ tooltip: 'Condense the size of the table.', weight: 704 }, + { + key: 'hideLabel', + ignore: true + }, ]; diff --git a/src/components/tabs/editForm/Tabs.edit.display.js b/src/components/tabs/editForm/Tabs.edit.display.js index 7a9615763d..1f1fb19b0d 100644 --- a/src/components/tabs/editForm/Tabs.edit.display.js +++ b/src/components/tabs/editForm/Tabs.edit.display.js @@ -81,4 +81,8 @@ export default [ key: 'verticalLayout', input: true }, + { + key: 'hideLabel', + ignore: true + }, ]; From b638e1377a1e78e109a0f2823338d2b480d9429c Mon Sep 17 00:00:00 2001 From: TanyaGashtold <61136841+TanyaGashtold@users.noreply.github.com> Date: Wed, 4 Oct 2023 18:12:37 +0300 Subject: [PATCH 16/22] FIO-5910: allow manual input for w and W date formats (#5002) * FIO-5910: allow manual input for w and W date formats * Update Formio.js --------- Co-authored-by: Travis Tidwell --- src/utils/utils.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/utils/utils.js b/src/utils/utils.js index 1359933ef0..473ba571b3 100644 --- a/src/utils/utils.js +++ b/src/utils/utils.js @@ -803,8 +803,10 @@ export function convertFormatToMask(format) { .replace(/M{3}/g, '***') // Short month conversion if input as text. .replace(/e/g, 'Q') + // Month number conversion. + .replace(/W/g, '99') // Year conversion. - .replace(/[ydhmsHMG]/g, '9') + .replace(/[ydhmswHMG]/g, '9') // AM/PM conversion. .replace(/a/g, 'AA'); } From d65139c215cd21f34aedbcc212ba6d5f766ddea9 Mon Sep 17 00:00:00 2001 From: Travis Tidwell Date: Wed, 4 Oct 2023 10:14:56 -0500 Subject: [PATCH 17/22] Update Changelog.md --- Changelog.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Changelog.md b/Changelog.md index 1217765d59..b4ccf7383a 100644 --- a/Changelog.md +++ b/Changelog.md @@ -22,6 +22,9 @@ and this project adheres to [Semantic Versioning](http://semver.org/). - FIO-7207: changed tooltip and removed 'Hide label' option from the list of layout components - FIO-7074: fixed an issue where setting submission on wizard does not update data - FIO-7082: Moved Wizard Breadcrumbs Type to form settings + - FIO-7224: Fixed issues with layout components when Condensed mode is enabled + - FIO-4833: Removes Hide Label setting from Well, Columns, Tabs and Table components since they do not render a label + - FIO-5910: allow manual input for w and W date formats ## 5.0.0-rc.26 ### Changed From 3578c96d1387ff0adc7d6c033a52a7675fbf5199 Mon Sep 17 00:00:00 2001 From: Ryan Eggleston <112976114+ryanformio@users.noreply.github.com> Date: Wed, 4 Oct 2023 10:15:11 -0500 Subject: [PATCH 18/22] FIO-7146: formiojs-circleci-to-ghactions (#5305) * Adds config to repo * remove need for keys * Separate the Test from Build Job * Improve speed * Wasn't using artifacts * Wasn't creating workspace correctly * Downloading the workspace takes a lot of time rather than just running both in same job * Remove workspace download * updates to cache/v3 --- .github/workflows/config.yml | 131 +++++++++++++++++++++++++++++++++++ 1 file changed, 131 insertions(+) create mode 100644 .github/workflows/config.yml diff --git a/.github/workflows/config.yml b/.github/workflows/config.yml new file mode 100644 index 0000000000..ab65e6faa4 --- /dev/null +++ b/.github/workflows/config.yml @@ -0,0 +1,131 @@ +# name: Build & Test + +# on: push + +# env: +# NODE_VERSION: 18.x + +# jobs: +# test: +# runs-on: ubuntu-latest +# steps: +# - run: echo "Triggered by ${{ github.event_name }} event." + +# - name: Check out repository code ${{ github.repository }} on ${{ github.ref }} +# uses: actions/checkout@v3 + +# - name: Set up Node.js ${{ env.NODE_VERSION }} +# uses: actions/setup-node@v3 +# with: +# node-version: ${{ env.NODE_VERSION }} +# cache: 'npm' + +# - name: Cache node modules +# uses: actions/cache@v3 +# with: +# path: node_modules +# key: ${{ runner.os }}-node-${{ hashFiles('**/yarn.lock') }} +# restore-keys: | +# ${{ runner.os }}-node- + +# - name: Installing dependencies +# if: steps.cache.outputs.cache-hit != 'true' +# uses: borales/actions-yarn@v4 +# with: +# cmd: install --frozen-lockfile + +# - name: Lint +# uses: borales/actions-yarn@v4 +# with: +# cmd: lint + +# - name: Build +# uses: borales/actions-yarn@v4 +# with: +# cmd: build + +# - name: Test +# uses: borales/actions-yarn@v4 +# with: +# cmd: test + +name: Build & Test + +on: push + +env: + NODE_VERSION: 18.x + +jobs: + setup: + runs-on: ubuntu-latest + steps: + - run: echo "Triggered by ${{ github.event_name }} event." + + - name: Check out repository code ${{ github.repository }} on ${{ github.ref }} + uses: actions/checkout@v3 + + - name: Set up Node.js ${{ env.NODE_VERSION }} + uses: actions/setup-node@v3 + with: + node-version: ${{ env.NODE_VERSION }} + cache: 'npm' + + - name: Cache node modules + uses: actions/cache@v3 + with: + path: node_modules + key: ${{ runner.os }}-node-${{ hashFiles('**/yarn.lock') }} + restore-keys: | + ${{ runner.os }}-node- + + - name: Installing dependencies + if: steps.cache.outputs.cache-hit != 'true' + uses: borales/actions-yarn@v4 + with: + cmd: install --frozen-lockfile + + - name: Lint + uses: borales/actions-yarn@v4 + with: + cmd: lint + + build: + needs: setup + runs-on: ubuntu-latest + steps: + - name: Check out repository code ${{ github.repository }} on ${{ github.ref }} + uses: actions/checkout@v3 + + - name: Restore node modules from cache + uses: actions/cache@v3 + with: + path: node_modules + key: ${{ runner.os }}-node-${{ hashFiles('**/yarn.lock') }} + restore-keys: | + ${{ runner.os }}-node- + + - name: Build + uses: borales/actions-yarn@v4 + with: + cmd: build + + test: + needs: setup + runs-on: ubuntu-latest + steps: + - name: Check out repository code ${{ github.repository }} on ${{ github.ref }} + uses: actions/checkout@v3 + + - name: Restore node modules from cache + uses: actions/cache@v3 + with: + path: node_modules + key: ${{ runner.os }}-node-${{ hashFiles('**/yarn.lock') }} + restore-keys: | + ${{ runner.os }}-node- + + - name: Test + uses: borales/actions-yarn@v4 + with: + cmd: test \ No newline at end of file From efe2abcfa3fe2392bda96f184c4dd9c52b42e4f2 Mon Sep 17 00:00:00 2001 From: alexandraRamanenka <60643585+alexandraRamanenka@users.noreply.github.com> Date: Wed, 4 Oct 2023 18:15:42 +0300 Subject: [PATCH 19/22] FIO-6370: Fixes issues with PasswordStrength Addon settings (#5158) * FIO-6370: Fixes issues with PasswordStrength Addon settings * Removed redundant file --------- Co-authored-by: Travis Tidwell --- src/WebformBuilder.js | 9 +++++- src/addons/index.js | 6 +++- .../editForm/Component.edit.addons.js | 32 ++++++++++++++++++- src/components/file/fixtures/comp3.js | 29 +++++++++++++++++ 4 files changed, 73 insertions(+), 3 deletions(-) create mode 100644 src/components/file/fixtures/comp3.js diff --git a/src/WebformBuilder.js b/src/WebformBuilder.js index b7df181d86..461e4559bd 100644 --- a/src/WebformBuilder.js +++ b/src/WebformBuilder.js @@ -1588,8 +1588,15 @@ export default class WebformBuilder extends Component { } } + // If the edit form has any nested form inside, we get a partial data (nested form's data) in the + // event.data property + let editFormData; + if (event.changed.instance && event.changed.instance.root && event.changed.instance.root.id !== this.editForm.id) { + editFormData = this.editForm.data; + } + // Update the component. - this.updateComponent(event.data.componentJson || event.data, event.changed); + this.updateComponent(event.data.componentJson || editFormData || event.data, event.changed); } }); diff --git a/src/addons/index.js b/src/addons/index.js index 1555897676..fb579eb0c7 100644 --- a/src/addons/index.js +++ b/src/addons/index.js @@ -7,7 +7,11 @@ export const editForms = [ key: 'settings', display: 'form', input: true, - components, + components: components.map((comp) => { + comp.tableView = false; + return comp; + }), + tableView: false, defaultValue: { data: defaultSettings }, diff --git a/src/components/_classes/component/editForm/Component.edit.addons.js b/src/components/_classes/component/editForm/Component.edit.addons.js index b3ac3f7da1..7d63552572 100644 --- a/src/components/_classes/component/editForm/Component.edit.addons.js +++ b/src/components/_classes/component/editForm/Component.edit.addons.js @@ -10,6 +10,33 @@ export default [ input: true, key: 'addons', label: 'Addons', + templates: { + // eslint-disable-next-line quotes + header: `
+
{{ t(components[0].label) }}
+
Settings
+
`, + // eslint-disable-next-line quotes + row: `
+
+ {{ row.name.label }} +
+
+ Click Edit to see addon's settings +
+ + {% if (!instance.options.readOnly && !instance.disabled) { %} +
+
+ + {% if (!instance.hasRemoveButtons || instance.hasRemoveButtons()) { %} + + {% } %} +
+
+ {% } %} +
`, + }, components: [ { label: 'Name', @@ -32,7 +59,10 @@ export default [ })); }, }, - input: true + input: true, + validate: { + required: true, + }, }, ...editForms, ] diff --git a/src/components/file/fixtures/comp3.js b/src/components/file/fixtures/comp3.js new file mode 100644 index 0000000000..3e6cf953c1 --- /dev/null +++ b/src/components/file/fixtures/comp3.js @@ -0,0 +1,29 @@ +export default { + type: 'form', + display: 'form', + components: [ + { + label: 'Upload', + tableView: false, + storage: 'base64', + webcam: false, + fileTypes: [ + { + label: '', + value: '' + } + ], + key: 'file', + type: 'file', + input: true + }, + { + type: 'button', + label: 'Submit', + key: 'submit', + disableOnInvalid: true, + input: true, + tableView: false + } + ], +}; From 857f68c2e822ea2df73aab39163041464b49ed7f Mon Sep 17 00:00:00 2001 From: Travis Tidwell Date: Wed, 4 Oct 2023 10:16:18 -0500 Subject: [PATCH 20/22] Update Changelog.md --- Changelog.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Changelog.md b/Changelog.md index b4ccf7383a..286a98346c 100644 --- a/Changelog.md +++ b/Changelog.md @@ -25,6 +25,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/). - FIO-7224: Fixed issues with layout components when Condensed mode is enabled - FIO-4833: Removes Hide Label setting from Well, Columns, Tabs and Table components since they do not render a label - FIO-5910: allow manual input for w and W date formats + - FIO-6370: Fixes issues with PasswordStrength Addon settings + - FIO-7146: formiojs-circleci-to-ghactions ## 5.0.0-rc.26 ### Changed From 640ffd74e6907f53619cfc93b2fd6e11c20144d6 Mon Sep 17 00:00:00 2001 From: Ryan Eggleston <112976114+ryanformio@users.noreply.github.com> Date: Wed, 4 Oct 2023 16:25:13 -0500 Subject: [PATCH 21/22] FIO-6859: update-s3-to-accept-headers-from-signer-presign (#5337) * Loops over the headers that have been sent from server at src/storage/s3/aws.js signed.presigned() * Need to be updated in light of https://github.com/formio/formio-server/pull/1336\#discussion_r1333648380 discussion --------- Co-authored-by: ryaneggz --- src/providers/storage/s3.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/providers/storage/s3.js b/src/providers/storage/s3.js index 7d41a52b97..0963e3c57a 100644 --- a/src/providers/storage/s3.js +++ b/src/providers/storage/s3.js @@ -6,7 +6,9 @@ const s3 = (formio) => ({ response.data.key = XHR.path([response.data.key, dir, fileName]); if (response.signed) { xhr.openAndSetHeaders('PUT', response.signed); - xhr.setRequestHeader('Content-Type', file.type); + Object.keys(response.data.headers).forEach(key => { + xhr.setRequestHeader(key, response.data.headers[key]); + }); return file; } else { From a381c68afa0b335e36457ac1f2a9177ea7456ad5 Mon Sep 17 00:00:00 2001 From: Travis Tidwell Date: Wed, 4 Oct 2023 16:25:34 -0500 Subject: [PATCH 22/22] Update Changelog.md --- Changelog.md | 1 + 1 file changed, 1 insertion(+) diff --git a/Changelog.md b/Changelog.md index 286a98346c..eea6cb5340 100644 --- a/Changelog.md +++ b/Changelog.md @@ -27,6 +27,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/). - FIO-5910: allow manual input for w and W date formats - FIO-6370: Fixes issues with PasswordStrength Addon settings - FIO-7146: formiojs-circleci-to-ghactions + - FIO-6859: update-s3-to-accept-headers-from-signer-presign ## 5.0.0-rc.26 ### Changed