@sankhyalabs/sankhyablocks 8.15.0-rc.1 → 8.15.0-rc.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/{ConfigStorage-302bbbd4.js → ConfigStorage-34be11ce.js} +70 -7
- package/dist/cjs/{DataFetcher-ba94ed5b.js → DataFetcher-99f0f6ed.js} +5 -3
- package/dist/cjs/{SnkFormConfigManager-71c4768e.js → SnkFormConfigManager-531a191c.js} +21 -13
- package/dist/cjs/{SnkMessageBuilder-e7dcf408.js → SnkMessageBuilder-141aa18d.js} +2 -1
- package/dist/cjs/SnkMultiSelectionListDataSource-5213120b.js +140 -0
- package/dist/cjs/{auth-fetcher-c8467c07.js → auth-fetcher-5161d082.js} +1 -1
- package/dist/cjs/{form-config-fetcher-df043d3d.js → form-config-fetcher-9f1a13ca.js} +1 -1
- package/dist/cjs/index-f9e81701.js +2 -10
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/{pesquisa-fetcher-e4a7c4c3.js → pesquisa-fetcher-94f6b316.js} +235 -24
- package/dist/cjs/sankhyablocks.cjs.js +1 -1
- package/dist/cjs/{snk-actions-button_2.cjs.entry.js → snk-actions-button_4.cjs.entry.js} +520 -5
- package/dist/cjs/snk-application.cjs.entry.js +34 -8
- package/dist/cjs/snk-attach.cjs.entry.js +7 -8
- package/dist/cjs/snk-crud.cjs.entry.js +16 -10
- package/dist/cjs/snk-data-exporter.cjs.entry.js +8 -4
- package/dist/cjs/{snk-data-unit-82c08a8c.js → snk-data-unit-6026a9f7.js} +1 -1
- package/dist/cjs/snk-data-unit.cjs.entry.js +2 -2
- package/dist/cjs/snk-detail-view.cjs.entry.js +9 -10
- package/dist/cjs/snk-entity-list.cjs.entry.js +5 -3
- package/dist/cjs/snk-filter-bar.cjs.entry.js +36 -7
- package/dist/cjs/snk-filter-modal-item.cjs.entry.js +3 -3
- package/dist/cjs/snk-form-config.cjs.entry.js +47 -27
- package/dist/cjs/snk-form.cjs.entry.js +11 -4
- package/dist/cjs/snk-grid.cjs.entry.js +40 -22
- package/dist/cjs/{snk-guides-viewer-d32c096f.js → snk-guides-viewer-76b4c346.js} +15 -9
- package/dist/cjs/snk-guides-viewer.cjs.entry.js +7 -8
- package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +3 -1
- package/dist/cjs/snk-personalized-filter.cjs.entry.js +3 -3
- package/dist/cjs/snk-simple-crud.cjs.entry.js +215 -23
- package/dist/cjs/snk-taskbar.cjs.entry.js +100 -14
- package/dist/cjs/{taskbar-elements-01b85b99.js → taskbar-elements-3ecd1278.js} +9 -9
- package/dist/collection/collection-manifest.json +6 -6
- package/dist/collection/components/snk-application/__mocks__/snk-application.js +7 -0
- package/dist/collection/components/snk-application/snk-application.js +51 -11
- package/dist/collection/components/snk-crud/snk-crud.js +95 -3
- package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +2 -2
- package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.css +11 -2
- package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +27 -3
- package/dist/collection/components/snk-data-exporter/snk-data-exporter.js +5 -1
- package/dist/collection/components/snk-entity-list/snk-entity-list.js +5 -3
- package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-personalized-filter-editor/snk-personalized-filter-editor.js +3 -1
- package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +23 -1
- package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +116 -4
- package/dist/collection/components/snk-form/snk-form.js +25 -1
- package/dist/collection/components/{snk-form → snk-form-config}/SnkFormConfigManager.js +20 -12
- package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.js +50 -30
- package/dist/collection/components/snk-grid/snk-grid.js +103 -16
- package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.js +130 -123
- package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.js +1 -1
- package/dist/collection/components/snk-simple-crud/regular-buttons.js +3 -0
- package/dist/collection/components/snk-simple-crud/snk-simple-crud.css +5 -0
- package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +344 -17
- package/dist/collection/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.js +1 -1
- package/dist/collection/components/snk-taskbar/elements/taskbar-elements.js +9 -9
- package/dist/collection/components/snk-taskbar/snk-taskbar.css +17 -0
- package/dist/collection/components/snk-taskbar/snk-taskbar.js +139 -13
- package/dist/collection/lib/configs/ConfigStorage.js +63 -3
- package/dist/collection/lib/http/data-fetcher/DataFetcher.js +5 -3
- package/dist/collection/lib/http/data-fetcher/fetchers/parameters-fecher.js +21 -0
- package/dist/collection/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.js +6 -3
- package/dist/collection/lib/http/data-fetcher/fetchers/pesquisa-fetcher.js +4 -11
- package/dist/collection/lib/message/resources/snk-data-exporter.msg.js +2 -1
- package/dist/collection/lib/utils/CrudUtils.js +13 -1
- package/dist/components/ConfigStorage.js +68 -5
- package/dist/components/DataFetcher.js +5 -3
- package/dist/components/SnkFormConfigManager.js +19 -11
- package/dist/components/SnkMessageBuilder.js +2 -1
- package/dist/components/dataunit-fetcher.js +4 -11
- package/dist/components/field-search.js +93 -3
- package/dist/components/index.d.ts +6 -6
- package/dist/components/snk-application2.js +30 -1
- package/dist/components/snk-attach2.js +54 -12
- package/dist/components/snk-crud.js +15 -3
- package/dist/components/snk-data-exporter2.js +5 -1
- package/dist/components/snk-detail-view2.js +40 -7
- package/dist/components/snk-entity-list.js +5 -3
- package/dist/components/snk-filter-bar2.js +38 -5
- package/dist/components/snk-form-config2.js +46 -26
- package/dist/components/snk-form.js +8 -0
- package/dist/components/snk-grid-config2.js +128 -102
- package/dist/components/snk-grid2.js +41 -17
- package/dist/components/snk-personalized-filter-editor.js +3 -1
- package/dist/components/snk-simple-crud2.js +272 -28
- package/dist/components/snk-taskbar2.js +114 -24
- package/dist/components/taskbar-actions-button2.js +1 -1
- package/dist/esm/{ConfigStorage-4151acc8.js → ConfigStorage-101a2b4c.js} +70 -7
- package/dist/esm/{DataFetcher-aa159c5a.js → DataFetcher-a650ae58.js} +5 -3
- package/dist/esm/{SnkFormConfigManager-5c7d3771.js → SnkFormConfigManager-02ecf57f.js} +21 -13
- package/dist/esm/{SnkMessageBuilder-0fb796b9.js → SnkMessageBuilder-9747ddd2.js} +2 -1
- package/dist/esm/SnkMultiSelectionListDataSource-7e7eada5.js +133 -0
- package/dist/esm/{auth-fetcher-c05dc474.js → auth-fetcher-17dc5b5e.js} +1 -1
- package/dist/esm/{form-config-fetcher-36219cd3.js → form-config-fetcher-f121f880.js} +1 -1
- package/dist/esm/index-a7d3d3f1.js +2 -10
- package/dist/esm/loader.js +1 -1
- package/dist/esm/{pesquisa-fetcher-fa0c2540.js → pesquisa-fetcher-f05a12ca.js} +226 -16
- package/dist/esm/sankhyablocks.js +1 -1
- package/dist/esm/{snk-actions-button_2.entry.js → snk-actions-button_4.entry.js} +519 -6
- package/dist/esm/snk-application.entry.js +34 -8
- package/dist/esm/snk-attach.entry.js +6 -7
- package/dist/esm/snk-crud.entry.js +16 -10
- package/dist/esm/snk-data-exporter.entry.js +8 -4
- package/dist/esm/{snk-data-unit-5d201fb3.js → snk-data-unit-4c343635.js} +1 -1
- package/dist/esm/snk-data-unit.entry.js +2 -2
- package/dist/esm/snk-detail-view.entry.js +9 -10
- package/dist/esm/snk-entity-list.entry.js +5 -3
- package/dist/esm/snk-filter-bar.entry.js +36 -7
- package/dist/esm/snk-filter-modal-item.entry.js +3 -3
- package/dist/esm/snk-form-config.entry.js +48 -28
- package/dist/esm/snk-form.entry.js +11 -4
- package/dist/esm/snk-grid.entry.js +41 -23
- package/dist/esm/{snk-guides-viewer-f49613c6.js → snk-guides-viewer-90ca9105.js} +15 -9
- package/dist/esm/snk-guides-viewer.entry.js +7 -8
- package/dist/esm/snk-personalized-filter-editor.entry.js +3 -1
- package/dist/esm/snk-personalized-filter.entry.js +3 -3
- package/dist/esm/snk-simple-crud.entry.js +216 -24
- package/dist/esm/snk-taskbar.entry.js +101 -15
- package/dist/esm/{taskbar-elements-d4d0b424.js → taskbar-elements-2473c8ac.js} +9 -9
- package/dist/sankhyablocks/p-1f3174cb.entry.js +1 -0
- package/dist/sankhyablocks/p-1fa5a18c.entry.js +11 -0
- package/dist/sankhyablocks/p-20b46647.entry.js +1 -0
- package/dist/sankhyablocks/p-2897fb8c.js +1 -0
- package/dist/sankhyablocks/{p-05243555.js → p-2936303b.js} +1 -1
- package/dist/sankhyablocks/p-2cfe0c2c.entry.js +1 -0
- package/dist/sankhyablocks/p-33718dfc.entry.js +1 -0
- package/dist/sankhyablocks/p-384fd6ae.js +1 -0
- package/dist/sankhyablocks/p-50783a8b.js +1 -0
- package/dist/sankhyablocks/p-5c0b53ce.js +56 -0
- package/dist/sankhyablocks/p-663ff67b.entry.js +1 -0
- package/dist/sankhyablocks/{p-7f3c7b09.entry.js → p-6b28cc74.entry.js} +1 -1
- package/dist/sankhyablocks/{p-e0fd9555.entry.js → p-7ddd95b6.entry.js} +1 -1
- package/dist/sankhyablocks/p-7e05bd83.entry.js +1 -0
- package/dist/sankhyablocks/p-7f97fee2.entry.js +1 -0
- package/dist/sankhyablocks/p-8111f63f.entry.js +1 -0
- package/dist/sankhyablocks/{p-f3d1c48e.js → p-9a5d1b39.js} +1 -1
- package/dist/sankhyablocks/{p-0d7863ed.js → p-a13ccb86.js} +1 -1
- package/dist/sankhyablocks/p-a83487a0.entry.js +1 -0
- package/dist/sankhyablocks/p-ae4fc9a9.js +1 -0
- package/dist/sankhyablocks/p-b11aa1e0.entry.js +1 -0
- package/dist/sankhyablocks/p-b41a622a.entry.js +1 -0
- package/dist/sankhyablocks/p-ba4871b5.entry.js +1 -0
- package/dist/sankhyablocks/{p-9695f78b.js → p-be75153c.js} +1 -1
- package/dist/sankhyablocks/p-d01ceda6.entry.js +1 -0
- package/dist/sankhyablocks/p-d304659d.entry.js +1 -0
- package/dist/sankhyablocks/p-d78d4062.js +65 -0
- package/dist/sankhyablocks/p-e7dbe53a.entry.js +1 -0
- package/dist/sankhyablocks/p-fad4c2fe.js +1 -0
- package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
- package/dist/types/components/snk-actions-button/subcomponents/snk-actions-form.d.ts +1 -1
- package/dist/types/components/snk-application/__mocks__/snk-application.d.ts +3 -0
- package/dist/types/components/snk-application/snk-application.d.ts +8 -0
- package/dist/types/components/snk-crud/snk-crud.d.ts +21 -0
- package/dist/types/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.d.ts +1 -1
- package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +6 -1
- package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +19 -1
- package/dist/types/components/snk-form/snk-form.d.ts +6 -1
- package/dist/types/components/{snk-form → snk-form-config}/SnkFormConfigManager.d.ts +2 -1
- package/dist/types/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.d.ts +5 -3
- package/dist/types/components/snk-grid/snk-grid.d.ts +20 -1
- package/dist/types/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.d.ts +11 -6
- package/dist/types/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.d.ts +1 -1
- package/dist/types/components/snk-simple-crud/regular-buttons.d.ts +3 -0
- package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +65 -3
- package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +28 -1
- package/dist/types/components.d.ts +201 -12
- package/dist/types/lib/configs/ConfigStorage.d.ts +21 -1
- package/dist/types/lib/http/data-fetcher/fetchers/parameters-fecher.d.ts +1 -0
- package/dist/types/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.d.ts +2 -1
- package/dist/types/lib/utils/CrudUtils.d.ts +3 -0
- package/package.json +9 -2
- package/dist/cjs/PreloadManager-84466da6.js +0 -224
- package/dist/cjs/SnkMultiSelectionListDataSource-ba5838c2.js +0 -49
- package/dist/cjs/snk-grid-config.cjs.entry.js +0 -483
- package/dist/cjs/snk-select-box.cjs.entry.js +0 -25
- package/dist/esm/PreloadManager-c1c2f2b4.js +0 -222
- package/dist/esm/SnkMultiSelectionListDataSource-44494b0e.js +0 -43
- package/dist/esm/snk-grid-config.entry.js +0 -479
- package/dist/esm/snk-select-box.entry.js +0 -21
- package/dist/sankhyablocks/p-02e3a45b.entry.js +0 -1
- package/dist/sankhyablocks/p-094c30cb.js +0 -1
- package/dist/sankhyablocks/p-0ec5b2e5.js +0 -1
- package/dist/sankhyablocks/p-1d75d9f9.entry.js +0 -1
- package/dist/sankhyablocks/p-2582537c.entry.js +0 -1
- package/dist/sankhyablocks/p-282789a6.entry.js +0 -1
- package/dist/sankhyablocks/p-374d03f6.js +0 -1
- package/dist/sankhyablocks/p-3b0e4e08.js +0 -65
- package/dist/sankhyablocks/p-40915359.entry.js +0 -1
- package/dist/sankhyablocks/p-573a07c5.js +0 -1
- package/dist/sankhyablocks/p-62896624.entry.js +0 -1
- package/dist/sankhyablocks/p-69efa80d.entry.js +0 -1
- package/dist/sankhyablocks/p-761ed32f.entry.js +0 -1
- package/dist/sankhyablocks/p-98674137.entry.js +0 -1
- package/dist/sankhyablocks/p-9b5944a4.entry.js +0 -1
- package/dist/sankhyablocks/p-9bdbc7d8.entry.js +0 -1
- package/dist/sankhyablocks/p-aa95fb2c.js +0 -56
- package/dist/sankhyablocks/p-ac384baf.entry.js +0 -1
- package/dist/sankhyablocks/p-b05ab13d.entry.js +0 -1
- package/dist/sankhyablocks/p-c22c1d8e.js +0 -1
- package/dist/sankhyablocks/p-c4874327.entry.js +0 -1
- package/dist/sankhyablocks/p-c758265f.entry.js +0 -1
- package/dist/sankhyablocks/p-cb7419e0.entry.js +0 -1
- package/dist/sankhyablocks/p-d4f9ee17.entry.js +0 -1
- package/dist/sankhyablocks/p-e6380c60.js +0 -1
- package/dist/sankhyablocks/p-e817f254.entry.js +0 -11
- /package/dist/collection/components/{snk-form/subcomponents/snk-form-config → snk-form-config}/snk-form-config.css +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.css +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.js +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.css +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.js +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.css +0 -0
- /package/dist/collection/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.js +0 -0
- /package/dist/collection/components/{snk-grid/subcomponents/snk-grid-config → snk-grid-config}/snk-grid-config.css +0 -0
- /package/dist/collection/components/{snk-grid/subcomponents → snk-grid-config}/snk-select-box/snk-select-box.css +0 -0
- /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-config-options/snk-config-options.d.ts +0 -0
- /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-field-config/snk-field-config.d.ts +0 -0
- /package/dist/types/components/{snk-form → snk-form-config}/subcomponents/snk-tab-config/snk-tab-config.d.ts +0 -0
@@ -5,25 +5,29 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
5
5
|
const index = require('./index-f9e81701.js');
|
6
6
|
const core = require('@sankhyalabs/core');
|
7
7
|
const constants = require('./constants-35ddd366.js');
|
8
|
-
const taskbarElements = require('./taskbar-elements-
|
9
|
-
require('./DataFetcher-
|
10
|
-
const pesquisaFetcher = require('./pesquisa-fetcher-
|
8
|
+
const taskbarElements = require('./taskbar-elements-3ecd1278.js');
|
9
|
+
require('./DataFetcher-99f0f6ed.js');
|
10
|
+
const pesquisaFetcher = require('./pesquisa-fetcher-94f6b316.js');
|
11
|
+
const SnkMultiSelectionListDataSource = require('./SnkMultiSelectionListDataSource-5213120b.js');
|
11
12
|
const index$1 = require('./index-0922807b.js');
|
12
13
|
require('./ISave-e91b70a7.js');
|
13
14
|
require('@sankhyalabs/ezui/dist/collection/utils/constants');
|
14
15
|
require('@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata');
|
15
|
-
require('./PreloadManager-84466da6.js');
|
16
16
|
require('./filter-item-type.enum-a7ffdaa6.js');
|
17
|
-
require('./form-config-fetcher-
|
17
|
+
require('./form-config-fetcher-9f1a13ca.js');
|
18
18
|
const fieldSearch = require('./field-search-f56aa7d6.js');
|
19
|
-
const
|
19
|
+
const ConfigStorage = require('./ConfigStorage-34be11ce.js');
|
20
|
+
const SnkFormConfigManager = require('./SnkFormConfigManager-531a191c.js');
|
20
21
|
require('./index-102ba62d.js');
|
21
22
|
require('./PrintUtils-bcaeb82f.js');
|
22
|
-
require('./ResourceIDUtils-5ff86aa7.js');
|
23
23
|
require('@sankhyalabs/ezui/dist/collection/components/ez-grid/utils');
|
24
|
+
require('./ResourceIDUtils-5ff86aa7.js');
|
24
25
|
require('@sankhyalabs/ezui/dist/collection/components/ez-grid/utils/InMemoryFilterColumnDataSource');
|
25
26
|
|
26
|
-
const
|
27
|
+
const REGULAR_DEFAULT_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "MORE_OPTIONS"];
|
28
|
+
const REGULAR_SELECTED_BTNS = ["INSERT", "REFRESH", "PREVIOUS", "NEXT", "DIVIDER", "CLONE", "REMOVE", "DIVIDER", "MORE_OPTIONS"];
|
29
|
+
|
30
|
+
const snkSimpleCrudCss = ".sc-snk-simple-crud-h{display:flex;height:100%;width:100%}.simple-crud__container.sc-snk-simple-crud{display:grid;grid-template-rows:max-content;row-gap:12px;height:100%;width:100%}.simple-crud__container-section.sc-snk-simple-crud{flex-wrap:unset;flex-direction:column}.simple-crud__form--hidden.sc-snk-simple-crud{display:none}ez-grid.sc-snk-simple-crud{--ez-grid__container--shadow:none;min-height:300px}ez-form.sc-snk-simple-crud{min-height:300px}";
|
27
31
|
|
28
32
|
const SnkSimpleCrud = class {
|
29
33
|
constructor(hostRef) {
|
@@ -32,20 +36,23 @@ const SnkSimpleCrud = class {
|
|
32
36
|
this.dataUnitReady = index.createEvent(this, "dataUnitReady", 3);
|
33
37
|
this.actionClick = index.createEvent(this, "actionClick", 7);
|
34
38
|
this.formItemsReady = index.createEvent(this, "formItemsReady", 7);
|
35
|
-
this.
|
36
|
-
this.
|
39
|
+
this.configuratorSave = index.createEvent(this, "configuratorSave", 7);
|
40
|
+
this.configuratorCancel = index.createEvent(this, "configuratorCancel", 7);
|
37
41
|
this._multiSelectionListDataSource = new SnkMultiSelectionListDataSource.SnkMultiSelectionListDataSource();
|
38
42
|
this._keyDownHandler = (event) => this.keyDownListener(event);
|
39
43
|
this._taskbarProcessor = new fieldSearch.TaskbarProcessor({
|
40
|
-
"snkSimpleCrudTaskbar.form_regular": this.
|
41
|
-
"snkSimpleCrudTaskbar.grid_regular": this.
|
42
|
-
"snkSimpleCrudTaskbar.form_selected": this.
|
43
|
-
"snkSimpleCrudTaskbar.grid_selected": this.
|
44
|
+
"snkSimpleCrudTaskbar.form_regular": this.getButtons(false, taskbarElements.TaskbarElement.GRID_MODE),
|
45
|
+
"snkSimpleCrudTaskbar.grid_regular": this.getButtons(false, taskbarElements.TaskbarElement.FORM_MODE),
|
46
|
+
"snkSimpleCrudTaskbar.form_selected": this.getButtons(true, taskbarElements.TaskbarElement.GRID_MODE),
|
47
|
+
"snkSimpleCrudTaskbar.grid_selected": this.getButtons(true, taskbarElements.TaskbarElement.FORM_MODE),
|
44
48
|
"snkSimpleCrudTaskbar.finish_edition": ["CANCEL", "SAVE"]
|
45
49
|
});
|
50
|
+
this._showPopUpGridConfig = false;
|
51
|
+
this._showFormConfig = false;
|
46
52
|
this._currentViewMode = constants.VIEW_MODE.GRID;
|
47
53
|
this._config = undefined;
|
48
54
|
this._fieldToGetFocus = undefined;
|
55
|
+
this._customContainerId = `SNK-SIMPLE-CRUD-CUSTOM-CONTAINER-${core.StringUtils.generateUUID()}`;
|
49
56
|
this.dataState = undefined;
|
50
57
|
this.dataUnit = undefined;
|
51
58
|
this.mode = constants.SIMPLE_CRUD_MODE.SERVER;
|
@@ -59,6 +66,23 @@ const SnkSimpleCrud = class {
|
|
59
66
|
this.useEnterLikeTab = false;
|
60
67
|
this.actionsList = undefined;
|
61
68
|
this.configName = undefined;
|
69
|
+
this.showConfiguratorButtons = undefined;
|
70
|
+
this.gridLegacyConfigName = undefined;
|
71
|
+
this.formLegacyConfigName = undefined;
|
72
|
+
this.ignoreReadOnlyFormFields = false;
|
73
|
+
}
|
74
|
+
getButtons(selected, changeModeBtn) {
|
75
|
+
return this.addConfigButton(this.resolveInMemoryBtns(selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS)
|
76
|
+
.concat(changeModeBtn));
|
77
|
+
}
|
78
|
+
addConfigButton(buttons) {
|
79
|
+
if (this.configName === undefined) {
|
80
|
+
return buttons;
|
81
|
+
}
|
82
|
+
return buttons.concat(taskbarElements.TaskbarElement.CONFIGURATOR);
|
83
|
+
}
|
84
|
+
get application() {
|
85
|
+
return core.ApplicationContext.getContextValue("__SNK__APPLICATION__");
|
62
86
|
}
|
63
87
|
resolveInMemoryBtns(taskbarButtons) {
|
64
88
|
const newTaskBarConfig = [...taskbarButtons];
|
@@ -78,7 +102,10 @@ const SnkSimpleCrud = class {
|
|
78
102
|
}
|
79
103
|
actionClickListener(evt) {
|
80
104
|
const act = evt.detail;
|
81
|
-
if (act === taskbarElements.TaskbarElement.
|
105
|
+
if (act === taskbarElements.TaskbarElement.CONFIGURATOR) {
|
106
|
+
this._snkConfigurator.open();
|
107
|
+
}
|
108
|
+
else if (act === taskbarElements.TaskbarElement.GRID_MODE) {
|
82
109
|
this.goToView(constants.VIEW_MODE.GRID);
|
83
110
|
}
|
84
111
|
else if (act === taskbarElements.TaskbarElement.FORM_MODE) {
|
@@ -96,8 +123,111 @@ const SnkSimpleCrud = class {
|
|
96
123
|
this.dataStateChange.emit(newValue);
|
97
124
|
}
|
98
125
|
}
|
99
|
-
|
126
|
+
async observeFormLegacy() {
|
127
|
+
await this.handleUpdateFormLegacyConfig();
|
128
|
+
}
|
129
|
+
async observeGridLegacy() {
|
130
|
+
await this.handleUpdateGridLegacyConfig();
|
131
|
+
}
|
132
|
+
async handleUpdateGridLegacyConfig() {
|
133
|
+
if (this.gridLegacyConfigName) {
|
134
|
+
this.addGridLegacyConfigName();
|
135
|
+
if (this._gridConfigAlreadyLoaded) {
|
136
|
+
await this.loadGridConfig(true);
|
137
|
+
}
|
138
|
+
}
|
139
|
+
}
|
140
|
+
async handleUpdateFormLegacyConfig() {
|
141
|
+
var _a, _b, _c;
|
142
|
+
if (this.formLegacyConfigName) {
|
143
|
+
const legacyConfig = await this.fetchFormLegacyConfig();
|
144
|
+
if (!legacyConfig)
|
145
|
+
return;
|
146
|
+
const rawFields = (_c = (_b = (_a = legacyConfig === null || legacyConfig === void 0 ? void 0 : legacyConfig.formConfig) === null || _a === void 0 ? void 0 : _a.layout) === null || _b === void 0 ? void 0 : _b.field) !== null && _c !== void 0 ? _c : [];
|
147
|
+
const fields = Array.isArray(rawFields) ? rawFields : [rawFields];
|
148
|
+
const newConfig = { emptyConfig: false, fields: fields };
|
149
|
+
this.setFormConfig(newConfig, true);
|
150
|
+
this._formConfigManager.setConfig(this.formConfig);
|
151
|
+
}
|
152
|
+
}
|
153
|
+
async fetchFormLegacyConfig() {
|
154
|
+
const payload = {
|
155
|
+
'requestBody': {
|
156
|
+
'config': {
|
157
|
+
'chave': this.formLegacyConfigName,
|
158
|
+
'tipo': 'T',
|
159
|
+
},
|
160
|
+
},
|
161
|
+
};
|
162
|
+
return await this.application.callServiceBroker('SystemUtilsSP.getConf', JSON.stringify(payload));
|
163
|
+
}
|
164
|
+
openConfig(viewMode) {
|
165
|
+
this._snkConfigurator.close();
|
166
|
+
if (viewMode === constants.VIEW_MODE.GRID) {
|
167
|
+
this.openGridConfig();
|
168
|
+
}
|
169
|
+
else if (viewMode === constants.VIEW_MODE.FORM) {
|
170
|
+
this.openFormConfig();
|
171
|
+
}
|
172
|
+
}
|
173
|
+
openGridConfig() {
|
174
|
+
this._grid.getColumnsState()
|
175
|
+
.then((gridColumns) => {
|
176
|
+
this._snkGridConfig.columns = gridColumns.filter(c => c.name);
|
177
|
+
this._snkGridConfig.selectedIndex = 0;
|
178
|
+
this._showPopUpGridConfig = true;
|
179
|
+
});
|
180
|
+
}
|
181
|
+
openFormConfig() {
|
182
|
+
//No momento não daremos suporte para configuraçao de formulário quando houver legacy config
|
183
|
+
if (this.formLegacyConfigName)
|
184
|
+
return;
|
185
|
+
this._showFormConfig = true;
|
186
|
+
}
|
187
|
+
addGridLegacyConfigName() {
|
188
|
+
if (this.gridLegacyConfigName && this.configName) {
|
189
|
+
ConfigStorage.ConfigStorage.addGridLegacyConfig(this.configName, this.gridLegacyConfigName);
|
190
|
+
}
|
191
|
+
}
|
192
|
+
loadGridConfig(forceUpdate) {
|
193
|
+
if ((this.gridConfig != undefined || this._gridConfigAlreadyLoaded) && !forceUpdate) {
|
194
|
+
return;
|
195
|
+
}
|
196
|
+
this._gridConfigAlreadyLoaded = true;
|
197
|
+
return new Promise((accept, reject) => {
|
198
|
+
ConfigStorage.ConfigStorage.loadGridConfig(this.configName, this._resourceID)
|
199
|
+
.then(config => {
|
200
|
+
this.setGridConfig(config);
|
201
|
+
accept();
|
202
|
+
})
|
203
|
+
.catch(reason => {
|
204
|
+
reject(reason);
|
205
|
+
});
|
206
|
+
});
|
207
|
+
}
|
208
|
+
async loadFormConfig() {
|
209
|
+
if (this._formConfigManager == undefined) {
|
210
|
+
this._formConfigManager = new SnkFormConfigManager.SnkFormConfigManager(this.configName, this._resourceID);
|
211
|
+
this._formConfigManager.setConfig(this.formConfig);
|
212
|
+
}
|
213
|
+
if (this.formConfig != undefined || this._formConfigAlreadyLoaded) {
|
214
|
+
return;
|
215
|
+
}
|
216
|
+
this._formConfigAlreadyLoaded = true;
|
217
|
+
this.setFormConfig(await this._formConfigManager.loadConfig());
|
218
|
+
}
|
219
|
+
async componentWillRender() {
|
220
|
+
this._resourceID = await this.application.getResourceID();
|
100
221
|
this._taskbarProcessor.process(this.getTaskBarId(), this.taskbarManager, this.dataState, this.getTaskBarDisabledButtons());
|
222
|
+
if (this.configName === undefined) {
|
223
|
+
return;
|
224
|
+
}
|
225
|
+
if (this.gridConfig != undefined || this._gridConfigAlreadyLoaded) {
|
226
|
+
return;
|
227
|
+
}
|
228
|
+
await this.addGridLegacyConfigName();
|
229
|
+
this.loadGridConfig();
|
230
|
+
this.loadFormConfig();
|
101
231
|
}
|
102
232
|
componentWillLoad() {
|
103
233
|
this.processMetadata();
|
@@ -105,8 +235,7 @@ const SnkSimpleCrud = class {
|
|
105
235
|
this.configDatasource();
|
106
236
|
}
|
107
237
|
configDatasource() {
|
108
|
-
|
109
|
-
this._multiSelectionListDataSource.setApplication(application);
|
238
|
+
this._multiSelectionListDataSource.setApplication(this.application);
|
110
239
|
this._multiSelectionListDataSource.setDataUnit(this.dataUnit);
|
111
240
|
}
|
112
241
|
getTaskBarId() {
|
@@ -147,6 +276,20 @@ const SnkSimpleCrud = class {
|
|
147
276
|
getRecords() {
|
148
277
|
return Promise.resolve(this.dataUnit.records);
|
149
278
|
}
|
279
|
+
/**
|
280
|
+
* Usado para abrir o configurator do CRUD
|
281
|
+
*/
|
282
|
+
async openConfigurator() {
|
283
|
+
var _a;
|
284
|
+
(_a = this._snkConfigurator) === null || _a === void 0 ? void 0 : _a.open();
|
285
|
+
}
|
286
|
+
/**
|
287
|
+
* Usado para fechar o configurator do CRUD
|
288
|
+
*/
|
289
|
+
async closeConfigurator() {
|
290
|
+
var _a;
|
291
|
+
(_a = this._snkConfigurator) === null || _a === void 0 ? void 0 : _a.close();
|
292
|
+
}
|
150
293
|
processMetadata() {
|
151
294
|
const fieldsMetadataElem = this._element.querySelectorAll("snk-field-metadata");
|
152
295
|
const fieldMetadata = [];
|
@@ -201,6 +344,14 @@ const SnkSimpleCrud = class {
|
|
201
344
|
this.dataUnit.clearSelection();
|
202
345
|
}
|
203
346
|
}
|
347
|
+
handleConfiguratorEvent(evt, type) {
|
348
|
+
evt.stopImmediatePropagation();
|
349
|
+
if (type === 'SAVE') {
|
350
|
+
this.configuratorSave.emit();
|
351
|
+
return;
|
352
|
+
}
|
353
|
+
this.configuratorCancel.emit();
|
354
|
+
}
|
204
355
|
getColumnSearch(actionButton, item) {
|
205
356
|
if (this._columnSearch != undefined) {
|
206
357
|
return this._columnSearch;
|
@@ -242,7 +393,9 @@ const SnkSimpleCrud = class {
|
|
242
393
|
return (_b = (_a = this.formConfig) === null || _a === void 0 ? void 0 : _a.fields) !== null && _b !== void 0 ? _b : this._formFields;
|
243
394
|
}
|
244
395
|
handleFormSetFields(fields) {
|
245
|
-
this._formFields
|
396
|
+
if (!core.ObjectUtils.equals(this._formFields, fields)) {
|
397
|
+
this._formFields = fields !== null && fields !== void 0 ? fields : [];
|
398
|
+
}
|
246
399
|
}
|
247
400
|
fieldsOptionLoader(argument) {
|
248
401
|
const searchTerm = argument === null || argument === void 0 ? void 0 : argument.toLowerCase();
|
@@ -314,16 +467,55 @@ const SnkSimpleCrud = class {
|
|
314
467
|
disconnectedCallback() {
|
315
468
|
window.removeEventListener("keydown", this._keyDownHandler);
|
316
469
|
}
|
470
|
+
gridConfigChangeHandler(evt) {
|
471
|
+
const config = evt.detail;
|
472
|
+
ConfigStorage.ConfigStorage.saveGridConfig(config, this.configName, this._resourceID);
|
473
|
+
evt.stopPropagation();
|
474
|
+
}
|
475
|
+
modalConfigChangeHandler(evt) {
|
476
|
+
const config = evt.detail;
|
477
|
+
this._grid.setColumnsState(config.columns)
|
478
|
+
.then(() => {
|
479
|
+
this.setGridConfig(config);
|
480
|
+
this.closeGridConfig();
|
481
|
+
});
|
482
|
+
evt.stopPropagation();
|
483
|
+
}
|
484
|
+
setGridConfig(config) {
|
485
|
+
this.gridConfig = config;
|
486
|
+
SnkMultiSelectionListDataSource.CrudUtils.assertDefaultSorting(this.gridConfig, this.dataUnit);
|
487
|
+
}
|
488
|
+
setFormConfig(config, forceUpdate) {
|
489
|
+
if (this.formConfig && !forceUpdate)
|
490
|
+
return;
|
491
|
+
this.formConfig = config;
|
492
|
+
}
|
493
|
+
closeGridConfig() {
|
494
|
+
this._showPopUpGridConfig = false;
|
495
|
+
}
|
496
|
+
closeFormConfig() {
|
497
|
+
this._showFormConfig = false;
|
498
|
+
}
|
499
|
+
//No momento não daremos suporte para configuração de formulário quando houver formLegacyConfigName
|
500
|
+
handleShowFormConfig() {
|
501
|
+
return this._showFormConfig && !this.formLegacyConfigName;
|
502
|
+
}
|
503
|
+
/* istanbul ignore next */
|
317
504
|
render() {
|
318
|
-
var _a;
|
319
|
-
|
505
|
+
var _a, _b, _c;
|
506
|
+
if (this.dataUnit == undefined) {
|
507
|
+
return;
|
508
|
+
}
|
509
|
+
return (index.h("snk-data-unit", { class: "simple-crud__container", dataUnit: this.dataUnit, useCancelConfirm: this.useCancelConfirm, onDataStateChange: evt => this.onDataStateChange(evt), onCancelEdition: this.handleCancelEdit.bind(this), onInsertionMode: () => this.goToView(constants.VIEW_MODE.FORM), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), ignoreSaveMessage: this._currentViewMode === constants.VIEW_MODE.GRID, onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail }, index.h("header", null, index.h("slot", { name: "snkSimpleCrudHeader" })), index.h("section", { class: "ez-box ez-box--shadow simple-crud__container-section" }, index.h("snk-taskbar", { class: "ez-box ez-box--shadow ez-padding--medium", dataUnit: this.dataUnit, primaryButton: ((_a = this.dataState) === null || _a === void 0 ? void 0 : _a.isDirty) ? "SAVE" : "INSERT", "data-element-id": "grid_left", messagesBuilder: this.messagesBuilder, buttons: this._taskbarProcessor.buttons, actionsList: this.getActionsList(), disabledButtons: this._taskbarProcessor.disabledButtons, customButtons: this._taskbarProcessor.customButtons, slot: "leftButtons", presentationMode: index$1.PresentationMode.SECONDARY }, index.h("slot", { name: "TASKBAR_CUSTOM_ELEMENTS" })), index.h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, index.h("stack-item", null, index.h("ez-grid", { class: "ez-margin-bottom--large", ref: ref => this._grid = ref, dataUnit: this.dataUnit, config: this.gridConfig, "no-header": true, multipleSelection: this.multipleSelection, onEzDoubleClick: () => this.goToView(constants.VIEW_MODE.FORM), onConfigChange: evt => this.gridConfigChangeHandler(evt), columnfilterDataSource: this.dataUnit.name && this.dataUnit.name.includes(pesquisaFetcher.InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
|
320
510
|
? undefined
|
321
|
-
: this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab }, index.h("div", { slot: "footer" }, index.h("slot", { name: "snkSimpleCrudFooter" })))), index.h("stack-item", null, index.h("ez-form", { dataUnit: this.dataUnit, config: this.
|
511
|
+
: this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab }, index.h("div", { slot: "footer" }, index.h("slot", { name: "snkSimpleCrudFooter" })))), index.h("stack-item", null, index.h("ez-form", { class: `ez-margin-top--large ${this.handleShowFormConfig() ? "simple-crud__form--hidden" : ""}`, dataUnit: this.dataUnit, config: (_b = this._formConfigManager) === null || _b === void 0 ? void 0 : _b.getConfig((_c = this.dataState) === null || _c === void 0 ? void 0 : _c.insertionMode, this.dataUnit, this.ignoreReadOnlyFormFields), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this) }), this.handleShowFormConfig() && index.h("snk-form-config", { messagesBuilder: this.messagesBuilder, dataUnit: this.dataUnit, configManager: this._formConfigManager, onConfigClose: () => this.closeFormConfig() })), this.messagesBuilder && index.h("snk-configurator", { ref: (ref) => this._snkConfigurator = ref, viewMode: this._currentViewMode, messagesBuilder: this.messagesBuilder, onConfigSelected: (evt) => this.goToView(evt.detail), onOpenConfig: (evt) => this.openConfig(evt.detail), showActionButtons: this.showConfiguratorButtons, onSave: evt => this.handleConfiguratorEvent(evt, 'SAVE'), onCancel: evt => this.handleConfiguratorEvent(evt, 'CANCEL'), resourceID: this._resourceID, customContainerId: this._customContainerId })), index.h("div", { id: `${this._customContainerId}` }, index.h("slot", { name: "SnkConfigContainerSlot" }))), index.h("ez-modal", { modalSize: "small", closeEsc: false, closeOutsideClick: false, opened: this._showPopUpGridConfig, onEzCloseModal: () => this.closeGridConfig() }, index.h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(core.ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this._resourceID }))));
|
322
512
|
}
|
323
513
|
get _element() { return index.getElement(this); }
|
324
514
|
static get watchers() { return {
|
325
515
|
"mode": ["onModeChange"],
|
326
|
-
"dataState": ["observeDataState"]
|
516
|
+
"dataState": ["observeDataState"],
|
517
|
+
"formLegacyConfigName": ["observeFormLegacy"],
|
518
|
+
"gridLegacyConfigName": ["observeGridLegacy"]
|
327
519
|
}; }
|
328
520
|
};
|
329
521
|
SnkSimpleCrud.style = snkSimpleCrudCss;
|
@@ -5,17 +5,20 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
5
5
|
const index = require('./index-f9e81701.js');
|
6
6
|
const core = require('@sankhyalabs/core');
|
7
7
|
const AuthorizationConfig = require('./AuthorizationConfig-79ffae4b.js');
|
8
|
-
const taskbarElements = require('./taskbar-elements-
|
8
|
+
const taskbarElements = require('./taskbar-elements-3ecd1278.js');
|
9
9
|
const index$1 = require('./index-0922807b.js');
|
10
10
|
require('./index-102ba62d.js');
|
11
11
|
|
12
|
-
const snkTaskbarCss = ".sc-snk-taskbar-h{display:flex}";
|
12
|
+
const snkTaskbarCss = ".sc-snk-taskbar-h{display:flex;flex-wrap:wrap}.no-wrap.sc-snk-taskbar-h{flex-wrap:nowrap}.full-width.sc-snk-taskbar-h{width:100%}.align-right.sc-snk-taskbar-h{justify-content:flex-end}.overflowed.sc-snk-taskbar{display:none}";
|
13
13
|
|
14
14
|
const SnkTaskbar = class {
|
15
15
|
constructor(hostRef) {
|
16
16
|
index.registerInstance(this, hostRef);
|
17
17
|
this.actionClick = index.createEvent(this, "actionClick", 7);
|
18
18
|
this.TASKBAR_ITEM_ID_PREFIX = 'TASKBAR_ITEM_';
|
19
|
+
this.TASKBAR_CUSTOM_ELEMENTS_CONTAINER_CLASS_NAME = 'taskbar-custom-elements-container';
|
20
|
+
this.ACTIONS_BUTTON_TAG = 'TASKBAR-ACTIONS-BUTTON';
|
21
|
+
this.NOT_OVERFLOW_ELEMENTS = ["moreOptions", "dataExporter_snkDataExporter", "actionsButton_snkActionsButton"];
|
19
22
|
this._titleKeyByElement = {
|
20
23
|
[taskbarElements.TaskbarElement.UPDATE]: "snkTaskbar.titleUpdate",
|
21
24
|
[taskbarElements.TaskbarElement.PREVIOUS]: "snkTaskbar.titlePrevious",
|
@@ -33,11 +36,15 @@ const SnkTaskbar = class {
|
|
33
36
|
[taskbarElements.TaskbarElement.ATTACH]: "snkTaskbar.titleAttach",
|
34
37
|
};
|
35
38
|
this._permissions = undefined;
|
39
|
+
this._overFlowedElements = [];
|
36
40
|
this._customElements = undefined;
|
37
41
|
this._customElementsId = undefined;
|
38
42
|
this._slotContainer = undefined;
|
43
|
+
this._hiddenActionsList = [];
|
44
|
+
this.alignRigth = false;
|
39
45
|
this.customSlotId = "TASKBAR_CUSTOM_ELEMENTS";
|
40
46
|
this.customContainerId = undefined;
|
47
|
+
this.overflowStrategy = 'hiddenItems';
|
41
48
|
this.configName = undefined;
|
42
49
|
this.resourceID = undefined;
|
43
50
|
this.buttons = undefined;
|
@@ -51,6 +58,13 @@ const SnkTaskbar = class {
|
|
51
58
|
}
|
52
59
|
observeButtons() {
|
53
60
|
this._definitions = undefined;
|
61
|
+
requestAnimationFrame(() => {
|
62
|
+
requestAnimationFrame(() => { var _a; return (_a = this._overFlowWatcher) === null || _a === void 0 ? void 0 : _a.forceUpdate(); });
|
63
|
+
});
|
64
|
+
}
|
65
|
+
observeDisabledButtons() {
|
66
|
+
var _a;
|
67
|
+
(_a = this._overFlowWatcher) === null || _a === void 0 ? void 0 : _a.forceUpdate();
|
54
68
|
}
|
55
69
|
// Internal methods
|
56
70
|
elementsFromString(strButtons) {
|
@@ -146,12 +160,19 @@ const SnkTaskbar = class {
|
|
146
160
|
}
|
147
161
|
const taskbarElement = taskbarElements.TaskbarElement[def.toString()];
|
148
162
|
if (taskbarElement) {
|
149
|
-
return taskbarElements.buildElem(def, className, this.getIdElemBtnNative(def), elem => this.getTitle(elem), elem => this.elementClick(elem), elem => this.isEnabled(elem), this.
|
163
|
+
return taskbarElements.buildElem(def, className, this.getIdElemBtnNative(def), elem => this.getTitle(elem), elem => this.elementClick(elem), elem => this.isEnabled(elem), this.buildDynamicActionsList(), this.configName, this.presentationMode);
|
150
164
|
}
|
151
165
|
else {
|
152
166
|
return taskbarElements.buildCustomButton(def, className, this.getIdElemBtnCustom(def), elem => this.elementClick(elem), elem => this.isEnabled(elem));
|
153
167
|
}
|
154
168
|
}
|
169
|
+
buildDynamicActionsList() {
|
170
|
+
var _a;
|
171
|
+
if (this._hiddenActionsList.length) {
|
172
|
+
return [...((_a = this.actionsList) !== null && _a !== void 0 ? _a : []), { type: 'divider', label: "", value: "" }, ...this._hiddenActionsList];
|
173
|
+
}
|
174
|
+
return this.actionsList;
|
175
|
+
}
|
155
176
|
getIdElemBtnNative(taskbarElem) {
|
156
177
|
return core.StringUtils.toCamelCase(taskbarElem);
|
157
178
|
}
|
@@ -192,11 +213,13 @@ const SnkTaskbar = class {
|
|
192
213
|
});
|
193
214
|
}
|
194
215
|
addCustomElementContainer(elem) {
|
216
|
+
var _a;
|
195
217
|
const elementId = `${this.TASKBAR_ITEM_ID_PREFIX}${elem}`;
|
196
218
|
if (!this._customElementsId.includes(elementId)) {
|
197
219
|
this._customElementsId.push(elementId);
|
220
|
+
(_a = this._overFlowWatcher) === null || _a === void 0 ? void 0 : _a.addNotOverFlowElement(elementId);
|
198
221
|
}
|
199
|
-
return index.h("span", { key: elementId, id: elementId });
|
222
|
+
return index.h("span", { class: "ez-padding-left--medium", key: elementId, id: elementId });
|
200
223
|
}
|
201
224
|
getCustomElements() {
|
202
225
|
var _a, _b;
|
@@ -231,15 +254,76 @@ const SnkTaskbar = class {
|
|
231
254
|
}
|
232
255
|
this.validatePresentationMode();
|
233
256
|
}
|
257
|
+
handleOverFlow(overFlowingElements) {
|
258
|
+
const elementsToHandle = overFlowingElements.filter(element => !this.hasToIgnoreOverFlow(element));
|
259
|
+
this.resetOverFlowedElements();
|
260
|
+
this.doOverFlowElements(elementsToHandle);
|
261
|
+
}
|
262
|
+
resetOverFlowedElements() {
|
263
|
+
this._overFlowedElements.forEach(element => {
|
264
|
+
element.classList.remove(core.OVERFLOWED_CLASS_NAME);
|
265
|
+
});
|
266
|
+
this._hiddenActionsList = [];
|
267
|
+
this._overFlowedElements = [];
|
268
|
+
}
|
269
|
+
doOverFlowElements(overFlowedElements) {
|
270
|
+
overFlowedElements.forEach(element => {
|
271
|
+
element.classList.add(core.OVERFLOWED_CLASS_NAME);
|
272
|
+
this._overFlowedElements.push(element);
|
273
|
+
this.addItemToActionList(element);
|
274
|
+
});
|
275
|
+
}
|
276
|
+
addItemToActionList(element) {
|
277
|
+
const taskbarElement = this.getTaskbarElementName(element);
|
278
|
+
if (taskbarElement && this.isEnabled(taskbarElement) && this.isAllowed(taskbarElement)) {
|
279
|
+
const optionItem = {
|
280
|
+
value: taskbarElement,
|
281
|
+
label: this.getTaskbarElementLabel(element),
|
282
|
+
iconName: this.getTaskbarElementIcon(element)
|
283
|
+
};
|
284
|
+
this._hiddenActionsList.push(optionItem);
|
285
|
+
}
|
286
|
+
}
|
287
|
+
getTaskbarElementName(element) {
|
288
|
+
var _a;
|
289
|
+
return (_a = element.getAttribute('data-taskbar-element')) !== null && _a !== void 0 ? _a : "";
|
290
|
+
}
|
291
|
+
getTaskbarElementIcon(element) {
|
292
|
+
var _a;
|
293
|
+
return (_a = element.getAttribute('data-taskbar-icon')) !== null && _a !== void 0 ? _a : "";
|
294
|
+
}
|
295
|
+
getTaskbarElementLabel(element) {
|
296
|
+
var _a;
|
297
|
+
return (_a = element.getAttribute('data-taskbar-label')) !== null && _a !== void 0 ? _a : "";
|
298
|
+
}
|
299
|
+
hasToIgnoreOverFlow(element) {
|
300
|
+
return element.classList.contains(this.TASKBAR_CUSTOM_ELEMENTS_CONTAINER_CLASS_NAME);
|
301
|
+
}
|
302
|
+
handleOverFlowStrategy() {
|
303
|
+
if (this.overflowStrategy === 'hiddenItems') {
|
304
|
+
this._overFlowWatcher = new core.OverflowWatcher(this.buildOverFlowWatcherParams());
|
305
|
+
}
|
306
|
+
}
|
307
|
+
buildOverFlowWatcherParams() {
|
308
|
+
return {
|
309
|
+
element: this._element,
|
310
|
+
callback: this.handleOverFlow.bind(this),
|
311
|
+
overFlowDirection: core.OverflowDirection.HORIZONTAL,
|
312
|
+
notOverFlow: this.NOT_OVERFLOW_ELEMENTS
|
313
|
+
};
|
314
|
+
}
|
234
315
|
componentDidLoad() {
|
235
316
|
const dataInfo = { dataUnit: this.dataUnit };
|
236
317
|
core.ElementIDUtils.addIDInfo(this._element, null, dataInfo);
|
318
|
+
this.handleOverFlowStrategy();
|
237
319
|
}
|
238
320
|
componentDidRender() {
|
239
321
|
this.appendCustomElementsInTaskbar();
|
240
322
|
}
|
241
323
|
disconnectedCallback() {
|
324
|
+
var _a;
|
242
325
|
this.unlinkAllCustomElements();
|
326
|
+
(_a = this._overFlowWatcher) === null || _a === void 0 ? void 0 : _a.destroy();
|
243
327
|
}
|
244
328
|
unlinkAllCustomElements() {
|
245
329
|
var _a;
|
@@ -257,14 +341,9 @@ const SnkTaskbar = class {
|
|
257
341
|
return undefined;
|
258
342
|
}
|
259
343
|
let index$1 = 0;
|
260
|
-
return (index.h(index.Host,
|
261
|
-
var _a;
|
262
|
-
|
263
|
-
index$1 = 0;
|
264
|
-
}
|
265
|
-
else {
|
266
|
-
index$1++;
|
267
|
-
}
|
344
|
+
return (index.h(index.Host, { class: this.getHostClasses() }, this.removeEmpty(this._definitions.map((elem) => {
|
345
|
+
var _a, _b;
|
346
|
+
index$1++;
|
268
347
|
if (taskbarElements.TaskbarElement[elem]) {
|
269
348
|
return this.getElement(index$1, taskbarElements.TaskbarElement[elem]);
|
270
349
|
}
|
@@ -274,12 +353,19 @@ const SnkTaskbar = class {
|
|
274
353
|
if (this._customElements.has(elem)) {
|
275
354
|
return this.addCustomElementContainer(elem);
|
276
355
|
}
|
356
|
+
(_b = this._overFlowWatcher) === null || _b === void 0 ? void 0 : _b.addNotOverFlowElement(elem);
|
277
357
|
return index.h("slot", { name: elem });
|
278
|
-
})), index.h("div", { class:
|
358
|
+
})), index.h("div", { class: this.TASKBAR_CUSTOM_ELEMENTS_CONTAINER_CLASS_NAME }, index.h("slot", { name: this.customSlotId }))));
|
359
|
+
}
|
360
|
+
getHostClasses() {
|
361
|
+
if (this.overflowStrategy !== 'hiddenItems')
|
362
|
+
return 'no-wrap';
|
363
|
+
return `full-width ${this.alignRigth ? 'align-right' : ""}`;
|
279
364
|
}
|
280
365
|
get _element() { return index.getElement(this); }
|
281
366
|
static get watchers() { return {
|
282
|
-
"buttons": ["observeButtons"]
|
367
|
+
"buttons": ["observeButtons"],
|
368
|
+
"disabledButtons": ["observeDisabledButtons"]
|
283
369
|
}; }
|
284
370
|
};
|
285
371
|
SnkTaskbar.style = snkTaskbarCss;
|
@@ -89,31 +89,31 @@ const buildElem = (element, className, dataElementId, getTitle, action, isEnable
|
|
89
89
|
case exports.TaskbarElement.CONFIGURATOR:
|
90
90
|
return iconButton("settings-inverted", element, className, dataElementId, title, action, isEnabled);
|
91
91
|
case exports.TaskbarElement.MORE_OPTIONS:
|
92
|
-
return actionButton(element, dataElementId, title, isEnabled, actions, action);
|
92
|
+
return actionButton(element, className, dataElementId, title, isEnabled, actions, action);
|
93
93
|
case exports.TaskbarElement.DIVIDER:
|
94
|
-
return index.h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin-
|
94
|
+
return index.h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin--none ez-margin-left--medium", "data-taskbar-divider": true });
|
95
95
|
case exports.TaskbarElement.DATA_EXPORTER:
|
96
96
|
const provider = (_a = index$1.store.get("exporterProviders")) === null || _a === void 0 ? void 0 : _a[configName];
|
97
|
-
return index.h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId });
|
97
|
+
return index.h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId, "data-taskbar-element": element });
|
98
98
|
case exports.TaskbarElement.ATTACH:
|
99
99
|
return iconButton("anexo", element, className, dataElementId, title, action, isEnabled);
|
100
100
|
case exports.TaskbarElement.ACTIONS_BUTTON:
|
101
|
-
return index.h("snk-actions-button", { "data-element-id": dataElementId });
|
101
|
+
return index.h("snk-actions-button", { "data-element-id": dataElementId, "data-taskbar-element": element });
|
102
102
|
}
|
103
103
|
};
|
104
104
|
function textButton(name, className, dataElementId, text, title, action, isEnabled) {
|
105
|
-
return index.h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) });
|
105
|
+
return index.h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-taskbar-label": text, "data-taskbar-element": name, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) });
|
106
106
|
}
|
107
107
|
function iconButton(iconName, name, className, dataElementId, title, action, isEnabled) {
|
108
|
-
return index.h("ez-button", { key: dataElementId, title: title, mode: "icon", size: "small", class: className, "data-element-id": dataElementId, iconName: iconName, enabled: isEnabled(name), onClick: () => action(name) });
|
108
|
+
return index.h("ez-button", { key: dataElementId, title: title, mode: "icon", size: "small", class: className, "data-taskbar-label": title, "data-taskbar-element": name, "data-taskbar-icon": iconName, "data-element-id": dataElementId, iconName: iconName, enabled: isEnabled(name), onClick: () => action(name) });
|
109
109
|
}
|
110
110
|
function iconTextButton(iconName, name, className, dataElementId, text, title, action, isEnabled) {
|
111
|
-
return index.h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) },
|
111
|
+
return index.h("ez-button", { key: dataElementId, title: title, label: text, size: "small", class: className, "data-taskbar-label": text, "data-taskbar-icon": iconName, "data-taskbar-element": name, "data-element-id": dataElementId, enabled: isEnabled(name), onClick: () => action(name) },
|
112
112
|
index.h("ez-icon", { class: "ez-padding-right--small", slot: "leftIcon", iconName: iconName }));
|
113
113
|
}
|
114
|
-
function actionButton(element, dataElementId, title, isEnabled, actions, action) {
|
114
|
+
function actionButton(element, className, dataElementId, title, isEnabled, actions, action) {
|
115
115
|
return actions && actions.length > 0
|
116
|
-
? index.h("taskbar-actions-button", { key: dataElementId, title: title, "data-element-id": dataElementId, enabled: isEnabled(element), actions: actions, onTaskbarActionSelected: (evt) => action(evt.detail.value) })
|
116
|
+
? index.h("taskbar-actions-button", { class: className, key: dataElementId, title: title, "data-taskbar-element": element, "data-element-id": dataElementId, enabled: isEnabled(element), actions: actions, onTaskbarActionSelected: (evt) => action(evt.detail.value) })
|
117
117
|
: undefined;
|
118
118
|
}
|
119
119
|
|
@@ -6,7 +6,6 @@
|
|
6
6
|
"./components/snk-taskbar/snk-taskbar.js",
|
7
7
|
"./components/snk-filter-bar/filter-list/snk-filter-list.js",
|
8
8
|
"./components/snk-print-selector/snk-print-selector.js",
|
9
|
-
"./components/snk-form/subcomponents/snk-tab-config/snk-tab-config.js",
|
10
9
|
"./components/snk-actions-button/snk-actions-button.js",
|
11
10
|
"./components/snk-actions-button/subcomponents/snk-actions-form.js",
|
12
11
|
"./components/snk-actions-button/subcomponents/snk-client-confirm.js",
|
@@ -35,12 +34,13 @@
|
|
35
34
|
"./components/snk-filter-bar/filter-modal/subcomponents/snk-filter-modal-item.js",
|
36
35
|
"./components/snk-filter-field-search/snk-filter-field-search.js",
|
37
36
|
"./components/snk-form/snk-form.js",
|
38
|
-
"./components/snk-form/subcomponents/snk-config
|
39
|
-
"./components/snk-form
|
40
|
-
"./components/snk-form/subcomponents/snk-
|
37
|
+
"./components/snk-form-config/subcomponents/snk-tab-config/snk-tab-config.js",
|
38
|
+
"./components/snk-form-config/snk-form-config.js",
|
39
|
+
"./components/snk-form-config/subcomponents/snk-config-options/snk-config-options.js",
|
40
|
+
"./components/snk-form-config/subcomponents/snk-field-config/snk-field-config.js",
|
41
41
|
"./components/snk-grid/snk-grid.js",
|
42
|
-
"./components/snk-grid
|
43
|
-
"./components/snk-grid/
|
42
|
+
"./components/snk-grid-config/snk-grid-config.js",
|
43
|
+
"./components/snk-grid-config/snk-select-box/snk-select-box.js",
|
44
44
|
"./components/snk-personalized-filter/snk-personalized-filter.js",
|
45
45
|
"./components/snk-personalized-filter/subcomponents/snk-expression-group/snk-expression-group.js",
|
46
46
|
"./components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.js",
|