@sankhyalabs/sankhyablocks 1.4.0-beta.7 → 1.4.0-beta.9

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.
Files changed (194) hide show
  1. package/dist/cjs/{SnkMessageBuilder-b54dfb89.js → SnkMessageBuilder-6c2f7bcd.js} +87 -11
  2. package/dist/cjs/_commonjsHelpers-537d719a.js +20 -0
  3. package/dist/cjs/configurableElementsStorage-93459c72.js +20 -0
  4. package/dist/cjs/constants-9056ca9e.js +84 -0
  5. package/dist/cjs/draggable.bundle-82a25c06.js +6886 -0
  6. package/dist/cjs/form-config-fetcher-2de7c16a.js +6895 -0
  7. package/dist/cjs/{index-6fcf07f3.js → index-20e8b68a.js} +50 -2
  8. package/dist/cjs/loader.cjs.js +2 -2
  9. package/dist/cjs/sankhyablocks.cjs.js +2 -2
  10. package/dist/cjs/snk-application.cjs.entry.js +209 -6976
  11. package/dist/cjs/snk-config-modal.cjs.entry.js +62 -0
  12. package/dist/cjs/snk-config-options.cjs.entry.js +230 -0
  13. package/dist/cjs/{snk-filter-bar_5.cjs.entry.js → snk-configurator_6.cjs.entry.js} +194 -7
  14. package/dist/cjs/snk-crud.cjs.entry.js +13 -11
  15. package/dist/cjs/snk-data-unit.cjs.entry.js +2 -2
  16. package/dist/cjs/snk-field-config_2.cjs.entry.js +135 -0
  17. package/dist/cjs/snk-filter-binary-select.cjs.entry.js +1 -1
  18. package/dist/cjs/snk-filter-detail.cjs.entry.js +1 -1
  19. package/dist/cjs/snk-filter-multi-select.cjs.entry.js +1 -1
  20. package/dist/cjs/snk-filter-number.cjs.entry.js +1 -1
  21. package/dist/cjs/snk-filter-period.cjs.entry.js +1 -1
  22. package/dist/cjs/snk-filter-personalized.cjs.entry.js +3 -2
  23. package/dist/cjs/snk-filter-search.cjs.entry.js +1 -1
  24. package/dist/cjs/snk-filter-text.cjs.entry.js +1 -1
  25. package/dist/cjs/snk-form-config.cjs.entry.js +957 -0
  26. package/dist/cjs/snk-form.cjs.entry.js +146 -0
  27. package/dist/cjs/snk-pesquisa.cjs.entry.js +1 -1
  28. package/dist/cjs/snk-tab-config.cjs.entry.js +321 -0
  29. package/dist/cjs/{taskbar-elements-aedfeae6.js → taskbar-elements-9a4b1e19.js} +10 -6
  30. package/dist/cjs/taskbar-processor-6bd0d35c.js +47 -0
  31. package/dist/cjs/teste-pesquisa.cjs.entry.js +1 -1
  32. package/dist/collection/collection-manifest.json +27 -1
  33. package/dist/collection/components/snk-application/snk-application.js +144 -23
  34. package/dist/collection/components/snk-configurator/snk-configurator.js +261 -0
  35. package/dist/collection/components/snk-configurator/subcomponents/configModalProvider/configurableElementsStorage.js +16 -0
  36. package/dist/collection/components/snk-configurator/subcomponents/snk-config-modal/snk-config-modal.css +122 -0
  37. package/dist/collection/components/snk-configurator/subcomponents/snk-config-modal/snk-config-modal.js +137 -0
  38. package/dist/collection/components/snk-crud/snk-crud.js +15 -13
  39. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-personalized.js +35 -4
  40. package/dist/collection/components/snk-filter-bar/filter-item/editors/snk-filter-search.js +3 -3
  41. package/dist/collection/components/snk-filter-bar/filter-modal/snk-filter-modal.js +2 -1
  42. package/dist/collection/components/snk-filter-bar/snk-filter-bar.css +1 -1
  43. package/dist/collection/components/snk-form/snk-form.css +4 -0
  44. package/dist/collection/components/snk-form/snk-form.js +108 -30
  45. package/dist/collection/components/snk-form/subcomponents/snk-config-options/snk-config-options.css +9 -0
  46. package/dist/collection/components/snk-form/subcomponents/snk-config-options/snk-config-options.js +315 -0
  47. package/dist/collection/components/snk-form/subcomponents/snk-field-config/snk-field-config.css +164 -0
  48. package/dist/collection/components/snk-form/subcomponents/snk-field-config/snk-field-config.js +140 -0
  49. package/dist/collection/components/snk-form/subcomponents/snk-form-config/snk-form-config.css +185 -0
  50. package/dist/collection/components/snk-form/subcomponents/snk-form-config/snk-form-config.js +1062 -0
  51. package/dist/collection/components/snk-form/subcomponents/snk-tab-config/snk-tab-config.css +272 -0
  52. package/dist/collection/components/snk-form/subcomponents/snk-tab-config/snk-tab-config.js +476 -0
  53. package/dist/collection/components/snk-grid/snk-grid.js +92 -22
  54. package/dist/collection/components/snk-taskbar/elements/taskbar-elements.js +9 -5
  55. package/dist/collection/components/snk-taskbar/snk-taskbar.js +35 -3
  56. package/dist/collection/lib/http/data-fetcher/fetchers/form-config-fetcher.js +106 -3
  57. package/dist/collection/lib/http/data-fetcher/fetchers/resource-fetcher.js +9 -1
  58. package/dist/collection/lib/message/SnkMessageBuilder.js +8 -1
  59. package/dist/collection/lib/message/resources/snk-configurator.msg.js +11 -0
  60. package/dist/collection/lib/message/resources/snk-form.msg.js +59 -2
  61. package/dist/collection/lib/message/resources/snk-taskbar.msg.js +1 -1
  62. package/dist/collection/lib/utils/constants.js +72 -0
  63. package/dist/components/SnkMessageBuilder.js +87 -11
  64. package/dist/components/_commonjsHelpers.js +17 -0
  65. package/dist/components/constants.js +74 -0
  66. package/dist/components/form-config-fetcher.js +6889 -0
  67. package/dist/components/index.d.ts +6 -0
  68. package/dist/components/index.js +6 -0
  69. package/dist/components/snk-application2.js +221 -6985
  70. package/dist/components/snk-config-modal.d.ts +11 -0
  71. package/dist/components/snk-config-modal.js +6 -0
  72. package/dist/components/snk-config-modal2.js +91 -0
  73. package/dist/components/snk-config-options.d.ts +11 -0
  74. package/dist/components/snk-config-options.js +6 -0
  75. package/dist/components/snk-config-options2.js +245 -0
  76. package/dist/components/snk-configurator.d.ts +11 -0
  77. package/dist/components/snk-configurator.js +6 -0
  78. package/dist/components/snk-configurator2.js +212 -0
  79. package/dist/components/snk-crud.js +62 -25
  80. package/dist/components/snk-field-config.d.ts +11 -0
  81. package/dist/components/snk-field-config.js +6 -0
  82. package/dist/components/snk-field-config2.js +70 -0
  83. package/dist/components/snk-filter-bar2.js +1 -1
  84. package/dist/components/snk-filter-modal2.js +2 -1
  85. package/dist/components/snk-filter-personalized.js +4 -1
  86. package/dist/components/snk-form-config.d.ts +11 -0
  87. package/dist/components/snk-form-config.js +6 -0
  88. package/dist/components/snk-form-config2.js +996 -0
  89. package/dist/components/snk-form2.js +79 -29
  90. package/dist/components/snk-grid2.js +43 -24
  91. package/dist/components/snk-tab-config.d.ts +11 -0
  92. package/dist/components/snk-tab-config.js +6 -0
  93. package/dist/components/snk-tab-config2.js +7220 -0
  94. package/dist/components/snk-taskbar2.js +27 -9
  95. package/dist/esm/{SnkMessageBuilder-d440381c.js → SnkMessageBuilder-5792c260.js} +87 -11
  96. package/dist/esm/_commonjsHelpers-9943807e.js +17 -0
  97. package/dist/esm/configurableElementsStorage-cdc144b5.js +18 -0
  98. package/dist/esm/constants-c6039d3d.js +74 -0
  99. package/dist/esm/draggable.bundle-41d56f06.js +6884 -0
  100. package/dist/esm/form-config-fetcher-96c6c2dc.js +6889 -0
  101. package/dist/esm/{index-81dda3cf.js → index-e4121713.js} +50 -3
  102. package/dist/esm/loader.js +2 -2
  103. package/dist/esm/sankhyablocks.js +2 -2
  104. package/dist/esm/snk-application.entry.js +220 -6987
  105. package/dist/esm/snk-config-modal.entry.js +58 -0
  106. package/dist/esm/snk-config-options.entry.js +226 -0
  107. package/dist/esm/{snk-filter-bar_5.entry.js → snk-configurator_6.entry.js} +195 -9
  108. package/dist/esm/snk-crud.entry.js +13 -11
  109. package/dist/esm/snk-data-unit.entry.js +2 -2
  110. package/dist/esm/snk-field-config_2.entry.js +130 -0
  111. package/dist/esm/snk-filter-binary-select.entry.js +1 -1
  112. package/dist/esm/snk-filter-detail.entry.js +1 -1
  113. package/dist/esm/snk-filter-multi-select.entry.js +1 -1
  114. package/dist/esm/snk-filter-number.entry.js +1 -1
  115. package/dist/esm/snk-filter-period.entry.js +1 -1
  116. package/dist/esm/snk-filter-personalized.entry.js +3 -2
  117. package/dist/esm/snk-filter-search.entry.js +1 -1
  118. package/dist/esm/snk-filter-text.entry.js +1 -1
  119. package/dist/esm/snk-form-config.entry.js +953 -0
  120. package/dist/esm/snk-form.entry.js +142 -0
  121. package/dist/esm/snk-pesquisa.entry.js +1 -1
  122. package/dist/esm/snk-tab-config.entry.js +317 -0
  123. package/dist/esm/{taskbar-elements-38eb5d51.js → taskbar-elements-e2ed0536.js} +10 -6
  124. package/dist/esm/taskbar-processor-aa6772c9.js +45 -0
  125. package/dist/esm/teste-pesquisa.entry.js +1 -1
  126. package/dist/sankhyablocks/{p-4574a955.entry.js → p-029ae4e4.entry.js} +1 -1
  127. package/dist/sankhyablocks/p-03f9c407.js +1 -0
  128. package/dist/sankhyablocks/p-112455b1.js +1 -0
  129. package/dist/sankhyablocks/p-12ad2a19.entry.js +1 -0
  130. package/dist/sankhyablocks/p-1feabfc7.entry.js +1 -0
  131. package/dist/sankhyablocks/p-21c8929b.js +1 -0
  132. package/dist/sankhyablocks/p-2284c850.entry.js +1 -0
  133. package/dist/sankhyablocks/p-2b891c4a.entry.js +1 -0
  134. package/dist/sankhyablocks/{p-0ea25487.entry.js → p-2dc76d79.entry.js} +1 -1
  135. package/dist/sankhyablocks/p-361299e8.js +26 -0
  136. package/dist/sankhyablocks/p-366aa0f5.entry.js +1 -0
  137. package/dist/sankhyablocks/p-36d2d9cf.entry.js +75 -0
  138. package/dist/sankhyablocks/{p-6386d720.entry.js → p-3a276f3d.entry.js} +1 -1
  139. package/dist/sankhyablocks/{p-0352c0e2.entry.js → p-44ce5b90.entry.js} +1 -1
  140. package/dist/sankhyablocks/{p-aecf3e0a.entry.js → p-6988f4a6.entry.js} +1 -1
  141. package/dist/sankhyablocks/p-776ff4d1.entry.js +1 -0
  142. package/dist/sankhyablocks/p-7b4a4a50.entry.js +1 -0
  143. package/dist/sankhyablocks/p-9ba3df4c.js +2 -0
  144. package/dist/sankhyablocks/{p-40b27004.entry.js → p-9dc4426d.entry.js} +1 -1
  145. package/dist/sankhyablocks/p-a17a4fca.entry.js +1 -0
  146. package/dist/sankhyablocks/p-a5b26df2.js +1 -0
  147. package/dist/sankhyablocks/p-b6d6b172.js +1 -0
  148. package/dist/sankhyablocks/{p-5bdb8452.entry.js → p-cc4bef9f.entry.js} +1 -1
  149. package/dist/sankhyablocks/{p-2e49afef.entry.js → p-d1ac09c9.entry.js} +1 -1
  150. package/dist/sankhyablocks/p-d50651a3.js +1 -0
  151. package/dist/sankhyablocks/p-d9fbb26f.js +1 -0
  152. package/dist/sankhyablocks/{p-49580cdd.entry.js → p-deb1f523.entry.js} +1 -1
  153. package/dist/sankhyablocks/p-e871aa92.entry.js +1 -0
  154. package/dist/sankhyablocks/{p-ba426ea9.entry.js → p-e9beab79.entry.js} +1 -1
  155. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  156. package/dist/types/components/snk-application/snk-application.d.ts +29 -14
  157. package/dist/types/components/snk-configurator/snk-configurator.d.ts +46 -0
  158. package/dist/types/components/snk-configurator/subcomponents/configModalProvider/configurableElementsStorage.d.ts +8 -0
  159. package/dist/types/components/snk-configurator/subcomponents/snk-config-modal/snk-config-modal.d.ts +38 -0
  160. package/dist/types/components/snk-crud/snk-crud.d.ts +50 -0
  161. package/dist/types/components/snk-data-unit/snk-data-unit.d.ts +92 -0
  162. package/dist/types/components/snk-filter-bar/filter-item/editors/snk-filter-personalized.d.ts +8 -6
  163. package/dist/types/components/snk-filter-bar/filter-item/editors/snk-filter-search.d.ts +3 -3
  164. package/dist/types/components/snk-filter-bar/filter-item/snk-filter-item.d.ts +40 -0
  165. package/dist/types/components/snk-filter-bar/snk-filter-bar.d.ts +65 -0
  166. package/dist/types/components/snk-form/snk-form.d.ts +71 -0
  167. package/dist/types/components/snk-form/subcomponents/snk-config-options/snk-config-options.d.ts +51 -0
  168. package/dist/types/components/snk-form/subcomponents/snk-field-config/snk-field-config.d.ts +32 -0
  169. package/dist/types/components/snk-form/subcomponents/snk-form-config/snk-form-config.d.ts +139 -0
  170. package/dist/types/components/snk-form/subcomponents/snk-tab-config/snk-tab-config.d.ts +97 -0
  171. package/dist/types/components/snk-grid/snk-grid.d.ts +59 -0
  172. package/dist/types/components/snk-taskbar/elements/taskbar-elements.d.ts +6 -5
  173. package/dist/types/components/snk-taskbar/snk-taskbar.d.ts +11 -3
  174. package/dist/types/components.d.ts +358 -13
  175. package/dist/types/lib/http/data-fetcher/fetchers/form-config-fetcher.d.ts +21 -3
  176. package/dist/types/lib/http/data-fetcher/fetchers/resource-fetcher.d.ts +1 -0
  177. package/dist/types/lib/message/resources/snk-configurator.msg.d.ts +2 -0
  178. package/dist/types/lib/message/resources/snk-form.msg.d.ts +5 -2
  179. package/dist/types/lib/utils/constants.d.ts +76 -0
  180. package/dist/types/lib/utils/pesquisa.d.ts +2 -1
  181. package/package.json +4 -3
  182. package/react/components.d.ts +6 -0
  183. package/react/components.js +6 -0
  184. package/react/components.js.map +1 -1
  185. package/dist/cjs/snk-form_2.cjs.entry.js +0 -247
  186. package/dist/esm/snk-form_2.entry.js +0 -242
  187. package/dist/sankhyablocks/p-21e940aa.entry.js +0 -1
  188. package/dist/sankhyablocks/p-2eea7eea.js +0 -1
  189. package/dist/sankhyablocks/p-42036db1.entry.js +0 -84
  190. package/dist/sankhyablocks/p-77216252.entry.js +0 -1
  191. package/dist/sankhyablocks/p-86f15ffe.js +0 -1
  192. package/dist/sankhyablocks/p-97009a2c.entry.js +0 -1
  193. package/dist/sankhyablocks/p-a14c49db.entry.js +0 -1
  194. package/dist/sankhyablocks/p-fac2b6a9.js +0 -2
@@ -0,0 +1,58 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host } from './index-e4121713.js';
2
+ import { ApplicationContext } from '@sankhyalabs/core';
3
+ import { c as VIEW_MODE } from './constants-c6039d3d.js';
4
+ import { C as ConfigurableElementsStorage } from './configurableElementsStorage-cdc144b5.js';
5
+
6
+ const snkConfigModalCss = ".sc-snk-config-modal-h{--snk-config-modal__button-close--padding-left:var(--space--medium, 12px);--snk-config-modal__title--color:var(--title--primary, #2B3A54);--snk-config-modal__title--font-family:var(--font-pattern, \"Sora\");--snk-config-modal__title--font-size:var(--title--large, 20px);--snk-config-modal__title--font-weight:var(--text-weight--extra-large, 700);--snk-config-modal__subtitle--color:var(--title--primary, #2B3A54);--snk-config-modal__subtitle--font-family:var(--font-pattern, \"Sora\");--snk-config-modal__subtitle--font-size:var(--text--medium, 14px);--snk-config-modal__subtitle--font-weight:var(--text-weight--large, 600);--snk-config-modal__scrollbar--border-radius:var(--border--radius-small, 6px);--snk-config-modal__scrollbar--width:var(--space--medium, 12px);--snk-config-modal__scrollbar--background-color-primary:var(--scrollbar--primary, #2B3A54);--snk-config-modal__scrollbar--background-color-secondary:var(--scrollbar--secondary, #E5EAF0);display:grid;grid-template-rows:auto 1fr auto;max-height:100%;width:100%}@media screen and (min-width: 480px){.sc-snk-config-modal-h{width:359px;max-width:359px}}.snk-config-modal__button-config.sc-snk-config-modal{--ez-button--min-width:100%}.snk-config-modal__header.sc-snk-config-modal{display:flex;justify-content:space-between;align-items:center;width:100%}.snk-config-modal__title.sc-snk-config-modal{display:flex;margin:0;line-height:normal;letter-spacing:0em;text-align:left;color:var(--snk-config-modal__title--color);font-size:var(--snk-config-modal__title--font-size);font-family:var(--snk-config-modal__title--font-family);font-weight:var(--snk-config-modal__title--font-weight)}.snk-config-modal__subtitle.sc-snk-config-modal{display:flex;margin:0;padding-top:var(--space--medium);padding-bottom:var(--space--small);color:var(--snk-config-modal__subtitle--color);font-size:var(--snk-config-modal__subtitle--font-size);font-family:var(--snk-config-modal__subtitle--font-family);font-weight:var(--snk-config-modal__subtitle--font-weight)}.snk-config-modal__button-close.sc-snk-config-modal{padding-left:var(--snk-config-modal__button-close--padding-left)}.snk-config-modal__main.sc-snk-config-modal{overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--snk-config-modal__scrollbar--background-color-primary) var(--snk-config-modal__scrollbar--background-color-secondary)}.snk-config-modal__main.sc-snk-config-modal::-webkit-scrollbar-track{background-color:var(--snk-config-modal__scrollbar--background-color-secondary)}.snk-config-modal__main.sc-snk-config-modal::-webkit-scrollbar-thumb{background-color:var(--snk-config-modal__scrollbar--background-color-primary);border-radius:var(--snk-config-modal__scrollbar--border-radius)}.snk-config-modal__main.sc-snk-config-modal::-webkit-scrollbar{background-color:var(--snk-config-modal__scrollbar--background-color-secondary);width:var(--snk-config-modal__scrollbar--width);max-width:var(--snk-config-modal__scrollbar--width);min-width:var(--snk-config-modal__scrollbar--width)}";
7
+
8
+ const GRID_MODE = VIEW_MODE.grid;
9
+ const FORM_MODE = VIEW_MODE.form;
10
+ const SnkConfigModal = class {
11
+ constructor(hostRef) {
12
+ registerInstance(this, hostRef);
13
+ this.cancelConfig = createEvent(this, "cancelConfig", 7);
14
+ this.changeConfig = createEvent(this, "changeConfig", 7);
15
+ /**
16
+ * Define se o modo grid está ativo.
17
+ */
18
+ this.gridMode = true;
19
+ }
20
+ dispatchChange(openConfig = false) {
21
+ const data = {
22
+ viewMode: this.gridMode ? GRID_MODE.index : FORM_MODE.index,
23
+ openConfig
24
+ };
25
+ this.changeConfig.emit(data);
26
+ }
27
+ closeConfig() {
28
+ this.cancelConfig.emit();
29
+ }
30
+ onChecked(evt) {
31
+ const value = evt === null || evt === void 0 ? void 0 : evt.detail;
32
+ this.gridMode = value === "G" ? true : false;
33
+ this.dispatchChange();
34
+ }
35
+ onClicked() {
36
+ this.dispatchChange(true);
37
+ }
38
+ /**
39
+ * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
40
+ * através de um pequeno modulo na estrutura da aplicação:
41
+ * - Criar um arquivo no seguinte caminho: /messages/appmessages.msg.js.
42
+ * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-configurator.msg.ts"
43
+ */
44
+ getMessage(key) {
45
+ return this._application.messagesBuilder.getMessage(key, {});
46
+ }
47
+ componentWillLoad() {
48
+ this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
49
+ }
50
+ render() {
51
+ return (h(Host, null, h("div", { class: "snk-config-modal__header" }, h("label", { class: "snk-config-modal__title" }, this.getMessage("snkConfigModal.titleConfigurations")), h("div", { class: "snk-config-modal__button-close" }, h("ez-button", { mode: 'icon', iconName: "close", size: 'medium', onClick: () => this.closeConfig() }))), h("div", { class: "snk-config-modal__main" }, h("ez-radio-button", { class: "ez-margin-top--medium", label: this.getMessage("snkConfigModal.subTitleModeConfig"), value: this.gridMode ? "G" : "F", onEzChange: (evt) => this.onChecked(evt) }, ConfigurableElementsStorage.getForm(this.configName) && h("ez-radio-button-option", { label: this.getMessage("snkConfigModal.labelGrid"), value: "G" }), ConfigurableElementsStorage.getGrid(this.configName) && h("ez-radio-button-option", { label: this.getMessage("snkConfigModal.labelForm"), value: "F" })), h("ez-button", { mode: "slim", label: this.gridMode
52
+ ? this.getMessage("snkConfigModal.labelConfigGrid")
53
+ : this.getMessage("snkConfigModal.labelConfigForm"), class: "snk-config-modal__button-config ez-button--primary", onClick: () => this.onClicked() }), h("hr", { class: "ez-divider-horizontal ez-margin-vertical--medium" }))));
54
+ }
55
+ };
56
+ SnkConfigModal.style = snkConfigModalCss;
57
+
58
+ export { SnkConfigModal as snk_config_modal };
@@ -0,0 +1,226 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-e4121713.js';
2
+ import { UserInterface, ObjectUtils, ApplicationContext } from '@sankhyalabs/core';
3
+ import { DataType, getConvertedValue } from '@sankhyalabs/core/dist/dataunit/metadata/DataType';
4
+ import { CheckMode } from '@sankhyalabs/ezui/dist/collection/utils';
5
+ import { V as VARS_BY_TYPE, D as DEFAULT_TYPE, a as TAGS_BY_TYPE } from './constants-c6039d3d.js';
6
+
7
+ const snkConfigOptionsCss = ".sc-snk-config-options-h{width:100%;border:2px solid var(--color--secondary-200);border-radius:15px}.config-options__switch-row.sc-snk-config-options{margin-top:-30px}";
8
+
9
+ const SnkConfigOptions = class {
10
+ constructor(hostRef) {
11
+ registerInstance(this, hostRef);
12
+ this.configOptionsChanged = createEvent(this, "configOptionsChanged", 7);
13
+ /**
14
+ * Armazena as propriedades do campo
15
+ */
16
+ this.fieldConfig = {};
17
+ }
18
+ onConfigDefault(optionSelected) {
19
+ if (optionSelected != undefined) {
20
+ this._defaultType = optionSelected;
21
+ this.fieldConfig.defaultValue = {
22
+ type: this._defaultType
23
+ };
24
+ this.configOptionsChanged.emit(this.fieldConfig);
25
+ }
26
+ }
27
+ buildOptions() {
28
+ var _a, _b, _c;
29
+ const interfaceField = (_c = (_a = this.dataUnit) === null || _a === void 0 ? void 0 : _a.getField((_b = this.fieldConfig) === null || _b === void 0 ? void 0 : _b.name)) === null || _c === void 0 ? void 0 : _c.userInterface;
30
+ return VARS_BY_TYPE.UserInterface[interfaceField];
31
+ }
32
+ enabledValueDefault() {
33
+ var _a, _b, _c;
34
+ const field = (_a = this.dataUnit) === null || _a === void 0 ? void 0 : _a.getField((_b = this.fieldConfig) === null || _b === void 0 ? void 0 : _b.name);
35
+ const allowDefault = (_c = field === null || field === void 0 ? void 0 : field.properties) === null || _c === void 0 ? void 0 : _c.allowDefault;
36
+ const hasVariableVar = VARS_BY_TYPE.UserInterface.hasOwnProperty(field === null || field === void 0 ? void 0 : field.userInterface);
37
+ if ((allowDefault == undefined || allowDefault === "true") && hasVariableVar) {
38
+ return true;
39
+ }
40
+ return false;
41
+ }
42
+ isAllowDefault() {
43
+ var _a, _b;
44
+ const allowDefault = (_b = (_a = this._fieldProperties) === null || _a === void 0 ? void 0 : _a.properties) === null || _b === void 0 ? void 0 : _b.allowDefault;
45
+ if (allowDefault == undefined) {
46
+ return true;
47
+ }
48
+ return allowDefault === "true";
49
+ }
50
+ loadDefaultValue() {
51
+ var _a;
52
+ if (this.fieldConfig == undefined) {
53
+ this._defaultType = DEFAULT_TYPE.fixed;
54
+ this.fieldConfig = {
55
+ defaultValue: {
56
+ type: this._defaultType
57
+ }
58
+ };
59
+ }
60
+ else if (((_a = this.fieldConfig.defaultValue) === null || _a === void 0 ? void 0 : _a.type) == undefined) {
61
+ this._defaultType = DEFAULT_TYPE.fixed;
62
+ this.fieldConfig.defaultValue = {
63
+ type: this._defaultType
64
+ };
65
+ }
66
+ else {
67
+ this._defaultType = this.fieldConfig.defaultValue.type;
68
+ }
69
+ }
70
+ getFieldProperties(field) {
71
+ var _a;
72
+ if (field != undefined) {
73
+ return (_a = this.dataUnit) === null || _a === void 0 ? void 0 : _a.getField(field);
74
+ }
75
+ }
76
+ getMessage(key, params) {
77
+ return this._application.messagesBuilder.getMessage(key, params);
78
+ }
79
+ getDefaultType() {
80
+ var _a;
81
+ return (_a = this.fieldConfig.defaultValue.type) !== null && _a !== void 0 ? _a : DEFAULT_TYPE.fixed;
82
+ }
83
+ getEnabledByProperty(property) {
84
+ const properties = this._fieldProperties;
85
+ if (properties != undefined && properties[property] === true) {
86
+ return false;
87
+ }
88
+ return true;
89
+ }
90
+ getValueByProperty(property) {
91
+ const properties = this._fieldProperties;
92
+ if (properties != undefined && properties[property] === true) {
93
+ return true;
94
+ }
95
+ return this.fieldConfig[property];
96
+ }
97
+ getValidatedValue(fieldValue) {
98
+ var _a, _b;
99
+ if (fieldValue == undefined) {
100
+ return;
101
+ }
102
+ const field = (_a = this.dataUnit) === null || _a === void 0 ? void 0 : _a.getField((_b = this.fieldConfig) === null || _b === void 0 ? void 0 : _b.name);
103
+ const dataType = field === null || field === void 0 ? void 0 : field.dataType;
104
+ if (dataType == undefined) {
105
+ return;
106
+ }
107
+ const value = (fieldValue === null || fieldValue === void 0 ? void 0 : fieldValue.waitmessage) != undefined ? undefined :
108
+ dataType !== DataType.OBJECT && dataType !== DataType.DATE
109
+ && typeof fieldValue === "object"
110
+ ? fieldValue.value
111
+ : fieldValue;
112
+ return dataType === DataType.OBJECT ? JSON.stringify(value) : value;
113
+ }
114
+ buildInputDefault({ value, enabled, label, name, required, userInterface }, properties = undefined, mode = undefined) {
115
+ let options;
116
+ let precision = 0;
117
+ let prettyPrecision = 0;
118
+ const TagName = userInterface == undefined || TAGS_BY_TYPE[userInterface] == undefined
119
+ ? TAGS_BY_TYPE.DEFAULT
120
+ : TAGS_BY_TYPE[userInterface];
121
+ if (userInterface === UserInterface.OPTIONSELECTOR) {
122
+ const prop = properties === null || properties === void 0 ? void 0 : properties.options;
123
+ if (typeof prop === "string") {
124
+ const parsed = ObjectUtils.stringToObject(prop);
125
+ options = Object.keys(parsed).map(key => { return { value: key, label: parsed[key] }; });
126
+ }
127
+ else {
128
+ options = prop;
129
+ }
130
+ }
131
+ else if (userInterface === UserInterface.DECIMALNUMBER) {
132
+ precision = Number((properties === null || properties === void 0 ? void 0 : properties.precision) || 2);
133
+ prettyPrecision = Number((properties === null || properties === void 0 ? void 0 : properties.prettyPrecision) || precision);
134
+ }
135
+ return h(TagName, Object.assign({ value: value, enabled: enabled, label: label, "data-field-name": name, key: name, onEzChange: (evt) => this.onChange(evt === null || evt === void 0 ? void 0 : evt.detail) }, (this.getConditionalAttributes(userInterface, required, options, precision, prettyPrecision, mode))));
136
+ }
137
+ getConditionalAttributes(userInterface, required, options, precision, prettyPrecision, mode) {
138
+ switch (userInterface) {
139
+ case UserInterface.SEARCH:
140
+ return {
141
+ suppressEmptyOption: required,
142
+ optionLoader: (searchArgument) => this.onSearch(searchArgument)
143
+ };
144
+ case UserInterface.OPTIONSELECTOR:
145
+ return {
146
+ suppressEmptyOption: required,
147
+ options
148
+ };
149
+ case UserInterface.CHECKBOX:
150
+ case UserInterface.SWITCH:
151
+ return {
152
+ mode
153
+ };
154
+ case UserInterface.INTEGERNUMBER:
155
+ case UserInterface.DECIMALNUMBER:
156
+ return {
157
+ precision,
158
+ prettyPrecision,
159
+ onEzStartChange: (evt) => this.onChange(evt === null || evt === void 0 ? void 0 : evt.detail)
160
+ };
161
+ case UserInterface.DATE:
162
+ case UserInterface.DATETIME:
163
+ case UserInterface.TIME:
164
+ return {
165
+ onEzStartChange: (evt) => this.onChange(evt === null || evt === void 0 ? void 0 : evt.detail)
166
+ };
167
+ default:
168
+ return {};
169
+ }
170
+ }
171
+ onChange(fieldValue) {
172
+ this.fieldConfig.defaultValue.value = this.getValidatedValue(fieldValue);
173
+ this.configOptionsChanged.emit(this.fieldConfig);
174
+ }
175
+ onSearch(searchArgument) {
176
+ if (this._application != undefined && this.fieldConfig != undefined) {
177
+ return this._application.executeSearch(searchArgument, this.fieldConfig.name, this.dataUnit);
178
+ }
179
+ }
180
+ buildField(field) {
181
+ const { config, descriptor } = field;
182
+ const { name, label, readOnly, required, defaultValue } = config;
183
+ const { userInterface, properties } = descriptor;
184
+ const enabled = (properties === null || properties === void 0 ? void 0 : properties.allowDefault) != undefined ? properties.allowDefault === "true" : !readOnly;
185
+ let value;
186
+ if (enabled) {
187
+ value = defaultValue === null || defaultValue === void 0 ? void 0 : defaultValue.value;
188
+ if (value != undefined) {
189
+ value = getConvertedValue(descriptor === null || descriptor === void 0 ? void 0 : descriptor.dataType, value);
190
+ }
191
+ }
192
+ const configField = { value, enabled, label, name, required, userInterface };
193
+ switch (userInterface) {
194
+ case UserInterface.SWITCH:
195
+ return this.buildInputDefault(configField, undefined, CheckMode.SWITCH);
196
+ case UserInterface.CHECKBOX:
197
+ return this.buildInputDefault(configField, undefined, CheckMode.REGULAR);
198
+ case UserInterface.OPTIONSELECTOR:
199
+ case UserInterface.DECIMALNUMBER:
200
+ return this.buildInputDefault(configField, properties);
201
+ default:
202
+ return this.buildInputDefault(configField);
203
+ }
204
+ }
205
+ componentWillLoad() {
206
+ var _a;
207
+ this.loadDefaultValue();
208
+ this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
209
+ this._fieldProperties = this.getFieldProperties((_a = this.fieldConfig) === null || _a === void 0 ? void 0 : _a.name);
210
+ }
211
+ render() {
212
+ var _a, _b;
213
+ return (h(Host, null, h("div", { id: this.idConfig }, h("div", { class: "ez-row ez-padding--medium" }, h("div", { class: "ez-col ez-col--sd-12 ez-col--tb-4 ez-padding--small" }, h("ez-text-input", { label: this.getMessage("snkConfigOptions.label.nameField"), value: (_a = this.fieldConfig) === null || _a === void 0 ? void 0 : _a.label, onEzChange: (evt) => { this.fieldConfig.label = evt.detail; this.configOptionsChanged.emit(this.fieldConfig); } })), h("div", { class: "ez-col ez-col--sd-12 ez-col--tb-4 ez-padding--small" }, h("ez-combo-box", { label: this.getMessage("snkConfigOptions.label.typeValueDefault"), suppressEmptyOption: true, enabled: this.enabledValueDefault(), onEzChange: (evt) => { var _a; return this.onConfigDefault((_a = evt.detail) === null || _a === void 0 ? void 0 : _a.value); }, value: this.getDefaultType() }, h("option", { value: DEFAULT_TYPE.fixed }, this.getMessage("snkConfigOptions.options.valueFixed")), h("option", { value: DEFAULT_TYPE.variable }, this.getMessage("snkConfigOptions.options.variable")))), h("div", { class: "ez-col ez-col--sd-12 ez-col--tb-4 ez-padding--small" }, this._defaultType === DEFAULT_TYPE.variable ?
214
+ h("ez-combo-box", { label: this.getMessage("snkConfigOptions.label.valueDefault"), enabled: this.isAllowDefault(), onEzChange: (evt) => { var _a; this.fieldConfig.defaultValue.value = (_a = evt.detail) === null || _a === void 0 ? void 0 : _a.value; this.configOptionsChanged.emit(this.fieldConfig); }, value: this.fieldConfig.defaultValue.value, options: this.buildOptions() })
215
+ :
216
+ ((_b = this._fieldProperties) === null || _b === void 0 ? void 0 : _b.userInterface) &&
217
+ this.buildField({
218
+ descriptor: this._fieldProperties,
219
+ config: this.fieldConfig
220
+ }))), h("div", { class: "ez-row ez-padding--medium config-options__switch-row" }, h("div", { class: "ez-col ez-col--sd-12 ez-col--tb-4 ez-padding--small" }, h("ez-check", { mode: CheckMode.SWITCH, label: this.getMessage("snkConfigOptions.label.clearDuplicate"), value: this.fieldConfig.cleanOnCopy, onEzChange: (evt) => { this.fieldConfig.cleanOnCopy = evt.detail; this.configOptionsChanged.emit(this.fieldConfig); } })), h("div", { class: "ez-col ez-col--sd-12 ez-col--tb-4 ez-padding--small" }, h("ez-check", { mode: CheckMode.SWITCH, label: this.getMessage("snkConfigOptions.label.requiredField"), enabled: this.getEnabledByProperty("required"), value: this.getValueByProperty("required"), onEzChange: (evt) => { this.fieldConfig.required = evt.detail; this.configOptionsChanged.emit(this.fieldConfig); } })), h("div", { class: "ez-col ez-col--sd-12 ez-col--tb-4 ez-padding--small" }, h("ez-check", { mode: CheckMode.SWITCH, label: this.getMessage("snkConfigOptions.label.protectedField"), enabled: this.getEnabledByProperty("readOnly"), value: this.getValueByProperty("readOnly"), onEzChange: (evt) => { this.fieldConfig.readOnly = evt.detail; this.configOptionsChanged.emit(this.fieldConfig); } }))))));
221
+ }
222
+ get _element() { return getElement(this); }
223
+ };
224
+ SnkConfigOptions.style = snkConfigOptionsCss;
225
+
226
+ export { SnkConfigOptions as snk_config_options };
@@ -1,9 +1,194 @@
1
- import { r as registerInstance, h, H as Host, g as getElement, c as createEvent } from './index-81dda3cf.js';
2
- import { DataType, ObjectUtils, StringUtils, ErrorException, ApplicationContext, FloatingManager, ArrayUtils } from '@sankhyalabs/core';
1
+ import { r as registerInstance, c as createEvent, h, g as getElement, H as Host } from './index-e4121713.js';
2
+ import { ObjectUtils, ApplicationContext, DataType, StringUtils, ErrorException, FloatingManager, ArrayUtils } from '@sankhyalabs/core';
3
+ import { ApplicationUtils, CheckMode } from '@sankhyalabs/ezui/dist/collection/utils';
4
+ import { C as CONFIG_EVENTS, c as VIEW_MODE } from './constants-c6039d3d.js';
5
+ import { C as ConfigurableElementsStorage } from './configurableElementsStorage-cdc144b5.js';
3
6
  import { F as FilterItemType } from './filter-item-type.enum-a79b2fa8.js';
4
7
  import { ModalAction, ModalButtonStatus } from '@sankhyalabs/ezui/dist/collection/components/ez-modal-container';
5
8
  import { toString } from '@sankhyalabs/core/dist/dataunit/metadata/DataType';
6
- import { T as TaskbarElement, V as VisibleWhenForbidden, A as AuthorizationElements, b as buildElem, a as buildCustomButton } from './taskbar-elements-38eb5d51.js';
9
+ import { T as TaskbarElement, V as VisibleWhenForbidden, A as AuthorizationElements, b as buildElem, a as buildCustomButton } from './taskbar-elements-e2ed0536.js';
10
+
11
+ const GRID_MODE = VIEW_MODE.grid;
12
+ const FORM_MODE = VIEW_MODE.form;
13
+ const SnkConfigurator = class {
14
+ constructor(hostRef) {
15
+ registerInstance(this, hostRef);
16
+ this.changeViewMode = createEvent(this, "changeViewMode", 7);
17
+ /**
18
+ * Nome do componente que será vinculado ao `data-configurator-parent` para controlar o modal de configurações.
19
+ */
20
+ this.name = "snkConfigurator";
21
+ /**
22
+ * Define se o campo está habilitado.
23
+ */
24
+ this.enabled = true;
25
+ }
26
+ /**
27
+ * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
28
+ * através de um pequeno modulo na estrutura da aplicação:
29
+ * - Criar um arquivo no seguinte caminho: /messages/appmessages.msg.js.
30
+ * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-configurator.msg.ts"
31
+ */
32
+ getMessage(key) {
33
+ return this._application.messagesBuilder.getMessage(key, {});
34
+ }
35
+ controlConfigModal(opened) {
36
+ var _a;
37
+ if (this._modal != undefined) {
38
+ this._modal.opened = opened;
39
+ if (this._configModal != undefined) {
40
+ this._configModal.gridMode = ((_a = this._grid) === null || _a === void 0 ? void 0 : _a.offsetParent) != undefined;
41
+ }
42
+ }
43
+ }
44
+ changeConfigModal(evt) {
45
+ const data = evt === null || evt === void 0 ? void 0 : evt.detail;
46
+ if (data === null || data === void 0 ? void 0 : data.openConfig) {
47
+ this.controlConfigModal(false);
48
+ this.callShowConfig(data === null || data === void 0 ? void 0 : data.viewMode);
49
+ }
50
+ else if ((data === null || data === void 0 ? void 0 : data.viewMode) === GRID_MODE.index) {
51
+ this.changeViewMode.emit(GRID_MODE.name);
52
+ }
53
+ else if ((data === null || data === void 0 ? void 0 : data.viewMode) === FORM_MODE.index) {
54
+ this.changeViewMode.emit(FORM_MODE.name);
55
+ }
56
+ }
57
+ callShowConfig(viewMode) {
58
+ if (viewMode === GRID_MODE.index) {
59
+ if (this._grid == undefined) {
60
+ this.findGrid();
61
+ }
62
+ if (this._grid != undefined) {
63
+ this._grid.setShowGridConfig(true);
64
+ }
65
+ }
66
+ else if (viewMode === FORM_MODE.index) {
67
+ if (this._form == undefined) {
68
+ this.findForm();
69
+ }
70
+ if (this._form != undefined) {
71
+ this._form.setShowFormConfig(true);
72
+ }
73
+ }
74
+ }
75
+ getConfigModal() {
76
+ const modalContainer = document.createElement("ez-modal");
77
+ modalContainer.modalSize = "small";
78
+ modalContainer.opened = false;
79
+ modalContainer.closeEsc = false;
80
+ modalContainer.closeOutsideClick = false;
81
+ modalContainer.dataset.configuratorModal = this.name;
82
+ modalContainer.addEventListener(CONFIG_EVENTS.closeModal, () => {
83
+ this.controlConfigModal(false);
84
+ });
85
+ const modalContent = document.createElement("snk-config-modal");
86
+ modalContent.addEventListener(CONFIG_EVENTS.cancelConfig, () => {
87
+ this.controlConfigModal(false);
88
+ });
89
+ modalContent.addEventListener(CONFIG_EVENTS.changeConfig, (evt) => {
90
+ this.changeConfigModal(evt);
91
+ });
92
+ modalContent.configName = this.configName;
93
+ modalContainer.append(modalContent);
94
+ return modalContainer;
95
+ }
96
+ findConfigModal() {
97
+ let modalContainer = document.body.querySelector(`[data-configurator-modal="${this.name}"]`);
98
+ if (modalContainer == undefined) {
99
+ modalContainer = this.getConfigModal();
100
+ document.body.appendChild(modalContainer);
101
+ }
102
+ this._modal = modalContainer;
103
+ this._configModal = modalContainer.querySelector("snk-config-modal");
104
+ }
105
+ findGrid() {
106
+ if (this._grid != undefined) {
107
+ return;
108
+ }
109
+ this._grid = ConfigurableElementsStorage.getGrid(this.configName);
110
+ if (this._grid != undefined && this._grid.dataset.eventConfigChanged == undefined) {
111
+ this._grid.dataset.eventConfigChanged = "true";
112
+ this._grid.addEventListener(CONFIG_EVENTS.configChanged, (evt) => {
113
+ this.saveConfig(evt);
114
+ });
115
+ }
116
+ }
117
+ findForm() {
118
+ if (this._form != undefined) {
119
+ return;
120
+ }
121
+ this._form = ConfigurableElementsStorage.getForm(this.configName);
122
+ if (this._form != undefined && this._form.dataset.eventConfigChanged == undefined) {
123
+ this._form.dataset.eventConfigChanged = "true";
124
+ this._form.addEventListener(CONFIG_EVENTS.configChanged, (evt) => {
125
+ this.saveConfig(evt);
126
+ });
127
+ }
128
+ }
129
+ saveConfig(evt) {
130
+ const config = evt === null || evt === void 0 ? void 0 : evt.detail;
131
+ if (this._application != undefined && config != undefined) {
132
+ if ((config === null || config === void 0 ? void 0 : config.fields) != undefined) {
133
+ this._application.saveFormConfig(config, this.configName)
134
+ .then((response) => {
135
+ if ((response === null || response === void 0 ? void 0 : response.resource) != undefined) {
136
+ this.loadFormConfig(true);
137
+ }
138
+ });
139
+ }
140
+ else if ((config === null || config === void 0 ? void 0 : config.columns) != undefined) {
141
+ this._application.saveGridConfig(config)
142
+ .then((response) => {
143
+ if ((response === null || response === void 0 ? void 0 : response.resource) != undefined) {
144
+ this.setGridConfig(response.resource);
145
+ }
146
+ });
147
+ }
148
+ }
149
+ }
150
+ setGridConfig(strConfig) {
151
+ if (this._grid != undefined) {
152
+ const config = ObjectUtils.stringToObject(strConfig);
153
+ this._grid.setConfig(config).then(() => {
154
+ ApplicationUtils.info(this.getMessage("snkConfigurator.msgSaveSuccessfully"), { iconName: "check" });
155
+ });
156
+ }
157
+ }
158
+ loadGridConfig() {
159
+ if (this._application != undefined && this.configName != undefined && this._grid != undefined) {
160
+ this._application.loadGridConfig(this.configName).then((config) => {
161
+ this._grid.setConfig(config);
162
+ });
163
+ }
164
+ }
165
+ loadFormConfig(showInfoSuccess = false) {
166
+ if (this._application != undefined && this.configName != undefined && this._form != undefined) {
167
+ this._application.loadFormConfig(this.configName).then((config) => {
168
+ this._form.setConfig(config).then(() => {
169
+ if (showInfoSuccess) {
170
+ ApplicationUtils.info(this.getMessage("snkConfigurator.msgSaveSuccessfully"), { iconName: "check" });
171
+ }
172
+ });
173
+ });
174
+ }
175
+ }
176
+ loadConfig() {
177
+ this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
178
+ this.loadGridConfig();
179
+ this.loadFormConfig();
180
+ }
181
+ componentDidLoad() {
182
+ this.findConfigModal();
183
+ this.findGrid();
184
+ this.findForm();
185
+ this.loadConfig();
186
+ }
187
+ render() {
188
+ return (h("ez-button", { mode: "icon", iconName: "settings-inverted", size: "small", enabled: this.enabled, onClick: () => this.controlConfigModal(true) }));
189
+ }
190
+ get _element() { return getElement(this); }
191
+ };
7
192
 
8
193
  const buildFilter = (item) => {
9
194
  switch (item.type) {
@@ -102,7 +287,7 @@ function buildPersonalized(item) {
102
287
  };
103
288
  }
104
289
 
105
- const snkFilterBarCss = ".sc-snk-filter-bar-h{display:grid;grid-template-columns:minmax(100px, 100%) 1fr 1fr}.snk-filter__popover-container.sc-snk-filter-bar{display:flex;cursor:auto}.snk-filter__popover.sc-snk-filter-bar{display:flex;flex-direction:column;position:absolute;width:fit-content;height:fit-content;min-width:265px;z-index:var(--more-visible, 1);background-color:var(--background--xlight, #fff);border-radius:var(--border--radius-medium, 12px);box-shadow:var(--shadow, 0px 0px 16px 0px #000)}.snk-filter-item__editor-header.sc-snk-filter-bar{flex-grow:1;font-weight:var(--text-weight--medium, 400);color:var(--color--title-primary, #2B3A54)}.snk-filter__popover-rule.sc-snk-filter-bar{border-style:solid;border-color:var(--color--disable-secondary, #F2F5F8);border-radius:1px;border-width:1px;width:100%}.editor__ez-check.sc-snk-filter-bar{--ez-check__label--padding-left:0}.snk-filter-item__editor-header-button.sc-snk-filter-bar{cursor:pointer;background-color:transparent;border:none;padding:3px;outline-color:var(--color--primary)}.snk-filter-bar__divider.sc-snk-filter-bar{margin-bottom:var(--space--small)}.snk-filter-bar__filter-list-items-container.sc-snk-filter-bar{overflow-y:auto;max-height:360px;margin-top:var(--space--small, 6px)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar{cursor:pointer;border-radius:var(--border--radius-small, 6px);border:none;background-color:transparent}.snk-filter-bar__filter-list-item__label.sc-snk-filter-bar{color:var(--title--primary)}.snk-filter-bar__filter-list-item__label--secondary.sc-snk-filter-bar{color:var(--text--primary)}.snk-filter-bar__filter-list-item__icon.sc-snk-filter-bar{--ez-icon--color:var(--title--primary)}.snk-filter-bar__filter-list-item__icon--secondary.sc-snk-filter-bar{--ez-icon--color:var(--text--secondary)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar:focus-visible{outline:none;background-color:var(--background--medium)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar:hover{background-color:var(--background--medium)}.snk-filter-bar__filter-list-items-container--empty.sc-snk-filter-bar{width:100%;height:100px;display:flex;justify-content:center;align-self:center;align-items:center}.snk-filter-bar__filter-list-items-button--active.sc-snk-filter-bar{position:relative}.snk-filter-bar__filter-list-items-button--active.sc-snk-filter-bar::after{display:flex;position:absolute;content:\"\";width:8px;height:8px;top:7px;left:17px;background-color:var(--icon--alert--color, #008561);border-radius:50%}.snk-filter-bar__filter-modal-item.sc-snk-filter-bar{--modal-item-border-width:2px;display:flex;flex-direction:row;margin-left:var(--modal-item-border-width);border-radius:var(--border--radius-medium, 12px);background-color:var(--background--medium, #f0f3f7);border:none;width:100%}.snk-filter-bar__filter-modal-item.sc-snk-filter-bar:focus-visible{outline:var(--color--primary) solid var(--modal-item-border-width)}.snk-filter-bar__filter-modal-item__check.sc-snk-filter-bar{width:auto}.snk-filter-bar__filter-modal-item__label.sc-snk-filter-bar{font-weight:var(--text-weight--medium)}.snk-filter-bar__filter-modal-content.sc-snk-filter-bar{display:grid;grid-template-rows:auto auto 1fr auto;width:100%;height:100%}";
290
+ const snkFilterBarCss = ".sc-snk-filter-bar-h{display:grid;grid-template-columns:minmax(100px, 100%) 1fr 1fr}.snk-filter__popover-container.sc-snk-filter-bar{display:flex;cursor:auto}.snk-filter__popover.sc-snk-filter-bar{display:flex;flex-direction:column;position:absolute;width:fit-content;height:fit-content;min-width:265px;z-index:var(--more-visible, 2);background-color:var(--background--xlight, #fff);border-radius:var(--border--radius-medium, 12px);box-shadow:var(--shadow, 0px 0px 16px 0px #000)}.snk-filter-item__editor-header.sc-snk-filter-bar{flex-grow:1;font-weight:var(--text-weight--medium, 400);color:var(--color--title-primary, #2B3A54)}.snk-filter__popover-rule.sc-snk-filter-bar{border-style:solid;border-color:var(--color--disable-secondary, #F2F5F8);border-radius:1px;border-width:1px;width:100%}.editor__ez-check.sc-snk-filter-bar{--ez-check__label--padding-left:0}.snk-filter-item__editor-header-button.sc-snk-filter-bar{cursor:pointer;background-color:transparent;border:none;padding:3px;outline-color:var(--color--primary)}.snk-filter-bar__divider.sc-snk-filter-bar{margin-bottom:var(--space--small)}.snk-filter-bar__filter-list-items-container.sc-snk-filter-bar{overflow-y:auto;max-height:360px;margin-top:var(--space--small, 6px)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar{cursor:pointer;border-radius:var(--border--radius-small, 6px);border:none;background-color:transparent}.snk-filter-bar__filter-list-item__label.sc-snk-filter-bar{color:var(--title--primary)}.snk-filter-bar__filter-list-item__label--secondary.sc-snk-filter-bar{color:var(--text--primary)}.snk-filter-bar__filter-list-item__icon.sc-snk-filter-bar{--ez-icon--color:var(--title--primary)}.snk-filter-bar__filter-list-item__icon--secondary.sc-snk-filter-bar{--ez-icon--color:var(--text--secondary)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar:focus-visible{outline:none;background-color:var(--background--medium)}.snk-filter-bar__filter-list-item.sc-snk-filter-bar:hover{background-color:var(--background--medium)}.snk-filter-bar__filter-list-items-container--empty.sc-snk-filter-bar{width:100%;height:100px;display:flex;justify-content:center;align-self:center;align-items:center}.snk-filter-bar__filter-list-items-button--active.sc-snk-filter-bar{position:relative}.snk-filter-bar__filter-list-items-button--active.sc-snk-filter-bar::after{display:flex;position:absolute;content:\"\";width:8px;height:8px;top:7px;left:17px;background-color:var(--icon--alert--color, #008561);border-radius:50%}.snk-filter-bar__filter-modal-item.sc-snk-filter-bar{--modal-item-border-width:2px;display:flex;flex-direction:row;margin-left:var(--modal-item-border-width);border-radius:var(--border--radius-medium, 12px);background-color:var(--background--medium, #f0f3f7);border:none;width:100%}.snk-filter-bar__filter-modal-item.sc-snk-filter-bar:focus-visible{outline:var(--color--primary) solid var(--modal-item-border-width)}.snk-filter-bar__filter-modal-item__check.sc-snk-filter-bar{width:auto}.snk-filter-bar__filter-modal-item__label.sc-snk-filter-bar{font-weight:var(--text-weight--medium)}.snk-filter-bar__filter-modal-content.sc-snk-filter-bar{display:grid;grid-template-rows:auto auto 1fr auto;width:100%;height:100%}";
106
291
 
107
292
  const PERSONALIZED_FILTER = "PERSONALIZED_FILTER";
108
293
  const DEFAULT_FILTER = "DEFAULT_FILTER";
@@ -778,7 +963,7 @@ const SnkFilterModal = class {
778
963
  }
779
964
  buildItems(list) {
780
965
  return list.map(item => {
781
- return (h("button", { onClick: () => this.updateValue(item.id), class: "ez-padding--medium sc-snk-filter-bar snk-filter-bar__filter-modal-item ez-align--middle ez-margin-bottom--small" }, h("ez-check", { id: `checkbox_${item.id}`, tabIndex: "-1", class: "sc-snk-filter-bar snk-filter-bar__filter-modal-item__check", onEzChange: evt => this.updateValue(item.id, evt.detail), enabled: item.enabled, value: item.active, mode: "switch" }), h("div", { class: "ez-text ez-title--primary ez-text--medium ez-margin-left--medium sc-snk-filter-bar snk-filter-bar__filter-modal-item__label" }, item.label)));
966
+ return (h("button", { onClick: () => this.updateValue(item.id), class: "ez-padding--medium sc-snk-filter-bar snk-filter-bar__filter-modal-item ez-align--middle ez-margin-bottom--small" }, h("ez-check", { id: `checkbox_${item.id}`, tabIndex: "-1", class: "sc-snk-filter-bar snk-filter-bar__filter-modal-item__check", onEzChange: evt => this.updateValue(item.id, evt.detail), enabled: item.enabled, value: item.active, mode: CheckMode.SWITCH }), h("div", { class: "ez-text ez-title--primary ez-text--medium ez-margin-left--medium sc-snk-filter-bar snk-filter-bar__filter-modal-item__label" }, item.label)));
782
967
  });
783
968
  }
784
969
  itemKeyBoardSelect(event, item) {
@@ -813,6 +998,7 @@ const SnkTaskbar = class {
813
998
  constructor(hostRef) {
814
999
  registerInstance(this, hostRef);
815
1000
  this.actionClick = createEvent(this, "actionClick", 7);
1001
+ this.actionChange = createEvent(this, "actionChange", 7);
816
1002
  this._titleKeyByElement = {
817
1003
  [TaskbarElement.UPDATE]: "snkTaskbar.titleUpdate",
818
1004
  [TaskbarElement.PREVIOUS]: "snkTaskbar.titlePrevious",
@@ -825,8 +1011,8 @@ const SnkTaskbar = class {
825
1011
  [TaskbarElement.CANCEL]: "snkTaskbar.titleCancel",
826
1012
  [TaskbarElement.SAVE]: "snkTaskbar.titleSave",
827
1013
  [TaskbarElement.GRID_MODE]: "snkTaskbar.titleGridMode",
828
- [TaskbarElement.CONFIG_GRID]: "snkTaskbar.titleConfigGrid",
829
- [TaskbarElement.FORM_MODE]: "snkTaskbar.titleFormMode"
1014
+ [TaskbarElement.FORM_MODE]: "snkTaskbar.titleFormMode",
1015
+ [TaskbarElement.CONFIGURATOR]: "snkTaskbar.titleConfigurator"
830
1016
  };
831
1017
  }
832
1018
  observeButtons() {
@@ -910,7 +1096,7 @@ const SnkTaskbar = class {
910
1096
  className += "ez-padding-left--medium";
911
1097
  }
912
1098
  if (TaskbarElement[def.toString()]) {
913
- return buildElem(def, className, elem => this.getTitle(elem), elem => this.elementClick(elem), elem => this.isEnabled(elem), this.actionsList);
1099
+ return buildElem(def, className, elem => this.getTitle(elem), elem => this.elementClick(elem), elem => this.isEnabled(elem), this.actionsList, this.configName);
914
1100
  }
915
1101
  else {
916
1102
  return buildCustomButton(def, className, elem => this.elementClick(elem), elem => this.isEnabled(elem));
@@ -958,4 +1144,4 @@ const SnkTaskbar = class {
958
1144
  };
959
1145
  SnkTaskbar.style = snkTaskbarCss;
960
1146
 
961
- export { SnkFilterBar as snk_filter_bar, SnkFilterItem as snk_filter_item, SnkFilterList as snk_filter_list, SnkFilterModal as snk_filter_modal, SnkTaskbar as snk_taskbar };
1147
+ export { SnkConfigurator as snk_configurator, SnkFilterBar as snk_filter_bar, SnkFilterItem as snk_filter_item, SnkFilterList as snk_filter_list, SnkFilterModal as snk_filter_modal, SnkTaskbar as snk_taskbar };
@@ -1,10 +1,12 @@
1
- import { r as registerInstance, c as createEvent, h, g as getElement } from './index-81dda3cf.js';
1
+ import { r as registerInstance, c as createEvent, h, g as getElement } from './index-e4121713.js';
2
2
  import { ApplicationContext } from '@sankhyalabs/core';
3
+ import { c as VIEW_MODE } from './constants-c6039d3d.js';
4
+ import { T as TaskbarElement } from './taskbar-elements-e2ed0536.js';
3
5
 
4
6
  const snkCrudCss = ".sc-snk-crud-h{display:flex;flex-direction:column;height:100%;width:100%}";
5
7
 
6
- const GRID_MODE = 0;
7
- const FORM_MODE = 1;
8
+ const GRID_MODE = VIEW_MODE.grid;
9
+ const FORM_MODE = VIEW_MODE.form;
8
10
  const SnkCrud = class {
9
11
  constructor(hostRef) {
10
12
  registerInstance(this, hostRef);
@@ -17,15 +19,15 @@ const SnkCrud = class {
17
19
  this.executeAction(mode);
18
20
  }
19
21
  async gridToForm(keepFormMode = false) {
20
- this._backToGrid = !keepFormMode && await this._viewStack.getSelectedIndex() === GRID_MODE;
21
- this._viewStack.show(FORM_MODE);
22
+ this._backToGrid = !keepFormMode && await this._viewStack.getSelectedIndex() === GRID_MODE.index;
23
+ this._viewStack.show(FORM_MODE.index);
22
24
  }
23
25
  async executeAction(act) {
24
- if (act === "GRID_MODE") {
25
- this._viewStack.show(GRID_MODE);
26
+ if (act === TaskbarElement.GRID_MODE) {
27
+ this._viewStack.show(GRID_MODE.index);
26
28
  }
27
- else if (act === "FORM_MODE" || act === "UPDATE") {
28
- this.gridToForm(act !== "UPDATE");
29
+ else if (act === TaskbarElement.FORM_MODE || act === TaskbarElement.UPDATE) {
30
+ this.gridToForm(act !== TaskbarElement.UPDATE);
29
31
  }
30
32
  }
31
33
  insertionModeHandler() {
@@ -33,7 +35,7 @@ const SnkCrud = class {
33
35
  }
34
36
  cancelHandler() {
35
37
  if (this._backToGrid) {
36
- this._viewStack.show(GRID_MODE);
38
+ this._viewStack.show(GRID_MODE.index);
37
39
  }
38
40
  }
39
41
  componentWillLoad() {
@@ -63,7 +65,7 @@ const SnkCrud = class {
63
65
  }
64
66
  }
65
67
  render() {
66
- return (h("ez-view-stack", { ref: (ref) => this._viewStack = ref }, h("stack-item", null, h("snk-grid", { configName: this.configName, onGridDoubleClick: () => this.gridToForm(true), taskbarManager: this.taskbarManager, onActionClick: evt => this.executeAction(evt.detail), actionsList: this.actionsList, statusResolver: this.statusResolver }, h("slot", { name: "SnkGridHeader" }), h("slot", { name: "SnkGridFooter" }), h("slot", { name: "SnkGridTaskBar" }))), h("stack-item", null, h("snk-form", { configName: this.configName, actionsList: this.actionsList, onExit: () => this._viewStack.show(GRID_MODE), recordsValidator: this.recordsValidator, taskbarManager: this.taskbarManager, onActionClick: evt => this.executeAction(evt.detail) }, h("slot", { name: "SnkFormTaskBar" })))));
68
+ return (h("ez-view-stack", { ref: (ref) => this._viewStack = ref, "data-configurator-parent": "snkConfigurator" }, h("stack-item", null, h("snk-grid", { configName: this.configName, onGridDoubleClick: () => this.gridToForm(true), taskbarManager: this.taskbarManager, onActionClick: evt => this.executeAction(evt.detail), actionsList: this.actionsList, statusResolver: this.statusResolver }, h("slot", { name: "SnkGridHeader" }), h("slot", { name: "SnkGridFooter" }), h("slot", { name: "SnkGridTaskBar" }))), h("stack-item", null, h("snk-form", { configName: this.configName, actionsList: this.actionsList, onExit: () => this._viewStack.show(GRID_MODE.index), recordsValidator: this.recordsValidator, taskbarManager: this.taskbarManager, onActionClick: evt => this.executeAction(evt.detail) }, h("slot", { name: "SnkFormTaskBar" })))));
67
69
  }
68
70
  get _element() { return getElement(this); }
69
71
  };
@@ -1,7 +1,7 @@
1
- import { r as registerInstance, c as createEvent, h, g as getElement, H as Host } from './index-81dda3cf.js';
1
+ import { r as registerInstance, c as createEvent, h, g as getElement, H as Host } from './index-e4121713.js';
2
2
  import { Action, ApplicationContext } from '@sankhyalabs/core';
3
3
  import { ApplicationUtils, DialogType } from '@sankhyalabs/ezui/dist/collection/utils';
4
- import { O as OperationMap } from './SnkMessageBuilder-d440381c.js';
4
+ import { O as OperationMap } from './SnkMessageBuilder-5792c260.js';
5
5
 
6
6
  const snkDataUnitCss = ".sc-snk-data-unit-h{display:flex;flex-direction:column;height:100%}";
7
7