sidesys-generic-ui 2.4.6 → 2.4.8

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 (129) hide show
  1. package/esm2022/lib/animation/animation.component.mjs +6 -3
  2. package/esm2022/lib/avatar/components/profile-group/s-profile-group.component.mjs +1 -1
  3. package/esm2022/lib/avatar/s-avatar.component.mjs +13 -16
  4. package/esm2022/lib/badge/s-badge.component.mjs +7 -6
  5. package/esm2022/lib/bottom-status-bar/bottom-status-bar.component.mjs +7 -11
  6. package/esm2022/lib/breadcrum/s-breadcrum.component.mjs +7 -4
  7. package/esm2022/lib/button/components/button/s-button.component.mjs +7 -3
  8. package/esm2022/lib/card/s-card.component.mjs +10 -7
  9. package/esm2022/lib/checkbox/checkbox-new/s-checkbox.component.mjs +12 -5
  10. package/esm2022/lib/checkbox/s-checkbox.component.mjs +8 -8
  11. package/esm2022/lib/collapse/s-collapse.component.mjs +7 -4
  12. package/esm2022/lib/company-logo/s-company-logo.component.mjs +9 -5
  13. package/esm2022/lib/container/s-container.component.mjs +6 -3
  14. package/esm2022/lib/content/s-content.component.mjs +6 -3
  15. package/esm2022/lib/dynamic-form/s-dynamic-form.component.mjs +1 -1
  16. package/esm2022/lib/empty/empty.component.mjs +4 -3
  17. package/esm2022/lib/footer/s-footer.component.mjs +3 -3
  18. package/esm2022/lib/grid-multi-inputs/grid-multi-inputs.component.mjs +1 -1
  19. package/esm2022/lib/icon-material/s-icon-material.component.mjs +6 -3
  20. package/esm2022/lib/input/components/calendar/s-calendar.component.mjs +11 -14
  21. package/esm2022/lib/input/components/color/s-color.component.mjs +10 -8
  22. package/esm2022/lib/input/components/error-control/s-error-control.component.mjs +18 -15
  23. package/esm2022/lib/input/components/input/s-input-model.mjs +2 -6
  24. package/esm2022/lib/input/components/input/s-input.component.mjs +18 -6
  25. package/esm2022/lib/input/components/input-number/s-input-number.component.mjs +12 -12
  26. package/esm2022/lib/input/components/input-textarea/s-input-textarea.component.mjs +11 -8
  27. package/esm2022/lib/input/components/slider/s-slider.component.mjs +21 -13
  28. package/esm2022/lib/input/components/time/s-time.component.mjs +11 -14
  29. package/esm2022/lib/input/components/validation-error/s-validation-error.component.mjs +7 -4
  30. package/esm2022/lib/link/s-link.component.mjs +6 -3
  31. package/esm2022/lib/list/s-list.component.mjs +6 -3
  32. package/esm2022/lib/list-simple/s-list-simple.component.mjs +6 -3
  33. package/esm2022/lib/modal/modal-confirm/modal-confirm.component.mjs +6 -13
  34. package/esm2022/lib/modal/modal-confirm/models/modal-confirm.interface.mjs +1 -1
  35. package/esm2022/lib/modal/modal-confirm/services/modal-confirm.service.mjs +1 -1
  36. package/esm2022/lib/navbar/components/icon-menu/components/s-notificaction.component.mjs +1 -1
  37. package/esm2022/lib/navbar/components/icon-menu/s-icon-menu.component.mjs +1 -1
  38. package/esm2022/lib/navbar/components/menu-main/s-menu-main.component.mjs +1 -1
  39. package/esm2022/lib/navbar/s-navbar.component.mjs +9 -3
  40. package/esm2022/lib/pagination/s-pagination.component.mjs +7 -4
  41. package/esm2022/lib/popup/s-popup.component.mjs +22 -19
  42. package/esm2022/lib/precode/s-precode.component.mjs +9 -7
  43. package/esm2022/lib/progressbar/s-progressbar.component.mjs +6 -3
  44. package/esm2022/lib/radio/s-radio.component.mjs +13 -11
  45. package/esm2022/lib/select/select/s-select.component.mjs +12 -8
  46. package/esm2022/lib/select/select-multiple/s-select-multiple-model.mjs +1 -1
  47. package/esm2022/lib/select/select-multiple/s-select-multiple.component.mjs +12 -10
  48. package/esm2022/lib/select/select-multiple-old/s-select-multiple-old.component.mjs +1 -1
  49. package/esm2022/lib/select/select-simple/s-select-simple.component.mjs +1 -1
  50. package/esm2022/lib/sidebar/s-sidebar.component.mjs +6 -3
  51. package/esm2022/lib/spinner/s-spinner.component.mjs +1 -1
  52. package/esm2022/lib/sub-menu/s-sub-menu.component.mjs +1 -1
  53. package/esm2022/lib/table-complete/table-complete.component.mjs +7 -3
  54. package/esm2022/lib/table-double/table-double.component.mjs +4 -3
  55. package/esm2022/lib/table-double/table-double.model.mjs +1 -1
  56. package/esm2022/lib/table-double-complete/table-double-complete.component.mjs +6 -4
  57. package/esm2022/lib/table-double-complete/table-double-complete.model.mjs +1 -1
  58. package/esm2022/lib/table-t/s-tablet.component.mjs +6 -3
  59. package/esm2022/lib/table-t/table-actions-buttons/interfaces/TypeActions.interface.mjs +1 -1
  60. package/esm2022/lib/table-t/table-actions-buttons/table-actions-buttons.component.mjs +6 -3
  61. package/esm2022/lib/tabs/models/configTabs.interface.mjs +1 -1
  62. package/esm2022/lib/tabs/s-tabs.component.mjs +8 -4
  63. package/esm2022/lib/tag/s-tag.component.mjs +6 -3
  64. package/esm2022/lib/timeline/s-timeline.component.mjs +6 -3
  65. package/esm2022/lib/toast/s-toast-service.mjs +3 -3
  66. package/esm2022/lib/toast/s-toast.component.mjs +3 -3
  67. package/esm2022/lib/toggle-switch/s-toggle-switch.component.mjs +1 -1
  68. package/esm2022/lib/toggle-switch/toggle-switch-form/toggle-switch-form.component.mjs +12 -10
  69. package/esm2022/lib/toolbar-top/toolbar-top.component.mjs +4 -3
  70. package/esm2022/lib/tooltip/s-tooltip.component.mjs +32 -16
  71. package/esm2022/lib/tree-list/s-tree-list.component.mjs +6 -3
  72. package/fesm2022/sidesys-generic-ui.mjs +588 -462
  73. package/fesm2022/sidesys-generic-ui.mjs.map +1 -1
  74. package/lib/animation/animation.component.d.ts +2 -1
  75. package/lib/avatar/s-avatar.component.d.ts +2 -2
  76. package/lib/badge/s-badge.component.d.ts +3 -5
  77. package/lib/bottom-status-bar/bottom-status-bar.component.d.ts +2 -0
  78. package/lib/breadcrum/s-breadcrum.component.d.ts +2 -1
  79. package/lib/button/components/button/s-button.component.d.ts +6 -5
  80. package/lib/card/s-card.component.d.ts +3 -2
  81. package/lib/checkbox/checkbox-new/s-checkbox.component.d.ts +5 -3
  82. package/lib/collapse/s-collapse.component.d.ts +2 -1
  83. package/lib/company-logo/s-company-logo.component.d.ts +2 -1
  84. package/lib/container/s-container.component.d.ts +2 -1
  85. package/lib/content/s-content.component.d.ts +2 -1
  86. package/lib/empty/empty.component.d.ts +2 -0
  87. package/lib/icon-material/s-icon-material.component.d.ts +2 -1
  88. package/lib/input/components/calendar/s-calendar.component.d.ts +4 -3
  89. package/lib/input/components/color/s-color.component.d.ts +4 -3
  90. package/lib/input/components/error-control/s-error-control.component.d.ts +2 -1
  91. package/lib/input/components/input/s-input-model.d.ts +0 -1
  92. package/lib/input/components/input/s-input.component.d.ts +3 -1
  93. package/lib/input/components/input-number/s-input-number.component.d.ts +4 -2
  94. package/lib/input/components/input-textarea/s-input-textarea.component.d.ts +4 -2
  95. package/lib/input/components/time/s-time.component.d.ts +4 -3
  96. package/lib/input/components/validation-error/s-validation-error.component.d.ts +2 -1
  97. package/lib/link/s-link.component.d.ts +2 -1
  98. package/lib/list/s-list.component.d.ts +2 -1
  99. package/lib/list-simple/s-list-simple.component.d.ts +2 -1
  100. package/lib/modal/modal-confirm/modal-confirm.component.d.ts +1 -0
  101. package/lib/modal/modal-confirm/models/modal-confirm.interface.d.ts +1 -0
  102. package/lib/navbar/s-navbar.component.d.ts +5 -3
  103. package/lib/pagination/s-pagination.component.d.ts +2 -1
  104. package/lib/popup/s-popup.component.d.ts +2 -1
  105. package/lib/precode/s-precode.component.d.ts +3 -5
  106. package/lib/progressbar/s-progressbar.component.d.ts +2 -1
  107. package/lib/radio/s-radio.component.d.ts +3 -2
  108. package/lib/select/select/s-select.component.d.ts +5 -3
  109. package/lib/select/select-multiple/s-select-multiple-model.d.ts +1 -0
  110. package/lib/select/select-multiple/s-select-multiple.component.d.ts +5 -3
  111. package/lib/sidebar/s-sidebar.component.d.ts +2 -1
  112. package/lib/table-complete/table-complete.component.d.ts +3 -1
  113. package/lib/table-double/table-double.component.d.ts +1 -0
  114. package/lib/table-double/table-double.model.d.ts +1 -0
  115. package/lib/table-double-complete/table-double-complete.component.d.ts +1 -0
  116. package/lib/table-double-complete/table-double-complete.model.d.ts +1 -0
  117. package/lib/table-t/s-tablet.component.d.ts +2 -1
  118. package/lib/table-t/table-actions-buttons/interfaces/TypeActions.interface.d.ts +1 -0
  119. package/lib/table-t/table-actions-buttons/table-actions-buttons.component.d.ts +2 -1
  120. package/lib/tabs/models/configTabs.interface.d.ts +1 -0
  121. package/lib/tabs/s-tabs.component.d.ts +2 -2
  122. package/lib/tag/s-tag.component.d.ts +2 -1
  123. package/lib/timeline/s-timeline.component.d.ts +2 -1
  124. package/lib/toast/s-toast-service.d.ts +3 -3
  125. package/lib/toggle-switch/toggle-switch-form/toggle-switch-form.component.d.ts +6 -3
  126. package/lib/toolbar-top/toolbar-top.component.d.ts +2 -0
  127. package/lib/tooltip/s-tooltip.component.d.ts +2 -1
  128. package/lib/tree-list/s-tree-list.component.d.ts +2 -1
  129. package/package.json +1 -1
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, Input, Output, ViewEncapsulation, signal, inject, } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, ViewEncapsulation, signal, inject } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { STabsModule } from '../tabs';
4
4
  import { STableDoubleComponent } from '../table-double/table-double.component';
@@ -25,6 +25,7 @@ export class STableDoubleCompleteComponent {
25
25
  this._sTranslateService = inject(STranslateService);
26
26
  }
27
27
  ngOnInit() {
28
+ this.id = this.config.id ?? `s-table-double-complete`;
28
29
  this.rightTableState = [...(this.config.tableConfig.tableRightItems ?? [])];
29
30
  const selectedTab = this.config.tabs.find(t => t.selected);
30
31
  if (selectedTab) {
@@ -118,6 +119,7 @@ export class STableDoubleCompleteComponent {
118
119
  },
119
120
  tableLeftItems: leftItems,
120
121
  tableRightItems: rightItems,
122
+ id: this.id,
121
123
  };
122
124
  }
123
125
  mapToTableDoubleItems(items) {
@@ -233,11 +235,11 @@ export class STableDoubleCompleteComponent {
233
235
  this.refreshTables();
234
236
  }
235
237
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: STableDoubleCompleteComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
236
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: STableDoubleCompleteComponent, isStandalone: true, selector: "s-table-double-complete", inputs: { config: "config" }, outputs: { updateEvent: "updateEvent", actionPositionEvent: "actionPositionEvent", bottomStatusBarPositionEvent: "bottomStatusBarPositionEvent", checkAllPositionEvent: "checkAllPositionEvent", deletePositionEvent: "deletePositionEvent", emptyPositionEvent: "emptyPositionEvent", filterPositionEvent: "filterPositionEvent", multiSelectPositionEvent: "multiSelectPositionEvent", orderByPositionEvent: "orderByPositionEvent", pillButtonPositionEvent: "pillButtonPositionEvent", scrollPositionEvent: "scrollPositionEvent", selectPositionEvent: "selectPositionEvent", switchChangeEvent: "switchChangeEvent" }, ngImport: i0, template: "<div class=\"s-table-double-complete\">\n <s-tabs\n [tabs]=\"config.tabs\"\n [configTabs]=\"config.configTabs\"\n (eventSelect)=\"onTabSelect($event)\">\n </s-tabs>\n\n <s-table-double\n [config]=\"tableDoubleAdapter\"\n (eventUpdateTables)=\"onUpdateTables($event)\"\n (actionPositionEvent)=\"actionPositionEvent.emit($event)\"\n (bottomStatusBarPositionEvent)=\"bottomStatusBarPositionEvent.emit($event)\"\n (checkAllPositionEvent)=\"checkAllPositionEvent.emit($event)\"\n (deletePositionEvent)=\"deletePositionEvent.emit($event)\"\n (emptyPositionEvent)=\"emptyPositionEvent.emit($event)\"\n (filterPositionEvent)=\"filterPositionEvent.emit($event)\"\n (multiSelectPositionEvent)=\"multiSelectPositionEvent.emit($event)\"\n (orderByPositionEvent)=\"orderByPositionEvent.emit($event)\"\n (pillButtonPositionEvent)=\"pillButtonPositionEvent.emit($event)\"\n (scrollPositionEvent)=\"scrollPositionEvent.emit($event)\"\n (toggleExpandEvent)=\"toggleNodeExpansion($event)\"\n (reorderItemEvent)=\"onReorderItem($event)\"\n (switchChangeEvent)=\"onSwitchChange($event)\">\n</s-table-double>\n</div>\n", styles: [".s-table-double-complete{display:flex;flex-direction:row;gap:.5rem}s-table-double{width:100%}s-tabs{width:15%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: STabsModule }, { kind: "component", type: i1.STabsComponent, selector: "s-tabs", inputs: ["tabs", "configTabs"], outputs: ["eventSelect"] }, { kind: "component", type: STableDoubleComponent, selector: "s-table-double", inputs: ["config"], outputs: ["actionPositionEvent", "bottomStatusBarPositionEvent", "checkAllPositionEvent", "deletePositionEvent", "emptyPositionEvent", "eventUpdateTables", "filterPositionEvent", "multiSelectPositionEvent", "orderByPositionEvent", "pagePositionEvent", "paginationPositionEvent", "pillButtonPositionEvent", "scrollPositionEvent", "selectPositionEvent", "rowSelectPositionEvent", "actionEvent", "toggleExpandEvent", "reorderItemEvent", "switchChangeEvent"] }], encapsulation: i0.ViewEncapsulation.None }); }
238
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: STableDoubleCompleteComponent, isStandalone: true, selector: "s-table-double-complete", inputs: { config: "config" }, outputs: { updateEvent: "updateEvent", actionPositionEvent: "actionPositionEvent", bottomStatusBarPositionEvent: "bottomStatusBarPositionEvent", checkAllPositionEvent: "checkAllPositionEvent", deletePositionEvent: "deletePositionEvent", emptyPositionEvent: "emptyPositionEvent", filterPositionEvent: "filterPositionEvent", multiSelectPositionEvent: "multiSelectPositionEvent", orderByPositionEvent: "orderByPositionEvent", pillButtonPositionEvent: "pillButtonPositionEvent", scrollPositionEvent: "scrollPositionEvent", selectPositionEvent: "selectPositionEvent", switchChangeEvent: "switchChangeEvent" }, ngImport: i0, template: "<div class=\"s-table-double-complete\" [id]=\"id\">\n <s-tabs [tabs]=\"config.tabs\" [configTabs]=\"config.configTabs\" (eventSelect)=\"onTabSelect($event)\"> </s-tabs>\n\n <s-table-double\n [config]=\"tableDoubleAdapter\"\n (eventUpdateTables)=\"onUpdateTables($event)\"\n (actionPositionEvent)=\"actionPositionEvent.emit($event)\"\n (bottomStatusBarPositionEvent)=\"bottomStatusBarPositionEvent.emit($event)\"\n (checkAllPositionEvent)=\"checkAllPositionEvent.emit($event)\"\n (deletePositionEvent)=\"deletePositionEvent.emit($event)\"\n (emptyPositionEvent)=\"emptyPositionEvent.emit($event)\"\n (filterPositionEvent)=\"filterPositionEvent.emit($event)\"\n (multiSelectPositionEvent)=\"multiSelectPositionEvent.emit($event)\"\n (orderByPositionEvent)=\"orderByPositionEvent.emit($event)\"\n (pillButtonPositionEvent)=\"pillButtonPositionEvent.emit($event)\"\n (scrollPositionEvent)=\"scrollPositionEvent.emit($event)\"\n (toggleExpandEvent)=\"toggleNodeExpansion($event)\"\n (reorderItemEvent)=\"onReorderItem($event)\"\n (switchChangeEvent)=\"onSwitchChange($event)\">\n </s-table-double>\n</div>\n", styles: [".s-table-double-complete{display:flex;flex-direction:row;gap:.5rem}s-table-double{width:100%}s-tabs{width:15%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: STabsModule }, { kind: "component", type: i1.STabsComponent, selector: "s-tabs", inputs: ["tabs", "configTabs", "id"], outputs: ["eventSelect"] }, { kind: "component", type: STableDoubleComponent, selector: "s-table-double", inputs: ["config"], outputs: ["actionPositionEvent", "bottomStatusBarPositionEvent", "checkAllPositionEvent", "deletePositionEvent", "emptyPositionEvent", "eventUpdateTables", "filterPositionEvent", "multiSelectPositionEvent", "orderByPositionEvent", "pagePositionEvent", "paginationPositionEvent", "pillButtonPositionEvent", "scrollPositionEvent", "selectPositionEvent", "rowSelectPositionEvent", "actionEvent", "toggleExpandEvent", "reorderItemEvent", "switchChangeEvent"] }], encapsulation: i0.ViewEncapsulation.None }); }
237
239
  }
238
240
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: STableDoubleCompleteComponent, decorators: [{
239
241
  type: Component,
240
- args: [{ selector: 's-table-double-complete', standalone: true, imports: [CommonModule, STabsModule, STableDoubleComponent], encapsulation: ViewEncapsulation.None, template: "<div class=\"s-table-double-complete\">\n <s-tabs\n [tabs]=\"config.tabs\"\n [configTabs]=\"config.configTabs\"\n (eventSelect)=\"onTabSelect($event)\">\n </s-tabs>\n\n <s-table-double\n [config]=\"tableDoubleAdapter\"\n (eventUpdateTables)=\"onUpdateTables($event)\"\n (actionPositionEvent)=\"actionPositionEvent.emit($event)\"\n (bottomStatusBarPositionEvent)=\"bottomStatusBarPositionEvent.emit($event)\"\n (checkAllPositionEvent)=\"checkAllPositionEvent.emit($event)\"\n (deletePositionEvent)=\"deletePositionEvent.emit($event)\"\n (emptyPositionEvent)=\"emptyPositionEvent.emit($event)\"\n (filterPositionEvent)=\"filterPositionEvent.emit($event)\"\n (multiSelectPositionEvent)=\"multiSelectPositionEvent.emit($event)\"\n (orderByPositionEvent)=\"orderByPositionEvent.emit($event)\"\n (pillButtonPositionEvent)=\"pillButtonPositionEvent.emit($event)\"\n (scrollPositionEvent)=\"scrollPositionEvent.emit($event)\"\n (toggleExpandEvent)=\"toggleNodeExpansion($event)\"\n (reorderItemEvent)=\"onReorderItem($event)\"\n (switchChangeEvent)=\"onSwitchChange($event)\">\n</s-table-double>\n</div>\n", styles: [".s-table-double-complete{display:flex;flex-direction:row;gap:.5rem}s-table-double{width:100%}s-tabs{width:15%}\n"] }]
242
+ args: [{ selector: 's-table-double-complete', standalone: true, imports: [CommonModule, STabsModule, STableDoubleComponent], encapsulation: ViewEncapsulation.None, template: "<div class=\"s-table-double-complete\" [id]=\"id\">\n <s-tabs [tabs]=\"config.tabs\" [configTabs]=\"config.configTabs\" (eventSelect)=\"onTabSelect($event)\"> </s-tabs>\n\n <s-table-double\n [config]=\"tableDoubleAdapter\"\n (eventUpdateTables)=\"onUpdateTables($event)\"\n (actionPositionEvent)=\"actionPositionEvent.emit($event)\"\n (bottomStatusBarPositionEvent)=\"bottomStatusBarPositionEvent.emit($event)\"\n (checkAllPositionEvent)=\"checkAllPositionEvent.emit($event)\"\n (deletePositionEvent)=\"deletePositionEvent.emit($event)\"\n (emptyPositionEvent)=\"emptyPositionEvent.emit($event)\"\n (filterPositionEvent)=\"filterPositionEvent.emit($event)\"\n (multiSelectPositionEvent)=\"multiSelectPositionEvent.emit($event)\"\n (orderByPositionEvent)=\"orderByPositionEvent.emit($event)\"\n (pillButtonPositionEvent)=\"pillButtonPositionEvent.emit($event)\"\n (scrollPositionEvent)=\"scrollPositionEvent.emit($event)\"\n (toggleExpandEvent)=\"toggleNodeExpansion($event)\"\n (reorderItemEvent)=\"onReorderItem($event)\"\n (switchChangeEvent)=\"onSwitchChange($event)\">\n </s-table-double>\n</div>\n", styles: [".s-table-double-complete{display:flex;flex-direction:row;gap:.5rem}s-table-double{width:100%}s-tabs{width:15%}\n"] }]
241
243
  }], propDecorators: { config: [{
242
244
  type: Input
243
245
  }], updateEvent: [{
@@ -267,4 +269,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
267
269
  }], switchChangeEvent: [{
268
270
  type: Output
269
271
  }] } });
270
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-double-complete.component.js","sourceRoot":"","sources":["../../../../../projects/sidesys-generic-ui/src/lib/table-double-complete/table-double-complete.component.ts","../../../../../projects/sidesys-generic-ui/src/lib/table-double-complete/table-double-complete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n  OnInit,\n  signal,\n  inject,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport { STabsModule } from '../tabs';\nimport { STableDoubleComponent } from '../table-double/table-double.component';\n\nimport {\n  STableDoubleCompleteConfig,\n  STableDoubleCompleteUpdateEvent,\n  STableDoubleCompleteItem,\n} from './table-double-complete.model';\n\nimport { ITab } from '../tabs/models';\nimport {\n  STableDouble,\n  STablesData,\n  STableDoubleItem,\n  STableDoubleBooleanEvent,\n  STableDoubleReorderEvent,\n  STableDoubleStringArrayEvent,\n  STableDoubleSortEvent,\n  STableDoubleStringEvent,\n  STableDoubleSwitchEvent,\n} from '../table-double/table-double.model';\nimport { STranslateService } from '../services/translate/translate.service';\n\n@Component({\n  selector: 's-table-double-complete',\n  standalone: true,\n  imports: [CommonModule, STabsModule, STableDoubleComponent],\n  templateUrl: './table-double-complete.component.html',\n  styleUrl: './table-double-complete.component.scss',\n  encapsulation: ViewEncapsulation.None,\n})\nexport class STableDoubleCompleteComponent implements OnInit {\n  @Input() config!: STableDoubleCompleteConfig;\n\n  @Output() updateEvent = new EventEmitter<STableDoubleCompleteUpdateEvent>();\n  @Output() actionPositionEvent = new EventEmitter<boolean>();\n  @Output() bottomStatusBarPositionEvent = new EventEmitter<STableDoubleBooleanEvent>();\n  @Output() checkAllPositionEvent = new EventEmitter<STableDoubleBooleanEvent>();\n  @Output() deletePositionEvent = new EventEmitter<boolean>();\n  @Output() emptyPositionEvent = new EventEmitter<boolean>();\n  @Output() filterPositionEvent = new EventEmitter<STableDoubleStringArrayEvent>();\n  @Output() multiSelectPositionEvent = new EventEmitter<STableDoubleStringArrayEvent>();\n  @Output() orderByPositionEvent = new EventEmitter<STableDoubleSortEvent>();\n  @Output() pillButtonPositionEvent = new EventEmitter<boolean>();\n  @Output() scrollPositionEvent = new EventEmitter<boolean>();\n  @Output() selectPositionEvent = new EventEmitter<STableDoubleStringEvent>();\n  @Output() switchChangeEvent = new EventEmitter<STableDoubleSwitchEvent>();\n\n  private activeTabKey!: string;\n  private rightTableState: STableDoubleCompleteItem[] = [];\n  private expandedNodes = new Map<string, boolean>();\n  private readonly _sTranslateService = inject(STranslateService);\n  \n  tableDoubleAdapter!: STableDouble;\n\n  ngOnInit(): void {\n    this.rightTableState = [...(this.config.tableConfig.tableRightItems ?? [])];\n\n    const selectedTab = this.config.tabs.find(t => t.selected);\n    if (selectedTab) {\n      this.setActiveTab(selectedTab);\n    }\n  }\n\n  onTabSelect(tab: ITab): void {\n    this.setActiveTab(tab);\n  }\n\n  private setActiveTab(tab: ITab): void {\n    this.activeTabKey = String(tab.value ?? tab.text);\n\n    const leftItems = this.config.itemsByTab[this.activeTabKey] ?? [];\n    const tableLeftItems = this.mapToTableDoubleItems(leftItems);\n\n    let tableRightItems = this.mapToTableDoubleItems(this.rightTableState);\n\n    if (this.config.treeMode) {\n      tableRightItems = this.flattenTree(this.buildTree(this.rightTableState));\n    }\n\n    this.tableDoubleAdapter = this.buildTableDoubleAdapter(tableLeftItems, tableRightItems);\n  }\n\n  onUpdateTables(event: STablesData): void {\n    const prevRightIds = new Set(this.rightTableState.map(i => i.id));\n    const sourceLeft = this.config.itemsByTab[this.activeTabKey] ?? [];\n    const selectedRightItems = event.tableRightItems.filter(i => i.selected);\n    const parentId = this.config.treeMode && selectedRightItems.length === 1 ? selectedRightItems[0].id : null;\n\n    const nextRight: STableDoubleCompleteItem[] = event.tableRightItems.map(item => {\n      const prev = this.rightTableState.find(r => r.id === item.id);\n      const fromLeft = sourceLeft.find(l => l.id === item.id);\n      return {\n        ...(prev ?? fromLeft ?? {}),\n        id: item.id,\n        name: item.name,\n        checked: !!item.checked,\n        parentId: prev?.parentId ?? null,\n      };\n    });\n\n    const addedItems = nextRight.filter(i => !prevRightIds.has(i.id));\n\n    if (this.config.treeMode && parentId) {\n      addedItems.forEach(item => {\n        item.parentId = parentId;\n      });\n    }\n\n    this.rightTableState = nextRight;\n    this.resetSelections();\n    this.refreshTables();\n  }\n\n  private refreshTables(): void {\n    const leftItems = this.config.itemsByTab[this.activeTabKey] ?? [];\n    const tableLeftItems = this.mapToTableDoubleItems(leftItems);\n\n    let tableRightItems = this.mapToTableDoubleItems(this.rightTableState);\n\n    if (this.config.treeMode) {\n      tableRightItems = this.flattenTree(this.buildTree(this.rightTableState));\n      tableLeftItems;\n    }\n\n    this.tableDoubleAdapter = this.buildTableDoubleAdapter(tableLeftItems, tableRightItems);\n\n    this.updateEvent.emit({\n      tabKey: this.activeTabKey,\n      tableLeftItems,\n      tableRightItems,\n    });\n  }\n\n  private buildTableDoubleAdapter(leftItems: STableDoubleItem[], rightItems: STableDoubleItem[]): STableDouble {\n    const rightColumns = [...this.config.tableConfig.tableRightConfig.columns];\n    if (this.config.showOrderButtons && !rightColumns.some(c => c.id === 'actions')) {\n      rightColumns.push({ id: 'actions', title: this._sTranslateService.instant('ui.generic.actions') });\n    }\n\n    return {\n      additionButton: true,\n      isTreeMode: !!this.config.treeMode,\n      showOrderButtons: !!this.config.showOrderButtons,\n      disableLeftRowSelection: true,\n      tableLeftConfig: {\n        ...this.config.tableConfig.tableLeftConfig,\n        totalItems: leftItems.length,\n        isTreeMode: false,\n        configBottomStatusBar: signal({\n          counter: leftItems.filter(i => i.checked).length,\n          total: leftItems.length,\n          disabled: leftItems.length === 0,\n        }),\n      },\n      tableRightConfig: {\n        ...this.config.tableConfig.tableRightConfig,\n        columns: rightColumns,\n        totalItems: rightItems.length,\n        isTreeMode: !!this.config.treeMode,\n        configBottomStatusBar: signal({\n          counter: rightItems.filter(i => i.checked).length,\n          total: rightItems.length,\n          disabled: rightItems.length === 0,\n        }),\n      },\n      tableLeftItems: leftItems,\n      tableRightItems: rightItems,\n    };\n  }\n\n  private mapToTableDoubleItems(items: STableDoubleCompleteItem[]): STableDoubleItem[] {\n    return items.map((item, index) => ({\n      ...item,\n      name: item.name ?? '',\n      checked: item.checked ?? false,\n    }));\n  }\n\n  private buildTree(items: STableDoubleCompleteItem[]): STableDoubleCompleteItem[] {\n    const map = new Map<string, STableDoubleCompleteItem & { children: STableDoubleCompleteItem[] }>();\n    const roots: STableDoubleCompleteItem[] = [];\n\n    items.forEach(item => {\n      map.set(item.id, { ...item, children: [] });\n    });\n\n    map.forEach(item => {\n      if (item.parentId) {\n        const parent = map.get(item.parentId);\n        if (parent) parent.children.push(item);\n      } else {\n        roots.push(item);\n      }\n    });\n\n    return roots;\n  }\n\n  private flattenTree(nodes: STableDoubleCompleteItem[], level: number = 0): STableDoubleItem[] {\n    let result: STableDoubleItem[] = [];\n\n    for (let i = 0; i < nodes.length; i++) {\n      const node = nodes[i];\n      const hasChildren = !!node.children?.length;\n      const isExpanded = this.expandedNodes.get(node.id) ?? true;\n\n      result.push({\n        ...node,\n        name: node.name ?? '',\n        checked: !!node.checked,\n        parentId: node.parentId ?? null,\n        level: level,\n        expanded: isExpanded,\n        hasChildren: hasChildren,\n      } as STableDoubleItem);\n\n      if (hasChildren && isExpanded && node.children) {\n        result = result.concat(this.flattenTree(node.children, level + 1));\n      }\n    }\n    return result;\n  }\n\n  private resetSelections(): void {\n    const leftItems = this.config.itemsByTab[this.activeTabKey] ?? [];\n    leftItems.forEach(i => {\n      i.checked = false;\n      i.selected = false;\n    });\n    this.rightTableState.forEach(i => {\n      i.checked = false;\n      i.selected = false;\n    });\n  }\n\n  onSwitchChange(event: STableDoubleSwitchEvent): void {\n    if (event.isLeftTable) {\n      const leftItems = this.config.itemsByTab[this.activeTabKey] ?? [];\n      const item = leftItems.find(i => i.id === event.itemId);\n      if (item) item[event.columnId] = event.value;\n    } else {\n      const item = this.rightTableState.find(i => i.id === event.itemId);\n      if (item) item[event.columnId] = event.value;\n    }\n    this.switchChangeEvent.emit(event);\n  }\n\n  toggleNodeExpansion(nodeId: string): void {\n    const currentState = this.expandedNodes.get(nodeId) ?? true;\n    this.expandedNodes.set(nodeId, !currentState);\n    this.refreshTables();\n  }\n\n  onReorderItem(event: STableDoubleReorderEvent): void {\n    const { itemId, direction } = event;\n    const item = this.rightTableState.find(i => i.id === itemId);\n    if (!item) return;\n\n    const parentId = item.parentId ?? null;\n    const siblings = this.rightTableState.filter(i => (i.parentId ?? null) === parentId);\n    const siblingIndex = siblings.findIndex(i => i.id === itemId);\n    if (siblingIndex === -1) return;\n\n    let targetIndex: number;\n    switch (direction) {\n      case 'top':\n        targetIndex = 0;\n        break;\n      case 'up':\n        targetIndex = siblingIndex - 1;\n        break;\n      case 'down':\n        targetIndex = siblingIndex + 1;\n        break;\n      case 'bottom':\n        targetIndex = siblings.length - 1;\n        break;\n      default:\n        return;\n    }\n\n    if (targetIndex < 0 || targetIndex >= siblings.length || targetIndex === siblingIndex) return;\n\n    siblings.splice(siblingIndex, 1);\n    siblings.splice(targetIndex, 0, item);\n\n    this.rightTableState = this.rightTableState.filter(i => (i.parentId ?? null) !== parentId);\n    const insertRef = parentId ? this.rightTableState.findIndex(i => i.id === parentId) + 1 : 0;\n    this.rightTableState.splice(insertRef, 0, ...siblings);\n\n    this.refreshTables();\n  }\n}\n","<div class=\"s-table-double-complete\">\n  <s-tabs\n    [tabs]=\"config.tabs\"\n    [configTabs]=\"config.configTabs\"\n    (eventSelect)=\"onTabSelect($event)\">\n  </s-tabs>\n\n  <s-table-double\n  [config]=\"tableDoubleAdapter\"\n  (eventUpdateTables)=\"onUpdateTables($event)\"\n  (actionPositionEvent)=\"actionPositionEvent.emit($event)\"\n  (bottomStatusBarPositionEvent)=\"bottomStatusBarPositionEvent.emit($event)\"\n  (checkAllPositionEvent)=\"checkAllPositionEvent.emit($event)\"\n  (deletePositionEvent)=\"deletePositionEvent.emit($event)\"\n  (emptyPositionEvent)=\"emptyPositionEvent.emit($event)\"\n  (filterPositionEvent)=\"filterPositionEvent.emit($event)\"\n  (multiSelectPositionEvent)=\"multiSelectPositionEvent.emit($event)\"\n  (orderByPositionEvent)=\"orderByPositionEvent.emit($event)\"\n  (pillButtonPositionEvent)=\"pillButtonPositionEvent.emit($event)\"\n  (scrollPositionEvent)=\"scrollPositionEvent.emit($event)\"\n  (toggleExpandEvent)=\"toggleNodeExpansion($event)\"\n  (reorderItemEvent)=\"onReorderItem($event)\"\n  (switchChangeEvent)=\"onSwitchChange($event)\">\n</s-table-double>\n</div>\n"]}
272
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-double-complete.component.js","sourceRoot":"","sources":["../../../../../projects/sidesys-generic-ui/src/lib/table-double-complete/table-double-complete.component.ts","../../../../../projects/sidesys-generic-ui/src/lib/table-double-complete/table-double-complete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewEncapsulation, OnInit, signal, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { STabsModule } from '../tabs';\nimport { STableDoubleComponent } from '../table-double/table-double.component';\nimport {\n  STableDoubleCompleteConfig,\n  STableDoubleCompleteUpdateEvent,\n  STableDoubleCompleteItem,\n} from './table-double-complete.model';\nimport { ITab } from '../tabs/models';\nimport {\n  STableDouble,\n  STablesData,\n  STableDoubleItem,\n  STableDoubleBooleanEvent,\n  STableDoubleReorderEvent,\n  STableDoubleStringArrayEvent,\n  STableDoubleSortEvent,\n  STableDoubleStringEvent,\n  STableDoubleSwitchEvent,\n} from '../table-double/table-double.model';\nimport { STranslateService } from '../services/translate/translate.service';\n\n@Component({\n  selector: 's-table-double-complete',\n  standalone: true,\n  imports: [CommonModule, STabsModule, STableDoubleComponent],\n  templateUrl: './table-double-complete.component.html',\n  styleUrl: './table-double-complete.component.scss',\n  encapsulation: ViewEncapsulation.None,\n})\nexport class STableDoubleCompleteComponent implements OnInit {\n  @Input() config!: STableDoubleCompleteConfig;\n\n  @Output() updateEvent = new EventEmitter<STableDoubleCompleteUpdateEvent>();\n  @Output() actionPositionEvent = new EventEmitter<boolean>();\n  @Output() bottomStatusBarPositionEvent = new EventEmitter<STableDoubleBooleanEvent>();\n  @Output() checkAllPositionEvent = new EventEmitter<STableDoubleBooleanEvent>();\n  @Output() deletePositionEvent = new EventEmitter<boolean>();\n  @Output() emptyPositionEvent = new EventEmitter<boolean>();\n  @Output() filterPositionEvent = new EventEmitter<STableDoubleStringArrayEvent>();\n  @Output() multiSelectPositionEvent = new EventEmitter<STableDoubleStringArrayEvent>();\n  @Output() orderByPositionEvent = new EventEmitter<STableDoubleSortEvent>();\n  @Output() pillButtonPositionEvent = new EventEmitter<boolean>();\n  @Output() scrollPositionEvent = new EventEmitter<boolean>();\n  @Output() selectPositionEvent = new EventEmitter<STableDoubleStringEvent>();\n  id!: string;\n  @Output() switchChangeEvent = new EventEmitter<STableDoubleSwitchEvent>();\n\n  private activeTabKey!: string;\n  private rightTableState: STableDoubleCompleteItem[] = [];\n  private expandedNodes = new Map<string, boolean>();\n  private readonly _sTranslateService = inject(STranslateService);\n\n  tableDoubleAdapter!: STableDouble;\n\n  ngOnInit(): void {\n    this.id = this.config.id ?? `s-table-double-complete`;\n    this.rightTableState = [...(this.config.tableConfig.tableRightItems ?? [])];\n\n    const selectedTab = this.config.tabs.find(t => t.selected);\n    if (selectedTab) {\n      this.setActiveTab(selectedTab);\n    }\n  }\n\n  onTabSelect(tab: ITab): void {\n    this.setActiveTab(tab);\n  }\n\n  private setActiveTab(tab: ITab): void {\n    this.activeTabKey = String(tab.value ?? tab.text);\n\n    const leftItems = this.config.itemsByTab[this.activeTabKey] ?? [];\n    const tableLeftItems = this.mapToTableDoubleItems(leftItems);\n\n    let tableRightItems = this.mapToTableDoubleItems(this.rightTableState);\n\n    if (this.config.treeMode) {\n      tableRightItems = this.flattenTree(this.buildTree(this.rightTableState));\n    }\n\n    this.tableDoubleAdapter = this.buildTableDoubleAdapter(tableLeftItems, tableRightItems);\n  }\n\n  onUpdateTables(event: STablesData): void {\n    const prevRightIds = new Set(this.rightTableState.map(i => i.id));\n    const sourceLeft = this.config.itemsByTab[this.activeTabKey] ?? [];\n    const selectedRightItems = event.tableRightItems.filter(i => i.selected);\n    const parentId = this.config.treeMode && selectedRightItems.length === 1 ? selectedRightItems[0].id : null;\n\n    const nextRight: STableDoubleCompleteItem[] = event.tableRightItems.map(item => {\n      const prev = this.rightTableState.find(r => r.id === item.id);\n      const fromLeft = sourceLeft.find(l => l.id === item.id);\n      return {\n        ...(prev ?? fromLeft ?? {}),\n        id: item.id,\n        name: item.name,\n        checked: !!item.checked,\n        parentId: prev?.parentId ?? null,\n      };\n    });\n\n    const addedItems = nextRight.filter(i => !prevRightIds.has(i.id));\n\n    if (this.config.treeMode && parentId) {\n      addedItems.forEach(item => {\n        item.parentId = parentId;\n      });\n    }\n\n    this.rightTableState = nextRight;\n    this.resetSelections();\n    this.refreshTables();\n  }\n\n  private refreshTables(): void {\n    const leftItems = this.config.itemsByTab[this.activeTabKey] ?? [];\n    const tableLeftItems = this.mapToTableDoubleItems(leftItems);\n\n    let tableRightItems = this.mapToTableDoubleItems(this.rightTableState);\n\n    if (this.config.treeMode) {\n      tableRightItems = this.flattenTree(this.buildTree(this.rightTableState));\n      tableLeftItems;\n    }\n\n    this.tableDoubleAdapter = this.buildTableDoubleAdapter(tableLeftItems, tableRightItems);\n\n    this.updateEvent.emit({\n      tabKey: this.activeTabKey,\n      tableLeftItems,\n      tableRightItems,\n    });\n  }\n\n  private buildTableDoubleAdapter(leftItems: STableDoubleItem[], rightItems: STableDoubleItem[]): STableDouble {\n    const rightColumns = [...this.config.tableConfig.tableRightConfig.columns];\n    if (this.config.showOrderButtons && !rightColumns.some(c => c.id === 'actions')) {\n      rightColumns.push({ id: 'actions', title: this._sTranslateService.instant('ui.generic.actions') });\n    }\n\n    return {\n      additionButton: true,\n      isTreeMode: !!this.config.treeMode,\n      showOrderButtons: !!this.config.showOrderButtons,\n      disableLeftRowSelection: true,\n      tableLeftConfig: {\n        ...this.config.tableConfig.tableLeftConfig,\n        totalItems: leftItems.length,\n        isTreeMode: false,\n        configBottomStatusBar: signal({\n          counter: leftItems.filter(i => i.checked).length,\n          total: leftItems.length,\n          disabled: leftItems.length === 0,\n        }),\n      },\n      tableRightConfig: {\n        ...this.config.tableConfig.tableRightConfig,\n        columns: rightColumns,\n        totalItems: rightItems.length,\n        isTreeMode: !!this.config.treeMode,\n        configBottomStatusBar: signal({\n          counter: rightItems.filter(i => i.checked).length,\n          total: rightItems.length,\n          disabled: rightItems.length === 0,\n        }),\n      },\n      tableLeftItems: leftItems,\n      tableRightItems: rightItems,\n      id: this.id,\n    };\n  }\n\n  private mapToTableDoubleItems(items: STableDoubleCompleteItem[]): STableDoubleItem[] {\n    return items.map((item, index) => ({\n      ...item,\n      name: item.name ?? '',\n      checked: item.checked ?? false,\n    }));\n  }\n\n  private buildTree(items: STableDoubleCompleteItem[]): STableDoubleCompleteItem[] {\n    const map = new Map<string, STableDoubleCompleteItem & { children: STableDoubleCompleteItem[] }>();\n    const roots: STableDoubleCompleteItem[] = [];\n\n    items.forEach(item => {\n      map.set(item.id, { ...item, children: [] });\n    });\n\n    map.forEach(item => {\n      if (item.parentId) {\n        const parent = map.get(item.parentId);\n        if (parent) parent.children.push(item);\n      } else {\n        roots.push(item);\n      }\n    });\n\n    return roots;\n  }\n\n  private flattenTree(nodes: STableDoubleCompleteItem[], level: number = 0): STableDoubleItem[] {\n    let result: STableDoubleItem[] = [];\n\n    for (let i = 0; i < nodes.length; i++) {\n      const node = nodes[i];\n      const hasChildren = !!node.children?.length;\n      const isExpanded = this.expandedNodes.get(node.id) ?? true;\n\n      result.push({\n        ...node,\n        name: node.name ?? '',\n        checked: !!node.checked,\n        parentId: node.parentId ?? null,\n        level: level,\n        expanded: isExpanded,\n        hasChildren: hasChildren,\n      } as STableDoubleItem);\n\n      if (hasChildren && isExpanded && node.children) {\n        result = result.concat(this.flattenTree(node.children, level + 1));\n      }\n    }\n    return result;\n  }\n\n  private resetSelections(): void {\n    const leftItems = this.config.itemsByTab[this.activeTabKey] ?? [];\n    leftItems.forEach(i => {\n      i.checked = false;\n      i.selected = false;\n    });\n    this.rightTableState.forEach(i => {\n      i.checked = false;\n      i.selected = false;\n    });\n  }\n\n  onSwitchChange(event: STableDoubleSwitchEvent): void {\n    if (event.isLeftTable) {\n      const leftItems = this.config.itemsByTab[this.activeTabKey] ?? [];\n      const item = leftItems.find(i => i.id === event.itemId);\n      if (item) item[event.columnId] = event.value;\n    } else {\n      const item = this.rightTableState.find(i => i.id === event.itemId);\n      if (item) item[event.columnId] = event.value;\n    }\n    this.switchChangeEvent.emit(event);\n  }\n\n  toggleNodeExpansion(nodeId: string): void {\n    const currentState = this.expandedNodes.get(nodeId) ?? true;\n    this.expandedNodes.set(nodeId, !currentState);\n    this.refreshTables();\n  }\n\n  onReorderItem(event: STableDoubleReorderEvent): void {\n    const { itemId, direction } = event;\n    const item = this.rightTableState.find(i => i.id === itemId);\n    if (!item) return;\n\n    const parentId = item.parentId ?? null;\n    const siblings = this.rightTableState.filter(i => (i.parentId ?? null) === parentId);\n    const siblingIndex = siblings.findIndex(i => i.id === itemId);\n    if (siblingIndex === -1) return;\n\n    let targetIndex: number;\n    switch (direction) {\n      case 'top':\n        targetIndex = 0;\n        break;\n      case 'up':\n        targetIndex = siblingIndex - 1;\n        break;\n      case 'down':\n        targetIndex = siblingIndex + 1;\n        break;\n      case 'bottom':\n        targetIndex = siblings.length - 1;\n        break;\n      default:\n        return;\n    }\n\n    if (targetIndex < 0 || targetIndex >= siblings.length || targetIndex === siblingIndex) return;\n\n    siblings.splice(siblingIndex, 1);\n    siblings.splice(targetIndex, 0, item);\n\n    this.rightTableState = this.rightTableState.filter(i => (i.parentId ?? null) !== parentId);\n    const insertRef = parentId ? this.rightTableState.findIndex(i => i.id === parentId) + 1 : 0;\n    this.rightTableState.splice(insertRef, 0, ...siblings);\n\n    this.refreshTables();\n  }\n}\n","<div class=\"s-table-double-complete\" [id]=\"id\">\n  <s-tabs [tabs]=\"config.tabs\" [configTabs]=\"config.configTabs\" (eventSelect)=\"onTabSelect($event)\"> </s-tabs>\n\n  <s-table-double\n    [config]=\"tableDoubleAdapter\"\n    (eventUpdateTables)=\"onUpdateTables($event)\"\n    (actionPositionEvent)=\"actionPositionEvent.emit($event)\"\n    (bottomStatusBarPositionEvent)=\"bottomStatusBarPositionEvent.emit($event)\"\n    (checkAllPositionEvent)=\"checkAllPositionEvent.emit($event)\"\n    (deletePositionEvent)=\"deletePositionEvent.emit($event)\"\n    (emptyPositionEvent)=\"emptyPositionEvent.emit($event)\"\n    (filterPositionEvent)=\"filterPositionEvent.emit($event)\"\n    (multiSelectPositionEvent)=\"multiSelectPositionEvent.emit($event)\"\n    (orderByPositionEvent)=\"orderByPositionEvent.emit($event)\"\n    (pillButtonPositionEvent)=\"pillButtonPositionEvent.emit($event)\"\n    (scrollPositionEvent)=\"scrollPositionEvent.emit($event)\"\n    (toggleExpandEvent)=\"toggleNodeExpansion($event)\"\n    (reorderItemEvent)=\"onReorderItem($event)\"\n    (switchChangeEvent)=\"onSwitchChange($event)\">\n  </s-table-double>\n</div>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtZG91YmxlLWNvbXBsZXRlLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2lkZXN5cy1nZW5lcmljLXVpL3NyYy9saWIvdGFibGUtZG91YmxlLWNvbXBsZXRlL3RhYmxlLWRvdWJsZS1jb21wbGV0ZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVRhYiwgSUNvbmZpZ1RhYnMgfSBmcm9tICcuLi90YWJzL21vZGVscyc7XG5pbXBvcnQgeyBTb3J0VGFibGUsIFNUYWJsZUNvbXBsZXRlLCBTVGFibGVzRGF0YSB9IGZyb20gJy4uLy4uL3B1YmxpYy1hcGknO1xuaW1wb3J0IHsgU1RhYmxlRG91YmxlU3dpdGNoRXZlbnQgfSBmcm9tICcuLi90YWJsZS1kb3VibGUvdGFibGUtZG91YmxlLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBTVGFibGVEb3VibGVDb21wbGV0ZUl0ZW0ge1xuICBpZDogc3RyaW5nO1xuICBzZWxlY3RlZENoZWNrYm94PzogYm9vbGVhbjtcbiAgbmFtZT86IHN0cmluZztcbiAgW2tleTogc3RyaW5nXTogYW55O1xuICBwYXJlbnRJZD86IHN0cmluZyB8IG51bGw7XG4gIGNoaWxkcmVuPzogU1RhYmxlRG91YmxlQ29tcGxldGVJdGVtW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU1RhYmxlRG91YmxlQ29tcGxldGVUYWJsZSB7XG4gIHRhYmxlTGVmdENvbmZpZzogU1RhYmxlQ29tcGxldGU7XG4gIHRhYmxlUmlnaHRDb25maWc6IFNUYWJsZUNvbXBsZXRlO1xuICB0YWJsZUxlZnRJdGVtczogU1RhYmxlRG91YmxlQ29tcGxldGVJdGVtW107XG4gIHRhYmxlUmlnaHRJdGVtczogU1RhYmxlRG91YmxlQ29tcGxldGVJdGVtW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU1RhYmxlRG91YmxlQ29tcGxldGVDb25maWcge1xuICB0YWJzOiBJVGFiW107XG4gIGNvbmZpZ1RhYnM/OiBJQ29uZmlnVGFicztcbiAgdGFibGVDb25maWc6IFNUYWJsZURvdWJsZUNvbXBsZXRlVGFibGU7XG4gIGl0ZW1zQnlUYWI6IFJlY29yZDxzdHJpbmcsIFNUYWJsZURvdWJsZUNvbXBsZXRlSXRlbVtdPjtcbiAgdHJlZU1vZGU/OiBib29sZWFuO1xuICBzaG93T3JkZXJCdXR0b25zPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgU1RhYmxlc0RvdWJsZUNvbXBsZXRlRGF0YSA9IFNUYWJsZXNEYXRhO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNUYWJsZURvdWJsZUNvbXBsZXRlVXBkYXRlRXZlbnRcbiAgZXh0ZW5kcyBTVGFibGVzRGF0YSB7XG4gIHRhYktleTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNUYWJsZURvdWJsZUNvbXBsZXRlRXZlbnQ8VD4ge1xuICBpc0xlZnRUYWJsZTogYm9vbGVhbjtcbiAgdmFsdWU6IFQ7XG59XG5cbmV4cG9ydCB0eXBlIFNUYWJsZURvdWJsZUNvbXBsZXRlQm9vbGVhbkV2ZW50ID1cbiAgU1RhYmxlRG91YmxlQ29tcGxldGVFdmVudDxib29sZWFuPjtcblxuZXhwb3J0IHR5cGUgU1RhYmxlRG91YmxlQ29tcGxldGVTdHJpbmdFdmVudCA9XG4gIFNUYWJsZURvdWJsZUNvbXBsZXRlRXZlbnQ8c3RyaW5nPjtcblxuZXhwb3J0IHR5cGUgU1RhYmxlRG91YmxlQ29tcGxldGVTdHJpbmdBcnJheUV2ZW50ID1cbiAgU1RhYmxlRG91YmxlQ29tcGxldGVFdmVudDxzdHJpbmdbXT47XG5cbmV4cG9ydCB0eXBlIFNUYWJsZURvdWJsZUNvbXBsZXRlTnVtYmVyRXZlbnQgPVxuICBTVGFibGVEb3VibGVDb21wbGV0ZUV2ZW50PG51bWJlcj47XG5cbmV4cG9ydCB0eXBlIFNUYWJsZURvdWJsZUNvbXBsZXRlU29ydEV2ZW50ID1cbiAgU1RhYmxlRG91YmxlQ29tcGxldGVFdmVudDxTb3J0VGFibGU+O1xuXG5leHBvcnQgdHlwZSBTVGFibGVEb3VibGVDb21wbGV0ZVN3aXRjaEV2ZW50ID0gU1RhYmxlRG91YmxlU3dpdGNoRXZlbnQ7XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtZG91YmxlLWNvbXBsZXRlLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2lkZXN5cy1nZW5lcmljLXVpL3NyYy9saWIvdGFibGUtZG91YmxlLWNvbXBsZXRlL3RhYmxlLWRvdWJsZS1jb21wbGV0ZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSVRhYiwgSUNvbmZpZ1RhYnMgfSBmcm9tICcuLi90YWJzL21vZGVscyc7XG5pbXBvcnQgeyBTb3J0VGFibGUsIFNUYWJsZUNvbXBsZXRlLCBTVGFibGVzRGF0YSB9IGZyb20gJy4uLy4uL3B1YmxpYy1hcGknO1xuaW1wb3J0IHsgU1RhYmxlRG91YmxlU3dpdGNoRXZlbnQgfSBmcm9tICcuLi90YWJsZS1kb3VibGUvdGFibGUtZG91YmxlLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBTVGFibGVEb3VibGVDb21wbGV0ZUl0ZW0ge1xuICBpZDogc3RyaW5nO1xuICBzZWxlY3RlZENoZWNrYm94PzogYm9vbGVhbjtcbiAgbmFtZT86IHN0cmluZztcbiAgW2tleTogc3RyaW5nXTogYW55O1xuICBwYXJlbnRJZD86IHN0cmluZyB8IG51bGw7XG4gIGNoaWxkcmVuPzogU1RhYmxlRG91YmxlQ29tcGxldGVJdGVtW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU1RhYmxlRG91YmxlQ29tcGxldGVUYWJsZSB7XG4gIHRhYmxlTGVmdENvbmZpZzogU1RhYmxlQ29tcGxldGU7XG4gIHRhYmxlUmlnaHRDb25maWc6IFNUYWJsZUNvbXBsZXRlO1xuICB0YWJsZUxlZnRJdGVtczogU1RhYmxlRG91YmxlQ29tcGxldGVJdGVtW107XG4gIHRhYmxlUmlnaHRJdGVtczogU1RhYmxlRG91YmxlQ29tcGxldGVJdGVtW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU1RhYmxlRG91YmxlQ29tcGxldGVDb25maWcge1xuICB0YWJzOiBJVGFiW107XG4gIGNvbmZpZ1RhYnM/OiBJQ29uZmlnVGFicztcbiAgdGFibGVDb25maWc6IFNUYWJsZURvdWJsZUNvbXBsZXRlVGFibGU7XG4gIGlkPzogc3RyaW5nO1xuICBpdGVtc0J5VGFiOiBSZWNvcmQ8c3RyaW5nLCBTVGFibGVEb3VibGVDb21wbGV0ZUl0ZW1bXT47XG4gIHRyZWVNb2RlPzogYm9vbGVhbjtcbiAgc2hvd09yZGVyQnV0dG9ucz86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIFNUYWJsZXNEb3VibGVDb21wbGV0ZURhdGEgPSBTVGFibGVzRGF0YTtcblxuZXhwb3J0IGludGVyZmFjZSBTVGFibGVEb3VibGVDb21wbGV0ZVVwZGF0ZUV2ZW50IGV4dGVuZHMgU1RhYmxlc0RhdGEge1xuICB0YWJLZXk6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTVGFibGVEb3VibGVDb21wbGV0ZUV2ZW50PFQ+IHtcbiAgaXNMZWZ0VGFibGU6IGJvb2xlYW47XG4gIHZhbHVlOiBUO1xufVxuXG5leHBvcnQgdHlwZSBTVGFibGVEb3VibGVDb21wbGV0ZUJvb2xlYW5FdmVudCA9IFNUYWJsZURvdWJsZUNvbXBsZXRlRXZlbnQ8Ym9vbGVhbj47XG5cbmV4cG9ydCB0eXBlIFNUYWJsZURvdWJsZUNvbXBsZXRlU3RyaW5nRXZlbnQgPSBTVGFibGVEb3VibGVDb21wbGV0ZUV2ZW50PHN0cmluZz47XG5cbmV4cG9ydCB0eXBlIFNUYWJsZURvdWJsZUNvbXBsZXRlU3RyaW5nQXJyYXlFdmVudCA9IFNUYWJsZURvdWJsZUNvbXBsZXRlRXZlbnQ8c3RyaW5nW10+O1xuXG5leHBvcnQgdHlwZSBTVGFibGVEb3VibGVDb21wbGV0ZU51bWJlckV2ZW50ID0gU1RhYmxlRG91YmxlQ29tcGxldGVFdmVudDxudW1iZXI+O1xuXG5leHBvcnQgdHlwZSBTVGFibGVEb3VibGVDb21wbGV0ZVNvcnRFdmVudCA9IFNUYWJsZURvdWJsZUNvbXBsZXRlRXZlbnQ8U29ydFRhYmxlPjtcblxuZXhwb3J0IHR5cGUgU1RhYmxlRG91YmxlQ29tcGxldGVTd2l0Y2hFdmVudCA9IFNUYWJsZURvdWJsZVN3aXRjaEV2ZW50O1xuIl19
@@ -9,6 +9,7 @@ export class STabletComponent {
9
9
  constructor() {
10
10
  this.loading = false;
11
11
  this.isTreeMode = false;
12
+ this.id = 's-tablet';
12
13
  this.loadingScroll = input(false);
13
14
  this.updateDataEvent = new EventEmitter();
14
15
  this.ordenByEvent = new EventEmitter();
@@ -53,11 +54,11 @@ export class STabletComponent {
53
54
  }
54
55
  }
55
56
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: STabletComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
56
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: STabletComponent, selector: "s-tablet", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: false, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: false, isRequired: false, transformFunction: null }, caption: { classPropertyName: "caption", publicName: "caption", isSignal: false, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: false, isRequired: false, transformFunction: null }, bodyloading: { classPropertyName: "bodyloading", publicName: "bodyloading", isSignal: false, isRequired: false, transformFunction: null }, body: { classPropertyName: "body", publicName: "body", isSignal: false, isRequired: false, transformFunction: null }, configColumn: { classPropertyName: "configColumn", publicName: "configColumn", isSignal: false, isRequired: false, transformFunction: null }, isTreeMode: { classPropertyName: "isTreeMode", publicName: "isTreeMode", isSignal: false, isRequired: false, transformFunction: null }, loadingScroll: { classPropertyName: "loadingScroll", publicName: "loadingScroll", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { updateDataEvent: "updateDataEvent", ordenByEvent: "ordenByEvent", checkAllEvent: "checkAllEvent", scrollEvent: "scrollEvent" }, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"caption\"></ng-container>\n<div class=\"pre-s-tablet s-scroll\" (scroll)=\"onScroll($event)\">\n <table class=\"s-tablet\">\n <thead>\n <ng-container *ngTemplateOutlet=\"header\"></ng-container>\n <tr *ngIf=\"configColumn && configColumn.length > 0 && !loading\">\n <th\n *ngFor=\"let column of configColumn\"\n [width]=\"column.width\"\n tabindex=\"0\"\n (keydown.enter)=\"orderBy(column)\"\n (click)=\"orderBy(column)\">\n <div\n class=\"s-tablet__header\"\n [ngClass]=\"{\n 's-tablet__header--align-center': column.align === 'center',\n 's-tablet__header--align-right': column.align === 'right',\n 's-tablet__header--align-left': column.align === 'left' || !column.align,\n cursor: column.sortable !== false,\n 's-tablet__disabled': loading,\n }\">\n <ng-container *ngIf=\"column.checkbox\">\n <span *ngIf=\"isTreeMode\" class=\"s-table-double__tree-spacer\"></span>\n <s-checkbox\n [ngClass]=\"{ 'mr-2': column.title }\"\n [config]=\"checkboxConfig\"\n [(ngModel)]=\"column.checkboxValue\"\n (ngModelChange)=\"checkAll($event)\">\n </s-checkbox>\n </ng-container>\n <div\n class=\"s-tablet__header__label\"\n [ngClass]=\"{\n 's-tablet__header__select': fieldSelect && fieldSelect.SortField === column.id,\n }\">\n {{ column.title }}\n </div>\n <span *ngIf=\"fieldSelect && fieldSelect.SortField === column.id\" class=\"s-tablet__header__icon\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\">{{\n fieldSelect.SortAsc ? 'keyboard_arrow_up' : 'keyboard_arrow_down'\n }}</s-icon-mat>\n </span>\n <span\n *ngIf=\"column.sortable !== false && column.title && fieldSelect && fieldSelect.SortField !== column.id\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n >keyboard_arrow_down</s-icon-mat\n >\n </span>\n <span\n *ngIf=\"!fieldSelect && column.sortable !== false && column.title\"\n class=\"s-tablet__header__icon--standard\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n >keyboard_arrow_down</s-icon-mat\n >\n </span>\n </div>\n </th>\n </tr>\n </thead>\n <tbody [ngClass]=\"loading ? 's-tablet__empty' : 's-tablet__body'\">\n <ng-container *ngIf=\"loading; else body\">\n <ng-template #body>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #loading *ngTemplateOutlet=\"bodyloading\"></ng-template>\n </ng-container>\n </tbody>\n @if (loadingScroll()) {\n <tbody class=\"s-tablet__body\">\n <tr>\n <td [attr.colspan]=\"configColumn.length || 1\" class=\"s-table-complete__loading\">\n <s-spinner size=\"sm\"></s-spinner>\n </td>\n </tr>\n </tbody>\n }\n </table>\n</div>\n", styles: [".pre-s-tablet{max-width:100%;overflow-x:auto}.pre-s-tablet .s-tablet{background-color:var(--primary-100);border-collapse:collapse;width:100%}.pre-s-tablet .s-tablet thead{background-color:var(--neutrals-1200);font-weight:700}.pre-s-tablet .s-tablet thead th{vertical-align:middle;color:var(--secondary-600);font-size:.875rem;line-height:1.375rem;letter-spacing:.016rem;font-weight:700!important;text-align:left}.pre-s-tablet .s-tablet thead th:last-of-type{text-align:center}.pre-s-tablet .s-tablet__body{background-color:var(--neutrals-1200);color:var(--secondary-600)}.pre-s-tablet .s-tablet__disabled{color:var(--neutrals-700);pointer-events:none}.pre-s-tablet .s-tablet__empty{display:table-caption;caption-side:bottom;width:100%}.pre-s-tablet .s-tablet tbody tr td,.pre-s-tablet .s-tablet thead tr th{padding:.875rem;height:3.5rem;vertical-align:middle;font-size:.875rem}.pre-s-tablet .s-tablet th,.pre-s-tablet .s-tablet td{box-sizing:border-box;border:none;box-shadow:inset 0 -.063rem 0 var(--neutrals-900)}.pre-s-tablet .s-tablet td,.pre-s-tablet .s-tablet thead tr{height:3.5rem}.pre-s-tablet .s-tablet thead tr th{position:sticky;top:0;background-color:var(--neutrals-1200)}.pre-s-tablet .s-tablet__header{display:flex;gap:.5rem;align-items:center}.pre-s-tablet .s-tablet__header__icon{color:var(--primary-600)}.pre-s-tablet .s-tablet__header__icon--standard .s-icon-mat span{color:var(--neutrals-800)}.pre-s-tablet .s-tablet__header--align-left{justify-content:flex-start}.pre-s-tablet .s-tablet__header--align-center{justify-content:center}.pre-s-tablet .s-tablet__header--align-right{justify-content:flex-end}.pre-s-tablet .s-tablet__header__label{color:var(--secondary-500);font-weight:600}.pre-s-tablet .s-tablet__header__select{color:var(--secondary-600);font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.SIconMaterialComponent, selector: "s-icon-mat", inputs: ["name", "size", "fill", "weight", "grade", "style", "type"] }, { kind: "component", type: i3.SCheckboxComponent, selector: "s-checkbox", inputs: ["config"], outputs: ["blur", "focus"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.SSpinnerComponent, selector: "s-spinner", inputs: ["size", "animation"] }], encapsulation: i0.ViewEncapsulation.None }); }
57
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: STabletComponent, selector: "s-tablet", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: false, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: false, isRequired: false, transformFunction: null }, caption: { classPropertyName: "caption", publicName: "caption", isSignal: false, isRequired: false, transformFunction: null }, header: { classPropertyName: "header", publicName: "header", isSignal: false, isRequired: false, transformFunction: null }, bodyloading: { classPropertyName: "bodyloading", publicName: "bodyloading", isSignal: false, isRequired: false, transformFunction: null }, body: { classPropertyName: "body", publicName: "body", isSignal: false, isRequired: false, transformFunction: null }, configColumn: { classPropertyName: "configColumn", publicName: "configColumn", isSignal: false, isRequired: false, transformFunction: null }, isTreeMode: { classPropertyName: "isTreeMode", publicName: "isTreeMode", isSignal: false, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: false, isRequired: false, transformFunction: null }, loadingScroll: { classPropertyName: "loadingScroll", publicName: "loadingScroll", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { updateDataEvent: "updateDataEvent", ordenByEvent: "ordenByEvent", checkAllEvent: "checkAllEvent", scrollEvent: "scrollEvent" }, ngImport: i0, template: "<ng-container *ngTemplateOutlet=\"caption\"></ng-container>\n<div class=\"pre-s-tablet s-scroll\" (scroll)=\"onScroll($event)\">\n <table class=\"s-tablet\" [id]=\"id\">\n <thead>\n <ng-container *ngTemplateOutlet=\"header\"></ng-container>\n <tr *ngIf=\"configColumn && configColumn.length > 0 && !loading\">\n <th\n *ngFor=\"let column of configColumn\"\n [width]=\"column.width\"\n tabindex=\"0\"\n (keydown.enter)=\"orderBy(column)\"\n (click)=\"orderBy(column)\">\n <div\n class=\"s-tablet__header\"\n [ngClass]=\"{\n 's-tablet__header--align-center': column.align === 'center',\n 's-tablet__header--align-right': column.align === 'right',\n 's-tablet__header--align-left': column.align === 'left' || !column.align,\n cursor: column.sortable !== false,\n 's-tablet__disabled': loading,\n }\">\n <ng-container *ngIf=\"column.checkbox\">\n <span *ngIf=\"isTreeMode\" class=\"s-table-double__tree-spacer\"></span>\n <s-checkbox\n [ngClass]=\"{ 'mr-2': column.title }\"\n [config]=\"checkboxConfig\"\n [(ngModel)]=\"column.checkboxValue\"\n (ngModelChange)=\"checkAll($event)\">\n </s-checkbox>\n </ng-container>\n <div\n class=\"s-tablet__header__label\"\n [id]=\"id + '-column-' + column.id\"\n [ngClass]=\"{\n 's-tablet__header__select': fieldSelect && fieldSelect.SortField === column.id,\n }\">\n {{ column.title }}\n </div>\n <span *ngIf=\"fieldSelect && fieldSelect.SortField === column.id\" class=\"s-tablet__header__icon\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\">{{\n fieldSelect.SortAsc ? 'keyboard_arrow_up' : 'keyboard_arrow_down'\n }}</s-icon-mat>\n </span>\n <span\n *ngIf=\"column.sortable !== false && column.title && fieldSelect && fieldSelect.SortField !== column.id\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n >keyboard_arrow_down</s-icon-mat\n >\n </span>\n <span\n *ngIf=\"!fieldSelect && column.sortable !== false && column.title\"\n class=\"s-tablet__header__icon--standard\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n >keyboard_arrow_down</s-icon-mat\n >\n </span>\n </div>\n </th>\n </tr>\n </thead>\n <tbody [ngClass]=\"loading ? 's-tablet__empty' : 's-tablet__body'\">\n <ng-container *ngIf=\"loading; else body\">\n <ng-template #body>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #loading *ngTemplateOutlet=\"bodyloading\"></ng-template>\n </ng-container>\n </tbody>\n @if (loadingScroll()) {\n <tbody class=\"s-tablet__body\">\n <tr>\n <td [attr.colspan]=\"configColumn.length || 1\" class=\"s-table-complete__loading\">\n <s-spinner [id]=\"id + '-spinner'\" size=\"sm\"></s-spinner>\n </td>\n </tr>\n </tbody>\n }\n </table>\n</div>\n", styles: [".pre-s-tablet{max-width:100%;overflow-x:auto}.pre-s-tablet .s-tablet{background-color:var(--primary-100);border-collapse:collapse;width:100%}.pre-s-tablet .s-tablet thead{background-color:var(--neutrals-1200);font-weight:700}.pre-s-tablet .s-tablet thead th{vertical-align:middle;color:var(--secondary-600);font-size:.875rem;line-height:1.375rem;letter-spacing:.016rem;font-weight:700!important;text-align:left}.pre-s-tablet .s-tablet thead th:last-of-type{text-align:center}.pre-s-tablet .s-tablet__body{background-color:var(--neutrals-1200);color:var(--secondary-600)}.pre-s-tablet .s-tablet__disabled{color:var(--neutrals-700);pointer-events:none}.pre-s-tablet .s-tablet__empty{display:table-caption;caption-side:bottom;width:100%}.pre-s-tablet .s-tablet tbody tr td,.pre-s-tablet .s-tablet thead tr th{padding:.875rem;height:3.5rem;vertical-align:middle;font-size:.875rem}.pre-s-tablet .s-tablet th,.pre-s-tablet .s-tablet td{box-sizing:border-box;border:none;box-shadow:inset 0 -.063rem 0 var(--neutrals-900)}.pre-s-tablet .s-tablet td,.pre-s-tablet .s-tablet thead tr{height:3.5rem}.pre-s-tablet .s-tablet thead tr th{position:sticky;top:0;background-color:var(--neutrals-1200)}.pre-s-tablet .s-tablet__header{display:flex;gap:.5rem;align-items:center}.pre-s-tablet .s-tablet__header__icon{color:var(--primary-600)}.pre-s-tablet .s-tablet__header__icon--standard .s-icon-mat span{color:var(--neutrals-800)}.pre-s-tablet .s-tablet__header--align-left{justify-content:flex-start}.pre-s-tablet .s-tablet__header--align-center{justify-content:center}.pre-s-tablet .s-tablet__header--align-right{justify-content:flex-end}.pre-s-tablet .s-tablet__header__label{color:var(--secondary-500);font-weight:600}.pre-s-tablet .s-tablet__header__select{color:var(--secondary-600);font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.SIconMaterialComponent, selector: "s-icon-mat", inputs: ["name", "size", "fill", "weight", "grade", "style", "type", "id"] }, { kind: "component", type: i3.SCheckboxComponent, selector: "s-checkbox", inputs: ["config", "id"], outputs: ["blur", "focus"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.SSpinnerComponent, selector: "s-spinner", inputs: ["size", "animation"] }], encapsulation: i0.ViewEncapsulation.None }); }
57
58
  }
58
59
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: STabletComponent, decorators: [{
59
60
  type: Component,
60
- args: [{ selector: 's-tablet', encapsulation: ViewEncapsulation.None, template: "<ng-container *ngTemplateOutlet=\"caption\"></ng-container>\n<div class=\"pre-s-tablet s-scroll\" (scroll)=\"onScroll($event)\">\n <table class=\"s-tablet\">\n <thead>\n <ng-container *ngTemplateOutlet=\"header\"></ng-container>\n <tr *ngIf=\"configColumn && configColumn.length > 0 && !loading\">\n <th\n *ngFor=\"let column of configColumn\"\n [width]=\"column.width\"\n tabindex=\"0\"\n (keydown.enter)=\"orderBy(column)\"\n (click)=\"orderBy(column)\">\n <div\n class=\"s-tablet__header\"\n [ngClass]=\"{\n 's-tablet__header--align-center': column.align === 'center',\n 's-tablet__header--align-right': column.align === 'right',\n 's-tablet__header--align-left': column.align === 'left' || !column.align,\n cursor: column.sortable !== false,\n 's-tablet__disabled': loading,\n }\">\n <ng-container *ngIf=\"column.checkbox\">\n <span *ngIf=\"isTreeMode\" class=\"s-table-double__tree-spacer\"></span>\n <s-checkbox\n [ngClass]=\"{ 'mr-2': column.title }\"\n [config]=\"checkboxConfig\"\n [(ngModel)]=\"column.checkboxValue\"\n (ngModelChange)=\"checkAll($event)\">\n </s-checkbox>\n </ng-container>\n <div\n class=\"s-tablet__header__label\"\n [ngClass]=\"{\n 's-tablet__header__select': fieldSelect && fieldSelect.SortField === column.id,\n }\">\n {{ column.title }}\n </div>\n <span *ngIf=\"fieldSelect && fieldSelect.SortField === column.id\" class=\"s-tablet__header__icon\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\">{{\n fieldSelect.SortAsc ? 'keyboard_arrow_up' : 'keyboard_arrow_down'\n }}</s-icon-mat>\n </span>\n <span\n *ngIf=\"column.sortable !== false && column.title && fieldSelect && fieldSelect.SortField !== column.id\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n >keyboard_arrow_down</s-icon-mat\n >\n </span>\n <span\n *ngIf=\"!fieldSelect && column.sortable !== false && column.title\"\n class=\"s-tablet__header__icon--standard\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n >keyboard_arrow_down</s-icon-mat\n >\n </span>\n </div>\n </th>\n </tr>\n </thead>\n <tbody [ngClass]=\"loading ? 's-tablet__empty' : 's-tablet__body'\">\n <ng-container *ngIf=\"loading; else body\">\n <ng-template #body>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #loading *ngTemplateOutlet=\"bodyloading\"></ng-template>\n </ng-container>\n </tbody>\n @if (loadingScroll()) {\n <tbody class=\"s-tablet__body\">\n <tr>\n <td [attr.colspan]=\"configColumn.length || 1\" class=\"s-table-complete__loading\">\n <s-spinner size=\"sm\"></s-spinner>\n </td>\n </tr>\n </tbody>\n }\n </table>\n</div>\n", styles: [".pre-s-tablet{max-width:100%;overflow-x:auto}.pre-s-tablet .s-tablet{background-color:var(--primary-100);border-collapse:collapse;width:100%}.pre-s-tablet .s-tablet thead{background-color:var(--neutrals-1200);font-weight:700}.pre-s-tablet .s-tablet thead th{vertical-align:middle;color:var(--secondary-600);font-size:.875rem;line-height:1.375rem;letter-spacing:.016rem;font-weight:700!important;text-align:left}.pre-s-tablet .s-tablet thead th:last-of-type{text-align:center}.pre-s-tablet .s-tablet__body{background-color:var(--neutrals-1200);color:var(--secondary-600)}.pre-s-tablet .s-tablet__disabled{color:var(--neutrals-700);pointer-events:none}.pre-s-tablet .s-tablet__empty{display:table-caption;caption-side:bottom;width:100%}.pre-s-tablet .s-tablet tbody tr td,.pre-s-tablet .s-tablet thead tr th{padding:.875rem;height:3.5rem;vertical-align:middle;font-size:.875rem}.pre-s-tablet .s-tablet th,.pre-s-tablet .s-tablet td{box-sizing:border-box;border:none;box-shadow:inset 0 -.063rem 0 var(--neutrals-900)}.pre-s-tablet .s-tablet td,.pre-s-tablet .s-tablet thead tr{height:3.5rem}.pre-s-tablet .s-tablet thead tr th{position:sticky;top:0;background-color:var(--neutrals-1200)}.pre-s-tablet .s-tablet__header{display:flex;gap:.5rem;align-items:center}.pre-s-tablet .s-tablet__header__icon{color:var(--primary-600)}.pre-s-tablet .s-tablet__header__icon--standard .s-icon-mat span{color:var(--neutrals-800)}.pre-s-tablet .s-tablet__header--align-left{justify-content:flex-start}.pre-s-tablet .s-tablet__header--align-center{justify-content:center}.pre-s-tablet .s-tablet__header--align-right{justify-content:flex-end}.pre-s-tablet .s-tablet__header__label{color:var(--secondary-500);font-weight:600}.pre-s-tablet .s-tablet__header__select{color:var(--secondary-600);font-weight:700}\n"] }]
61
+ args: [{ selector: 's-tablet', encapsulation: ViewEncapsulation.None, template: "<ng-container *ngTemplateOutlet=\"caption\"></ng-container>\n<div class=\"pre-s-tablet s-scroll\" (scroll)=\"onScroll($event)\">\n <table class=\"s-tablet\" [id]=\"id\">\n <thead>\n <ng-container *ngTemplateOutlet=\"header\"></ng-container>\n <tr *ngIf=\"configColumn && configColumn.length > 0 && !loading\">\n <th\n *ngFor=\"let column of configColumn\"\n [width]=\"column.width\"\n tabindex=\"0\"\n (keydown.enter)=\"orderBy(column)\"\n (click)=\"orderBy(column)\">\n <div\n class=\"s-tablet__header\"\n [ngClass]=\"{\n 's-tablet__header--align-center': column.align === 'center',\n 's-tablet__header--align-right': column.align === 'right',\n 's-tablet__header--align-left': column.align === 'left' || !column.align,\n cursor: column.sortable !== false,\n 's-tablet__disabled': loading,\n }\">\n <ng-container *ngIf=\"column.checkbox\">\n <span *ngIf=\"isTreeMode\" class=\"s-table-double__tree-spacer\"></span>\n <s-checkbox\n [ngClass]=\"{ 'mr-2': column.title }\"\n [config]=\"checkboxConfig\"\n [(ngModel)]=\"column.checkboxValue\"\n (ngModelChange)=\"checkAll($event)\">\n </s-checkbox>\n </ng-container>\n <div\n class=\"s-tablet__header__label\"\n [id]=\"id + '-column-' + column.id\"\n [ngClass]=\"{\n 's-tablet__header__select': fieldSelect && fieldSelect.SortField === column.id,\n }\">\n {{ column.title }}\n </div>\n <span *ngIf=\"fieldSelect && fieldSelect.SortField === column.id\" class=\"s-tablet__header__icon\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\">{{\n fieldSelect.SortAsc ? 'keyboard_arrow_up' : 'keyboard_arrow_down'\n }}</s-icon-mat>\n </span>\n <span\n *ngIf=\"column.sortable !== false && column.title && fieldSelect && fieldSelect.SortField !== column.id\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n >keyboard_arrow_down</s-icon-mat\n >\n </span>\n <span\n *ngIf=\"!fieldSelect && column.sortable !== false && column.title\"\n class=\"s-tablet__header__icon--standard\">\n <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n >keyboard_arrow_down</s-icon-mat\n >\n </span>\n </div>\n </th>\n </tr>\n </thead>\n <tbody [ngClass]=\"loading ? 's-tablet__empty' : 's-tablet__body'\">\n <ng-container *ngIf=\"loading; else body\">\n <ng-template #body>\n <ng-content></ng-content>\n </ng-template>\n <ng-template #loading *ngTemplateOutlet=\"bodyloading\"></ng-template>\n </ng-container>\n </tbody>\n @if (loadingScroll()) {\n <tbody class=\"s-tablet__body\">\n <tr>\n <td [attr.colspan]=\"configColumn.length || 1\" class=\"s-table-complete__loading\">\n <s-spinner [id]=\"id + '-spinner'\" size=\"sm\"></s-spinner>\n </td>\n </tr>\n </tbody>\n }\n </table>\n</div>\n", styles: [".pre-s-tablet{max-width:100%;overflow-x:auto}.pre-s-tablet .s-tablet{background-color:var(--primary-100);border-collapse:collapse;width:100%}.pre-s-tablet .s-tablet thead{background-color:var(--neutrals-1200);font-weight:700}.pre-s-tablet .s-tablet thead th{vertical-align:middle;color:var(--secondary-600);font-size:.875rem;line-height:1.375rem;letter-spacing:.016rem;font-weight:700!important;text-align:left}.pre-s-tablet .s-tablet thead th:last-of-type{text-align:center}.pre-s-tablet .s-tablet__body{background-color:var(--neutrals-1200);color:var(--secondary-600)}.pre-s-tablet .s-tablet__disabled{color:var(--neutrals-700);pointer-events:none}.pre-s-tablet .s-tablet__empty{display:table-caption;caption-side:bottom;width:100%}.pre-s-tablet .s-tablet tbody tr td,.pre-s-tablet .s-tablet thead tr th{padding:.875rem;height:3.5rem;vertical-align:middle;font-size:.875rem}.pre-s-tablet .s-tablet th,.pre-s-tablet .s-tablet td{box-sizing:border-box;border:none;box-shadow:inset 0 -.063rem 0 var(--neutrals-900)}.pre-s-tablet .s-tablet td,.pre-s-tablet .s-tablet thead tr{height:3.5rem}.pre-s-tablet .s-tablet thead tr th{position:sticky;top:0;background-color:var(--neutrals-1200)}.pre-s-tablet .s-tablet__header{display:flex;gap:.5rem;align-items:center}.pre-s-tablet .s-tablet__header__icon{color:var(--primary-600)}.pre-s-tablet .s-tablet__header__icon--standard .s-icon-mat span{color:var(--neutrals-800)}.pre-s-tablet .s-tablet__header--align-left{justify-content:flex-start}.pre-s-tablet .s-tablet__header--align-center{justify-content:center}.pre-s-tablet .s-tablet__header--align-right{justify-content:flex-end}.pre-s-tablet .s-tablet__header__label{color:var(--secondary-500);font-weight:600}.pre-s-tablet .s-tablet__header__select{color:var(--secondary-600);font-weight:700}\n"] }]
61
62
  }], propDecorators: { data: [{
62
63
  type: Input
63
64
  }], loading: [{
@@ -74,6 +75,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
74
75
  type: Input
75
76
  }], isTreeMode: [{
76
77
  type: Input
78
+ }], id: [{
79
+ type: Input
77
80
  }], updateDataEvent: [{
78
81
  type: Output
79
82
  }], ordenByEvent: [{
@@ -232,4 +235,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
232
235
  type: Input,
233
236
  args: ['STemplate']
234
237
  }] } });
235
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"s-tablet.component.js","sourceRoot":"","sources":["../../../../../projects/sidesys-generic-ui/src/lib/table-t/s-tablet.component.ts","../../../../../projects/sidesys-generic-ui/src/lib/table-t/s-tablet.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  Directive,\n  EventEmitter,\n  HostListener,\n  input,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ConfigColumn, SortTable } from './s-tablet-model';\n\n@Component({\n  selector: 's-tablet',\n  templateUrl: './s-tablet.component.html',\n  styleUrls: ['./s-tablet.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class STabletComponent implements OnInit {\n  @Input() data: any;\n  @Input() loading: boolean = false;\n  @Input() caption!: TemplateRef<any>;\n  @Input() header!: TemplateRef<any>;\n  @Input() bodyloading!: TemplateRef<any>;\n  @Input() body!: TemplateRef<any>;\n  @Input() configColumn!: ConfigColumn[];\n  @Input() isTreeMode: boolean = false;\n  loadingScroll = input<boolean>(false);\n\n  @Output() updateDataEvent = new EventEmitter<any>();\n  @Output() ordenByEvent = new EventEmitter<SortTable>();\n  @Output() checkAllEvent = new EventEmitter<boolean>();\n  @Output() scrollEvent = new EventEmitter<void>();\n\n  initData: any;\n  fieldSelect!: SortTable;\n  checkboxConfig = {\n    useFormControl: false,\n  };\n\n  ngOnInit(): void {\n    this.initData = this.data;\n  }\n\n  orderBy(column: ConfigColumn) {\n    if (column.sortable !== false && !column.disabled && !column.checkbox) {\n      if (column.id) {\n        //column.id es el campo a ordenar.\n        const sortAsc =\n          this.fieldSelect && this.fieldSelect.SortField === column.id && this.fieldSelect.SortAsc === true\n            ? false\n            : true;\n        this.fieldSelect = {\n          SortAsc: sortAsc,\n          SortField: column.id,\n        };\n        this.ordenByEvent.emit(this.fieldSelect);\n      }\n    }\n  }\n\n  updateData(_dataSort?: any): void {\n    this.updateDataEvent.next(_dataSort);\n  }\n\n  restartData(): void {\n    this.updateDataEvent.next(this.initData);\n  }\n\n  checkAll(event: any) {\n    this.checkAllEvent.emit(event);\n  }\n\n  onScroll(event: Event): void {\n    const element = event.target as HTMLElement;\n    const atBottom = element.scrollHeight - element.scrollTop <= element.clientHeight + element.scrollHeight * 0.1; // antes del final para disparar el evento\n\n    if (atBottom) {\n      this.scrollEvent.emit();\n    }\n  }\n}\n\n@Directive({\n  selector: '[SSorteableColumn]',\n  host: {\n    class: 'p-element',\n    '[class.p-sortable-column]': 'isEnabled()',\n    '[attr.aria-sort]': 'sortOrder',\n  },\n})\nexport class SortableColumn {\n  @Input('SSorteableColumn') field!: string;\n  @Input() pSortableColumnDisabled: boolean = false;\n\n  _dataSort: any;\n  sorted: boolean = false;\n  sortOrder!: string;\n\n  constructor(public data: STabletComponent) {\n    this._dataSort = this.data.data;\n  }\n\n  compareValues(key: any, order = 'asc') {\n    return function innerSort(\n      a: { [x: string]: any; hasOwnProperty: (arg0: any) => any },\n      b: { [x: string]: any; hasOwnProperty: (arg0: any) => any }\n    ) {\n      if (!a.hasOwnProperty(key) || !b.hasOwnProperty(key)) {\n        // property doesn't exist on either object\n        return 0;\n      }\n\n      const varA = typeof a[key] === 'string' ? a[key].toUpperCase() : a[key];\n      const varB = typeof b[key] === 'string' ? b[key].toUpperCase() : b[key];\n\n      let comparison = 0;\n      if (varA > varB) {\n        comparison = 1;\n      } else if (varA < varB) {\n        comparison = -1;\n      }\n      return order === 'desc' ? comparison * -1 : comparison;\n    };\n  }\n\n  updateSortState() {\n    this.sorted = !this.sorted;\n    this.sorted\n      ? this._dataSort.sort(this.compareValues(this.field, 'asc'))\n      : this._dataSort.sort(this.compareValues(this.field, 'desc'));\n  }\n\n  @HostListener('click', ['$event'])\n  onClick() {\n    if (this.isEnabled()) {\n      this.updateSortState();\n    }\n  }\n\n  isEnabled() {\n    return this.pSortableColumnDisabled !== true;\n  }\n}\n\n@Directive({\n  selector: '[SInputSearch]',\n  host: {\n    class: 's-element-search',\n  },\n})\nexport class InputSearch {\n  @Input('SInputSearch') fields!: string;\n\n  _dataFilter: any;\n  inputTimeout?: any;\n  dataBeforeSearch: any;\n\n  constructor(private data: STabletComponent) {\n    this._dataFilter = data.data;\n  }\n\n  filterItems(query: any) {\n    let results = [\n      ...this.data.data.filter((item: any) => {\n        const regexp = new RegExp(query, 'i');\n        const properties = Object.keys(item);\n        return properties.some(property => regexp.test(item[property]));\n      }),\n    ];\n    this._dataFilter = results;\n    this.data.updateData(this._dataFilter);\n  }\n\n  @HostListener('keyup', ['$event.target'])\n  onEnterKey(e: any) {\n    if (this.inputTimeout) {\n      clearTimeout(this.inputTimeout);\n    }\n    this.inputTimeout = setTimeout(\n      () => {\n        this.filterItems(e.value);\n      },\n      1000,\n      null\n    );\n\n    if (e.value === '') {\n      this.data.restartData();\n    }\n  }\n\n  @HostListener('search', ['$event.target'])\n  search(e: any) {\n    if (e.value === '') {\n      this.data.restartData();\n    }\n  }\n}\n\n@Directive({\n  selector: '[STemplate]',\n})\nexport class STemplate implements AfterContentInit {\n  @Input('STemplate') field!: string;\n\n  constructor(\n    private element: TemplateRef<any>,\n    public table: STabletComponent\n  ) {}\n\n  ngAfterContentInit(): void {\n    switch (this.field) {\n      case 'caption':\n        this.table.caption = this.element;\n        break;\n      case 'header':\n        this.table.header = this.element;\n        break;\n      case 'body':\n        this.table.body = this.element;\n        break;\n      case 'bodyloading':\n        this.table.bodyloading = this.element;\n        break;\n      default:\n        break;\n    }\n  }\n}\n","<ng-container *ngTemplateOutlet=\"caption\"></ng-container>\n<div class=\"pre-s-tablet s-scroll\" (scroll)=\"onScroll($event)\">\n  <table class=\"s-tablet\">\n    <thead>\n      <ng-container *ngTemplateOutlet=\"header\"></ng-container>\n      <tr *ngIf=\"configColumn && configColumn.length > 0 && !loading\">\n        <th\n          *ngFor=\"let column of configColumn\"\n          [width]=\"column.width\"\n          tabindex=\"0\"\n          (keydown.enter)=\"orderBy(column)\"\n          (click)=\"orderBy(column)\">\n          <div\n            class=\"s-tablet__header\"\n            [ngClass]=\"{\n              's-tablet__header--align-center': column.align === 'center',\n              's-tablet__header--align-right': column.align === 'right',\n              's-tablet__header--align-left': column.align === 'left' || !column.align,\n              cursor: column.sortable !== false,\n              's-tablet__disabled': loading,\n            }\">\n            <ng-container *ngIf=\"column.checkbox\">\n              <span *ngIf=\"isTreeMode\" class=\"s-table-double__tree-spacer\"></span>\n              <s-checkbox\n                [ngClass]=\"{ 'mr-2': column.title }\"\n                [config]=\"checkboxConfig\"\n                [(ngModel)]=\"column.checkboxValue\"\n                (ngModelChange)=\"checkAll($event)\">\n              </s-checkbox>\n            </ng-container>\n            <div\n              class=\"s-tablet__header__label\"\n              [ngClass]=\"{\n                's-tablet__header__select': fieldSelect && fieldSelect.SortField === column.id,\n              }\">\n              {{ column.title }}\n            </div>\n            <span *ngIf=\"fieldSelect && fieldSelect.SortField === column.id\" class=\"s-tablet__header__icon\">\n              <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\">{{\n                fieldSelect.SortAsc ? 'keyboard_arrow_up' : 'keyboard_arrow_down'\n              }}</s-icon-mat>\n            </span>\n            <span\n              *ngIf=\"column.sortable !== false && column.title && fieldSelect && fieldSelect.SortField !== column.id\">\n              <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n                >keyboard_arrow_down</s-icon-mat\n              >\n            </span>\n            <span\n              *ngIf=\"!fieldSelect && column.sortable !== false && column.title\"\n              class=\"s-tablet__header__icon--standard\">\n              <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n                >keyboard_arrow_down</s-icon-mat\n              >\n            </span>\n          </div>\n        </th>\n      </tr>\n    </thead>\n    <tbody [ngClass]=\"loading ? 's-tablet__empty' : 's-tablet__body'\">\n      <ng-container *ngIf=\"loading; else body\">\n        <ng-template #body>\n          <ng-content></ng-content>\n        </ng-template>\n        <ng-template #loading *ngTemplateOutlet=\"bodyloading\"></ng-template>\n      </ng-container>\n    </tbody>\n    @if (loadingScroll()) {\n      <tbody class=\"s-tablet__body\">\n        <tr>\n          <td [attr.colspan]=\"configColumn.length || 1\" class=\"s-table-complete__loading\">\n            <s-spinner size=\"sm\"></s-spinner>\n          </td>\n        </tr>\n      </tbody>\n    }\n  </table>\n</div>\n"]}
238
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"s-tablet.component.js","sourceRoot":"","sources":["../../../../../projects/sidesys-generic-ui/src/lib/table-t/s-tablet.component.ts","../../../../../projects/sidesys-generic-ui/src/lib/table-t/s-tablet.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  Directive,\n  EventEmitter,\n  HostListener,\n  input,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ConfigColumn, SortTable } from './s-tablet-model';\n\n@Component({\n  selector: 's-tablet',\n  templateUrl: './s-tablet.component.html',\n  styleUrls: ['./s-tablet.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class STabletComponent implements OnInit {\n  @Input() data: any;\n  @Input() loading: boolean = false;\n  @Input() caption!: TemplateRef<any>;\n  @Input() header!: TemplateRef<any>;\n  @Input() bodyloading!: TemplateRef<any>;\n  @Input() body!: TemplateRef<any>;\n  @Input() configColumn!: ConfigColumn[];\n  @Input() isTreeMode: boolean = false;\n  @Input() id?: string = 's-tablet';\n  loadingScroll = input<boolean>(false);\n\n  @Output() updateDataEvent = new EventEmitter<any>();\n  @Output() ordenByEvent = new EventEmitter<SortTable>();\n  @Output() checkAllEvent = new EventEmitter<boolean>();\n  @Output() scrollEvent = new EventEmitter<void>();\n\n  initData: any;\n  fieldSelect!: SortTable;\n  checkboxConfig = {\n    useFormControl: false,\n  };\n\n  ngOnInit(): void {\n    this.initData = this.data;\n  }\n\n  orderBy(column: ConfigColumn) {\n    if (column.sortable !== false && !column.disabled && !column.checkbox) {\n      if (column.id) {\n        //column.id es el campo a ordenar.\n        const sortAsc =\n          this.fieldSelect && this.fieldSelect.SortField === column.id && this.fieldSelect.SortAsc === true\n            ? false\n            : true;\n        this.fieldSelect = {\n          SortAsc: sortAsc,\n          SortField: column.id,\n        };\n        this.ordenByEvent.emit(this.fieldSelect);\n      }\n    }\n  }\n\n  updateData(_dataSort?: any): void {\n    this.updateDataEvent.next(_dataSort);\n  }\n\n  restartData(): void {\n    this.updateDataEvent.next(this.initData);\n  }\n\n  checkAll(event: any) {\n    this.checkAllEvent.emit(event);\n  }\n\n  onScroll(event: Event): void {\n    const element = event.target as HTMLElement;\n    const atBottom = element.scrollHeight - element.scrollTop <= element.clientHeight + element.scrollHeight * 0.1; // antes del final para disparar el evento\n\n    if (atBottom) {\n      this.scrollEvent.emit();\n    }\n  }\n}\n\n@Directive({\n  selector: '[SSorteableColumn]',\n  host: {\n    class: 'p-element',\n    '[class.p-sortable-column]': 'isEnabled()',\n    '[attr.aria-sort]': 'sortOrder',\n  },\n})\nexport class SortableColumn {\n  @Input('SSorteableColumn') field!: string;\n  @Input() pSortableColumnDisabled: boolean = false;\n\n  _dataSort: any;\n  sorted: boolean = false;\n  sortOrder!: string;\n\n  constructor(public data: STabletComponent) {\n    this._dataSort = this.data.data;\n  }\n\n  compareValues(key: any, order = 'asc') {\n    return function innerSort(\n      a: { [x: string]: any; hasOwnProperty: (arg0: any) => any },\n      b: { [x: string]: any; hasOwnProperty: (arg0: any) => any }\n    ) {\n      if (!a.hasOwnProperty(key) || !b.hasOwnProperty(key)) {\n        // property doesn't exist on either object\n        return 0;\n      }\n\n      const varA = typeof a[key] === 'string' ? a[key].toUpperCase() : a[key];\n      const varB = typeof b[key] === 'string' ? b[key].toUpperCase() : b[key];\n\n      let comparison = 0;\n      if (varA > varB) {\n        comparison = 1;\n      } else if (varA < varB) {\n        comparison = -1;\n      }\n      return order === 'desc' ? comparison * -1 : comparison;\n    };\n  }\n\n  updateSortState() {\n    this.sorted = !this.sorted;\n    this.sorted\n      ? this._dataSort.sort(this.compareValues(this.field, 'asc'))\n      : this._dataSort.sort(this.compareValues(this.field, 'desc'));\n  }\n\n  @HostListener('click', ['$event'])\n  onClick() {\n    if (this.isEnabled()) {\n      this.updateSortState();\n    }\n  }\n\n  isEnabled() {\n    return this.pSortableColumnDisabled !== true;\n  }\n}\n\n@Directive({\n  selector: '[SInputSearch]',\n  host: {\n    class: 's-element-search',\n  },\n})\nexport class InputSearch {\n  @Input('SInputSearch') fields!: string;\n\n  _dataFilter: any;\n  inputTimeout?: any;\n  dataBeforeSearch: any;\n\n  constructor(private data: STabletComponent) {\n    this._dataFilter = data.data;\n  }\n\n  filterItems(query: any) {\n    let results = [\n      ...this.data.data.filter((item: any) => {\n        const regexp = new RegExp(query, 'i');\n        const properties = Object.keys(item);\n        return properties.some(property => regexp.test(item[property]));\n      }),\n    ];\n    this._dataFilter = results;\n    this.data.updateData(this._dataFilter);\n  }\n\n  @HostListener('keyup', ['$event.target'])\n  onEnterKey(e: any) {\n    if (this.inputTimeout) {\n      clearTimeout(this.inputTimeout);\n    }\n    this.inputTimeout = setTimeout(\n      () => {\n        this.filterItems(e.value);\n      },\n      1000,\n      null\n    );\n\n    if (e.value === '') {\n      this.data.restartData();\n    }\n  }\n\n  @HostListener('search', ['$event.target'])\n  search(e: any) {\n    if (e.value === '') {\n      this.data.restartData();\n    }\n  }\n}\n\n@Directive({\n  selector: '[STemplate]',\n})\nexport class STemplate implements AfterContentInit {\n  @Input('STemplate') field!: string;\n\n  constructor(\n    private element: TemplateRef<any>,\n    public table: STabletComponent\n  ) {}\n\n  ngAfterContentInit(): void {\n    switch (this.field) {\n      case 'caption':\n        this.table.caption = this.element;\n        break;\n      case 'header':\n        this.table.header = this.element;\n        break;\n      case 'body':\n        this.table.body = this.element;\n        break;\n      case 'bodyloading':\n        this.table.bodyloading = this.element;\n        break;\n      default:\n        break;\n    }\n  }\n}\n","<ng-container *ngTemplateOutlet=\"caption\"></ng-container>\n<div class=\"pre-s-tablet s-scroll\" (scroll)=\"onScroll($event)\">\n  <table class=\"s-tablet\" [id]=\"id\">\n    <thead>\n      <ng-container *ngTemplateOutlet=\"header\"></ng-container>\n      <tr *ngIf=\"configColumn && configColumn.length > 0 && !loading\">\n        <th\n          *ngFor=\"let column of configColumn\"\n          [width]=\"column.width\"\n          tabindex=\"0\"\n          (keydown.enter)=\"orderBy(column)\"\n          (click)=\"orderBy(column)\">\n          <div\n            class=\"s-tablet__header\"\n            [ngClass]=\"{\n              's-tablet__header--align-center': column.align === 'center',\n              's-tablet__header--align-right': column.align === 'right',\n              's-tablet__header--align-left': column.align === 'left' || !column.align,\n              cursor: column.sortable !== false,\n              's-tablet__disabled': loading,\n            }\">\n            <ng-container *ngIf=\"column.checkbox\">\n              <span *ngIf=\"isTreeMode\" class=\"s-table-double__tree-spacer\"></span>\n              <s-checkbox\n                [ngClass]=\"{ 'mr-2': column.title }\"\n                [config]=\"checkboxConfig\"\n                [(ngModel)]=\"column.checkboxValue\"\n                (ngModelChange)=\"checkAll($event)\">\n              </s-checkbox>\n            </ng-container>\n            <div\n              class=\"s-tablet__header__label\"\n              [id]=\"id + '-column-' + column.id\"\n              [ngClass]=\"{\n                's-tablet__header__select': fieldSelect && fieldSelect.SortField === column.id,\n              }\">\n              {{ column.title }}\n            </div>\n            <span *ngIf=\"fieldSelect && fieldSelect.SortField === column.id\" class=\"s-tablet__header__icon\">\n              <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\">{{\n                fieldSelect.SortAsc ? 'keyboard_arrow_up' : 'keyboard_arrow_down'\n              }}</s-icon-mat>\n            </span>\n            <span\n              *ngIf=\"column.sortable !== false && column.title && fieldSelect && fieldSelect.SortField !== column.id\">\n              <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n                >keyboard_arrow_down</s-icon-mat\n              >\n            </span>\n            <span\n              *ngIf=\"!fieldSelect && column.sortable !== false && column.title\"\n              class=\"s-tablet__header__icon--standard\">\n              <s-icon-mat [type]=\"'symbol'\" size=\"sm\" class=\"icon cursor\" class=\"s-tablet__header__icon--standard\"\n                >keyboard_arrow_down</s-icon-mat\n              >\n            </span>\n          </div>\n        </th>\n      </tr>\n    </thead>\n    <tbody [ngClass]=\"loading ? 's-tablet__empty' : 's-tablet__body'\">\n      <ng-container *ngIf=\"loading; else body\">\n        <ng-template #body>\n          <ng-content></ng-content>\n        </ng-template>\n        <ng-template #loading *ngTemplateOutlet=\"bodyloading\"></ng-template>\n      </ng-container>\n    </tbody>\n    @if (loadingScroll()) {\n      <tbody class=\"s-tablet__body\">\n        <tr>\n          <td [attr.colspan]=\"configColumn.length || 1\" class=\"s-table-complete__loading\">\n            <s-spinner [id]=\"id + '-spinner'\" size=\"sm\"></s-spinner>\n          </td>\n        </tr>\n      </tbody>\n    }\n  </table>\n</div>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVHlwZUFjdGlvbnMuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2lkZXN5cy1nZW5lcmljLXVpL3NyYy9saWIvdGFibGUtdC90YWJsZS1hY3Rpb25zLWJ1dHRvbnMvaW50ZXJmYWNlcy9UeXBlQWN0aW9ucy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRIRU1FIH0gZnJvbSAnLi4vLi4vLi4vZW51bXMnO1xuaW1wb3J0IHsgQWN0aW9uc0J1dHRvbnNUeXBlIH0gZnJvbSAnLi4vZW51bXMvQWN0aW9uc0J1dHRvbnNUeXBlLmVudW0nO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFjdGlvbkJ1dHRvbiB7XG4gIGNvbG9yPzogVEhFTUU7XG4gIGN1c3RvbVR5cGU/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgaWNvbj86IHN0cmluZztcbiAgdHlwZT86IEFjdGlvbnNCdXR0b25zVHlwZTtcbiAgdG9vbHRpcFBvc2l0aW9uPzogJ2xlZnQnIHwgJ3JpZ2h0JyB8ICdib3R0b20nIHwgJ3RvcCc7XG4gIHRvb2x0aXA6IHN0cmluZztcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVHlwZUFjdGlvbnMuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2lkZXN5cy1nZW5lcmljLXVpL3NyYy9saWIvdGFibGUtdC90YWJsZS1hY3Rpb25zLWJ1dHRvbnMvaW50ZXJmYWNlcy9UeXBlQWN0aW9ucy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRIRU1FIH0gZnJvbSAnLi4vLi4vLi4vZW51bXMnO1xuaW1wb3J0IHsgQWN0aW9uc0J1dHRvbnNUeXBlIH0gZnJvbSAnLi4vZW51bXMvQWN0aW9uc0J1dHRvbnNUeXBlLmVudW0nO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFjdGlvbkJ1dHRvbiB7XG4gIGNvbG9yPzogVEhFTUU7XG4gIGN1c3RvbVR5cGU/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgaWNvbj86IHN0cmluZztcbiAgaWQ/OiBzdHJpbmc7XG4gIHR5cGU/OiBBY3Rpb25zQnV0dG9uc1R5cGU7XG4gIHRvb2x0aXBQb3NpdGlvbj86ICdsZWZ0JyB8ICdyaWdodCcgfCAnYm90dG9tJyB8ICd0b3AnO1xuICB0b29sdGlwOiBzdHJpbmc7XG59XG4iXX0=
@@ -8,6 +8,7 @@ import * as i3 from "../../tooltip/s-tooltip.component";
8
8
  import * as i4 from "../../tooltip/directive/s-tooltip-directive";
9
9
  export class TableActionsButtonsComponent {
10
10
  constructor() {
11
+ this.id = 's-table-actions-buttons';
11
12
  this.clickButtonEvent = new EventEmitter();
12
13
  this.Type = ActionsButtonsType;
13
14
  this.ActionsButtons = ActionsButtons;
@@ -32,14 +33,16 @@ export class TableActionsButtonsComponent {
32
33
  }
33
34
  }
34
35
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableActionsButtonsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
35
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TableActionsButtonsComponent, selector: "s-table-actions-buttons", inputs: { tableActionsButtons: "tableActionsButtons" }, outputs: { clickButtonEvent: "clickButtonEvent" }, ngImport: i0, template: "<div class=\"d-flex justify-content-center table-actions-buttons\">\n <ng-container *ngFor=\"let button of tableActionsButtons\">\n <s-icon-mat\n tabindex=\"0\"\n class=\"table-actions-buttons__icon px-1 no-select\"\n size=\"md\"\n [ngClass]=\"getButtonsClass(button)\"\n [tooltip]=\"tooltip\"\n (keyup.enter)=\"handleButtonClick(button)\"\n (click)=\"handleButtonClick(button)\">\n {{ button.icon ?? getButtonsType(button.type).icon }}\n </s-icon-mat>\n <s-tooltip #tooltip [title]=\"button.tooltip\" [position]=\"button.tooltipPosition ?? 'top'\" theme=\"dark\"></s-tooltip>\n </ng-container>\n</div>\n", styles: [".table-actions-buttons__icon{color:var(--primary-600);cursor:pointer}.table-actions-buttons__icon__primary{color:var(--primary-600)}.table-actions-buttons__icon__primary--disabled{color:var(--primary-300)}.table-actions-buttons__icon__primary:not(.table-actions-buttons__icon__primary--disabled):hover{color:var(--primary-900)}.table-actions-buttons__icon__secondary{color:var(--primary-600)}.table-actions-buttons__icon__secondary--disabled{color:var(--primary-300)}.table-actions-buttons__icon__secondary:not(.table-actions-buttons__icon__secondary--disabled):hover{color:var(--secondary-900)}.table-actions-buttons__icon__green{color:var(--green-600)}.table-actions-buttons__icon__green--disabled{color:var(--green-300)}.table-actions-buttons__icon__green:not(.table-actions-buttons__icon__green--disabled):hover{color:var(--green-900)}.table-actions-buttons__icon__red{color:var(--red-600)}.table-actions-buttons__icon__red--disabled{color:var(--red-300)}.table-actions-buttons__icon__red:not(.table-actions-buttons__icon__red--disabled):hover{color:var(--red-900)}.table-actions-buttons__icon__yellow{color:var(--yellow-600)}.table-actions-buttons__icon__yellow--disabled{color:var(--yellow-300)}.table-actions-buttons__icon__yellow:not(.table-actions-buttons__icon__yellow--disabled):hover{color:var(--yellow-900)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.SIconMaterialComponent, selector: "s-icon-mat", inputs: ["name", "size", "fill", "weight", "grade", "style", "type"] }, { kind: "component", type: i3.STooltipComponent, selector: "s-tooltip", inputs: ["title", "description", "theme", "position"] }, { kind: "directive", type: i4.CustomTooltipDirective, selector: "[tooltip]", inputs: ["tooltip"] }] }); }
36
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TableActionsButtonsComponent, selector: "s-table-actions-buttons", inputs: { tableActionsButtons: "tableActionsButtons", id: "id" }, outputs: { clickButtonEvent: "clickButtonEvent" }, ngImport: i0, template: "<div class=\"d-flex justify-content-center table-actions-buttons\">\n <ng-container *ngFor=\"let button of tableActionsButtons\">\n <s-icon-mat\n tabindex=\"0\"\n class=\"table-actions-buttons__icon px-1 no-select\"\n size=\"md\"\n [ngClass]=\"getButtonsClass(button)\"\n [tooltip]=\"tooltip\"\n [id]=\"id + '-' + button.type\"\n (keyup.enter)=\"handleButtonClick(button)\"\n (click)=\"handleButtonClick(button)\">\n {{ button.icon ?? getButtonsType(button.type).icon }}\n </s-icon-mat>\n <s-tooltip #tooltip [title]=\"button.tooltip\" [position]=\"button.tooltipPosition ?? 'top'\" theme=\"dark\"></s-tooltip>\n </ng-container>\n</div>\n", styles: [".table-actions-buttons__icon{color:var(--primary-600);cursor:pointer}.table-actions-buttons__icon__primary{color:var(--primary-600)}.table-actions-buttons__icon__primary--disabled{color:var(--primary-300)}.table-actions-buttons__icon__primary:not(.table-actions-buttons__icon__primary--disabled):hover{color:var(--primary-900)}.table-actions-buttons__icon__secondary{color:var(--primary-600)}.table-actions-buttons__icon__secondary--disabled{color:var(--primary-300)}.table-actions-buttons__icon__secondary:not(.table-actions-buttons__icon__secondary--disabled):hover{color:var(--secondary-900)}.table-actions-buttons__icon__green{color:var(--green-600)}.table-actions-buttons__icon__green--disabled{color:var(--green-300)}.table-actions-buttons__icon__green:not(.table-actions-buttons__icon__green--disabled):hover{color:var(--green-900)}.table-actions-buttons__icon__red{color:var(--red-600)}.table-actions-buttons__icon__red--disabled{color:var(--red-300)}.table-actions-buttons__icon__red:not(.table-actions-buttons__icon__red--disabled):hover{color:var(--red-900)}.table-actions-buttons__icon__yellow{color:var(--yellow-600)}.table-actions-buttons__icon__yellow--disabled{color:var(--yellow-300)}.table-actions-buttons__icon__yellow:not(.table-actions-buttons__icon__yellow--disabled):hover{color:var(--yellow-900)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.SIconMaterialComponent, selector: "s-icon-mat", inputs: ["name", "size", "fill", "weight", "grade", "style", "type", "id"] }, { kind: "component", type: i3.STooltipComponent, selector: "s-tooltip", inputs: ["title", "description", "theme", "position", "id"] }, { kind: "directive", type: i4.CustomTooltipDirective, selector: "[tooltip]", inputs: ["tooltip"] }] }); }
36
37
  }
37
38
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableActionsButtonsComponent, decorators: [{
38
39
  type: Component,
39
- args: [{ selector: 's-table-actions-buttons', template: "<div class=\"d-flex justify-content-center table-actions-buttons\">\n <ng-container *ngFor=\"let button of tableActionsButtons\">\n <s-icon-mat\n tabindex=\"0\"\n class=\"table-actions-buttons__icon px-1 no-select\"\n size=\"md\"\n [ngClass]=\"getButtonsClass(button)\"\n [tooltip]=\"tooltip\"\n (keyup.enter)=\"handleButtonClick(button)\"\n (click)=\"handleButtonClick(button)\">\n {{ button.icon ?? getButtonsType(button.type).icon }}\n </s-icon-mat>\n <s-tooltip #tooltip [title]=\"button.tooltip\" [position]=\"button.tooltipPosition ?? 'top'\" theme=\"dark\"></s-tooltip>\n </ng-container>\n</div>\n", styles: [".table-actions-buttons__icon{color:var(--primary-600);cursor:pointer}.table-actions-buttons__icon__primary{color:var(--primary-600)}.table-actions-buttons__icon__primary--disabled{color:var(--primary-300)}.table-actions-buttons__icon__primary:not(.table-actions-buttons__icon__primary--disabled):hover{color:var(--primary-900)}.table-actions-buttons__icon__secondary{color:var(--primary-600)}.table-actions-buttons__icon__secondary--disabled{color:var(--primary-300)}.table-actions-buttons__icon__secondary:not(.table-actions-buttons__icon__secondary--disabled):hover{color:var(--secondary-900)}.table-actions-buttons__icon__green{color:var(--green-600)}.table-actions-buttons__icon__green--disabled{color:var(--green-300)}.table-actions-buttons__icon__green:not(.table-actions-buttons__icon__green--disabled):hover{color:var(--green-900)}.table-actions-buttons__icon__red{color:var(--red-600)}.table-actions-buttons__icon__red--disabled{color:var(--red-300)}.table-actions-buttons__icon__red:not(.table-actions-buttons__icon__red--disabled):hover{color:var(--red-900)}.table-actions-buttons__icon__yellow{color:var(--yellow-600)}.table-actions-buttons__icon__yellow--disabled{color:var(--yellow-300)}.table-actions-buttons__icon__yellow:not(.table-actions-buttons__icon__yellow--disabled):hover{color:var(--yellow-900)}\n"] }]
40
+ args: [{ selector: 's-table-actions-buttons', template: "<div class=\"d-flex justify-content-center table-actions-buttons\">\n <ng-container *ngFor=\"let button of tableActionsButtons\">\n <s-icon-mat\n tabindex=\"0\"\n class=\"table-actions-buttons__icon px-1 no-select\"\n size=\"md\"\n [ngClass]=\"getButtonsClass(button)\"\n [tooltip]=\"tooltip\"\n [id]=\"id + '-' + button.type\"\n (keyup.enter)=\"handleButtonClick(button)\"\n (click)=\"handleButtonClick(button)\">\n {{ button.icon ?? getButtonsType(button.type).icon }}\n </s-icon-mat>\n <s-tooltip #tooltip [title]=\"button.tooltip\" [position]=\"button.tooltipPosition ?? 'top'\" theme=\"dark\"></s-tooltip>\n </ng-container>\n</div>\n", styles: [".table-actions-buttons__icon{color:var(--primary-600);cursor:pointer}.table-actions-buttons__icon__primary{color:var(--primary-600)}.table-actions-buttons__icon__primary--disabled{color:var(--primary-300)}.table-actions-buttons__icon__primary:not(.table-actions-buttons__icon__primary--disabled):hover{color:var(--primary-900)}.table-actions-buttons__icon__secondary{color:var(--primary-600)}.table-actions-buttons__icon__secondary--disabled{color:var(--primary-300)}.table-actions-buttons__icon__secondary:not(.table-actions-buttons__icon__secondary--disabled):hover{color:var(--secondary-900)}.table-actions-buttons__icon__green{color:var(--green-600)}.table-actions-buttons__icon__green--disabled{color:var(--green-300)}.table-actions-buttons__icon__green:not(.table-actions-buttons__icon__green--disabled):hover{color:var(--green-900)}.table-actions-buttons__icon__red{color:var(--red-600)}.table-actions-buttons__icon__red--disabled{color:var(--red-300)}.table-actions-buttons__icon__red:not(.table-actions-buttons__icon__red--disabled):hover{color:var(--red-900)}.table-actions-buttons__icon__yellow{color:var(--yellow-600)}.table-actions-buttons__icon__yellow--disabled{color:var(--yellow-300)}.table-actions-buttons__icon__yellow:not(.table-actions-buttons__icon__yellow--disabled):hover{color:var(--yellow-900)}\n"] }]
40
41
  }], propDecorators: { tableActionsButtons: [{
41
42
  type: Input
43
+ }], id: [{
44
+ type: Input
42
45
  }], clickButtonEvent: [{
43
46
  type: Output
44
47
  }] } });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtYWN0aW9ucy1idXR0b25zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpZGVzeXMtZ2VuZXJpYy11aS9zcmMvbGliL3RhYmxlLXQvdGFibGUtYWN0aW9ucy1idXR0b25zL3RhYmxlLWFjdGlvbnMtYnV0dG9ucy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaWRlc3lzLWdlbmVyaWMtdWkvc3JjL2xpYi90YWJsZS10L3RhYmxlLWFjdGlvbnMtYnV0dG9ucy90YWJsZS1hY3Rpb25zLWJ1dHRvbnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7Ozs7OztBQU83RCxNQUFNLE9BQU8sNEJBQTRCO0lBTHpDO1FBT1kscUJBQWdCLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUV4RCxTQUFJLEdBQUcsa0JBQWtCLENBQUM7UUFDMUIsbUJBQWMsR0FBRyxjQUFjLENBQUM7S0F1QmpDO0lBckJDLGNBQWMsQ0FBQyxJQUF5QjtRQUN0QyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLENBQUM7UUFDekUsT0FBTyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbkIsQ0FBQztJQUVELGVBQWUsQ0FBQyxNQUFvQjtRQUNsQyxNQUFNLElBQUksR0FBbUMsTUFBTSxDQUFDLElBQUksSUFBSSxTQUFTLENBQUM7UUFDdEUsSUFBSSxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssQ0FBQztRQUM3RCxzRUFBc0U7UUFDdEUsSUFBSSxDQUFDLEtBQUssSUFBSSxLQUFLLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDbEMsS0FBSyxHQUFHLFNBQVMsQ0FBQztRQUNwQixDQUFDO1FBQ0QsT0FBTyxnQ0FBZ0MsS0FBSyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUM7SUFDdkYsQ0FBQztJQUVELGlCQUFpQixDQUFDLE1BQW9CO1FBQ3BDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDckIsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLFVBQVUsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDO1lBQzlDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbkMsQ0FBQztJQUNILENBQUM7K0dBM0JVLDRCQUE0QjttR0FBNUIsNEJBQTRCLDBLQ1Z6QyxpcEJBZUE7OzRGRExhLDRCQUE0QjtrQkFMeEMsU0FBUzsrQkFDRSx5QkFBeUI7OEJBSzFCLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDSSxnQkFBZ0I7c0JBQXpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWN0aW9uQnV0dG9uIH0gZnJvbSAnLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEFjdGlvbnNCdXR0b25zVHlwZSB9IGZyb20gJy4vZW51bXMvQWN0aW9uc0J1dHRvbnNUeXBlLmVudW0nO1xuaW1wb3J0IHsgQWN0aW9uc0J1dHRvbnMgfSBmcm9tICcuL2NvbnN0YW50cy9hY3Rpb25zLWJ1dHRvbnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzLXRhYmxlLWFjdGlvbnMtYnV0dG9ucycsXG4gIHRlbXBsYXRlVXJsOiAnLi90YWJsZS1hY3Rpb25zLWJ1dHRvbnMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90YWJsZS1hY3Rpb25zLWJ1dHRvbnMuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVBY3Rpb25zQnV0dG9uc0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHRhYmxlQWN0aW9uc0J1dHRvbnMhOiBBY3Rpb25CdXR0b25bXTtcbiAgQE91dHB1dCgpIGNsaWNrQnV0dG9uRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBUeXBlID0gQWN0aW9uc0J1dHRvbnNUeXBlO1xuICBBY3Rpb25zQnV0dG9ucyA9IEFjdGlvbnNCdXR0b25zO1xuXG4gIGdldEJ1dHRvbnNUeXBlKHR5cGU/OiBBY3Rpb25zQnV0dG9uc1R5cGUpIHtcbiAgICBjb25zdCBidXR0b24gPSB0aGlzLkFjdGlvbnNCdXR0b25zLmZpbHRlcihhY3Rpb24gPT4gYWN0aW9uLnR5cGUgPT0gdHlwZSk7XG4gICAgcmV0dXJuIGJ1dHRvblswXTtcbiAgfVxuXG4gIGdldEJ1dHRvbnNDbGFzcyhidXR0b246IEFjdGlvbkJ1dHRvbik6IHN0cmluZyB7XG4gICAgY29uc3QgdHlwZTogQWN0aW9uc0J1dHRvbnNUeXBlIHwgdW5kZWZpbmVkID0gYnV0dG9uLnR5cGUgPz8gdW5kZWZpbmVkO1xuICAgIGxldCBjb2xvciA9IGJ1dHRvbi5jb2xvciA/PyB0aGlzLmdldEJ1dHRvbnNUeXBlKHR5cGUpPy5jb2xvcjtcbiAgICAvL0N1YW5kbyBubyBleGlzdGUgZWwgY29sb3IgLCBvIGVzIGRlZmF1bHQgc2UgcG9uZSBwb3IgZGVmZWN0byBwcmltYXJ5XG4gICAgaWYgKCFjb2xvciB8fCBjb2xvciA9PT0gJ2RlZmF1bHQnKSB7XG4gICAgICBjb2xvciA9ICdwcmltYXJ5JztcbiAgICB9XG4gICAgcmV0dXJuIGB0YWJsZS1hY3Rpb25zLWJ1dHRvbnNfX2ljb25fXyR7Y29sb3J9JHtidXR0b24uZGlzYWJsZWQgPyAnLS1kaXNhYmxlZCcgOiAnJ31gO1xuICB9XG5cbiAgaGFuZGxlQnV0dG9uQ2xpY2soYnV0dG9uOiBBY3Rpb25CdXR0b24pOiB2b2lkIHtcbiAgICBpZiAoIWJ1dHRvbi5kaXNhYmxlZCkge1xuICAgICAgY29uc3QgdHlwZSA9IGJ1dHRvbi5jdXN0b21UeXBlID8/IGJ1dHRvbi50eXBlO1xuICAgICAgdGhpcy5jbGlja0J1dHRvbkV2ZW50LmVtaXQodHlwZSk7XG4gICAgfVxuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1jZW50ZXIgdGFibGUtYWN0aW9ucy1idXR0b25zXCI+XG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGJ1dHRvbiBvZiB0YWJsZUFjdGlvbnNCdXR0b25zXCI+XG4gICAgPHMtaWNvbi1tYXRcbiAgICAgIHRhYmluZGV4PVwiMFwiXG4gICAgICBjbGFzcz1cInRhYmxlLWFjdGlvbnMtYnV0dG9uc19faWNvbiBweC0xIG5vLXNlbGVjdFwiXG4gICAgICBzaXplPVwibWRcIlxuICAgICAgW25nQ2xhc3NdPVwiZ2V0QnV0dG9uc0NsYXNzKGJ1dHRvbilcIlxuICAgICAgW3Rvb2x0aXBdPVwidG9vbHRpcFwiXG4gICAgICAoa2V5dXAuZW50ZXIpPVwiaGFuZGxlQnV0dG9uQ2xpY2soYnV0dG9uKVwiXG4gICAgICAoY2xpY2spPVwiaGFuZGxlQnV0dG9uQ2xpY2soYnV0dG9uKVwiPlxuICAgICAge3sgYnV0dG9uLmljb24gPz8gZ2V0QnV0dG9uc1R5cGUoYnV0dG9uLnR5cGUpLmljb24gfX1cbiAgICA8L3MtaWNvbi1tYXQ+XG4gICAgPHMtdG9vbHRpcCAjdG9vbHRpcCBbdGl0bGVdPVwiYnV0dG9uLnRvb2x0aXBcIiBbcG9zaXRpb25dPVwiYnV0dG9uLnRvb2x0aXBQb3NpdGlvbiA/PyAndG9wJ1wiIHRoZW1lPVwiZGFya1wiPjwvcy10b29sdGlwPlxuICA8L25nLWNvbnRhaW5lcj5cbjwvZGl2PlxuIl19
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtYWN0aW9ucy1idXR0b25zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpZGVzeXMtZ2VuZXJpYy11aS9zcmMvbGliL3RhYmxlLXQvdGFibGUtYWN0aW9ucy1idXR0b25zL3RhYmxlLWFjdGlvbnMtYnV0dG9ucy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaWRlc3lzLWdlbmVyaWMtdWkvc3JjL2xpYi90YWJsZS10L3RhYmxlLWFjdGlvbnMtYnV0dG9ucy90YWJsZS1hY3Rpb25zLWJ1dHRvbnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7Ozs7OztBQU83RCxNQUFNLE9BQU8sNEJBQTRCO0lBTHpDO1FBT1csT0FBRSxHQUFZLHlCQUF5QixDQUFDO1FBQ3ZDLHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFFeEQsU0FBSSxHQUFHLGtCQUFrQixDQUFDO1FBQzFCLG1CQUFjLEdBQUcsY0FBYyxDQUFDO0tBdUJqQztJQXJCQyxjQUFjLENBQUMsSUFBeUI7UUFDdEMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxDQUFDO1FBQ3pFLE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25CLENBQUM7SUFFRCxlQUFlLENBQUMsTUFBb0I7UUFDbEMsTUFBTSxJQUFJLEdBQW1DLE1BQU0sQ0FBQyxJQUFJLElBQUksU0FBUyxDQUFDO1FBQ3RFLElBQUksS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLENBQUM7UUFDN0Qsc0VBQXNFO1FBQ3RFLElBQUksQ0FBQyxLQUFLLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO1lBQ2xDLEtBQUssR0FBRyxTQUFTLENBQUM7UUFDcEIsQ0FBQztRQUNELE9BQU8sZ0NBQWdDLEtBQUssR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDO0lBQ3ZGLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxNQUFvQjtRQUNwQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3JCLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxVQUFVLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQztZQUM5QyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ25DLENBQUM7SUFDSCxDQUFDOytHQTVCVSw0QkFBNEI7bUdBQTVCLDRCQUE0QixvTENWekMsd3JCQWdCQTs7NEZETmEsNEJBQTRCO2tCQUx4QyxTQUFTOytCQUNFLHlCQUF5Qjs4QkFLMUIsbUJBQW1CO3NCQUEzQixLQUFLO2dCQUNHLEVBQUU7c0JBQVYsS0FBSztnQkFDSSxnQkFBZ0I7c0JBQXpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWN0aW9uQnV0dG9uIH0gZnJvbSAnLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEFjdGlvbnNCdXR0b25zVHlwZSB9IGZyb20gJy4vZW51bXMvQWN0aW9uc0J1dHRvbnNUeXBlLmVudW0nO1xuaW1wb3J0IHsgQWN0aW9uc0J1dHRvbnMgfSBmcm9tICcuL2NvbnN0YW50cy9hY3Rpb25zLWJ1dHRvbnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzLXRhYmxlLWFjdGlvbnMtYnV0dG9ucycsXG4gIHRlbXBsYXRlVXJsOiAnLi90YWJsZS1hY3Rpb25zLWJ1dHRvbnMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90YWJsZS1hY3Rpb25zLWJ1dHRvbnMuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVBY3Rpb25zQnV0dG9uc0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHRhYmxlQWN0aW9uc0J1dHRvbnMhOiBBY3Rpb25CdXR0b25bXTtcbiAgQElucHV0KCkgaWQ/OiBzdHJpbmcgPSAncy10YWJsZS1hY3Rpb25zLWJ1dHRvbnMnO1xuICBAT3V0cHV0KCkgY2xpY2tCdXR0b25FdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xuXG4gIFR5cGUgPSBBY3Rpb25zQnV0dG9uc1R5cGU7XG4gIEFjdGlvbnNCdXR0b25zID0gQWN0aW9uc0J1dHRvbnM7XG5cbiAgZ2V0QnV0dG9uc1R5cGUodHlwZT86IEFjdGlvbnNCdXR0b25zVHlwZSkge1xuICAgIGNvbnN0IGJ1dHRvbiA9IHRoaXMuQWN0aW9uc0J1dHRvbnMuZmlsdGVyKGFjdGlvbiA9PiBhY3Rpb24udHlwZSA9PSB0eXBlKTtcbiAgICByZXR1cm4gYnV0dG9uWzBdO1xuICB9XG5cbiAgZ2V0QnV0dG9uc0NsYXNzKGJ1dHRvbjogQWN0aW9uQnV0dG9uKTogc3RyaW5nIHtcbiAgICBjb25zdCB0eXBlOiBBY3Rpb25zQnV0dG9uc1R5cGUgfCB1bmRlZmluZWQgPSBidXR0b24udHlwZSA/PyB1bmRlZmluZWQ7XG4gICAgbGV0IGNvbG9yID0gYnV0dG9uLmNvbG9yID8/IHRoaXMuZ2V0QnV0dG9uc1R5cGUodHlwZSk/LmNvbG9yO1xuICAgIC8vQ3VhbmRvIG5vIGV4aXN0ZSBlbCBjb2xvciAsIG8gZXMgZGVmYXVsdCBzZSBwb25lIHBvciBkZWZlY3RvIHByaW1hcnlcbiAgICBpZiAoIWNvbG9yIHx8IGNvbG9yID09PSAnZGVmYXVsdCcpIHtcbiAgICAgIGNvbG9yID0gJ3ByaW1hcnknO1xuICAgIH1cbiAgICByZXR1cm4gYHRhYmxlLWFjdGlvbnMtYnV0dG9uc19faWNvbl9fJHtjb2xvcn0ke2J1dHRvbi5kaXNhYmxlZCA/ICctLWRpc2FibGVkJyA6ICcnfWA7XG4gIH1cblxuICBoYW5kbGVCdXR0b25DbGljayhidXR0b246IEFjdGlvbkJ1dHRvbik6IHZvaWQge1xuICAgIGlmICghYnV0dG9uLmRpc2FibGVkKSB7XG4gICAgICBjb25zdCB0eXBlID0gYnV0dG9uLmN1c3RvbVR5cGUgPz8gYnV0dG9uLnR5cGU7XG4gICAgICB0aGlzLmNsaWNrQnV0dG9uRXZlbnQuZW1pdCh0eXBlKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJkLWZsZXgganVzdGlmeS1jb250ZW50LWNlbnRlciB0YWJsZS1hY3Rpb25zLWJ1dHRvbnNcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgYnV0dG9uIG9mIHRhYmxlQWN0aW9uc0J1dHRvbnNcIj5cbiAgICA8cy1pY29uLW1hdFxuICAgICAgdGFiaW5kZXg9XCIwXCJcbiAgICAgIGNsYXNzPVwidGFibGUtYWN0aW9ucy1idXR0b25zX19pY29uIHB4LTEgbm8tc2VsZWN0XCJcbiAgICAgIHNpemU9XCJtZFwiXG4gICAgICBbbmdDbGFzc109XCJnZXRCdXR0b25zQ2xhc3MoYnV0dG9uKVwiXG4gICAgICBbdG9vbHRpcF09XCJ0b29sdGlwXCJcbiAgICAgIFtpZF09XCJpZCArICctJyArIGJ1dHRvbi50eXBlXCJcbiAgICAgIChrZXl1cC5lbnRlcik9XCJoYW5kbGVCdXR0b25DbGljayhidXR0b24pXCJcbiAgICAgIChjbGljayk9XCJoYW5kbGVCdXR0b25DbGljayhidXR0b24pXCI+XG4gICAgICB7eyBidXR0b24uaWNvbiA/PyBnZXRCdXR0b25zVHlwZShidXR0b24udHlwZSkuaWNvbiB9fVxuICAgIDwvcy1pY29uLW1hdD5cbiAgICA8cy10b29sdGlwICN0b29sdGlwIFt0aXRsZV09XCJidXR0b24udG9vbHRpcFwiIFtwb3NpdGlvbl09XCJidXR0b24udG9vbHRpcFBvc2l0aW9uID8/ICd0b3AnXCIgdGhlbWU9XCJkYXJrXCI+PC9zLXRvb2x0aXA+XG4gIDwvbmctY29udGFpbmVyPlxuPC9kaXY+XG4iXX0=
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnVGFicy5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaWRlc3lzLWdlbmVyaWMtdWkvc3JjL2xpYi90YWJzL21vZGVscy9jb25maWdUYWJzLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJQ29uZmlnVGFicyB7XG4gIHdpZHRoPzogbnVtYmVyO1xuICBiYWNrZ3JvdW5kPzogYm9vbGVhbjtcbiAgcGlsbD86IGJvb2xlYW47XG4gIHNpemU/OiAnc20nIHwgJ21kJztcbiAgb3JpZW50YXRpb24/OiAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnO1xuICB1bmRlcmxpbmU/OiBib29sZWFuO1xuICBiYWNrZ3JvdW5kU2VsZWN0ZWQ/OiBib29sZWFuO1xuICBoZWlnaHQ/OiBudW1iZXI7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnVGFicy5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaWRlc3lzLWdlbmVyaWMtdWkvc3JjL2xpYi90YWJzL21vZGVscy9jb25maWdUYWJzLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJQ29uZmlnVGFicyB7XG4gIHdpZHRoPzogbnVtYmVyO1xuICBiYWNrZ3JvdW5kPzogYm9vbGVhbjtcbiAgcGlsbD86IGJvb2xlYW47XG4gIGlkPzogc3RyaW5nO1xuICBzaXplPzogJ3NtJyB8ICdtZCc7XG4gIG9yaWVudGF0aW9uPzogJ2hvcml6b250YWwnIHwgJ3ZlcnRpY2FsJztcbiAgdW5kZXJsaW5lPzogYm9vbGVhbjtcbiAgYmFja2dyb3VuZFNlbGVjdGVkPzogYm9vbGVhbjtcbiAgaGVpZ2h0PzogbnVtYmVyO1xufVxuIl19