@sankhyalabs/sankhyablocks 5.5.0 → 5.6.0

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 (122) hide show
  1. package/dist/cjs/{SnkMessageBuilder-26da04f7.js → SnkMessageBuilder-e64dce7f.js} +14 -0
  2. package/dist/cjs/index-8d94b7e0.js +7 -0
  3. package/dist/cjs/index-de79181a.js +201 -0
  4. package/dist/cjs/loader.cjs.js +1 -1
  5. package/dist/cjs/sankhyablocks.cjs.js +1 -1
  6. package/dist/cjs/snk-application.cjs.entry.js +1 -1
  7. package/dist/cjs/snk-attach.cjs.entry.js +2 -1
  8. package/dist/cjs/snk-crud.cjs.entry.js +2 -1
  9. package/dist/cjs/snk-data-exporter.cjs.entry.js +2 -2
  10. package/dist/cjs/{snk-data-unit-c43df27b.js → snk-data-unit-85d6565e.js} +1 -1
  11. package/dist/cjs/snk-data-unit.cjs.entry.js +2 -2
  12. package/dist/cjs/snk-detail-view.cjs.entry.js +4 -3
  13. package/dist/cjs/snk-expression-item.cjs.entry.js +213 -0
  14. package/dist/cjs/snk-filter-field-search_2.cjs.entry.js +435 -0
  15. package/dist/cjs/snk-grid.cjs.entry.js +3 -2
  16. package/dist/cjs/{snk-guides-viewer-e6a65393.js → snk-guides-viewer-9784c527.js} +1 -1
  17. package/dist/cjs/snk-guides-viewer.cjs.entry.js +3 -2
  18. package/dist/cjs/snk-personalized-filter.cjs.entry.js +126 -0
  19. package/dist/cjs/snk-simple-bar_2.cjs.entry.js +2 -1
  20. package/dist/cjs/snk-taskbar.cjs.entry.js +2 -1
  21. package/dist/cjs/taskbar-elements-bc2598f9.js +118 -0
  22. package/dist/collection/collection-manifest.json +2 -0
  23. package/dist/collection/components/snk-filter-field-search/snk-filter-field-search.js +62 -69
  24. package/dist/collection/components/snk-personalized-filter/snk-personalized-filter.css +4 -0
  25. package/dist/collection/components/snk-personalized-filter/snk-personalized-filter.js +87 -0
  26. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-item/filter-operands/filter-operands.js +34 -0
  27. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.css +97 -0
  28. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.js +298 -0
  29. package/dist/collection/components/snk-personalized-filter/subcomponents/snk-filter-param-config/snk-filter-param-config.js +2 -2
  30. package/dist/collection/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.js +63 -0
  31. package/dist/collection/lib/message/SnkMessageBuilder.js +2 -0
  32. package/dist/collection/lib/message/resources/snk-personalized-filter.msg.js +12 -0
  33. package/dist/collection/lib/store/index.js +2 -1
  34. package/dist/components/SnkMessageBuilder.js +14 -0
  35. package/dist/components/index.d.ts +2 -0
  36. package/dist/components/index.js +2 -0
  37. package/dist/components/index2.js +1 -1
  38. package/dist/components/index3.js +199 -0
  39. package/dist/components/snk-data-exporter2.js +1 -1
  40. package/dist/components/snk-expression-item.d.ts +11 -0
  41. package/dist/components/snk-expression-item.js +6 -0
  42. package/dist/components/snk-expression-item2.js +241 -0
  43. package/dist/components/snk-filter-field-search.js +1 -200
  44. package/dist/{esm/snk-filter-field-search.entry.js → components/snk-filter-field-search2.js} +65 -38
  45. package/dist/components/snk-filter-param-config.js +1 -273
  46. package/dist/{esm/snk-filter-param-config.entry.js → components/snk-filter-param-config2.js} +35 -11
  47. package/dist/components/snk-grid2.js +2 -1
  48. package/dist/components/snk-personalized-filter.d.ts +11 -0
  49. package/dist/components/snk-personalized-filter.js +158 -0
  50. package/dist/components/snk-taskbar2.js +3 -197
  51. package/dist/esm/{SnkMessageBuilder-7a9392e6.js → SnkMessageBuilder-f3590f65.js} +14 -0
  52. package/dist/esm/{index-6519a79e.js → index-507e19ec.js} +1 -1
  53. package/dist/esm/index-620ac460.js +7 -0
  54. package/dist/esm/index-8efbf198.js +199 -0
  55. package/dist/esm/loader.js +1 -1
  56. package/dist/esm/sankhyablocks.js +1 -1
  57. package/dist/esm/snk-application.entry.js +1 -1
  58. package/dist/esm/snk-attach.entry.js +3 -2
  59. package/dist/esm/snk-crud.entry.js +3 -2
  60. package/dist/esm/snk-data-exporter.entry.js +3 -3
  61. package/dist/esm/{snk-data-unit-f9e4c694.js → snk-data-unit-50b1660c.js} +1 -1
  62. package/dist/esm/snk-data-unit.entry.js +2 -2
  63. package/dist/esm/snk-detail-view.entry.js +5 -4
  64. package/dist/esm/snk-expression-item.entry.js +209 -0
  65. package/dist/esm/snk-filter-field-search_2.entry.js +430 -0
  66. package/dist/esm/snk-grid.entry.js +3 -2
  67. package/dist/esm/{snk-guides-viewer-62a9f74d.js → snk-guides-viewer-4d12f268.js} +2 -2
  68. package/dist/esm/snk-guides-viewer.entry.js +4 -3
  69. package/dist/esm/snk-personalized-filter.entry.js +122 -0
  70. package/dist/esm/snk-simple-bar_2.entry.js +3 -2
  71. package/dist/esm/snk-taskbar.entry.js +3 -2
  72. package/dist/esm/taskbar-elements-e6af3e93.js +115 -0
  73. package/dist/sankhyablocks/p-1dcfd32a.entry.js +1 -0
  74. package/dist/sankhyablocks/p-27e264d9.entry.js +1 -0
  75. package/dist/sankhyablocks/p-343699ad.entry.js +1 -0
  76. package/dist/sankhyablocks/{p-f2223502.js → p-3d3263b4.js} +1 -1
  77. package/dist/sankhyablocks/{p-b2523981.entry.js → p-3fbe2d69.entry.js} +1 -1
  78. package/dist/sankhyablocks/p-433dfa63.entry.js +1 -0
  79. package/dist/sankhyablocks/{p-f132e371.js → p-4c2015a9.js} +1 -1
  80. package/dist/sankhyablocks/p-4eefe631.entry.js +1 -0
  81. package/dist/sankhyablocks/p-6a02e236.js +1 -0
  82. package/dist/sankhyablocks/p-8bdf5e57.entry.js +1 -0
  83. package/dist/sankhyablocks/{p-a412992c.entry.js → p-c4417efb.entry.js} +1 -1
  84. package/dist/sankhyablocks/{p-92a0fca4.js → p-c9477950.js} +1 -1
  85. package/dist/sankhyablocks/{p-aeffd219.js → p-ccd26e3a.js} +1 -1
  86. package/dist/sankhyablocks/p-d410f45a.js +1 -0
  87. package/dist/sankhyablocks/p-df8f13b4.entry.js +1 -0
  88. package/dist/sankhyablocks/p-e9f42525.entry.js +1 -0
  89. package/dist/sankhyablocks/p-f344b811.entry.js +1 -0
  90. package/dist/sankhyablocks/p-f4184ce7.js +1 -0
  91. package/dist/sankhyablocks/p-fd4ed40a.entry.js +1 -0
  92. package/dist/sankhyablocks/p-ff96b509.entry.js +27 -0
  93. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  94. package/dist/types/components/snk-filter-field-search/interfaces/index.d.ts +14 -4
  95. package/dist/types/components/snk-filter-field-search/snk-filter-field-search.d.ts +13 -10
  96. package/dist/types/components/snk-personalized-filter/snk-personalized-filter.d.ts +20 -0
  97. package/dist/types/components/snk-personalized-filter/subcomponents/snk-expression-item/filter-operands/filter-operands.d.ts +9 -0
  98. package/dist/types/components/snk-personalized-filter/subcomponents/snk-expression-item/snk-expression-item.d.ts +54 -0
  99. package/dist/types/components/snk-personalized-filter/subcomponents/snk-filter-param-config/interfaces/IExpressionItem.d.ts +4 -2
  100. package/dist/types/components.d.ts +83 -9
  101. package/dist/types/lib/http/data-fetcher/fetchers/personalized-filter-fetcher.d.ts +7 -0
  102. package/dist/types/lib/message/resources/snk-personalized-filter.msg.d.ts +1 -0
  103. package/dist/types/lib/store/index.d.ts +1 -0
  104. package/package.json +1 -1
  105. package/react/components.d.ts +2 -0
  106. package/react/components.js +2 -0
  107. package/react/components.js.map +1 -1
  108. package/dist/cjs/snk-filter-field-search.cjs.entry.js +0 -185
  109. package/dist/cjs/snk-filter-param-config.cjs.entry.js +0 -256
  110. package/dist/cjs/taskbar-elements-80285601.js +0 -313
  111. package/dist/esm/taskbar-elements-055ba1ad.js +0 -309
  112. package/dist/sankhyablocks/p-4512cc6c.entry.js +0 -1
  113. package/dist/sankhyablocks/p-5cbbe1f7.entry.js +0 -1
  114. package/dist/sankhyablocks/p-63d01871.entry.js +0 -1
  115. package/dist/sankhyablocks/p-741b00ef.entry.js +0 -1
  116. package/dist/sankhyablocks/p-79d22df0.entry.js +0 -1
  117. package/dist/sankhyablocks/p-93d8fe00.entry.js +0 -1
  118. package/dist/sankhyablocks/p-999d1953.entry.js +0 -1
  119. package/dist/sankhyablocks/p-c3efd4eb.entry.js +0 -1
  120. package/dist/sankhyablocks/p-ebe876f5.entry.js +0 -1
  121. package/dist/sankhyablocks/p-ed438690.js +0 -1
  122. package/dist/sankhyablocks/p-f3d0c744.entry.js +0 -1
@@ -0,0 +1,430 @@
1
+ import { h, r as registerInstance, c as createEvent, g as getElement } from './index-cfd4bb13.js';
2
+ import { S as SelectedItemType } from './index-620ac460.js';
3
+ import { UserInterface, JSUtils, ElementIDUtils, ApplicationContext, StringUtils, DataType } from '@sankhyalabs/core';
4
+ import { ModalAction } from '@sankhyalabs/ezui/dist/collection/components/ez-modal-container';
5
+ import { c as FilterOperand, d as FilterConfigType, e as FilterEntities, F as FilterUserConfigTypes } from './index-507e19ec.js';
6
+
7
+ const ICON_MODES = {
8
+ [UserInterface.SHORTTEXT]: 'text',
9
+ [UserInterface.LONGTEXT]: 'text',
10
+ [UserInterface.INTEGERNUMBER]: 'number',
11
+ [UserInterface.DECIMALNUMBER]: 'number',
12
+ [UserInterface.DATE]: 'calendar',
13
+ [UserInterface.DATETIME]: 'calendar',
14
+ [UserInterface.SWITCH]: 'boolean',
15
+ [UserInterface.CHECKBOX]: 'check-circle-inverted',
16
+ [UserInterface.OPTIONSELECTOR]: 'list',
17
+ [UserInterface.SEARCH]: 'search',
18
+ [UserInterface.HTML]: 'tag_code',
19
+ [UserInterface.IMAGE]: 'png',
20
+ [UserInterface.FILE]: 'edit-file',
21
+ [UserInterface.TIME]: 'timer-outline',
22
+ [UserInterface.ELAPSEDTIME]: 'timer',
23
+ [UserInterface.MASKEDTEXT]: 'text',
24
+ [UserInterface.PASSWORD]: 'email',
25
+ };
26
+ const ListItem = ({ userInterface, description }) => {
27
+ return (h("ez-icon", { iconName: ICON_MODES[userInterface], className: "ez-padding-left--small", title: description }));
28
+ };
29
+
30
+ const snkFilterFieldSearchCss = ".sc-snk-filter-field-search-h{--snk-filter-field-search--container-width:468px;--snk-filter-field-search--container-height:322px}.snk-filter-field-search__container.sc-snk-filter-field-search{display:flex;flex-direction:column;padding:var(--space--medium);width:var(--snk-filter-field-search--container-width);height:var(--snk-filter-field-search--container-height)}.snk-filter-field-search__section.sc-snk-filter-field-search{display:grid;grid-template-columns:1fr 1fr;place-items:flex-start;overflow:hidden;gap:var(--space--small)}.snk-filter-field-search__input.sc-snk-filter-field-search{margin-bottom:var(--space--medium)}.snk-filter-field-search__list_container.sc-snk-filter-field-search{display:flex;flex-direction:column}.snk-filter-field-search__list.sc-snk-filter-field-search{overflow-y:auto}";
31
+
32
+ const SNK_CONTEXT_KEY = "__SNK__APPLICATION__";
33
+ const SnkFilterFieldSearch = class {
34
+ constructor(hostRef) {
35
+ registerInstance(this, hostRef);
36
+ this.ezSelectFilterItem = createEvent(this, "ezSelectFilterItem", 7);
37
+ this._filterMetadataStorage = new Map();
38
+ this._currentMetadata = null;
39
+ this._filterText = "";
40
+ this._isLoading = false;
41
+ this.searchable = true;
42
+ this.fieldsDataSource = undefined;
43
+ this.breadcrumbItems = [];
44
+ this.linkItems = [];
45
+ this.fieldItems = [];
46
+ }
47
+ /**
48
+ * Realiza a abertura do componente e faz a primeira carga
49
+ * de dados.
50
+ * */
51
+ async show() {
52
+ var _a;
53
+ (_a = this._ezPopover) === null || _a === void 0 ? void 0 : _a.show();
54
+ return this.loadData();
55
+ }
56
+ /**
57
+ * Filtra a fonte de dados do componente.
58
+ * @param {string} filterText - Texto para filtrar a fonte de dados.
59
+ * @throws {Error} - Quando o componente estiver com a propriedade searchable como true.
60
+ */
61
+ async applyFilter(filterText) {
62
+ if (this.searchable)
63
+ throw new Error('This method is not available when searchable is true');
64
+ this.handleFilterChange(filterText);
65
+ }
66
+ async loadData() {
67
+ this._isLoading = true;
68
+ let metadata;
69
+ if (this._currentLink != undefined) {
70
+ metadata = this._filterMetadataStorage.get(this._currentLink.uri);
71
+ }
72
+ if (!metadata) {
73
+ metadata = await this.fieldsDataSource.fetchData(this._currentLink);
74
+ this._currentLink = metadata.currentLink;
75
+ this._filterMetadataStorage.set(this._currentLink.uri, metadata);
76
+ }
77
+ const { fields, links } = metadata || {};
78
+ if (!Array.isArray(fields) || !Array.isArray(links))
79
+ throw new Error('Invalid metadata');
80
+ this._currentMetadata = metadata;
81
+ this.mapDataSourceToLinkItems();
82
+ this.mapDataSourceToFieldItems();
83
+ this._isLoading = false;
84
+ this._ezFieldList.scrollToTop();
85
+ this._ezLinkList.scrollToTop();
86
+ }
87
+ mapDataSourceToLinkItems() {
88
+ var _a;
89
+ const { links } = this._currentMetadata;
90
+ const filterLinkLabelMessage = this.getMessage('snkFilterFieldSearch.linkLabel', { link: (_a = this._currentLink) === null || _a === void 0 ? void 0 : _a.description });
91
+ const items = links.map(link => (Object.assign({ label: link.description }, link)));
92
+ this.linkItems = [{
93
+ group: filterLinkLabelMessage,
94
+ items,
95
+ }];
96
+ if (this.breadcrumbItems.length === 0) {
97
+ this.breadcrumbItems = [Object.assign({ id: JSUtils.generateUUID(), label: this._currentLink.description }, this._currentLink)];
98
+ }
99
+ }
100
+ mapDataSourceToFieldItems() {
101
+ var _a;
102
+ const { fields } = this._currentMetadata;
103
+ const filterFieldLabelMessage = this.getMessage('snkFilterFieldSearch.fieldLabel', { link: (_a = this._currentLink) === null || _a === void 0 ? void 0 : _a.description });
104
+ const filteredFields = fields.filter(field => {
105
+ if (!this._currentLink)
106
+ return true;
107
+ const searchableByDescription = field.description.toLowerCase().includes(this._filterText.toLowerCase());
108
+ const searchableByName = field.name.toLowerCase().includes(this._filterText.toLowerCase());
109
+ return searchableByDescription || searchableByName;
110
+ });
111
+ const items = filteredFields.map(field => (Object.assign({ label: field.description }, field)));
112
+ this.fieldItems = [{
113
+ group: filterFieldLabelMessage,
114
+ items
115
+ }];
116
+ }
117
+ handleFilterChange(filterText) {
118
+ if (this._isLoading)
119
+ return;
120
+ this._filterText = filterText;
121
+ this.mapDataSourceToFieldItems();
122
+ }
123
+ handleSelectLink({ detail: item }) {
124
+ if (this._isLoading)
125
+ return;
126
+ const breadcrumbByIndex = this.breadcrumbItems.findIndex(breadcrumbItem => breadcrumbItem.id === item.id);
127
+ item.cache = this._filterMetadataStorage.has(item.uri);
128
+ if (breadcrumbByIndex > -1) {
129
+ this.breadcrumbItems = this.breadcrumbItems.slice(0, (breadcrumbByIndex + 1));
130
+ }
131
+ else {
132
+ this.breadcrumbItems = [...this.breadcrumbItems, Object.assign({ id: JSUtils.generateUUID(), label: item.description }, item)];
133
+ }
134
+ const selectedItem = Object.assign(Object.assign({}, item), { type: SelectedItemType.LINK });
135
+ this._currentLink = selectedItem;
136
+ this.ezSelectFilterItem.emit(selectedItem);
137
+ this.loadData();
138
+ }
139
+ handleSelectField({ detail: item }) {
140
+ var _a;
141
+ const breadcrumbPath = this.breadcrumbItems.map(breadcrumbItem => breadcrumbItem.label).join('>>');
142
+ const selectedField = Object.assign(Object.assign({}, item), { type: SelectedItemType.FIELD, path: `${breadcrumbPath} >> ${item.description}` });
143
+ this.ezSelectFilterItem.emit(selectedField);
144
+ (_a = this._ezPopover) === null || _a === void 0 ? void 0 : _a.hide();
145
+ }
146
+ getElementID(sufix) {
147
+ return {
148
+ [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: ElementIDUtils.getInternalIDInfo(sufix)
149
+ };
150
+ }
151
+ /**
152
+ * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
153
+ * através de um pequeno modulo na estrutura da aplicação:
154
+ * - Criar um arquivo no seguinte caminho: /messages/appmessages.msg.js.
155
+ * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-filter-field-search.msg.ts"
156
+ */
157
+ getMessage(key, params) {
158
+ var _a, _b, _c;
159
+ if (!this._application)
160
+ this._application = ApplicationContext.getContextValue(SNK_CONTEXT_KEY);
161
+ return (_c = (_b = (_a = this._application) === null || _a === void 0 ? void 0 : _a.messagesBuilder) === null || _b === void 0 ? void 0 : _b.getMessage) === null || _c === void 0 ? void 0 : _c.call(_b, key, params);
162
+ }
163
+ ;
164
+ componentWillLoad() {
165
+ this._application = ApplicationContext.getContextValue(SNK_CONTEXT_KEY);
166
+ }
167
+ componentDidLoad() {
168
+ ElementIDUtils.addIDInfoIfNotExists(this._ezPopover, 'popover');
169
+ }
170
+ disconnectedCallback() {
171
+ var _a;
172
+ this._filterMetadataStorage.clear();
173
+ (_a = this._ezPopover) === null || _a === void 0 ? void 0 : _a.hide();
174
+ }
175
+ render() {
176
+ var _a;
177
+ const searchLabelMessage = this.getMessage('snkFilterFieldSearch.searchLabel');
178
+ return (h("ez-popover", Object.assign({ ref: (el) => this._ezPopover = el, role: "dialog", overlayType: "none", "aria-hidden": !((_a = this._ezPopover) === null || _a === void 0 ? void 0 : _a.opened) }, this.getElementID('EzPopover')), h("div", { class: "snk-filter-field-search__container" }, h("header", { class: "snk-filter-field-search__header" }, this.searchable && !!searchLabelMessage && (h("ez-filter-input", Object.assign({ class: "snk-filter-field-search__input", label: searchLabelMessage, asyncSearch: true, canShowError: false, onEzSearching: (event) => this.handleFilterChange.bind(this)(event.detail), "aria-label": searchLabelMessage, "aria-required": "false", "aria-invalid": "false" }, this.getElementID('EzFilterInput')))), this.breadcrumbItems.length > 0 && (h("ez-breadcrumb", Object.assign({ items: this.breadcrumbItems, onSelectedItem: this.handleSelectLink.bind(this), role: "navigation", "aria-current": "step" }, this.getElementID('EzBreadcrumb')))), h("hr", { class: "ez-divider-horizontal ez-margin-vertical--medium" })), h("section", { class: "snk-filter-field-search__section" }, h("ez-list", Object.assign({ ref: (el) => this._ezLinkList = el, class: "snk-filter-field-search__list", id: "filterLinkList", useGroups: true, dataSource: this.linkItems, onEzSelectItem: this.handleSelectLink.bind(this), hoverFeedback: true, ezSelectable: true, itemSlotBuilder: ({ fieldCount }) => h("ez-badge", { label: fieldCount }), "aria-describedby": "filterLinkLabel" }, this.getElementID('EzListLinks'))), h("ez-list", Object.assign({ ref: (el) => this._ezFieldList = el, class: "snk-filter-field-search__list", id: "filterFieldList", useGroups: true, dataSource: this.fieldItems, onEzSelectItem: this.handleSelectField.bind(this), hoverFeedback: true, ezSelectable: true, itemSlotBuilder: ListItem, "aria-describedby": "filterFieldLabel" }, this.getElementID('EzListFields')))))));
179
+ }
180
+ };
181
+ SnkFilterFieldSearch.style = snkFilterFieldSearchCss;
182
+
183
+ class PersonalizedFilterUtils {
184
+ /**
185
+ * Cria uma expressão de filtro a partir de um IExpressionItem.
186
+ * @param expressionItem - Objeto com os parâmetros necessários para montar a expressão.
187
+ * @returns Retorna a expressão de filtro.
188
+ */
189
+ static buildFilterExpression(expressionItem) {
190
+ if (expressionItem == undefined) {
191
+ return;
192
+ }
193
+ const value = this.buildVariableParameterValue(expressionItem);
194
+ let expression = expressionItem.expression || "";
195
+ switch (expressionItem.operand) {
196
+ case FilterOperand.IN:
197
+ expression += ` ${expressionItem.operand} (${value})`;
198
+ break;
199
+ case FilterOperand.NULL:
200
+ case FilterOperand.NOT_NULL:
201
+ expression += ` IS ${value}`;
202
+ break;
203
+ case FilterOperand.LIKE:
204
+ expression += ` LIKE '%${value}%'`;
205
+ break;
206
+ case FilterOperand.START_WITH:
207
+ expression += ` LIKE '${value}%'`;
208
+ break;
209
+ case FilterOperand.FINISHED_WITH:
210
+ expression += ` LIKE '%${value}'`;
211
+ break;
212
+ default:
213
+ expression += ` ${expressionItem.operand} ${value}`;
214
+ }
215
+ return expression;
216
+ }
217
+ /**
218
+ * Obtém o valor do parâmetro a partir de um IExpressionItem.
219
+ * @param expressionItem - Objeto com os parâmetros necessários para montar a expressão.
220
+ * @returns Retorna o valor do parâmetro.
221
+ */
222
+ static buildVariableParameterValue(expressionItem) {
223
+ if (expressionItem == undefined) {
224
+ return;
225
+ }
226
+ if (expressionItem.systemConfig != undefined) {
227
+ const systemConfig = expressionItem.systemConfig;
228
+ return `?:{entidade=${systemConfig.entity || ""};campo=${systemConfig.fieldName || ""}}`;
229
+ }
230
+ if (expressionItem.userConfig != undefined) {
231
+ const userConfig = expressionItem.userConfig;
232
+ return `?:{desc=${userConfig.description || ""};tipo=${userConfig.type || ""}}`;
233
+ }
234
+ return `?:{entidade=${expressionItem.entityName || ""};campo=${expressionItem.fieldName || ""}}`;
235
+ }
236
+ }
237
+
238
+ const snkFilterParamConfigCss = ":host{--snk-filter-param-config__expression--color:var(--title--primary, #2b3a54);display:flex;position:relative}.snk-filter-param-config__expression{--text-area__input--disabled--color:var(--snk-filter-param-config__expression--color)}";
239
+
240
+ const SnkFilterParamConfig = class {
241
+ constructor(hostRef) {
242
+ registerInstance(this, hostRef);
243
+ this._opened = false;
244
+ this._configType = FilterConfigType.SYSTEM_CONFIG;
245
+ this._expressionItem = undefined;
246
+ this._informedInstance = false;
247
+ this._canSave = false;
248
+ this.messagesBuilder = undefined;
249
+ }
250
+ open(expressionItem) {
251
+ this._opened = true;
252
+ this._expressionItem = expressionItem;
253
+ this.loadValues();
254
+ return new Promise(accept => {
255
+ this._promiseResolver = accept;
256
+ });
257
+ }
258
+ close() {
259
+ this._opened = false;
260
+ return new Promise(accept => {
261
+ this._promiseResolver = accept;
262
+ });
263
+ }
264
+ /**
265
+ * Conforme mecanismo de mensagens, é possível customizar as mensagens dos blocos de construção
266
+ * através de um pequeno modulo na estrutura da aplicação:
267
+ * - Criar um arquivo no seguinte caminho: /messages/appmessages.msg.js.
268
+ * Para conhecer os detalhes do módulo, vide o arquivo neste projeto "/src/lib/message/resources/snk-filter-param-config.msg.ts"
269
+ */
270
+ getMessage(key, params) {
271
+ var _a;
272
+ return (_a = this.messagesBuilder) === null || _a === void 0 ? void 0 : _a.getMessage(key, params);
273
+ }
274
+ getConfigValue(configName, inputName, inputAlias = "") {
275
+ var _a, _b, _c;
276
+ return ((_b = (_a = this._expressionItem) === null || _a === void 0 ? void 0 : _a[configName]) === null || _b === void 0 ? void 0 : _b[inputName])
277
+ || ((_c = this._expressionItem) === null || _c === void 0 ? void 0 : _c[inputAlias || inputName]);
278
+ }
279
+ loadValues() {
280
+ var _a;
281
+ const entityName = this.getConfigValue("systemConfig", "entity", "entityName");
282
+ const fieldName = this.getConfigValue("systemConfig", "fieldName");
283
+ const description = this.getConfigValue("userConfig", "description");
284
+ const type = this.getConfigValue("userConfig", "type");
285
+ if (((_a = this._expressionItem) === null || _a === void 0 ? void 0 : _a.userConfig) != undefined) {
286
+ this._configType = FilterConfigType.USER_CONFIG;
287
+ }
288
+ else {
289
+ this._configType = FilterConfigType.SYSTEM_CONFIG;
290
+ }
291
+ if (!StringUtils.isEmpty(entityName) && !StringUtils.isEmpty(fieldName)) {
292
+ this._instanceElement.value = { value: entityName, label: "" };
293
+ this._fieldElement.value = { value: fieldName, label: "" };
294
+ }
295
+ if (!StringUtils.isEmpty(description) && !StringUtils.isEmpty(type)) {
296
+ this._descriptionElement.value = description;
297
+ this._typeElement.value = type;
298
+ }
299
+ this.buildFilterExpression();
300
+ }
301
+ changeDefinitionUsed(option) {
302
+ this._configType = option !== null && option !== void 0 ? option : FilterConfigType.SYSTEM_CONFIG;
303
+ if (this._configType === FilterConfigType.SYSTEM_CONFIG) {
304
+ const entityName = this.getConfigValue("systemConfig", "entity", "entityName");
305
+ const fieldName = this.getConfigValue("systemConfig", "fieldName");
306
+ this._instanceElement.value = this._instanceElement.value || { value: entityName, label: "" };
307
+ this._fieldElement.value = this._fieldElement.value || { value: fieldName, label: "" };
308
+ }
309
+ else if (this._configType === FilterConfigType.USER_CONFIG) {
310
+ const description = this.getConfigValue("userConfig", "description");
311
+ const type = this.getConfigValue("userConfig", "type");
312
+ this._descriptionElement.value = this._descriptionElement.value || description;
313
+ this._typeElement.value = this._typeElement.value || type;
314
+ }
315
+ this.buildFilterExpression();
316
+ }
317
+ getTypeValue() {
318
+ var _a;
319
+ const value = (_a = this._typeElement) === null || _a === void 0 ? void 0 : _a.value;
320
+ return ((value === null || value === void 0 ? void 0 : value.value) || value);
321
+ }
322
+ getExpressionValues() {
323
+ var _a, _b, _c, _d, _e;
324
+ let systemConfig;
325
+ let userConfig;
326
+ if (this._configType === FilterConfigType.SYSTEM_CONFIG) {
327
+ const entity = (_b = (_a = this._instanceElement) === null || _a === void 0 ? void 0 : _a.value) === null || _b === void 0 ? void 0 : _b.value;
328
+ const fieldName = (_d = (_c = this._fieldElement) === null || _c === void 0 ? void 0 : _c.value) === null || _d === void 0 ? void 0 : _d.value;
329
+ systemConfig = { entity, fieldName };
330
+ }
331
+ else if (this._configType === FilterConfigType.USER_CONFIG) {
332
+ const description = (_e = this._descriptionElement) === null || _e === void 0 ? void 0 : _e.value;
333
+ const type = this.getTypeValue();
334
+ userConfig = { description, type };
335
+ }
336
+ return Object.assign(Object.assign(Object.assign({}, this._expressionItem), { systemConfig }), { userConfig });
337
+ }
338
+ isEnabled(value) {
339
+ return this._configType === value;
340
+ }
341
+ isInformedInstance() {
342
+ var _a, _b;
343
+ return !StringUtils.isEmpty((_b = (_a = this._instanceElement) === null || _a === void 0 ? void 0 : _a.value) === null || _b === void 0 ? void 0 : _b.value);
344
+ }
345
+ save() {
346
+ var _a;
347
+ this._expressionItem = Object.assign(Object.assign({}, this.getExpressionValues()), { expression: (_a = this._expressionElement) === null || _a === void 0 ? void 0 : _a.value });
348
+ this._promiseResolver(this._expressionItem);
349
+ this._opened = false;
350
+ }
351
+ buildFilterExpression() {
352
+ var _a;
353
+ this._informedInstance = this.isInformedInstance();
354
+ const expression = PersonalizedFilterUtils.buildFilterExpression(this.getExpressionValues());
355
+ this._expressionElement.value = expression || ((_a = this._expressionItem) === null || _a === void 0 ? void 0 : _a.expression);
356
+ this._canSave = this.getCanSave();
357
+ }
358
+ handleChangeInstance() {
359
+ this._informedInstance = this.isInformedInstance();
360
+ if (this._fieldElement != undefined && !StringUtils.isEmpty(this._fieldElement.value)) {
361
+ this._fieldElement.value = null;
362
+ }
363
+ this.buildFilterExpression();
364
+ }
365
+ getInstanceCriteria() {
366
+ var _a, _b;
367
+ const value = (_b = (_a = this._instanceElement) === null || _a === void 0 ? void 0 : _a.value) === null || _b === void 0 ? void 0 : _b.value;
368
+ return {
369
+ expression: "this.NOMETAB = (SELECT NOMETAB FROM TDDINS WHERE NOMEINSTANCIA = ?)",
370
+ params: [
371
+ {
372
+ name: "NOMEINSTANCIA",
373
+ dataType: DataType.TEXT,
374
+ value
375
+ }
376
+ ]
377
+ };
378
+ }
379
+ onSearch({ mode, argument }, entity) {
380
+ if (this._application == undefined) {
381
+ return;
382
+ }
383
+ const isField = entity === FilterEntities.FIELD;
384
+ const criteria = isField ? this.getInstanceCriteria() : undefined;
385
+ const messageKey = `snkFilterParamConfig.label${isField ? "Field" : "Instance"}`;
386
+ const entityDescription = this.getMessage(messageKey);
387
+ const searchOptions = {
388
+ descriptionFieldName: isField ? "DESCRCAMPO" : "DESCRINSTANCIA",
389
+ codeFieldName: isField ? "NOMECAMPO" : "NOMEINSTANCIA",
390
+ showInactives: false
391
+ };
392
+ const options = {
393
+ entity,
394
+ entityDescription,
395
+ criteria,
396
+ searchOptions
397
+ };
398
+ return this._application.executePreparedSearch(mode, argument, options);
399
+ }
400
+ getElementID(sufix) {
401
+ return {
402
+ [ElementIDUtils.DATA_ELEMENT_ID_ATTRIBUTE_NAME]: ElementIDUtils.getInternalIDInfo(sufix)
403
+ };
404
+ }
405
+ getCanSave() {
406
+ var _a;
407
+ if (this._configType === FilterConfigType.USER_CONFIG) {
408
+ const description = (_a = this._descriptionElement) === null || _a === void 0 ? void 0 : _a.value;
409
+ const type = this.getTypeValue();
410
+ return !StringUtils.isEmpty(description) && !StringUtils.isEmpty(type);
411
+ }
412
+ return true;
413
+ }
414
+ componentWillLoad() {
415
+ this._application = ApplicationContext.getContextValue("__SNK__APPLICATION__");
416
+ }
417
+ render() {
418
+ ElementIDUtils.addIDInfoIfNotExists(this._element, 'snkFilterParamConfig');
419
+ return (h("ez-popup", Object.assign({ useHeader: false, size: "small", heightMode: "auto", opened: this._opened }, this.getElementID("popup")), h("ez-modal-container", Object.assign({ onEzModalAction: (evt) => {
420
+ if (evt.detail === ModalAction.CLOSE)
421
+ this.close();
422
+ }, modalTitle: this.getMessage("snkFilterParamConfig.modalTitle") }, this.getElementID("modalContainer")), h("div", { class: "ez-flex" }, h("div", { class: "ez-col ez-col--sd-6 ez-flex--column" }, h("ez-radio-button", Object.assign({ value: this._configType, onEzChange: (evt) => this.changeDefinitionUsed(evt.detail) }, this.getElementID("systemConfigOption")), h("ez-radio-button-option", { label: this.getMessage("snkFilterParamConfig.labelSystemConfig"), value: FilterConfigType.SYSTEM_CONFIG })), h("ez-search", Object.assign({ ref: (ref) => this._instanceElement = ref, label: this.getMessage("snkFilterParamConfig.labelInstance"), enabled: this.isEnabled(FilterConfigType.SYSTEM_CONFIG), suppressEmptyOption: true, showOptionValue: false, showSelectedValue: false, onEzChange: () => this.handleChangeInstance(), optionLoader: (searchArgument) => this.onSearch(searchArgument, FilterEntities.INSTANCE) }, this.getElementID("configFindEntity"))), h("ez-search", Object.assign({ ref: (ref) => this._fieldElement = ref, label: this.getMessage("snkFilterParamConfig.labelField"), enabled: this.isEnabled(FilterConfigType.SYSTEM_CONFIG) && this._informedInstance, suppressEmptyOption: true, showOptionValue: false, showSelectedValue: false, onEzChange: () => this.buildFilterExpression(), optionLoader: (searchArgument) => this.onSearch(searchArgument, FilterEntities.FIELD) }, this.getElementID("configFindField")))), h("div", { class: "ez-flex ez-padding--medium" }, h("hr", { class: "ez-divider-vertical" })), h("div", { class: "ez-col ez-col--sd-6 ez-flex--column" }, h("ez-radio-button", Object.assign({ value: this._configType, onEzChange: (evt) => this.changeDefinitionUsed(evt.detail) }, this.getElementID("userConfigOption")), h("ez-radio-button-option", { label: this.getMessage("snkFilterParamConfig.labelUserConfig"), value: FilterConfigType.USER_CONFIG })), h("ez-text-input", Object.assign({ ref: (ref) => this._descriptionElement = ref, label: this.getMessage("snkFilterParamConfig.labelDescription"), enabled: this.isEnabled(FilterConfigType.USER_CONFIG), onEzChange: () => this.buildFilterExpression() }, this.getElementID("configParamLabel"))), h("ez-combo-box", Object.assign({ ref: (ref) => this._typeElement = ref, label: this.getMessage("snkFilterParamConfig.labelType"), enabled: this.isEnabled(FilterConfigType.USER_CONFIG), suppressEmptyOption: true, onEzChange: () => this.buildFilterExpression() }, this.getElementID("configParamType")), Object.keys(FilterUserConfigTypes).map((configType) => {
423
+ return (h("option", { value: FilterUserConfigTypes[configType] }, this.getMessage(`snkFilterParamConfig.labelTypeValues.${configType.toLowerCase()}`)));
424
+ })))), h("ez-text-area", Object.assign({ ref: (ref) => this._expressionElement = ref, class: "snk-filter-param-config__expression", label: this.getMessage("snkFilterParamConfig.labelExpression"), enabled: false }, this.getElementID("presentationExpression"))), h("div", { class: "ez-col ez-col--sd-12 ez-flex--justify-end ez-margin-vertical--small" }, h("ez-button", Object.assign({ class: "ez-padding-right--medium", label: this.getMessage("snkFilterParamConfig.labelCancel"), onClick: () => this.close() }, this.getElementID("cancelEditParam"))), h("ez-button", Object.assign({ class: "ez-button--primary", label: this.getMessage("snkFilterParamConfig.labelSave"), onClick: () => this.save(), enabled: this._canSave }, this.getElementID("saveEditParam")))))));
425
+ }
426
+ get _element() { return getElement(this); }
427
+ };
428
+ SnkFilterParamConfig.style = snkFilterParamConfigCss;
429
+
430
+ export { SnkFilterFieldSearch as snk_filter_field_search, SnkFilterParamConfig as snk_filter_param_config };
@@ -1,10 +1,11 @@
1
1
  import { r as registerInstance, c as createEvent, h, g as getElement } from './index-cfd4bb13.js';
2
2
  import { VersionUtils, ElementIDUtils, ApplicationContext, DataType } from '@sankhyalabs/core';
3
3
  import { UserInterface } from '@sankhyalabs/core/dist/dataunit/metadata/UnitMetadata';
4
- import { T as TaskbarElement, s as store } from './taskbar-elements-055ba1ad.js';
4
+ import { T as TaskbarElement } from './taskbar-elements-e6af3e93.js';
5
5
  import { C as ConfigStorage } from './ConfigStorage-ac77ff39.js';
6
- import { P as PresentationMode } from './index-6519a79e.js';
6
+ import { P as PresentationMode } from './index-507e19ec.js';
7
7
  import { T as TaskbarProcessor } from './taskbar-processor-94402e6e.js';
8
+ import { s as store } from './index-8efbf198.js';
8
9
  import './form-config-fetcher-018e7e73.js';
9
10
  import './DataFetcher-b3d8b2d5.js';
10
11
  import './_commonjsHelpers-9943807e.js';
@@ -3,11 +3,11 @@ import { ElementIDUtils } from '@sankhyalabs/core';
3
3
  import { S as SnkFormConfigManager } from './SnkFormConfigManager-40609500.js';
4
4
  import { buildFormMetadata, FormMetadata } from '@sankhyalabs/ezui/dist/collection/utils/form';
5
5
  import { T as TaskbarProcessor } from './taskbar-processor-94402e6e.js';
6
- import { T as TaskbarElement } from './taskbar-elements-055ba1ad.js';
6
+ import { T as TaskbarElement } from './taskbar-elements-e6af3e93.js';
7
7
  import { c as VIEW_MODE } from './constants-e916ccc3.js';
8
8
  import './DataFetcher-b3d8b2d5.js';
9
9
  import './pesquisa-fetcher-bd6af0e3.js';
10
- import { P as PresentationMode } from './index-6519a79e.js';
10
+ import { P as PresentationMode } from './index-507e19ec.js';
11
11
 
12
12
  const snkGuidesViewerCss = ".sc-snk-guides-viewer-h{--snk-guides-viewer--space-large:var(--space--large, 24px);--snk-guides-viewer--space-medium:var(--space--medium, 12px);--snk-guides-viewer__header--min-height:94px;--snk-guides-viewer__header--z-index:var(--more-visible, 2);--snk-guides-viewer__header--background-color:var(--background--body, #fafcff);--snk-guides-viewer__guide-navigator--width:340px;display:block}snk-form-view.sc-snk-guides-viewer{width:100%}.snk-guides-viewer.sc-snk-guides-viewer{position:relative;padding-left:0px;padding-top:0px;padding-right:var(--snk-guides-viewer--space-large);padding-bottom:var(--snk-guides-viewer--space-large)}.snk-guides-viewer__detail-container.sc-snk-guides-viewer{display:flex;row-gap:24px;flex-direction:column}.snk-guides-viewer__header.sc-snk-guides-viewer{position:sticky;align-items:center;top:0;z-index:var(--snk-guides-viewer__header--z-index);background-color:var(--snk-guides-viewer__header--background-color);min-height:var(--snk-guides-viewer__header--min-height);width:calc(100% + (var(--snk-guides-viewer--space-large) * 2));padding-left:var(--snk-guides-viewer--space-large);padding-right:var(--snk-guides-viewer--space-large);padding-top:var(--snk-guides-viewer--space-large);padding-bottom:var(--snk-guides-viewer--space-medium);margin-left:calc(var(--snk-guides-viewer--space-large) * -1);margin-right:calc(var(--snk-guides-viewer--space-large) * -1);margin-bottom:var(--snk-guides-viewer--space-medium)}.snk-guides-viewer__container.sc-snk-guides-viewer{display:grid;grid-template-columns:minmax(0, auto) minmax(0, 100%);height:100%;column-gap:var(--snk-guides-viewer--space-large)}.snk-guides-viewer__guide-navigator.sc-snk-guides-viewer{position:sticky;top:calc(var(--snk-guides-viewer__header--min-height) + var(--snk-guides-viewer--space-medium));height:calc(100vh - var(--snk-guides-viewer__header--min-height) - var(--snk-guides-viewer--space-large) - var(--snk-guides-viewer--space-medium))}.snk-guides-viewer__guide-navigator[open].sc-snk-guides-viewer{width:var(--snk-guides-viewer__guide-navigator--width);max-width:var(--snk-guides-viewer__guide-navigator--width);min-width:var(--snk-guides-viewer__guide-navigator--width)}.snk-guides-viewer__detail-content.sc-snk-guides-viewer{min-height:100%;align-items:flex-start;align-content:flex-start}";
13
13
 
@@ -1,4 +1,4 @@
1
- export { S as snk_guides_viewer } from './snk-guides-viewer-62a9f74d.js';
1
+ export { S as snk_guides_viewer } from './snk-guides-viewer-4d12f268.js';
2
2
  import './index-cfd4bb13.js';
3
3
  import '@sankhyalabs/core';
4
4
  import './SnkFormConfigManager-40609500.js';
@@ -8,7 +8,8 @@ import './DataFetcher-b3d8b2d5.js';
8
8
  import './_commonjsHelpers-9943807e.js';
9
9
  import '@sankhyalabs/ezui/dist/collection/utils/form';
10
10
  import './taskbar-processor-94402e6e.js';
11
- import './taskbar-elements-055ba1ad.js';
12
- import './index-6519a79e.js';
11
+ import './taskbar-elements-e6af3e93.js';
12
+ import './index-507e19ec.js';
13
+ import './index-8efbf198.js';
13
14
  import './constants-e916ccc3.js';
14
15
  import './pesquisa-fetcher-bd6af0e3.js';
@@ -0,0 +1,122 @@
1
+ import { r as registerInstance, h, H as Host } from './index-cfd4bb13.js';
2
+ import { d as dist, D as DataFetcher } from './DataFetcher-b3d8b2d5.js';
3
+ import { F as FilterUserConfigTypes, c as FilterOperand } from './index-507e19ec.js';
4
+ import { s as store } from './index-8efbf198.js';
5
+ import { StringUtils, ApplicationContext } from '@sankhyalabs/core';
6
+ import './_commonjsHelpers-9943807e.js';
7
+
8
+ class PersonalizedFilterFetcher {
9
+ constructor() {
10
+ this.templateByQuery = new Map();
11
+ this.buildTemplates();
12
+ }
13
+ buildTemplates() {
14
+ const query = dist.gql `
15
+ query($name: String!) {
16
+ $queryAlias$: fetchFilterFields(name: $name){
17
+ currentLink {
18
+ description
19
+ uri
20
+ }
21
+ links {
22
+ description
23
+ uri
24
+ fieldCount
25
+ }
26
+ fields {
27
+ name
28
+ description
29
+ uri
30
+ onlyDate
31
+ dataType
32
+ userInterface
33
+ properties {
34
+ name
35
+ value
36
+ }
37
+ }
38
+ }
39
+ }
40
+ `;
41
+ this.templateByQuery.set("fetchFilterFields", query);
42
+ }
43
+ loadFields(uri) {
44
+ return new Promise((resolve, reject) => {
45
+ DataFetcher.get()
46
+ .callGraphQL({
47
+ values: { name: uri },
48
+ query: this.templateByQuery.get("fetchFilterFields"),
49
+ })
50
+ .then((resp) => {
51
+ let fields = resp.fields;
52
+ for (const field of fields) {
53
+ if (Array.isArray(field.properties) && field.properties.length > 0 && field.userInterface === "SEARCH") {
54
+ const propertiesConvertedObject = field.properties.reduce((accumulator, prop) => {
55
+ accumulator[prop.name] = prop.value;
56
+ return accumulator;
57
+ }, {});
58
+ field.properties = propertiesConvertedObject;
59
+ }
60
+ }
61
+ resolve(Object.assign(Object.assign({}, resp), { fields: fields }));
62
+ })
63
+ .catch((error) => {
64
+ reject(error);
65
+ });
66
+ });
67
+ }
68
+ }
69
+
70
+ const snkPersonalizedFilterCss = ":host{display:flex}";
71
+
72
+ const SnkPersonalizedFilter = class {
73
+ constructor(hostRef) {
74
+ registerInstance(this, hostRef);
75
+ this._personalizedFilterFetcher = new PersonalizedFilterFetcher();
76
+ this._dataSourceFetcher = {
77
+ fetchData: async (entity) => {
78
+ let entityURI = entity === null || entity === void 0 ? void 0 : entity.uri;
79
+ if (StringUtils.isEmpty(entityURI)) {
80
+ entityURI = "dd://Financeiro/br.com.sankhya.fin.cad.receber"; //TODO: Receber como prop
81
+ }
82
+ return await this._personalizedFilterFetcher.loadFields(entityURI);
83
+ }
84
+ };
85
+ this.items = {
86
+ entityName: "Financeiro",
87
+ fieldName: "CODBCO",
88
+ description: "Financeiro >> Banco",
89
+ type: FilterUserConfigTypes.DECIMAL,
90
+ expression: "Financeiro.CODBCO",
91
+ operand: FilterOperand.EQUAL,
92
+ paramVariable: false,
93
+ value: "61",
94
+ systemConfig: null,
95
+ userConfig: null
96
+ };
97
+ this.handleFilterItemChange = (changes) => {
98
+ console.log("Campo do ExpressionItem alterado");
99
+ console.log(changes);
100
+ };
101
+ this.handleFilterItemRemove = (expression) => {
102
+ console.log("Event de deleção disparado");
103
+ console.log(expression);
104
+ };
105
+ this.messagesBuilder = undefined;
106
+ }
107
+ componentWillLoad() {
108
+ if (store.get("filterFieldsDataSource") == undefined) {
109
+ store.set("filterFieldsDataSource", this._dataSourceFetcher);
110
+ }
111
+ if (!this.messagesBuilder) {
112
+ const snkApp = ApplicationContext.getContextValue("__SNK__APPLICATION__");
113
+ this.messagesBuilder = snkApp === null || snkApp === void 0 ? void 0 : snkApp.messagesBuilder;
114
+ }
115
+ }
116
+ render() {
117
+ return (h(Host, null, h("div", null, h("snk-expression-item", { expression: this.items, canRemove: true, onEzFilterItemChange: (evt) => this.handleFilterItemChange(evt.detail), onEzFilterItemRemove: (evt) => this.handleFilterItemRemove(evt.detail), messagesBuilder: this.messagesBuilder }))));
118
+ }
119
+ };
120
+ SnkPersonalizedFilter.style = snkPersonalizedFilterCss;
121
+
122
+ export { SnkPersonalizedFilter as snk_personalized_filter };
@@ -1,11 +1,12 @@
1
1
  import { r as registerInstance, c as createEvent, h, g as getElement } from './index-cfd4bb13.js';
2
2
  import { ElementIDUtils, ApplicationContext, DataUnit, StringUtils, SortMode, DataType, ChangeOperation, ObjectUtils, UserInterface } from '@sankhyalabs/core';
3
3
  import { c as VIEW_MODE, S as SIMPLE_CRUD_MODE } from './constants-e916ccc3.js';
4
- import { T as TaskbarElement } from './taskbar-elements-055ba1ad.js';
4
+ import { T as TaskbarElement } from './taskbar-elements-e6af3e93.js';
5
5
  import './DataFetcher-b3d8b2d5.js';
6
6
  import './pesquisa-fetcher-bd6af0e3.js';
7
- import { P as PresentationMode } from './index-6519a79e.js';
7
+ import { P as PresentationMode } from './index-507e19ec.js';
8
8
  import { T as TaskbarProcessor } from './taskbar-processor-94402e6e.js';
9
+ import './index-8efbf198.js';
9
10
  import './_commonjsHelpers-9943807e.js';
10
11
 
11
12
  const snkSimpleBarCss = ".sc-snk-simple-bar-h{display:flex;height:100%;width:100%}.simple-bar__container.sc-snk-simple-bar{flex:1;display:flex;align-items:stretch;gap:var(--space--small)}.simple-bar__left-slot.sc-snk-simple-bar{min-width:280px;flex:1;display:flex;align-items:center}.simple-bar__right-slot.sc-snk-simple-bar{flex:1;display:flex;align-items:center;justify-content:flex-end}.simple-bar__column.sc-snk-simple-bar{flex:1;display:flex;flex-direction:column}";
@@ -1,8 +1,9 @@
1
1
  import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-cfd4bb13.js';
2
2
  import { StringUtils, ApplicationContext, ElementIDUtils } from '@sankhyalabs/core';
3
3
  import { A as AuthorizationConfig } from './AuthorizationConfig-dcbd207a.js';
4
- import { T as TaskbarElement, V as VisibleWhenForbidden, A as AuthorizationElements, b as buildElem, a as buildCustomButton } from './taskbar-elements-055ba1ad.js';
5
- import { P as PresentationMode } from './index-6519a79e.js';
4
+ import { T as TaskbarElement, V as VisibleWhenForbidden, A as AuthorizationElements, b as buildElem, a as buildCustomButton } from './taskbar-elements-e6af3e93.js';
5
+ import { P as PresentationMode } from './index-507e19ec.js';
6
+ import './index-8efbf198.js';
6
7
 
7
8
  const snkTaskbarCss = ".sc-snk-taskbar-h{display:flex}";
8
9