From 6dfed0011eafe4c7d2def96f5caf860a577808fe Mon Sep 17 00:00:00 2001 From: Mark Herwege Date: Sun, 26 Nov 2023 23:37:36 +0100 Subject: [PATCH] Sitemap Editor: Extend chart period config for ISO8601 (#2186) Adjust sitemap configuration in main UI for recent changes in sitemap chart period configuration, see https://github.com/openhab/openhab-core/pull/3863. Signed-off-by: Mark Herwege --- .../pagedesigner/sitemap/widget-details.vue | 25 +++---------------- .../__tests__/sitemap-edit_jest.spec.js | 12 +++++++-- .../settings/pages/sitemap/sitemap-edit.vue | 2 +- 3 files changed, 14 insertions(+), 25 deletions(-) diff --git a/bundles/org.openhab.ui/web/src/components/pagedesigner/sitemap/widget-details.vue b/bundles/org.openhab.ui/web/src/components/pagedesigner/sitemap/widget-details.vue index 9bae258b01..c6d870144a 100644 --- a/bundles/org.openhab.ui/web/src/components/pagedesigner/sitemap/widget-details.vue +++ b/bundles/org.openhab.ui/web/src/components/pagedesigner/sitemap/widget-details.vue @@ -23,13 +23,9 @@ - - - + @@ -97,21 +93,6 @@ export default { Input: ['inputHint'], Default: ['height'] }, - periodDefs: [ - { key: 'h', value: 'Hour' }, - { key: '4h', value: '4 Hours' }, - { key: '8h', value: '8 Hours' }, - { key: '12h', value: '12 Hours' }, - { key: 'D', value: 'Day' }, - { key: '2D', value: '2 Days' }, - { key: '3D', value: '3 Days' }, - { key: 'W', value: 'Week' }, - { key: '2W', value: '2 Weeks' }, - { key: 'M', value: 'Month' }, - { key: '2M', value: '2 Months' }, - { key: '4M', value: '4 Months' }, - { key: 'Y', value: 'Year' } - ], inputHintDefs: [ { key: 'text', value: 'Text' }, { key: 'number', value: 'Number' }, diff --git a/bundles/org.openhab.ui/web/src/pages/settings/pages/sitemap/__tests__/sitemap-edit_jest.spec.js b/bundles/org.openhab.ui/web/src/pages/settings/pages/sitemap/__tests__/sitemap-edit_jest.spec.js index 9fcf0eee99..543ac6fcd9 100644 --- a/bundles/org.openhab.ui/web/src/pages/settings/pages/sitemap/__tests__/sitemap-edit_jest.spec.js +++ b/bundles/org.openhab.ui/web/src/pages/settings/pages/sitemap/__tests__/sitemap-edit_jest.spec.js @@ -187,10 +187,10 @@ describe('SitemapEdit', () => { lastDialogConfig = null wrapper.vm.selectWidget([wrapper.vm.sitemap.slots.widgets[0], wrapper.vm.sitemap]) await wrapper.vm.$nextTick() - localVue.set(wrapper.vm.selectedWidget.config, 'period', '5h') + localVue.set(wrapper.vm.selectedWidget.config, 'period', '5d') wrapper.vm.validateWidgets() expect(lastDialogConfig).toBeTruthy() - expect(lastDialogConfig.content).toMatch(/Chart widget Chart Test, invalid period configured: 5h/) + expect(lastDialogConfig.content).toMatch(/Chart widget Chart Test, invalid period configured: 5d/) // configure a period for the Chart and check that there are no validation errors anymore lastDialogConfig = null @@ -199,6 +199,14 @@ describe('SitemapEdit', () => { localVue.set(wrapper.vm.selectedWidget.config, 'period', '4h') wrapper.vm.validateWidgets() expect(lastDialogConfig).toBeFalsy() + + // configure an ISO-8601 period for the Chart and check that there are no validation errors + lastDialogConfig = null + wrapper.vm.selectWidget([wrapper.vm.sitemap.slots.widgets[0], wrapper.vm.sitemap]) + await wrapper.vm.$nextTick() + localVue.set(wrapper.vm.selectedWidget.config, 'period', 'P10M2W1DT12H30M') + wrapper.vm.validateWidgets() + expect(lastDialogConfig).toBeFalsy() }) it('validates step is positive', async () => { diff --git a/bundles/org.openhab.ui/web/src/pages/settings/pages/sitemap/sitemap-edit.vue b/bundles/org.openhab.ui/web/src/pages/settings/pages/sitemap/sitemap-edit.vue index bd691eda49..4c22765e80 100644 --- a/bundles/org.openhab.ui/web/src/pages/settings/pages/sitemap/sitemap-edit.vue +++ b/bundles/org.openhab.ui/web/src/pages/settings/pages/sitemap/sitemap-edit.vue @@ -427,7 +427,7 @@ export default { } }) widgetList.filter(widget => widget.component === 'Chart').forEach(widget => { - if (!(widget.config && widget.config.period && ['h', '4h', '8h', '12h', 'D', '2D', '3D', 'W', '2W', 'M', '2M', '4M', 'Y'].includes(widget.config.period))) { + if (!(widget.config && widget.config.period && /^P(\d+Y)?(\d+M)?(\d+W)?(\d+D)?(T(\d+H)?(\d+M)?(\d+S)?)?$|^\d*[YMWDh]$/.test(widget.config.period))) { let label = widget.config && widget.config.label ? widget.config.label : 'without label' validationWarnings.push(widget.component + ' widget ' + label + ', invalid period configured: ' + widget.config.period) }