@sankhyalabs/sankhyablocks 10.1.0-dev.4 → 10.1.0-dev.41
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-b29e31be.js → ConfigStorage-a1fab5ca.js} +19 -2
- package/dist/cjs/ContinuousInsertUtils-1ae0c6ac.js +41 -0
- package/dist/cjs/{DataFetcher-ed9d97ea.js → DataFetcher-384d2ce8.js} +2 -2733
- package/dist/cjs/{FormConfigHelper-ebb77625.js → FormConfigHelper-28fe4668.js} +44 -0
- package/dist/cjs/{ISave-81eb2fbc.js → ISave-ecbe9336.js} +1 -1
- package/dist/cjs/ImageUtils-c46f2d11.js +142 -0
- package/dist/cjs/{PersonalizedFilterUtils-7259cf65.js → PersonalizedFilterUtils-eccb267a.js} +13 -0
- package/dist/cjs/{SnkFormConfigManager-6838389c.js → SnkFormConfigManager-44386305.js} +7 -7
- package/dist/cjs/SnkMessageBuilder-a9300ebe.js +2833 -0
- package/dist/cjs/{SnkMultiSelectionListDataSource-1e804147.js → SnkMultiSelectionListDataSource-b951ed91.js} +61 -47
- package/dist/cjs/{auth-fetcher-cc28d847.js → auth-fetcher-6b134ec4.js} +1 -1
- package/dist/cjs/config-header.cjs.entry.js +1 -1
- package/dist/cjs/configs-button.cjs.entry.js +1 -1
- package/dist/cjs/css-shim-a27d231b.js +6 -0
- package/dist/cjs/{dataunit-fetcher-ab1cc071.js → dataunit-fetcher-93f53260.js} +26 -3
- package/dist/cjs/dom-ff96a4bc.js +75 -0
- package/dist/cjs/field-config_2.cjs.entry.js +3 -3
- package/dist/cjs/fields-layout.cjs.entry.js +8 -5
- package/dist/cjs/fields-selector.cjs.entry.js +3 -3
- package/dist/cjs/{form-config-fetcher-f0897eb5.js → form-config-fetcher-45d1964c.js} +19 -1
- package/dist/cjs/guides-configurator.cjs.entry.js +6 -4
- package/dist/cjs/{index-1cf293c1.js → index-1894343a.js} +1529 -177
- package/dist/cjs/{index-13d05f03.js → index-f0fe7e6e.js} +90 -21
- package/dist/cjs/loader.cjs.js +16 -2
- package/dist/cjs/pesquisa-grid_2.cjs.entry.js +6 -5
- package/dist/cjs/sankhyablocks.cjs.js +132 -4
- package/dist/cjs/shadow-css-7e3e0ab1.js +389 -0
- package/dist/cjs/snk-actions-button_9.cjs.entry.js +160 -113
- package/dist/cjs/snk-actions-form.cjs.entry.js +1 -1
- package/dist/cjs/snk-application.cjs.entry.js +29 -9
- package/dist/cjs/snk-attach.cjs.entry.js +53 -26
- package/dist/cjs/snk-client-confirm.cjs.entry.js +1 -1
- package/dist/cjs/snk-configurator.cjs.entry.js +1 -1
- package/dist/cjs/snk-crud.cjs.entry.js +351 -108
- package/dist/cjs/snk-custom-slot-elements.cjs.entry.js +1 -1
- package/dist/cjs/snk-custom-slot-guide.cjs.entry.js +40 -0
- package/dist/cjs/snk-data-exporter.cjs.entry.js +9 -7
- package/dist/cjs/{snk-data-unit-68992932.js → snk-data-unit-6abc5efc.js} +21 -12
- package/dist/cjs/snk-data-unit.cjs.entry.js +5 -4
- package/dist/cjs/snk-default-filter.cjs.entry.js +1 -1
- package/dist/cjs/snk-detail-view.cjs.entry.js +19 -20
- package/dist/cjs/snk-entity-list.cjs.entry.js +1 -1
- package/dist/cjs/snk-entity-search.cjs.entry.js +211 -0
- package/dist/cjs/snk-exporter-email-sender.cjs.entry.js +2 -2
- package/dist/cjs/snk-expression-group_2.cjs.entry.js +2 -2
- package/dist/cjs/{snk-filter-advanced-mode_2.cjs.entry.js → snk-filter-advanced-mode_3.cjs.entry.js} +41 -3
- package/dist/cjs/snk-filter-bar_4.cjs.entry.js +147 -94
- package/dist/cjs/snk-filter-binary-select.cjs.entry.js +1 -1
- package/dist/cjs/snk-filter-checkbox-list.cjs.entry.js +1 -1
- package/dist/cjs/snk-filter-detail.cjs.entry.js +3 -3
- package/dist/cjs/snk-filter-field-search_2.cjs.entry.js +2 -2
- package/dist/cjs/snk-filter-modal-item.cjs.entry.js +5 -4
- package/dist/cjs/snk-filter-multi-select.cjs.entry.js +1 -1
- package/dist/cjs/snk-filter-number.cjs.entry.js +11 -7
- package/dist/cjs/snk-filter-period.cjs.entry.js +14 -7
- package/dist/cjs/snk-filter-search.cjs.entry.js +1 -1
- package/dist/cjs/snk-filter-text.cjs.entry.js +2 -2
- package/dist/cjs/snk-form-summary.cjs.entry.js +1 -1
- package/dist/cjs/snk-form-view.cjs.entry.js +70 -8
- package/dist/cjs/snk-form_2.cjs.entry.js +34 -10
- package/dist/cjs/snk-grid.cjs.entry.js +63 -30
- package/dist/cjs/{snk-guides-viewer-8b841753.js → snk-guides-viewer-b4ca3437.js} +114 -188
- package/dist/cjs/snk-guides-viewer.cjs.entry.js +11 -18
- package/dist/cjs/snk-image-input.cjs.entry.js +148 -0
- package/dist/cjs/snk-layout-form-config.cjs.entry.js +72 -0
- package/dist/cjs/snk-personalized-filter-editor.cjs.entry.js +1 -1
- package/dist/cjs/snk-personalized-filter.cjs.entry.js +8 -7
- package/dist/cjs/snk-pesquisa.cjs.entry.js +6 -6
- package/dist/cjs/snk-print-selector.cjs.entry.js +1 -1
- package/dist/cjs/snk-simple-crud.cjs.entry.js +30 -35
- package/dist/cjs/snk-taskbar.cjs.entry.js +237 -168
- package/dist/cjs/{sortable.esm-9a110bb7.js → sortable.esm-b87669ab.js} +76 -90
- package/dist/cjs/taskbar-elements-80eddec8.js +152 -0
- package/dist/cjs/teste-pesquisa.cjs.entry.js +1 -1
- package/dist/collection/collection-manifest.json +10 -1
- package/dist/collection/components/snk-actions-button/snk-actions-button.js +27 -3
- package/dist/collection/components/snk-application/errorhandler/snk-error-handler.js +1 -0
- package/dist/collection/components/snk-application/snk-application.js +20 -2
- package/dist/collection/components/snk-attach/snk-attach.css +29 -7
- package/dist/collection/components/snk-attach/snk-attach.js +82 -19
- package/dist/collection/components/snk-crud/snk-crud.css +46 -0
- package/dist/collection/components/snk-crud/snk-crud.js +190 -96
- package/dist/collection/components/snk-crud/subcomponents/GuideBuilder.js +1 -1
- package/dist/collection/components/snk-crud/subcomponents/snk-detail-view/snk-detail-view.js +5 -5
- package/dist/collection/components/snk-crud/subcomponents/snk-entity-search.css +17 -0
- package/dist/collection/components/snk-crud/subcomponents/snk-entity-search.js +330 -0
- package/dist/collection/components/snk-crud/subcomponents/snk-form-view.js +90 -8
- package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.css +22 -8
- package/dist/collection/components/snk-crud/subcomponents/snk-guides-viewer.js +165 -179
- package/dist/collection/components/snk-crud/utils/taskbarUtils.js +144 -0
- package/dist/collection/components/snk-custom-slot-guide/snk-custom-slot-guide.css +3 -0
- package/dist/collection/components/snk-custom-slot-guide/snk-custom-slot-guide.js +95 -0
- package/dist/collection/components/snk-data-exporter/exporter-email-sender/snk-exporter-email-sender.js +1 -1
- package/dist/collection/components/snk-data-exporter/snk-data-exporter.js +20 -1
- package/dist/collection/components/snk-data-unit/snk-data-unit.js +9 -0
- package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-number.js +13 -9
- package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-period.js +14 -7
- package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-text.js +1 -1
- package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-detail.js +1 -1
- package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-item.css +5 -1
- package/dist/collection/components/snk-filter-bar/filter-item/snk-filter-item.js +28 -2
- package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.css +7 -1
- package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.js +22 -8
- package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +1 -6
- package/dist/collection/components/snk-filter-bar/snk-filter-bar.js +166 -78
- package/dist/collection/components/snk-form-config/FormConfigHelper.js +42 -0
- package/dist/collection/components/snk-form-config/SnkFormConfigManager.js +6 -6
- package/dist/collection/components/snk-form-config/field-item/field-config/field-config.css +1 -0
- package/dist/collection/components/snk-form-config/fields-layout/fields-layout.css +16 -0
- package/dist/collection/components/snk-form-config/fields-layout/fields-layout.js +6 -3
- package/dist/collection/components/snk-form-config/guides-configurator/guides-configurator.css +3 -4
- package/dist/collection/components/snk-form-config/guides-configurator/guides-configurator.js +5 -3
- package/dist/collection/components/snk-form-config/snk-form-config.js +53 -6
- package/dist/collection/components/snk-grid/snk-grid.css +24 -3
- package/dist/collection/components/snk-grid/snk-grid.js +170 -18
- package/dist/collection/components/snk-grid-config/snk-grid-config.js +153 -51
- package/dist/collection/components/snk-image-input/snk-image-input.css +3 -0
- package/dist/collection/components/snk-image-input/snk-image-input.js +326 -0
- package/dist/collection/components/snk-image-input/utils/ImageUtils.js +133 -0
- package/dist/collection/components/snk-layout-form-config/snk-layout-form-config.js +1 -1
- package/dist/collection/components/snk-layout-form-config/snk-view-representation/snk-view-representation.js +1 -1
- package/dist/collection/components/snk-personalized-filter/snk-personalized-filter.js +1 -1
- package/dist/collection/components/snk-personalized-filter/subcomponents/snk-filter-param-config/utils/PersonalizedFilterUtils.js +13 -0
- package/dist/collection/components/snk-pesquisa/snk-pesquisa.js +0 -4
- package/dist/collection/components/snk-simple-crud/snk-simple-crud.js +35 -23
- package/dist/collection/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.css +8 -0
- package/dist/collection/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.js +38 -2
- package/dist/collection/components/snk-taskbar/elements/taskbar-elements.js +54 -37
- package/dist/collection/components/snk-taskbar/elements/taskbar-split-button/taskbar-split-button.js +27 -1
- package/dist/collection/components/snk-taskbar/processor/simple-taskbar-processor.js +55 -0
- package/dist/collection/components/snk-taskbar/snk-taskbar.css +44 -1
- package/dist/collection/components/snk-taskbar/snk-taskbar.js +304 -174
- package/dist/collection/components/snk-taskbar/subcomponents/snk-taskbar-skeleton.css +12 -0
- package/dist/collection/components/snk-taskbar/subcomponents/snk-taskbar-skeleton.js +19 -0
- package/dist/collection/lib/configs/ConfigStorage.js +5 -0
- package/dist/collection/lib/http/data-fetcher/fetchers/data-unit/dataunit-fetcher.js +24 -2
- package/dist/collection/lib/http/data-fetcher/fetchers/grid-config-fetcher.js +12 -0
- package/dist/collection/lib/http/data-fetcher/fetchers/resource-fetcher.js +18 -0
- package/dist/collection/lib/message/SnkMessageBuilder.js +11 -2
- package/dist/collection/lib/message/messageResourceEnUSUtils.js +2 -0
- package/dist/collection/lib/message/messageResourceEsESUtils.js +2 -0
- package/dist/collection/lib/message/messageResourcePtBRUtils.js +2 -0
- package/dist/collection/lib/message/resources/en-us/snk-crud.msg.js +9 -1
- package/dist/collection/lib/message/resources/en-us/snk-form.msg.js +7 -0
- package/dist/collection/lib/message/resources/en-us/snk-image-input.msg.js +11 -0
- package/dist/collection/lib/message/resources/en-us/snk-layout-form-config.msg.js +10 -2
- package/dist/collection/lib/message/resources/es-es/snk-crud.msg.js +9 -1
- package/dist/collection/lib/message/resources/es-es/snk-form.msg.js +7 -0
- package/dist/collection/lib/message/resources/es-es/snk-image-input.msg.js +11 -0
- package/dist/collection/lib/message/resources/es-es/snk-layout-form-config.msg.js +8 -0
- package/dist/collection/lib/message/resources/pt-br/snk-configurator.msg.js +1 -1
- package/dist/collection/lib/message/resources/pt-br/snk-crud.msg.js +9 -1
- package/dist/collection/lib/message/resources/pt-br/snk-form.msg.js +8 -1
- package/dist/collection/lib/message/resources/pt-br/snk-image-input.msg.js +11 -0
- package/dist/collection/lib/message/resources/pt-br/snk-layout-form-config.msg.js +10 -2
- package/dist/components/ConfigStorage.js +17 -0
- package/dist/components/ContinuousInsertUtils.js +1 -1
- package/dist/components/DataFetcher.js +3 -2713
- package/dist/components/PersonalizedFilterUtils.js +13 -0
- package/dist/components/SnkFormConfigManager.js +6 -6
- package/dist/components/SnkMessageBuilder.js +2831 -0
- package/dist/components/dataunit-fetcher.js +25 -2
- package/dist/components/field-config2.js +44 -2
- package/dist/components/fields-layout2.js +6 -3
- package/dist/components/form-config-fetcher.js +18 -0
- package/dist/components/guides-configurator2.js +5 -3
- package/dist/components/index.d.ts +4 -0
- package/dist/components/index.js +4 -0
- package/dist/components/index2.js +90 -21
- package/dist/components/snk-actions-button2.js +6 -3
- package/dist/components/snk-application2.js +22 -2
- package/dist/components/snk-attach2.js +59 -29
- package/dist/components/snk-crud.js +435 -174
- package/dist/components/snk-custom-slot-guide.d.ts +11 -0
- package/dist/components/snk-custom-slot-guide.js +55 -0
- package/dist/components/snk-data-exporter2.js +3 -1
- package/dist/components/snk-data-unit2.js +10 -1
- package/dist/components/snk-detail-view2.js +250 -292
- package/dist/components/snk-entity-search.d.ts +11 -0
- package/dist/components/snk-entity-search.js +6 -0
- package/dist/components/snk-entity-search2.js +231 -0
- package/dist/components/snk-exporter-email-sender2.js +1 -1
- package/dist/components/snk-filter-bar2.js +116 -80
- package/dist/components/snk-filter-detail2.js +1 -1
- package/dist/components/snk-filter-item2.js +9 -3
- package/dist/components/snk-filter-modal2.js +22 -9
- package/dist/components/snk-filter-number.js +12 -8
- package/dist/components/snk-filter-period.js +13 -6
- package/dist/components/snk-filter-text.js +1 -1
- package/dist/components/snk-form-config2.js +29 -5
- package/dist/components/snk-form-view2.js +79 -10
- package/dist/components/snk-grid-config2.js +109 -50
- package/dist/components/snk-grid2.js +103 -59
- package/dist/components/snk-image-input.d.ts +11 -0
- package/dist/components/snk-image-input.js +6 -0
- package/dist/components/snk-image-input2.js +302 -0
- package/dist/components/snk-layout-form-config2.js +1 -1
- package/dist/components/snk-personalized-filter2.js +1 -1
- package/dist/components/snk-pesquisa2.js +0 -1
- package/dist/components/snk-simple-crud2.js +47 -46
- package/dist/components/snk-taskbar-skeleton.d.ts +11 -0
- package/dist/components/snk-taskbar-skeleton.js +6 -0
- package/dist/components/snk-taskbar-skeleton2.js +29 -0
- package/dist/components/snk-taskbar2.js +310 -218
- package/dist/components/snk-view-representation2.js +1 -1
- package/dist/components/sortable.esm.js +76 -90
- package/dist/components/taskbar-actions-button2.js +21 -2
- package/dist/components/taskbar-split-button2.js +10 -1
- package/dist/esm/{ConfigStorage-13d80e36.js → ConfigStorage-76872695.js} +19 -2
- package/dist/esm/ContinuousInsertUtils-bce77dc1.js +39 -0
- package/dist/esm/{DataFetcher-f4ccd9f3.js → DataFetcher-e60f8d53.js} +3 -2713
- package/dist/esm/{FormConfigHelper-4e42f0b6.js → FormConfigHelper-d09669f3.js} +43 -1
- package/dist/esm/{ISave-288fa9df.js → ISave-4929c071.js} +1 -1
- package/dist/esm/ImageUtils-7f3a4149.js +136 -0
- package/dist/esm/{PersonalizedFilterUtils-2db38ff2.js → PersonalizedFilterUtils-d2439a9a.js} +13 -0
- package/dist/esm/{SnkFormConfigManager-3ee2937b.js → SnkFormConfigManager-83f6b22f.js} +7 -7
- package/dist/esm/SnkMessageBuilder-1eb7a1af.js +2831 -0
- package/dist/esm/{SnkMultiSelectionListDataSource-5d3a93f2.js → SnkMultiSelectionListDataSource-7fe25a58.js} +55 -41
- package/dist/esm/{auth-fetcher-59ab0c67.js → auth-fetcher-1a31c1e4.js} +1 -1
- package/dist/esm/config-header.entry.js +1 -1
- package/dist/esm/configs-button.entry.js +1 -1
- package/dist/esm/css-shim-9f2d321e.js +4 -0
- package/dist/esm/{dataunit-fetcher-c4f9f222.js → dataunit-fetcher-050b6d31.js} +25 -2
- package/dist/esm/dom-64053c71.js +73 -0
- package/dist/esm/field-config_2.entry.js +3 -3
- package/dist/esm/fields-layout.entry.js +8 -5
- package/dist/esm/fields-selector.entry.js +3 -3
- package/dist/esm/{form-config-fetcher-6a00fe9e.js → form-config-fetcher-b44b2727.js} +19 -1
- package/dist/esm/guides-configurator.entry.js +6 -4
- package/dist/esm/{index-479e1293.js → index-04f73a26.js} +1521 -177
- package/dist/esm/{index-446f9341.js → index-ea250be6.js} +90 -21
- package/dist/esm/loader.js +17 -3
- package/dist/esm/pesquisa-grid_2.entry.js +6 -5
- package/dist/esm/sankhyablocks.js +133 -5
- package/dist/esm/shadow-css-98135883.js +387 -0
- package/dist/esm/snk-actions-button_9.entry.js +161 -114
- package/dist/esm/snk-actions-form.entry.js +1 -1
- package/dist/esm/snk-application.entry.js +28 -8
- package/dist/esm/snk-attach.entry.js +52 -25
- package/dist/esm/snk-client-confirm.entry.js +1 -1
- package/dist/esm/snk-configurator.entry.js +1 -1
- package/dist/esm/snk-crud.entry.js +343 -100
- package/dist/esm/snk-custom-slot-elements.entry.js +1 -1
- package/dist/esm/snk-custom-slot-guide.entry.js +36 -0
- package/dist/esm/snk-data-exporter.entry.js +9 -7
- package/dist/esm/{snk-data-unit-0edeb967.js → snk-data-unit-ca2c9858.js} +12 -3
- package/dist/esm/snk-data-unit.entry.js +5 -4
- package/dist/esm/snk-default-filter.entry.js +1 -1
- package/dist/esm/snk-detail-view.entry.js +17 -18
- package/dist/esm/snk-entity-list.entry.js +1 -1
- package/dist/esm/snk-entity-search.entry.js +207 -0
- package/dist/esm/snk-exporter-email-sender.entry.js +2 -2
- package/dist/esm/snk-expression-group_2.entry.js +2 -2
- package/dist/esm/{snk-filter-advanced-mode_2.entry.js → snk-filter-advanced-mode_3.entry.js} +41 -4
- package/dist/esm/snk-filter-bar_4.entry.js +148 -95
- package/dist/esm/snk-filter-binary-select.entry.js +1 -1
- package/dist/esm/snk-filter-checkbox-list.entry.js +1 -1
- package/dist/esm/snk-filter-detail.entry.js +3 -3
- package/dist/esm/snk-filter-field-search_2.entry.js +2 -2
- package/dist/esm/snk-filter-modal-item.entry.js +5 -4
- package/dist/esm/snk-filter-multi-select.entry.js +1 -1
- package/dist/esm/snk-filter-number.entry.js +11 -7
- package/dist/esm/snk-filter-period.entry.js +14 -7
- package/dist/esm/snk-filter-search.entry.js +1 -1
- package/dist/esm/snk-filter-text.entry.js +2 -2
- package/dist/esm/snk-form-summary.entry.js +1 -1
- package/dist/esm/snk-form-view.entry.js +71 -9
- package/dist/esm/snk-form_2.entry.js +34 -10
- package/dist/esm/snk-grid.entry.js +60 -27
- package/dist/esm/{snk-guides-viewer-9cd4d20f.js → snk-guides-viewer-cc37535b.js} +115 -189
- package/dist/esm/snk-guides-viewer.entry.js +11 -18
- package/dist/esm/snk-image-input.entry.js +144 -0
- package/dist/esm/snk-layout-form-config.entry.js +68 -0
- package/dist/esm/snk-personalized-filter-editor.entry.js +1 -1
- package/dist/esm/snk-personalized-filter.entry.js +8 -7
- package/dist/esm/snk-pesquisa.entry.js +6 -6
- package/dist/esm/snk-print-selector.entry.js +1 -1
- package/dist/esm/snk-simple-crud.entry.js +28 -33
- package/dist/esm/snk-taskbar.entry.js +238 -169
- package/dist/esm/{sortable.esm-842f85a3.js → sortable.esm-bc277c12.js} +76 -90
- package/dist/esm/taskbar-elements-63651ca7.js +149 -0
- package/dist/esm/teste-pesquisa.entry.js +1 -1
- package/dist/sankhyablocks/p-09ba6bd4.js +1 -0
- package/dist/sankhyablocks/{p-7f7fe6c4.entry.js → p-0a160fb5.entry.js} +1 -1
- package/dist/sankhyablocks/p-10f27dc6.entry.js +1 -0
- package/dist/sankhyablocks/{p-162bddae.entry.js → p-175c9576.entry.js} +1 -1
- package/dist/sankhyablocks/p-20af4b6a.entry.js +1 -0
- package/dist/sankhyablocks/p-251aee41.entry.js +11 -0
- package/dist/sankhyablocks/{p-c4fcf1fb.entry.js → p-27e0cd68.entry.js} +1 -1
- package/dist/sankhyablocks/p-2af815bb.entry.js +1 -0
- package/dist/sankhyablocks/p-2af8aca3.js +1 -0
- package/dist/sankhyablocks/p-2b3c284c.entry.js +1 -0
- package/dist/sankhyablocks/p-2c9d0870.js +2 -0
- package/dist/sankhyablocks/{p-cb4343c4.entry.js → p-2cc2526e.entry.js} +1 -1
- package/dist/sankhyablocks/{p-75af335e.entry.js → p-2ebda226.entry.js} +1 -1
- package/dist/sankhyablocks/p-3072136e.js +1 -0
- package/dist/sankhyablocks/p-33492640.entry.js +1 -0
- package/dist/sankhyablocks/p-35317d9a.entry.js +1 -0
- package/dist/sankhyablocks/{p-1c2971e4.js → p-3704bf1b.js} +1 -1
- package/dist/sankhyablocks/p-3870748a.js +28 -0
- package/dist/sankhyablocks/p-3a35917e.entry.js +1 -0
- package/dist/sankhyablocks/{p-78ff8734.js → p-3c990841.js} +2 -2
- package/dist/sankhyablocks/p-420b39b5.js +1 -0
- package/dist/sankhyablocks/{p-49ddc27a.entry.js → p-438a225f.entry.js} +1 -1
- package/dist/sankhyablocks/p-46f75667.entry.js +1 -0
- package/dist/sankhyablocks/{p-53599b26.js → p-4f7adf97.js} +2 -2
- package/dist/sankhyablocks/p-554c0e54.js +1 -0
- package/dist/sankhyablocks/{p-27482793.entry.js → p-5aae5c74.entry.js} +1 -1
- package/dist/sankhyablocks/p-68c1a093.js +1 -0
- package/dist/sankhyablocks/p-6ae7543b.entry.js +1 -0
- package/dist/sankhyablocks/{p-825098c1.entry.js → p-752c57f4.entry.js} +1 -1
- package/dist/sankhyablocks/{p-e258de96.entry.js → p-76729994.entry.js} +1 -1
- package/dist/sankhyablocks/p-771b137e.js +1 -0
- package/dist/sankhyablocks/p-77f608bc.entry.js +1 -0
- package/dist/sankhyablocks/p-7c8bf699.entry.js +1 -0
- package/dist/sankhyablocks/p-855ccf64.entry.js +1 -0
- package/dist/sankhyablocks/p-8a8900a9.entry.js +1 -0
- package/dist/sankhyablocks/p-8b4d6719.js +1 -0
- package/dist/sankhyablocks/{p-3d41f5a8.entry.js → p-8d946600.entry.js} +1 -1
- package/dist/sankhyablocks/{p-96d45943.entry.js → p-90ae6c2e.entry.js} +1 -1
- package/dist/sankhyablocks/p-95af0bb1.entry.js +1 -0
- package/dist/sankhyablocks/{p-7b3ca294.entry.js → p-9742ea0e.entry.js} +1 -1
- package/dist/sankhyablocks/p-98241c21.entry.js +1 -0
- package/dist/sankhyablocks/{p-2fdac5e6.entry.js → p-9e109f5e.entry.js} +1 -1
- package/dist/sankhyablocks/p-9e7dc97d.entry.js +1 -0
- package/dist/sankhyablocks/p-a2a9f520.entry.js +1 -0
- package/dist/sankhyablocks/p-a46ac091.js +1 -0
- package/dist/sankhyablocks/p-a73b6b00.js +1 -0
- package/dist/sankhyablocks/p-ab12f544.entry.js +1 -0
- package/dist/sankhyablocks/p-ab5e12fa.js +1 -0
- package/dist/sankhyablocks/p-ac384a1e.entry.js +1 -0
- package/dist/sankhyablocks/{p-180716b2.entry.js → p-ae326d06.entry.js} +1 -1
- package/dist/sankhyablocks/p-aff2d081.entry.js +1 -0
- package/dist/sankhyablocks/p-b3b51693.entry.js +1 -0
- package/dist/sankhyablocks/p-b555ce38.entry.js +1 -0
- package/dist/sankhyablocks/p-bab4cde4.entry.js +1 -0
- package/dist/sankhyablocks/p-c3ec6642.js +19 -0
- package/dist/sankhyablocks/p-cbb8e351.js +7 -0
- package/dist/sankhyablocks/{p-c3dbf441.entry.js → p-cc64239c.entry.js} +1 -1
- package/dist/sankhyablocks/{p-471b34f4.entry.js → p-cd00a3d1.entry.js} +1 -1
- package/dist/sankhyablocks/p-ce3b284c.entry.js +1 -0
- package/dist/sankhyablocks/p-ce8ccd72.entry.js +1 -0
- package/dist/sankhyablocks/{p-4c763b10.entry.js → p-d657f71f.entry.js} +1 -1
- package/dist/sankhyablocks/p-d972a9c1.js +60 -0
- package/dist/sankhyablocks/p-da455c82.js +12 -0
- package/dist/sankhyablocks/p-e5a3711f.js +1 -0
- package/dist/sankhyablocks/{p-9a63f3f7.entry.js → p-e737fd5a.entry.js} +1 -1
- package/dist/sankhyablocks/p-ee56dda6.entry.js +1 -0
- package/dist/sankhyablocks/p-ef9343c3.entry.js +1 -0
- package/dist/sankhyablocks/p-efd18bc2.entry.js +1 -0
- package/dist/sankhyablocks/{p-667cab42.entry.js → p-f152ef98.entry.js} +1 -1
- package/dist/sankhyablocks/p-f185d5ad.js +1 -0
- package/dist/sankhyablocks/{p-7e250432.entry.js → p-f7170e10.entry.js} +1 -1
- package/dist/sankhyablocks/{p-7345782c.entry.js → p-f921270b.entry.js} +1 -1
- package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
- package/dist/types/components/snk-actions-button/snk-actions-button.d.ts +4 -0
- package/dist/types/components/snk-application/snk-application.d.ts +1 -1
- package/dist/types/components/snk-attach/snk-attach.d.ts +20 -4
- package/dist/types/components/snk-crud/snk-crud.d.ts +37 -9
- 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-entity-search.d.ts +62 -0
- package/dist/types/components/snk-crud/subcomponents/snk-form-view.d.ts +12 -0
- package/dist/types/components/snk-crud/subcomponents/snk-guides-viewer.d.ts +28 -18
- package/dist/types/components/snk-crud/utils/taskbarUtils.d.ts +13 -0
- package/dist/types/components/snk-custom-slot-guide/snk-custom-slot-guide.d.ts +16 -0
- package/dist/types/components/snk-data-exporter/snk-data-exporter.d.ts +4 -0
- package/dist/types/components/snk-data-unit/snk-data-unit.d.ts +1 -0
- package/dist/types/components/snk-filter-bar/filter-item/editors/snk-filter-number.d.ts +1 -1
- package/dist/types/components/snk-filter-bar/filter-item/editors/snk-filter-period.d.ts +1 -0
- package/dist/types/components/snk-filter-bar/filter-item/snk-filter-item.d.ts +5 -1
- package/dist/types/components/snk-filter-bar/filter-modal/snk-filter-modal.d.ts +2 -1
- package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +33 -16
- package/dist/types/components/snk-form-config/FormConfigHelper.d.ts +6 -1
- package/dist/types/components/snk-form-config/SnkFormConfigManager.d.ts +1 -1
- package/dist/types/components/snk-form-config/fields-layout/fields-layout.d.ts +2 -2
- package/dist/types/components/snk-form-config/guides-configurator/guides-configurator.d.ts +1 -1
- package/dist/types/components/snk-form-config/snk-form-config.d.ts +9 -2
- package/dist/types/components/snk-grid/snk-grid.d.ts +29 -1
- package/dist/types/components/snk-grid-config/snk-grid-config.d.ts +11 -0
- package/dist/types/components/snk-image-input/snk-image-input.d.ts +56 -0
- package/dist/types/components/snk-image-input/utils/ImageUtils.d.ts +15 -0
- package/dist/types/components/snk-personalized-filter/interfaces/IParameter.d.ts +1 -0
- package/dist/types/components/snk-pesquisa/snk-pesquisa.d.ts +0 -1
- package/dist/types/components/snk-simple-crud/snk-simple-crud.d.ts +4 -1
- package/dist/types/components/snk-taskbar/elements/taskbar-actions-button/taskbar-actions-button.d.ts +6 -0
- package/dist/types/components/snk-taskbar/elements/taskbar-elements.d.ts +29 -2
- package/dist/types/components/snk-taskbar/elements/taskbar-split-button/taskbar-split-button.d.ts +5 -0
- package/dist/types/components/snk-taskbar/processor/simple-taskbar-processor.d.ts +31 -0
- package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +37 -23
- package/dist/types/components/snk-taskbar/subcomponents/snk-taskbar-skeleton.d.ts +3 -0
- package/dist/types/components.d.ts +377 -5
- package/dist/types/lib/configs/ConfigStorage.d.ts +1 -0
- package/dist/types/lib/http/data-fetcher/fetchers/data-unit/dataunit-fetcher.d.ts +2 -1
- package/dist/types/lib/http/data-fetcher/fetchers/grid-config-fetcher.d.ts +1 -0
- package/dist/types/lib/http/data-fetcher/fetchers/resource-fetcher.d.ts +1 -0
- package/dist/types/lib/message/resources/en-us/snk-image-input.msg.d.ts +1 -0
- package/dist/types/lib/message/resources/es-es/snk-image-input.msg.d.ts +1 -0
- package/dist/types/lib/message/resources/pt-br/snk-image-input.msg.d.ts +1 -0
- package/package.json +6 -7
- package/react/components.d.ts +4 -0
- package/react/components.js +4 -0
- package/react/components.js.map +1 -1
- package/dist/cjs/snk-simple-bar.cjs.entry.js +0 -45
- package/dist/cjs/taskbar-elements-fb5d1e08.js +0 -132
- package/dist/cjs/taskbar-processor-2fba34a8.js +0 -53
- package/dist/esm/snk-simple-bar.entry.js +0 -41
- package/dist/esm/taskbar-elements-faaf5d8f.js +0 -129
- package/dist/esm/taskbar-processor-3436124c.js +0 -51
- package/dist/sankhyablocks/p-093f58fa.entry.js +0 -1
- package/dist/sankhyablocks/p-0e279e7a.js +0 -1
- package/dist/sankhyablocks/p-11346b8d.entry.js +0 -1
- package/dist/sankhyablocks/p-1858c023.entry.js +0 -1
- package/dist/sankhyablocks/p-1a0caadb.js +0 -1
- package/dist/sankhyablocks/p-21107f0d.entry.js +0 -1
- package/dist/sankhyablocks/p-26e0f63c.entry.js +0 -1
- package/dist/sankhyablocks/p-34df7eca.entry.js +0 -1
- package/dist/sankhyablocks/p-34f447ba.entry.js +0 -1
- package/dist/sankhyablocks/p-38e56b68.entry.js +0 -1
- package/dist/sankhyablocks/p-3abeeefa.entry.js +0 -1
- package/dist/sankhyablocks/p-3d021bef.entry.js +0 -1
- package/dist/sankhyablocks/p-3ed04f0d.entry.js +0 -1
- package/dist/sankhyablocks/p-44939a0e.entry.js +0 -1
- package/dist/sankhyablocks/p-51833248.js +0 -7
- package/dist/sankhyablocks/p-5304753a.js +0 -60
- package/dist/sankhyablocks/p-557368df.entry.js +0 -1
- package/dist/sankhyablocks/p-55798617.js +0 -1
- package/dist/sankhyablocks/p-583151c5.entry.js +0 -1
- package/dist/sankhyablocks/p-60dd1d27.entry.js +0 -1
- package/dist/sankhyablocks/p-6180de07.entry.js +0 -1
- package/dist/sankhyablocks/p-80014119.entry.js +0 -1
- package/dist/sankhyablocks/p-8f73da95.js +0 -1
- package/dist/sankhyablocks/p-91a9abb6.entry.js +0 -1
- package/dist/sankhyablocks/p-9317942f.js +0 -26
- package/dist/sankhyablocks/p-988afe78.js +0 -1
- package/dist/sankhyablocks/p-a2ed1ebd.entry.js +0 -1
- package/dist/sankhyablocks/p-a5108625.entry.js +0 -1
- package/dist/sankhyablocks/p-a644a956.js +0 -1
- package/dist/sankhyablocks/p-ae108ffd.entry.js +0 -11
- package/dist/sankhyablocks/p-b4322b87.entry.js +0 -1
- package/dist/sankhyablocks/p-b7e891cc.entry.js +0 -1
- package/dist/sankhyablocks/p-b987e15d.js +0 -1
- package/dist/sankhyablocks/p-bb2f5f38.js +0 -1
- package/dist/sankhyablocks/p-d8d8169b.js +0 -2
- package/dist/sankhyablocks/p-d9c54991.js +0 -1
- package/dist/sankhyablocks/p-dc851b6e.entry.js +0 -1
- package/dist/sankhyablocks/p-e9021f79.entry.js +0 -1
- package/dist/sankhyablocks/p-f15478a1.js +0 -1
- package/dist/sankhyablocks/p-f8f29e1a.entry.js +0 -1
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { ApplicationContext } from "@sankhyalabs/core";
|
|
2
|
+
export async function base64ToBlob(base64) {
|
|
3
|
+
const response = await fetch(base64);
|
|
4
|
+
return await response.blob();
|
|
5
|
+
}
|
|
6
|
+
export function buildFileKey(entityName, fieldName) {
|
|
7
|
+
if (entityName) {
|
|
8
|
+
return `${entityName}_${fieldName}`;
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
return fieldName;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
function hasSpecialCharacters(value) {
|
|
15
|
+
const specialChars = /[ !@#$%^&*()+\-=\[\]{};':"\\|,.<>\/?]/;
|
|
16
|
+
return specialChars.test(value);
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Gera a URL base para upload de sessão
|
|
20
|
+
*/
|
|
21
|
+
function getSessionUploadBaseUrl(fileKey, context = 'mge') {
|
|
22
|
+
let url = `/${context}/sessionUpload.${context}?sessionkey=${fileKey}`;
|
|
23
|
+
// Verifica se precisa processar caracteres especiais
|
|
24
|
+
if (canProcessSpecialKeys(context) && hasSpecialCharacters(fileKey)) {
|
|
25
|
+
url += `&encodedKey=${btoa(encodeURI(fileKey))}`;
|
|
26
|
+
}
|
|
27
|
+
return url;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Verifica se pode processar chaves especiais
|
|
31
|
+
* Baseado no método canProcessSpecialKeys do sessionfileupload.service.js
|
|
32
|
+
*/
|
|
33
|
+
async function canProcessSpecialKeys(context) {
|
|
34
|
+
var _a;
|
|
35
|
+
const application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
|
|
36
|
+
if (!application)
|
|
37
|
+
return false;
|
|
38
|
+
const resourceId = await ((_a = application.getResourceID) === null || _a === void 0 ? void 0 : _a.call(application)) || '';
|
|
39
|
+
const adPrefix = "br.com.sankhya.menu.adicional";
|
|
40
|
+
return context === 'mge' && resourceId.startsWith(adPrefix);
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Constrói a URL de upload
|
|
44
|
+
* Baseado no método buildUploadURL do sessionfileupload.service.js
|
|
45
|
+
*/
|
|
46
|
+
function buildUploadURL(fileKey) {
|
|
47
|
+
let url = getSessionUploadBaseUrl(fileKey);
|
|
48
|
+
url += "&fitem=S&salvar=S&useCache=N";
|
|
49
|
+
return url;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Faz upload de arquivo para a sessão usando XMLHttpRequest
|
|
53
|
+
* Baseado no método uploadSessionFile do sessionfileupload.service.js
|
|
54
|
+
*/
|
|
55
|
+
export async function sessionFileUpload(blob, entityName, fieldName, onProgress) {
|
|
56
|
+
const fileKey = buildFileKey(entityName, fieldName);
|
|
57
|
+
const uploadUrl = buildUploadURL(fileKey);
|
|
58
|
+
return new Promise((resolve, reject) => {
|
|
59
|
+
const formData = new FormData();
|
|
60
|
+
formData.append('arquivo', blob);
|
|
61
|
+
const http = new XMLHttpRequest();
|
|
62
|
+
http.addEventListener("load", () => {
|
|
63
|
+
if (http.status >= 200 && http.status < 300) {
|
|
64
|
+
resolve(`/mge/UPLOADING_${fileKey}.dbimage`);
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
reject(new Error(`Upload failed: ${http.statusText}`));
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
http.addEventListener("error", () => {
|
|
71
|
+
reject(new Error('Upload error'));
|
|
72
|
+
});
|
|
73
|
+
if (onProgress) {
|
|
74
|
+
http.upload.addEventListener("progress", onProgress);
|
|
75
|
+
}
|
|
76
|
+
http.open("POST", uploadUrl);
|
|
77
|
+
http.send(formData);
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
export function getUrlBase() {
|
|
81
|
+
return window.location.origin;
|
|
82
|
+
}
|
|
83
|
+
export function getBaseUrl(pk, entityName, fieldName) {
|
|
84
|
+
if (!pk)
|
|
85
|
+
return undefined;
|
|
86
|
+
const baseUrl = getUrlBase();
|
|
87
|
+
let url = `${baseUrl}/mge/${entityName}@${fieldName}`;
|
|
88
|
+
for (const pkField in pk) {
|
|
89
|
+
url += `@${pkField}=${pk[pkField]}`;
|
|
90
|
+
}
|
|
91
|
+
url += '.dbimage';
|
|
92
|
+
return url;
|
|
93
|
+
}
|
|
94
|
+
export function getPKs(dataUnit) {
|
|
95
|
+
if (!dataUnit) {
|
|
96
|
+
return undefined;
|
|
97
|
+
}
|
|
98
|
+
const pk = {};
|
|
99
|
+
const fields = dataUnit.metadata.fields;
|
|
100
|
+
const selectedRecord = dataUnit.getSelectedRecord();
|
|
101
|
+
fields.forEach((field) => {
|
|
102
|
+
if (field.properties['isPrimaryKey'] && selectedRecord) {
|
|
103
|
+
pk[field.name] = selectedRecord[field.name];
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
return pk;
|
|
107
|
+
}
|
|
108
|
+
export async function imageBlobToBase64(blob) {
|
|
109
|
+
return new Promise((resolve, reject) => {
|
|
110
|
+
const reader = new FileReader();
|
|
111
|
+
reader.onloadend = () => {
|
|
112
|
+
resolve(reader.result);
|
|
113
|
+
};
|
|
114
|
+
reader.onerror = reject;
|
|
115
|
+
reader.readAsDataURL(blob);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
export async function downloadImage(pks, fieldName, entityName) {
|
|
119
|
+
const uploadUrl = getBaseUrl(pks, entityName, fieldName);
|
|
120
|
+
if (!uploadUrl) {
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
try {
|
|
124
|
+
const response = await fetch(uploadUrl);
|
|
125
|
+
if (response.ok) {
|
|
126
|
+
const blob = await response.blob();
|
|
127
|
+
return await imageBlobToBase64(blob);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
131
|
+
console.error('Error downloading image:', error);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
@@ -43,7 +43,7 @@ export class SnkLayoutFormConfig {
|
|
|
43
43
|
return (_a = this.messagesBuilder) === null || _a === void 0 ? void 0 : _a.getMessage(key, params);
|
|
44
44
|
}
|
|
45
45
|
render() {
|
|
46
|
-
return (h("div", { class: "ez-flex ez-flex--column" }, h("div", { class: "ez-margin-bottom--small" }, h("ez-check", { label: this.getMessage('snkLayoutFormConfig.cascadeLayout.label'), class: "ez-margin-bottom--small", onEzChange: () => this.toggleLayout(FormLayout.CASCADE), value: this.layoutType === FormLayout.CASCADE }), h("snk-view-representation", { mode: FormLayout.CASCADE }), h("label", { class: "ez-label ez-margin--small ez-flex ez-text--medium" }, this.getMessage('snkLayoutFormConfig.cascadeLayout.description'))), h("div",
|
|
46
|
+
return (h("div", { class: "ez-flex ez-flex--column" }, h("div", { class: "ez-margin-bottom--small" }, h("ez-check", { label: this.getMessage('snkLayoutFormConfig.cascadeLayout.label'), class: "ez-margin-bottom--small", onEzChange: () => this.toggleLayout(FormLayout.CASCADE), value: this.layoutType === FormLayout.CASCADE }), h("snk-view-representation", { mode: FormLayout.CASCADE }), h("label", { class: "ez-label ez-margin--small ez-flex ez-text--medium" }, this.getMessage('snkLayoutFormConfig.cascadeLayout.description'))), h("div", { class: "ez-margin-bottom--small" }, h("ez-check", { label: this.getMessage('snkLayoutFormConfig.classicCascadeLayout.label'), class: "ez-margin-bottom--small", onEzChange: () => this.toggleLayout(FormLayout.CLASSIC_CASCADE), value: this.layoutType === FormLayout.CLASSIC_CASCADE }), h("snk-view-representation", { mode: FormLayout.CLASSIC_CASCADE }), h("label", { class: "ez-label ez-margin--small ez-flex ez-text--medium" }, this.getMessage('snkLayoutFormConfig.classicCascadeLayout.description'))), h("div", { class: "ez-margin-bottom--small" }, h("ez-check", { label: this.getMessage('snkLayoutFormConfig.sideBySideLayout.label'), class: "ez-margin-bottom--small", onEzChange: () => this.toggleLayout(FormLayout.SIDE_BY_SIDE), value: this.layoutType === FormLayout.SIDE_BY_SIDE }), h("snk-view-representation", { mode: FormLayout.SIDE_BY_SIDE }), h("label", { class: "ez-label ez-margin--small ez-flex ez-text--medium" }, this.getMessage('snkLayoutFormConfig.sideBySideLayout.description'))), h("div", null, h("ez-check", { label: this.getMessage('snkLayoutFormConfig.classicSideBySideLayout.label'), class: "ez-margin-bottom--small", onEzChange: () => this.toggleLayout(FormLayout.CLASSIC_SIDE_BY_SIDE), value: this.layoutType === FormLayout.CLASSIC_SIDE_BY_SIDE }), h("snk-view-representation", { mode: FormLayout.CLASSIC_SIDE_BY_SIDE }), h("label", { class: "ez-label ez-margin--small ez-flex ez-text--medium" }, this.getMessage('snkLayoutFormConfig.classicSideBySideLayout.description')))));
|
|
47
47
|
}
|
|
48
48
|
static get is() { return "snk-layout-form-config"; }
|
|
49
49
|
static get encapsulation() { return "scoped"; }
|
|
@@ -11,7 +11,7 @@ export class SnkViewRepresentation {
|
|
|
11
11
|
return (h("div", { class: "svg-container__inline" }, [...Array(2)].map(() => this.renderCascadeLayout())));
|
|
12
12
|
}
|
|
13
13
|
render() {
|
|
14
|
-
return (h("div", { class: "svg-container ez-margin-left--small" }, h("div", { class: "svg-container__background" }, h("div", { class: "svg-container__header" }, h("div", { class: "svg-container__circle svg-container__circle--red" }), h("div", { class: "svg-container__circle svg-container__circle--yellow" }), h("div", { class: "svg-container__circle svg-container__circle--green" })), this.mode === FormLayout.CASCADE
|
|
14
|
+
return (h("div", { class: "svg-container ez-margin-left--small" }, h("div", { class: "svg-container__background" }, h("div", { class: "svg-container__header" }, h("div", { class: "svg-container__circle svg-container__circle--red" }), h("div", { class: "svg-container__circle svg-container__circle--yellow" }), h("div", { class: "svg-container__circle svg-container__circle--green" })), (this.mode === FormLayout.CASCADE || this.mode === FormLayout.CLASSIC_CASCADE)
|
|
15
15
|
? this.renderCascadeLayout()
|
|
16
16
|
: this.renderSideBySideLayout())));
|
|
17
17
|
}
|
|
@@ -351,7 +351,7 @@ export class SnkPersonalizedFilter {
|
|
|
351
351
|
if (!((_a = this._filterAssistent) === null || _a === void 0 ? void 0 : _a.assistent) && this._filterAssistentMode) {
|
|
352
352
|
return;
|
|
353
353
|
}
|
|
354
|
-
return (h(Host, null, h("div", { class: "snk-personalized-filter" }, h("div", null, h("snk-simple-bar", { label: this.buildTitle(), onExit: () => this.handleCancel() }, h("div", { class: "snk-personalized-filter__header-actions", slot: "rightSlot" }, h("ez-button", {
|
|
354
|
+
return (h(Host, null, h("div", { class: "snk-personalized-filter" }, h("div", null, h("snk-simple-bar", { label: this.buildTitle(), onExit: () => this.handleCancel() }, h("div", { class: "snk-personalized-filter__header-actions", slot: "rightSlot" }, h("ez-button", { label: this.getMessage("snkPersonalizedFilter.info.labelCancel"), onClick: () => this.handleCancel() }), h("ez-button", { ref: (el) => this._elButtonSave = el, enabled: false, class: "ez-button--primary", label: this.getMessage("snkPersonalizedFilter.info.labelSave"), onClick: this.handleSave.bind(this) })))), h("div", { class: "ez-box ez-margin-bottom--medium ez-box__main" }, h("div", { class: "ez-box__container" }, h("div", { class: "ez-flex ez-flex--column ez-size-width--full" }, h("div", { class: "ez-flex" }, h("ez-tooltip", { message: this.getMessage("snkPersonalizedFilter.info.textInputDisabled"), active: this.isDefaultFilter }, h("ez-text-input", { class: "ez-padding-right--medium", label: this.getMessage("snkPersonalizedFilter.info.labelNameFilter"), value: (_b = this._filterAssistent) === null || _b === void 0 ? void 0 : _b.name, onEzChange: (evt) => this.handleTitleChange(evt.detail), enabled: !this.isDefaultFilter })), this.renderButtonAddField(), h("ez-button", { ref: (el) => this._elButtonMode = el, class: "snk-personalized-filter__button-mode", label: this._filterAssistentMode ? this.getMessage("snkPersonalizedFilter.info.activeModeAdvanced") : this.getMessage("snkPersonalizedFilter.info.activeModeAssistent"), onClick: () => this.handleModeChange(), "data-tooltip": !(this._filterAssistentMode || ((_c = this._filterAssistent) === null || _c === void 0 ? void 0 : _c.assistent)) ? this.getMessage("snkPersonalizedFilter.info.tooltipDisabledAssistentMode") : undefined, "data-flow": "bottom", enabled: (!this._filterAssistent.name || Boolean(this._filterAssistentMode || ((_d = this._filterAssistent) === null || _d === void 0 ? void 0 : _d.assistent))) })), this.buildContainerPersonalizedFilter()))))));
|
|
355
355
|
}
|
|
356
356
|
static get is() { return "snk-personalized-filter"; }
|
|
357
357
|
static get encapsulation() { return "scoped"; }
|
|
@@ -75,6 +75,9 @@ export class PersonalizedFilterUtils {
|
|
|
75
75
|
}
|
|
76
76
|
else if (DataType.DATE == type) {
|
|
77
77
|
value = this.convertDataValue(value);
|
|
78
|
+
if (value === undefined) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
78
81
|
}
|
|
79
82
|
else if (DataType.BOOLEAN == type) {
|
|
80
83
|
value = value ? "S" : "N";
|
|
@@ -100,9 +103,19 @@ export class PersonalizedFilterUtils {
|
|
|
100
103
|
return `?:{entidade=${expressionItem.entityName || ""};campo=${expressionItem.fieldName || ""}}`;
|
|
101
104
|
}
|
|
102
105
|
static convertDataValue(value) {
|
|
106
|
+
if (value == null || value === '' || value === undefined) {
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
103
109
|
if (typeof value == 'string') {
|
|
110
|
+
const trimmedValue = value.trim();
|
|
111
|
+
if (trimmedValue === '' || trimmedValue === '/' || trimmedValue === ' / /') {
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
104
114
|
value = new Date(value);
|
|
105
115
|
}
|
|
116
|
+
if (value instanceof Date && isNaN(value.getTime())) {
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
106
119
|
return DateUtils.formatDate(value);
|
|
107
120
|
}
|
|
108
121
|
/*
|
|
@@ -37,7 +37,6 @@ export class SnkPesquisa {
|
|
|
37
37
|
* Útil para cenários onde a pesquisa precisa ser disparada sem interação do usuário.
|
|
38
38
|
*
|
|
39
39
|
* @param text Texto utilizado como argumento de pesquisa.
|
|
40
|
-
* @returns Promise<void>
|
|
41
40
|
* @example
|
|
42
41
|
* await pesquisaRef.executeSearch("Texto para pesquisa");
|
|
43
42
|
*/
|
|
@@ -642,9 +641,6 @@ export class SnkPesquisa {
|
|
|
642
641
|
"tags": [{
|
|
643
642
|
"name": "param",
|
|
644
643
|
"text": "text Texto utilizado como argumento de pesquisa."
|
|
645
|
-
}, {
|
|
646
|
-
"name": "returns",
|
|
647
|
-
"text": "Promise<void>"
|
|
648
644
|
}, {
|
|
649
645
|
"name": "example",
|
|
650
646
|
"text": "await pesquisaRef.executeSearch(\"Texto para pesquisa\");"
|
|
@@ -57,6 +57,7 @@ export class SnkSimpleCrud {
|
|
|
57
57
|
this.domainMessagesBuilder = undefined;
|
|
58
58
|
this.multipleEditionEnabled = true;
|
|
59
59
|
this.layoutFormConfig = true;
|
|
60
|
+
this.disableGridEdition = false;
|
|
60
61
|
this.autoLoad = undefined;
|
|
61
62
|
this.outlineMode = false;
|
|
62
63
|
}
|
|
@@ -157,11 +158,10 @@ export class SnkSimpleCrud {
|
|
|
157
158
|
}
|
|
158
159
|
getButtons(selected, extraButtons, removeRefresh) {
|
|
159
160
|
let btnList = selected ? REGULAR_SELECTED_BTNS : REGULAR_DEFAULT_BTNS;
|
|
160
|
-
if (removeRefresh) {
|
|
161
|
+
if (removeRefresh || this.mode === SIMPLE_CRUD_MODE.IN_MEMORY) {
|
|
161
162
|
btnList = btnList.filter(item => item !== TaskbarElement.REFRESH);
|
|
162
163
|
}
|
|
163
|
-
return this.addConfigButton(
|
|
164
|
-
.concat(extraButtons));
|
|
164
|
+
return this.addConfigButton(btnList.concat(extraButtons));
|
|
165
165
|
}
|
|
166
166
|
addConfigButton(buttons) {
|
|
167
167
|
if (this.configName === undefined || (this.configName && this.gridLegacyConfigName)) {
|
|
@@ -172,13 +172,6 @@ export class SnkSimpleCrud {
|
|
|
172
172
|
get application() {
|
|
173
173
|
return ApplicationContext.getContextValue("__SNK__APPLICATION__");
|
|
174
174
|
}
|
|
175
|
-
resolveInMemoryBtns(taskbarButtons) {
|
|
176
|
-
const newTaskBarConfig = [...taskbarButtons];
|
|
177
|
-
if (this.mode === SIMPLE_CRUD_MODE.IN_MEMORY) {
|
|
178
|
-
newTaskBarConfig.splice(1, 1);
|
|
179
|
-
}
|
|
180
|
-
return newTaskBarConfig;
|
|
181
|
-
}
|
|
182
175
|
/**
|
|
183
176
|
* @description Usado para alternar a visão entre GRID e FORM externamente.
|
|
184
177
|
* @param {VIEW_MODE} view - A visão para a qual navegar.
|
|
@@ -279,22 +272,23 @@ export class SnkSimpleCrud {
|
|
|
279
272
|
}
|
|
280
273
|
await this.loadFormConfig(true);
|
|
281
274
|
}
|
|
282
|
-
openConfig(viewMode) {
|
|
283
|
-
this._snkConfigurator.close();
|
|
275
|
+
async openConfig(viewMode) {
|
|
276
|
+
await this._snkConfigurator.close();
|
|
284
277
|
if (viewMode === VIEW_MODE.GRID) {
|
|
285
|
-
this.openGridConfig();
|
|
278
|
+
await this.openGridConfig();
|
|
286
279
|
}
|
|
287
280
|
else if (viewMode === VIEW_MODE.FORM) {
|
|
288
|
-
this.openFormConfig();
|
|
281
|
+
await this.openFormConfig();
|
|
289
282
|
}
|
|
290
283
|
}
|
|
291
|
-
openGridConfig() {
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
284
|
+
async openGridConfig() {
|
|
285
|
+
var _a, _b, _c, _d;
|
|
286
|
+
const originalColumns = (_b = await ((_a = this._grid) === null || _a === void 0 ? void 0 : _a.getColumns())) !== null && _b !== void 0 ? _b : [];
|
|
287
|
+
const gridColumns = (_d = await ((_c = this._grid) === null || _c === void 0 ? void 0 : _c.getColumnsState())) !== null && _d !== void 0 ? _d : [];
|
|
288
|
+
this._snkGridConfig.columns = gridColumns.filter(c => c.name);
|
|
289
|
+
this._snkGridConfig.originalColumns = originalColumns.filter(c => c.name);
|
|
290
|
+
this._snkGridConfig.selectedIndex = 0;
|
|
291
|
+
this._showPopUpGridConfig = true;
|
|
298
292
|
}
|
|
299
293
|
async openFormConfig() {
|
|
300
294
|
if (this.formLegacyConfigName || this.configName) {
|
|
@@ -819,7 +813,7 @@ export class SnkSimpleCrud {
|
|
|
819
813
|
}
|
|
820
814
|
return (h("snk-data-unit", { ref: ref => this._snkDataUnit = ref, class: "simple-crud__container", dataUnit: this.dataUnit, useCancelConfirm: this.useCancelConfirm, onDataStateChange: evt => this.onDataStateChange(evt), onCancelEdition: this.handleCancelEdit.bind(this), pageSize: this.getPageSize(), onInsertionMode: this.handleDataUnitOnInsertionMode.bind(this), onDataUnitReady: (evt) => this.dataUnitReady.emit(evt.detail), onMessagesBuilderUpdated: evt => this.messagesBuilder = evt.detail, onDataUnitFieldsHidded: this.updateFormConfig.bind(this), domainMessagesBuilder: this.domainMessagesBuilder }, h("header", null, h("slot", { name: "snkSimpleCrudHeader" })), h("section", { class: `ez-box ez-box--no-outline ${this.outlineMode ? 'ez-box--outline' : 'ez-box--shadow'} simple-crud__container-section`, ref: (ref) => this._container = ref, tabindex: "0" }, h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-element-id": "simple-crud" }, h("stack-item", null, h("ez-grid", { class: "ez-margin-bottom--large ez-box--no-outline", ref: ref => this._grid = ref, dataUnit: this.dataUnit, config: this.gridConfig, "no-header": true, multipleSelection: this.multipleSelection, onEzDoubleClick: () => this.goToView(VIEW_MODE.FORM), onConfigChange: evt => this.gridConfigChangeHandler(evt), columnfilterDataSource: this.dataUnit.name && this.dataUnit.name.includes(InMemoryLoader.IN_MEMORY_DATA_UNIT_NAME)
|
|
821
815
|
? undefined
|
|
822
|
-
: this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab, autoFocus: this.autoFocus, enableGridInsert: this.enableGridInsert, enableContinuousInsert: this.enableContinuousInsert, enableLockManagerTaskbarClick: this.enableLockManagerTaskbarClick, enableLockManagerLoadingComp: this.enableLockManagerLoadingComp, outlineMode: this.outlineMode, tabindex: "0", paginationCounterMode: this.paginationCounterMode }, this.renderTaskbarContent(VIEW_MODE.GRID), h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, this.renderTaskbarContent(VIEW_MODE.FORM), h("ez-form", { ref: (ref) => this._form = ref, class: `ez-margin-top--large ez-box--no-outline`, dataUnit: this.dataUnit, config: this.getFormConfig(), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this), elementFocusSearchField: this._container, tabindex: "0" }), h("snk-simple-form-config", { ref: (ref) => this._snkSimpleFormConfig = ref, dataUnit: this.dataUnit, onSnkConfigSaved: this.handleFormConfigSaved.bind(this), configName: (_a = this.formLegacyConfigName) !== null && _a !== void 0 ? _a : this.configName, messagesBuilder: this.messagesBuilder })), this.messagesBuilder && 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.resolveResourceID(), customContainerId: this._customContainerId, layoutFormConfig: this.layoutFormConfig })), h("div", { id: `${this._customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }))), h("ez-popup", { size: "medium", heightMode: "auto", useHeader: false, opened: this._showPopUpGridConfig, onEzClosePopup: () => this.closeGridConfig() }, h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this.resolveResourceID() }))));
|
|
816
|
+
: this._multiSelectionListDataSource, useEnterLikeTab: this.useEnterLikeTab, autoFocus: this.autoFocus, enableGridInsert: this.enableGridInsert, enableContinuousInsert: this.enableContinuousInsert, enableLockManagerTaskbarClick: this.enableLockManagerTaskbarClick, enableLockManagerLoadingComp: this.enableLockManagerLoadingComp, outlineMode: this.outlineMode, tabindex: "0", paginationCounterMode: this.paginationCounterMode, canEdit: !this.disableGridEdition }, this.renderTaskbarContent(VIEW_MODE.GRID), h("div", { slot: "footer" }, h("slot", { name: "snkSimpleCrudFooter" })))), h("stack-item", null, this.renderTaskbarContent(VIEW_MODE.FORM), h("ez-form", { ref: (ref) => this._form = ref, class: `ez-margin-top--large ez-box--no-outline`, dataUnit: this.dataUnit, config: this.getFormConfig(), fieldToFocus: this._fieldToGetFocus, onEzFormSetFields: (evt) => this.handleFormSetFields(evt.detail), onEzFormRequestClearFieldToFocus: this.clearFieldToFocusHandler.bind(this), elementFocusSearchField: this._container, tabindex: "0" }), h("slot", { name: "snkSimpleCrudFormFooter" }), h("snk-simple-form-config", { ref: (ref) => this._snkSimpleFormConfig = ref, dataUnit: this.dataUnit, onSnkConfigSaved: this.handleFormConfigSaved.bind(this), configName: (_a = this.formLegacyConfigName) !== null && _a !== void 0 ? _a : this.configName, messagesBuilder: this.messagesBuilder })), this.messagesBuilder && 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.resolveResourceID(), customContainerId: this._customContainerId, layoutFormConfig: this.layoutFormConfig })), h("div", { id: `${this._customContainerId}` }, h("slot", { name: "SnkConfigContainerSlot" }))), h("ez-popup", { size: "medium", heightMode: "auto", useHeader: false, opened: this._showPopUpGridConfig, onEzClosePopup: () => this.closeGridConfig() }, h("snk-grid-config", { ref: ref => this._snkGridConfig = ref, config: this.gridConfig, "data-element-id": this._element.getAttribute(ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME), selectedIndex: 0, configName: this.configName, onConfigChange: (evt) => this.modalConfigChangeHandler(evt), onConfigCancel: () => this.closeGridConfig(), resourceID: this.resolveResourceID() }))));
|
|
823
817
|
}
|
|
824
818
|
static get is() { return "snk-simple-crud"; }
|
|
825
819
|
static get encapsulation() { return "scoped"; }
|
|
@@ -879,7 +873,7 @@ export class SnkSimpleCrud {
|
|
|
879
873
|
},
|
|
880
874
|
"dataState": {
|
|
881
875
|
"type": "unknown",
|
|
882
|
-
"mutable":
|
|
876
|
+
"mutable": true,
|
|
883
877
|
"complexType": {
|
|
884
878
|
"original": "DataState",
|
|
885
879
|
"resolved": "DataState",
|
|
@@ -1438,6 +1432,24 @@ export class SnkSimpleCrud {
|
|
|
1438
1432
|
"reflect": false,
|
|
1439
1433
|
"defaultValue": "true"
|
|
1440
1434
|
},
|
|
1435
|
+
"disableGridEdition": {
|
|
1436
|
+
"type": "boolean",
|
|
1437
|
+
"mutable": false,
|
|
1438
|
+
"complexType": {
|
|
1439
|
+
"original": "boolean",
|
|
1440
|
+
"resolved": "boolean",
|
|
1441
|
+
"references": {}
|
|
1442
|
+
},
|
|
1443
|
+
"required": false,
|
|
1444
|
+
"optional": false,
|
|
1445
|
+
"docs": {
|
|
1446
|
+
"tags": [],
|
|
1447
|
+
"text": "Desabilita a edi\u00E7\u00E3o na grade."
|
|
1448
|
+
},
|
|
1449
|
+
"attribute": "disable-grid-edition",
|
|
1450
|
+
"reflect": false,
|
|
1451
|
+
"defaultValue": "false"
|
|
1452
|
+
},
|
|
1441
1453
|
"autoLoad": {
|
|
1442
1454
|
"type": "boolean",
|
|
1443
1455
|
"mutable": false,
|
|
@@ -2,9 +2,11 @@ import { h, Host } from '@stencil/core';
|
|
|
2
2
|
export class TaskbarActionsButton {
|
|
3
3
|
constructor() {
|
|
4
4
|
this._showDropdown = false;
|
|
5
|
+
this._openToLeft = false;
|
|
5
6
|
this.title = undefined;
|
|
6
7
|
this.enabled = undefined;
|
|
7
8
|
this.actions = undefined;
|
|
9
|
+
this.size = 'medium';
|
|
8
10
|
}
|
|
9
11
|
async handleKeyDown(event) {
|
|
10
12
|
if (event.key === 'Escape' || event.key === 'Esc') {
|
|
@@ -18,6 +20,7 @@ export class TaskbarActionsButton {
|
|
|
18
20
|
* Exibe a lista de ações.
|
|
19
21
|
*/
|
|
20
22
|
async showActions() {
|
|
23
|
+
this.checkDropdownPosition();
|
|
21
24
|
this._showDropdown = true;
|
|
22
25
|
requestAnimationFrame(() => {
|
|
23
26
|
this._element.scrollIntoView({ behavior: 'smooth', block: 'nearest', inline: 'nearest' });
|
|
@@ -36,8 +39,19 @@ export class TaskbarActionsButton {
|
|
|
36
39
|
return this._showDropdown;
|
|
37
40
|
}
|
|
38
41
|
controlDropdown() {
|
|
42
|
+
if (!this._showDropdown) {
|
|
43
|
+
this.checkDropdownPosition();
|
|
44
|
+
}
|
|
39
45
|
this._showDropdown = !this._showDropdown;
|
|
40
46
|
}
|
|
47
|
+
checkDropdownPosition() {
|
|
48
|
+
const rect = this._element.getBoundingClientRect();
|
|
49
|
+
const viewportWidth = window.innerWidth;
|
|
50
|
+
const dropdownMinWidth = 150; // Largura mínima do dropdown
|
|
51
|
+
const spaceOnRight = viewportWidth - rect.right;
|
|
52
|
+
// Se não houver espaço suficiente à direita, abre para a esquerda
|
|
53
|
+
this._openToLeft = spaceOnRight < dropdownMinWidth;
|
|
54
|
+
}
|
|
41
55
|
loadItems() {
|
|
42
56
|
return this.actions.filter(action => action !== undefined).map(action => {
|
|
43
57
|
var _a;
|
|
@@ -118,7 +132,10 @@ export class TaskbarActionsButton {
|
|
|
118
132
|
this.taskbarActionsButtonDisconnected.emit();
|
|
119
133
|
}
|
|
120
134
|
render() {
|
|
121
|
-
return (h(Host, null, h("div", { class: `${this.canShowDropdown() ? ' ez-elevation--16' : ''} ez-dropdown-container` }, h("ez-
|
|
135
|
+
return (h(Host, null, h("div", { class: `${this.canShowDropdown() ? ' ez-elevation--16' : ''} ez-dropdown-container` }, h("ez-tooltip", { message: this.title }, h("ez-button", { mode: 'icon', iconName: 'dots-vertical', isDisabled: !this.enabled, onClick: () => this.controlDropdown(), size: this.size })), this.canShowDropdown() && (h("ez-dropdown", { class: {
|
|
136
|
+
'ez-dropdown--sticky': true,
|
|
137
|
+
'ez-dropdown--open-left': this._openToLeft
|
|
138
|
+
}, items: this.loadItems(), onEzClick: (evt) => this.onSelectAction(evt.detail), onEzOutsideClick: () => this._showDropdown = false, itemBuilder: (item, level) => this.dropdownItemBuilder(item, level) })))));
|
|
122
139
|
}
|
|
123
140
|
static get is() { return "taskbar-actions-button"; }
|
|
124
141
|
static get encapsulation() { return "scoped"; }
|
|
@@ -190,12 +207,31 @@ export class TaskbarActionsButton {
|
|
|
190
207
|
"tags": [],
|
|
191
208
|
"text": "Define a lista de a\u00E7\u00F5es."
|
|
192
209
|
}
|
|
210
|
+
},
|
|
211
|
+
"size": {
|
|
212
|
+
"type": "string",
|
|
213
|
+
"mutable": false,
|
|
214
|
+
"complexType": {
|
|
215
|
+
"original": "'small' | 'medium' | 'large'",
|
|
216
|
+
"resolved": "\"large\" | \"medium\" | \"small\"",
|
|
217
|
+
"references": {}
|
|
218
|
+
},
|
|
219
|
+
"required": false,
|
|
220
|
+
"optional": false,
|
|
221
|
+
"docs": {
|
|
222
|
+
"tags": [],
|
|
223
|
+
"text": "Define o tamanho do bot\u00E3o, podendo ser 'small', 'medium' ou 'large'."
|
|
224
|
+
},
|
|
225
|
+
"attribute": "size",
|
|
226
|
+
"reflect": false,
|
|
227
|
+
"defaultValue": "'medium'"
|
|
193
228
|
}
|
|
194
229
|
};
|
|
195
230
|
}
|
|
196
231
|
static get states() {
|
|
197
232
|
return {
|
|
198
|
-
"_showDropdown": {}
|
|
233
|
+
"_showDropdown": {},
|
|
234
|
+
"_openToLeft": {}
|
|
199
235
|
};
|
|
200
236
|
}
|
|
201
237
|
static get events() {
|
|
@@ -16,6 +16,7 @@ export var TaskbarElement;
|
|
|
16
16
|
TaskbarElement["FORM_MODE"] = "FORM_MODE";
|
|
17
17
|
TaskbarElement["MORE_OPTIONS"] = "MORE_OPTIONS";
|
|
18
18
|
TaskbarElement["DIVIDER"] = "DIVIDER";
|
|
19
|
+
TaskbarElement["SPACER"] = "SPACER";
|
|
19
20
|
TaskbarElement["CONFIGURATOR"] = "CONFIGURATOR";
|
|
20
21
|
TaskbarElement["DATA_EXPORTER"] = "DATA_EXPORTER";
|
|
21
22
|
TaskbarElement["ATTACH"] = "ATTACH";
|
|
@@ -34,92 +35,108 @@ export var VisibleWhenForbidden;
|
|
|
34
35
|
(function (VisibleWhenForbidden) {
|
|
35
36
|
VisibleWhenForbidden["CONFIGURATOR"] = "CONFIGURATOR";
|
|
36
37
|
})(VisibleWhenForbidden || (VisibleWhenForbidden = {}));
|
|
37
|
-
export const buildCustomButton = (def, className, dataElementId, action, isEnabled) => {
|
|
38
|
+
export const buildCustomButton = ({ def, className, dataElementId, action, isEnabled, size }) => {
|
|
38
39
|
const { hint, text, iconName } = def;
|
|
39
40
|
if (iconName) {
|
|
40
41
|
if (text) {
|
|
41
|
-
return iconTextButton(iconName, def.name, className, dataElementId, hint,
|
|
42
|
+
return iconTextButton({ iconName, element: def.name, className, dataElementId, title: hint, action, isEnabled, size });
|
|
42
43
|
}
|
|
43
44
|
else {
|
|
44
|
-
return iconButton(iconName, def.name, className, dataElementId, hint, action, isEnabled);
|
|
45
|
+
return iconButton({ iconName, element: def.name, className, dataElementId, title: hint, action, isEnabled, size });
|
|
45
46
|
}
|
|
46
47
|
}
|
|
47
48
|
else {
|
|
48
|
-
return textButton(def.name, className, dataElementId,
|
|
49
|
+
return textButton({ element: def.name, className, dataElementId, title: hint, action, isEnabled, size });
|
|
49
50
|
}
|
|
50
51
|
};
|
|
51
|
-
export const buildElem = (element, className, dataElementId, getTitle, action, isEnabled, actions, dataExporterStoreKey, presentationMode) => {
|
|
52
|
-
var _a;
|
|
52
|
+
export const buildElem = ({ element, className, dataElementId, getTitle, action, isEnabled, actions, dataExporterStoreKey, presentationMode, variant, size }) => {
|
|
53
|
+
var _a, _b;
|
|
53
54
|
const title = getTitle(element);
|
|
55
|
+
const propertiesItem = {
|
|
56
|
+
element, className, dataElementId, title, action, isEnabled, actions, variant, size
|
|
57
|
+
};
|
|
54
58
|
switch (element) {
|
|
55
59
|
case TaskbarElement.PREVIOUS:
|
|
56
|
-
return iconButton("chevron-left"
|
|
60
|
+
return iconButton(Object.assign({ iconName: "chevron-left" }, propertiesItem));
|
|
57
61
|
case TaskbarElement.NEXT:
|
|
58
|
-
return iconButton("chevron-right"
|
|
62
|
+
return iconButton(Object.assign({ iconName: "chevron-right" }, propertiesItem));
|
|
59
63
|
case TaskbarElement.REFRESH:
|
|
60
|
-
return iconButton("sync"
|
|
64
|
+
return iconButton(Object.assign({ iconName: "sync" }, propertiesItem));
|
|
61
65
|
case TaskbarElement.UPDATE:
|
|
62
|
-
return iconButton("edit"
|
|
66
|
+
return iconButton(Object.assign({ iconName: "edit" }, propertiesItem));
|
|
63
67
|
case TaskbarElement.UPDATE_MULTIPLE:
|
|
64
|
-
return iconButton("edit-table"
|
|
68
|
+
return iconButton(Object.assign({ iconName: "edit-table" }, propertiesItem));
|
|
65
69
|
case TaskbarElement.CLONE:
|
|
66
|
-
return iconButton("copy"
|
|
70
|
+
return iconButton(Object.assign({ iconName: "copy" }, propertiesItem));
|
|
67
71
|
case TaskbarElement.REMOVE:
|
|
68
|
-
return iconButton("delete"
|
|
72
|
+
return iconButton(Object.assign({ iconName: "delete" }, propertiesItem));
|
|
69
73
|
case TaskbarElement.INSERT:
|
|
70
74
|
if (presentationMode === PresentationMode.PRIMARY) {
|
|
71
|
-
return
|
|
75
|
+
return textButton(Object.assign({}, propertiesItem));
|
|
72
76
|
}
|
|
73
77
|
else {
|
|
74
|
-
return iconButton("plus"
|
|
78
|
+
return iconButton(Object.assign({ iconName: "plus" }, propertiesItem));
|
|
75
79
|
}
|
|
76
80
|
case TaskbarElement.CANCEL:
|
|
77
|
-
return textButton(
|
|
81
|
+
return textButton(Object.assign({}, propertiesItem));
|
|
78
82
|
case TaskbarElement.SAVE:
|
|
79
83
|
if (presentationMode === PresentationMode.PRIMARY) {
|
|
80
|
-
return iconTextButton("save"
|
|
84
|
+
return iconTextButton(Object.assign(Object.assign({ iconName: "save" }, propertiesItem), { variant: "primary" }));
|
|
81
85
|
}
|
|
82
86
|
else {
|
|
83
|
-
return iconButton("save"
|
|
87
|
+
return iconButton(Object.assign(Object.assign({ iconName: "save" }, propertiesItem), { variant: "primary" }));
|
|
84
88
|
}
|
|
85
89
|
case TaskbarElement.GRID_MODE:
|
|
86
|
-
return iconButton("table"
|
|
90
|
+
return iconButton(Object.assign({ iconName: "table" }, propertiesItem));
|
|
87
91
|
case TaskbarElement.FORM_MODE:
|
|
88
|
-
return iconButton("list"
|
|
92
|
+
return iconButton(Object.assign({ iconName: "list" }, propertiesItem));
|
|
89
93
|
case TaskbarElement.CONFIGURATOR:
|
|
90
94
|
if ((actions === null || actions === void 0 ? void 0 : actions.length) > 0) {
|
|
91
|
-
return splitButton("settings-inverted"
|
|
95
|
+
return splitButton(Object.assign({ iconName: "settings-inverted" }, propertiesItem));
|
|
92
96
|
}
|
|
93
|
-
return iconButton("settings-inverted"
|
|
97
|
+
return iconButton(Object.assign({ iconName: "settings-inverted" }, propertiesItem));
|
|
94
98
|
case TaskbarElement.MORE_OPTIONS:
|
|
95
|
-
|
|
99
|
+
const definedActions = (_a = actions === null || actions === void 0 ? void 0 : actions.filter(a => a !== undefined)) !== null && _a !== void 0 ? _a : [];
|
|
100
|
+
return actionButton(Object.assign(Object.assign({}, propertiesItem), { actions: definedActions }));
|
|
96
101
|
case TaskbarElement.DIVIDER:
|
|
97
102
|
return h("hr", { class: "ez-divider-vertical ez-divider--dark ez-margin--none ez-margin-left--medium", "data-taskbar-divider": true });
|
|
98
103
|
case TaskbarElement.DATA_EXPORTER:
|
|
99
|
-
const provider = (
|
|
100
|
-
return h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId, "data-taskbar-element": element });
|
|
104
|
+
const provider = (_b = store.get("exporterProviders")) === null || _b === void 0 ? void 0 : _b[dataExporterStoreKey];
|
|
105
|
+
return h("snk-data-exporter", { class: className, provider: provider, "data-element-id": dataElementId, "data-taskbar-element": element, size: size });
|
|
101
106
|
case TaskbarElement.ATTACH:
|
|
102
|
-
return iconButton("anexo"
|
|
107
|
+
return iconButton(Object.assign({ iconName: "anexo" }, propertiesItem));
|
|
103
108
|
case TaskbarElement.ACTIONS_BUTTON:
|
|
104
|
-
return h("snk-actions-button", { "data-element-id": dataElementId, "data-taskbar-element": element });
|
|
109
|
+
return h("snk-actions-button", { "data-element-id": dataElementId, "data-taskbar-element": element, class: className, size: size });
|
|
105
110
|
}
|
|
106
111
|
};
|
|
107
|
-
function textButton(
|
|
108
|
-
return h("ez-
|
|
112
|
+
function textButton({ action, className, dataElementId, title, element, isEnabled, variant, size }) {
|
|
113
|
+
return (h("ez-tooltip", { key: dataElementId, message: title, class: className }, h("ez-button", { label: title, "data-taskbar-label": title, "data-taskbar-element": element, "data-element-id": dataElementId, isDisabled: !isEnabled(element), onClick: () => action(element), variant: variant, size: size })));
|
|
109
114
|
}
|
|
110
|
-
function
|
|
111
|
-
|
|
115
|
+
function concatClass(className) {
|
|
116
|
+
if (typeof className === "string") {
|
|
117
|
+
return className;
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
return Object.keys(className).filter(key => className[key]).join(" ");
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
function iconButton({ iconName, element, className, dataElementId, title, action, isEnabled, variant, size }) {
|
|
124
|
+
return (h("ez-tooltip", { key: dataElementId, message: title, class: {
|
|
125
|
+
[concatClass(className)]: true,
|
|
126
|
+
[`icon-button--${size}`]: true
|
|
127
|
+
} }, h("ez-button", { mode: "icon", "data-taskbar-label": title, "data-taskbar-element": element, "data-taskbar-icon": iconName, "data-element-id": dataElementId, iconName: iconName, isDisabled: !isEnabled(element), onClick: () => action(element), variant: variant, size: size })));
|
|
112
128
|
}
|
|
113
|
-
function iconTextButton(iconName,
|
|
114
|
-
return h("ez-
|
|
129
|
+
function iconTextButton({ iconName, element, className, dataElementId, title, action, isEnabled, variant, size }) {
|
|
130
|
+
return (h("ez-tooltip", { key: dataElementId, message: title, class: className }, h("ez-button", { label: title, "data-taskbar-label": title, "data-taskbar-icon": iconName, "data-taskbar-element": element, "data-element-id": dataElementId, isDisabled: !isEnabled(element), onClick: () => action(element), variant: variant, size: size }, h("ez-icon", { class: "ez-padding-right--small", slot: "leftIcon", iconName: iconName }))));
|
|
115
131
|
}
|
|
116
|
-
function splitButton(iconName, element, className, title, dataElementId, isEnabled, actions, action) {
|
|
132
|
+
function splitButton({ iconName, element, className, title, dataElementId, isEnabled, actions, action, size }) {
|
|
117
133
|
return actions && actions.length > 0
|
|
118
|
-
?
|
|
134
|
+
?
|
|
135
|
+
h("taskbar-split-button", { key: dataElementId, class: className, iconName: iconName, "data-taskbar-icon": iconName, "data-taskbar-label": title, title: title, "data-taskbar-element": element, "data-element-id": dataElementId, enabled: isEnabled(element), actions: actions, action: () => action(element), size: size })
|
|
119
136
|
: undefined;
|
|
120
137
|
}
|
|
121
|
-
function actionButton(element, className, dataElementId, title, isEnabled, actions, action) {
|
|
138
|
+
function actionButton({ element, className, dataElementId, title, isEnabled, actions, action, size }) {
|
|
122
139
|
return actions && actions.length > 0
|
|
123
|
-
? 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) })
|
|
140
|
+
? 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), size: size })
|
|
124
141
|
: undefined;
|
|
125
142
|
}
|