@smartbit4all/ng-client 3.3.139 → 3.3.141

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 (100) hide show
  1. package/esm2020/lib/smart-client/smart-component-api-client.mjs +34 -31
  2. package/esm2020/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.mjs +1 -1
  3. package/esm2020/lib/smart-component-layout/api/model/smartComponentWidgetDefinition.mjs +1 -1
  4. package/esm2020/lib/smart-component-layout/smart-component-layout-utility.mjs +48 -9
  5. package/esm2020/lib/smart-component-layout/smart-component-layout.component.mjs +67 -28
  6. package/esm2020/lib/smart-component-layout/smart-component-layout.module.mjs +1 -5
  7. package/esm2020/lib/smart-dialog/smartdialog.model.mjs +1 -1
  8. package/esm2020/lib/smart-dialog/smartdialog.module.mjs +5 -5
  9. package/esm2020/lib/smart-expandable-section/expandable-section.component.mjs +12 -6
  10. package/esm2020/lib/smart-expandable-section/expandable-section.model.mjs +1 -1
  11. package/esm2020/lib/smart-filter/api/filter/model/filterExpressionFieldWidgetType.mjs +2 -1
  12. package/esm2020/lib/smart-filter/smart-filter.module.mjs +5 -5
  13. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionField.mjs +1 -1
  14. package/esm2020/lib/smart-filter-editor/api/model/filterExpressionFieldWidgetType.mjs +2 -1
  15. package/esm2020/lib/smart-filter-editor/api/model/smartFilterType.mjs +17 -0
  16. package/esm2020/lib/smart-filter-editor/smart-filter-editor.module.mjs +1 -8
  17. package/esm2020/lib/smart-form/api/model/smartFormWidgetType.mjs +1 -1
  18. package/esm2020/lib/smart-form/api/model/smartMatrixModel.mjs +1 -1
  19. package/esm2020/lib/smart-form/api/model/smartWidgetDefinition.mjs +1 -1
  20. package/esm2020/lib/smart-form/api/model/valueChangeMode.mjs +1 -1
  21. package/esm2020/lib/smart-form/projects.mjs +1 -2
  22. package/esm2020/lib/smart-form/services/smartform.layout-definition.service.mjs +21 -3
  23. package/esm2020/lib/smart-form/services/smartform.service.mjs +6 -1
  24. package/esm2020/lib/smart-form/smartform.component.mjs +19 -3
  25. package/esm2020/lib/smart-form/smartform.form-model.mjs +1 -1
  26. package/esm2020/lib/smart-form/widgets/smartformwidget/smartformwidget.component.mjs +118 -32
  27. package/esm2020/lib/smart-grid/api/grid-api/model/gridColumnMeta.mjs +1 -1
  28. package/esm2020/lib/smart-grid/api/grid-api/model/gridModel.mjs +1 -1
  29. package/esm2020/lib/smart-grid/api/grid-api/model/gridServerModel.mjs +1 -1
  30. package/esm2020/lib/smart-grid/smart-grid.component.mjs +26 -11
  31. package/esm2020/lib/smart-grid/smart-grid.module.mjs +3 -6
  32. package/esm2020/lib/smart-navbar/smart-navbar.module.mjs +5 -5
  33. package/esm2020/lib/smart-ng-client.module.mjs +1 -8
  34. package/esm2020/lib/smart-table/tables/table.mjs +6 -4
  35. package/esm2020/lib/smart-tree/smarttree-generic.service.mjs +20 -13
  36. package/esm2020/lib/smart-tree/smarttree.module.mjs +11 -3
  37. package/esm2020/lib/view-context/api/model/uiAction.mjs +1 -1
  38. package/esm2020/lib/view-context/api/model/uiActionRequest.mjs +1 -1
  39. package/esm2020/lib/view-context/api/model/valueSet.mjs +1 -1
  40. package/esm2020/lib/view-context/api/model/viewContextChange.mjs +1 -1
  41. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.component.mjs +15 -12
  42. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.service.mjs +2 -2
  43. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.mjs +13 -10
  44. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.service.mjs +2 -2
  45. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.component.mjs +17 -11
  46. package/esm2020/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.service.mjs +2 -2
  47. package/esm2020/lib/view-context/smart-ui-action/ui-action-toolbar.component.mjs +11 -6
  48. package/esm2020/lib/view-context/smart-ui-action/ui-action.model.mjs +1 -1
  49. package/esm2020/lib/view-context/smart-ui-action/ui-action.service.mjs +14 -8
  50. package/esm2020/lib/view-context/smart-view-context.module.mjs +132 -10
  51. package/esm2020/lib/view-context/smart-view-context.service.mjs +8 -1
  52. package/fesm2015/smartbit4all-ng-client.mjs +3962 -3728
  53. package/fesm2015/smartbit4all-ng-client.mjs.map +1 -1
  54. package/fesm2020/smartbit4all-ng-client.mjs +3776 -3550
  55. package/fesm2020/smartbit4all-ng-client.mjs.map +1 -1
  56. package/lib/smart-client/smart-component-api-client.d.ts +2 -1
  57. package/lib/smart-component-layout/api/model/smartComponentLayoutDefinition.d.ts +3 -5
  58. package/lib/smart-component-layout/api/model/smartComponentWidgetDefinition.d.ts +2 -2
  59. package/lib/smart-component-layout/smart-component-layout-utility.d.ts +4 -3
  60. package/lib/smart-component-layout/smart-component-layout.component.d.ts +10 -6
  61. package/lib/smart-component-layout/smart-component-layout.module.d.ts +5 -6
  62. package/lib/smart-dialog/smartdialog.model.d.ts +2 -2
  63. package/lib/smart-dialog/smartdialog.module.d.ts +2 -2
  64. package/lib/smart-expandable-section/expandable-section.model.d.ts +4 -2
  65. package/lib/smart-filter/api/filter/model/filterExpressionFieldWidgetType.d.ts +1 -0
  66. package/lib/smart-filter/smart-filter.module.d.ts +2 -2
  67. package/lib/smart-filter-editor/api/model/filterExpressionField.d.ts +3 -0
  68. package/lib/smart-filter-editor/api/model/filterExpressionFieldWidgetType.d.ts +1 -0
  69. package/lib/smart-filter-editor/api/model/smartFilterType.d.ts +15 -0
  70. package/lib/smart-filter-editor/smart-filter-editor.module.d.ts +4 -5
  71. package/lib/smart-form/api/model/smartWidgetDefinition.d.ts +2 -1
  72. package/lib/smart-form/projects.d.ts +0 -1
  73. package/lib/smart-form/services/smartform.layout-definition.service.d.ts +1 -0
  74. package/lib/smart-form/smartform.component.d.ts +6 -2
  75. package/lib/smart-form/smartform.form-model.d.ts +17 -1
  76. package/lib/smart-form/widgets/smartformwidget/smartformwidget.component.d.ts +31 -1
  77. package/lib/smart-grid/api/grid-api/model/gridColumnMeta.d.ts +4 -0
  78. package/lib/smart-grid/api/grid-api/model/gridModel.d.ts +2 -0
  79. package/lib/smart-grid/api/grid-api/model/gridServerModel.d.ts +2 -0
  80. package/lib/smart-grid/smart-grid.component.d.ts +2 -1
  81. package/lib/smart-grid/smart-grid.module.d.ts +3 -4
  82. package/lib/smart-navbar/smart-navbar.module.d.ts +2 -2
  83. package/lib/smart-ng-client.module.d.ts +12 -13
  84. package/lib/smart-tree/smarttree-generic.service.d.ts +2 -3
  85. package/lib/view-context/api/model/uiAction.d.ts +4 -0
  86. package/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.component.d.ts +5 -5
  87. package/lib/view-context/smart-ui-action/dialogs/ui-action-confirm-dialog/ui-action-confirm-dialog.service.d.ts +1 -1
  88. package/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.component.d.ts +1 -1
  89. package/lib/view-context/smart-ui-action/dialogs/ui-action-file-upload-dialog/ui-action-file-upload-dialog.service.d.ts +1 -1
  90. package/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.component.d.ts +2 -2
  91. package/lib/view-context/smart-ui-action/dialogs/ui-action-input-dialog/ui-action-input-dialog.service.d.ts +1 -1
  92. package/lib/view-context/smart-ui-action/ui-action.model.d.ts +1 -1
  93. package/lib/view-context/smart-ui-action/ui-action.service.d.ts +3 -3
  94. package/lib/view-context/smart-view-context.module.d.ts +34 -11
  95. package/lib/view-context/smart-view-context.service.d.ts +2 -0
  96. package/package.json +1 -1
  97. package/smartbit4all-ng-client-3.3.141.tgz +0 -0
  98. package/esm2020/lib/smart-form/smartform.module.mjs +0 -157
  99. package/lib/smart-form/smartform.module.d.ts +0 -35
  100. package/smartbit4all-ng-client-3.3.139.tgz +0 -0
@@ -2,7 +2,10 @@ import { Component, Input, ViewChildren, } from '@angular/core';
2
2
  import { ComponentType, ComponentWidgetType, LayoutDirection, } from './api';
3
3
  import { SmartFormWidgetDirection, } from '../smart-form/projects';
4
4
  import { GridUiActionType, SmartLayoutDef, } from '../smart-grid/projects';
5
+ import { ExpandableSectionComponent, } from '../smart-expandable-section/projects';
5
6
  import { Subject, takeUntil } from 'rxjs';
7
+ import { deepEqual } from 'fast-equals';
8
+ import { SmartComponentLayoutUtility } from './smart-component-layout-utility';
6
9
  import * as i0 from "@angular/core";
7
10
  import * as i1 from "../smart-form/projects";
8
11
  import * as i2 from "../smart-expandable-section/expandable-section.component";
@@ -12,10 +15,11 @@ import * as i5 from "../smart-tree/smarttree.component";
12
15
  import * as i6 from "../view-context/smart-ui-action/ui-action-toolbar.component";
13
16
  import * as i7 from "@angular/common";
14
17
  export class SmartComponentLayoutComponent {
15
- constructor(layoutService) {
18
+ constructor(layoutService, element, renderer) {
16
19
  this.layoutService = layoutService;
20
+ this.element = element;
21
+ this.renderer = renderer;
17
22
  this._destroy$ = new Subject();
18
- this.toolbarId = 'not_initialized_yet';
19
23
  }
20
24
  ngAfterViewInit() {
21
25
  if (this.smartFormList?.first) {
@@ -50,24 +54,29 @@ export class SmartComponentLayoutComponent {
50
54
  .subscribe((list) => {
51
55
  this.setToolbarComponent(list.first);
52
56
  });
53
- if (this.smartComponentLayout) {
54
- this.setUp();
55
- }
57
+ this.setUp();
56
58
  }
57
59
  ngOnDestroy() {
58
60
  this._destroy$.next();
59
61
  this._destroy$.complete();
60
62
  }
61
63
  ngOnChanges(changes) {
62
- this.smartComponentLayout = changes['smartComponentLayout'].currentValue;
63
- if (this.smartComponentLayout) {
64
- this.setUp();
65
- }
64
+ this.setUp();
66
65
  }
67
66
  setUp() {
68
- this.parent = this.smartComponentLayout?.parentComponent;
69
- this.uuid = this.parent.uuid;
70
- this.treeService = this.parent.smartTreeService;
67
+ if (!this.parentSmartComponent || !this.smartComponentLayout) {
68
+ return;
69
+ }
70
+ if (deepEqual(this.smartComponentLayout, this.currentLayout)) {
71
+ // no layout change, keep current state
72
+ this.smartComponentLayout = this.currentLayout;
73
+ return;
74
+ }
75
+ // layout changed, render, but save current
76
+ // this.currentLayout = JSON.parse(JSON.stringify(this.smartComponentLayout));
77
+ this.currentLayout = this.smartComponentLayout;
78
+ this.uuid = this.parentSmartComponent.uuid;
79
+ this.treeService = this.parentSmartComponent.smartTreeService;
71
80
  this.smartComponentLayout?.direction;
72
81
  if (this.smartComponentLayout?.expandable) {
73
82
  this.constructExpandableSection();
@@ -80,7 +89,8 @@ export class SmartComponentLayoutComponent {
80
89
  this.constructGrid();
81
90
  }
82
91
  else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.FILTER) {
83
- this.constructFilter();
92
+ console.warn('ComponentWidgetType.FILTER is not supported');
93
+ // this.constructFilter();
84
94
  }
85
95
  else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TREE) {
86
96
  this.constructTree();
@@ -88,8 +98,12 @@ export class SmartComponentLayoutComponent {
88
98
  else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TOOLBAR) {
89
99
  this.constructToolbar();
90
100
  }
91
- this.parent.initActions();
101
+ if (!this.parentLayoutComponent) {
102
+ // only top level component should call init actions
103
+ this.parentSmartComponent.initActions();
104
+ }
92
105
  }
106
+ SmartComponentLayoutUtility.applyStyle(this.smartComponentLayout.style, this.element, this.renderer);
93
107
  }
94
108
  type() {
95
109
  return ComponentType;
@@ -99,8 +113,11 @@ export class SmartComponentLayoutComponent {
99
113
  data.expandable = false;
100
114
  this.expandableSection = {
101
115
  title: this.smartComponentLayout?.expandableSectionLabel ?? '',
102
- data,
103
- inputName: 'smartComponentLayout',
116
+ inputs: new Map([
117
+ ['smartComponentLayout', data],
118
+ ['parentSmartComponent', this.parentSmartComponent],
119
+ ['parentLayoutComponent', this.parentLayoutComponent],
120
+ ]),
104
121
  customComponent: SmartComponentLayoutComponent,
105
122
  };
106
123
  }
@@ -110,7 +127,7 @@ export class SmartComponentLayoutComponent {
110
127
  });
111
128
  this.smartForm = {
112
129
  direction: this.getFormLayout(),
113
- componentModel: this.parent?.model,
130
+ componentModel: this.parentSmartComponent?.model,
114
131
  widgets,
115
132
  };
116
133
  this.bindForm();
@@ -130,8 +147,11 @@ export class SmartComponentLayoutComponent {
130
147
  }
131
148
  }
132
149
  bindForm() {
150
+ if (this.parentSmartComponent?.useQueryLists) {
151
+ return;
152
+ }
133
153
  if (this.smartForm && this.smartFormComponent) {
134
- this.parent?.addForm(
154
+ this.parentSmartComponent?.addForm(
135
155
  // unique identifier for the form
136
156
  `form_${this.makeid(5)}`, this.smartForm, this.smartFormComponent);
137
157
  }
@@ -168,8 +188,11 @@ export class SmartComponentLayoutComponent {
168
188
  }
169
189
  }
170
190
  bindGrid() {
191
+ if (this.parentSmartComponent?.useQueryLists) {
192
+ return;
193
+ }
171
194
  if (this.smartGrid && this.smartGridComponent) {
172
- this.smartGrid = this.parent?.addGrid(this.smartGrid, {
195
+ this.smartGrid = this.parentSmartComponent?.addGrid(this.smartGrid, {
173
196
  rowUiActionType: GridUiActionType.POPUP_MENU,
174
197
  }, false, this.smartGridComponent);
175
198
  }
@@ -177,14 +200,23 @@ export class SmartComponentLayoutComponent {
177
200
  setToolbarComponent(comp) {
178
201
  this.toolbar = comp;
179
202
  }
180
- constructFilter() {
181
- this.smartFilter = this.smartComponentLayout.parentComponent.addFilter(`filter_${this.makeid(5)}`, this.smartComponentLayout?.widget?.filterExpressionFieldList, this.smartComponentLayout?.widget?.filterType, this.smartFilterComponent);
182
- }
203
+ // NOT USED, DOESN'T WORK
204
+ // constructFilter(): void {
205
+ // this.smartFilter = (this.smartComponentLayout!.parentComponent as any).addFilter(
206
+ // `filter_${this.makeid(5)}`,
207
+ // this.smartComponentLayout?.widget?.filterExpressionFieldList,
208
+ // this.smartComponentLayout?.widget?.filterType,
209
+ // this.smartFilterComponent
210
+ // );
211
+ // }
183
212
  bindFilter() {
184
213
  // TODO
185
214
  }
186
215
  constructTree() {
187
- this.parent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);
216
+ if (this.parentSmartComponent?.useQueryLists) {
217
+ return;
218
+ }
219
+ this.parentSmartComponent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);
188
220
  this.treeService?.initialize();
189
221
  }
190
222
  constructToolbar() {
@@ -194,12 +226,16 @@ export class SmartComponentLayoutComponent {
194
226
  }
195
227
  }
196
228
  }
197
- SmartComponentLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, deps: [{ token: i1.SmartformLayoutDefinitionService }], target: i0.ɵɵFactoryTarget.Component });
198
- SmartComponentLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: { smartComponentLayout: "smartComponentLayout" }, viewQueries: [{ propertyName: "smartFormList", predicate: ["form"], descendants: true }, { propertyName: "smartGridList", predicate: ["grid"], descendants: true }, { propertyName: "smartFilterList", predicate: ["filter"], descendants: true }, { propertyName: "toolbarList", predicate: ["toolbar"], descendants: true }, { propertyName: "components", predicate: SmartComponentLayoutComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n <smart-expandable-section\r\n *ngIf=\"expandableSection\"\r\n [data]=\"expandableSection\"\r\n ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n <div\r\n *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n >\r\n <smart-component-layout\r\n *ngFor=\"let layout of smartComponentLayout?.components\"\r\n [smartComponentLayout]=\"layout\"\r\n ></smart-component-layout>\r\n </div>\r\n <smartform #form [smartForm]=\"smartForm\"></smartform>\r\n <smart-grid #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n <smart-ui-action-toolbar #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n", styles: [".horizontal{display:flex;flex-direction:row}.vertical{display:flex;flex-direction:column}\n"], components: [{ type: i2.ExpandableSectionComponent, selector: "smart-expandable-section", inputs: ["data", "index"] }, { type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: ["smartComponentLayout"] }, { type: i3.SmartformComponent, selector: "smartform", inputs: ["smartForm"] }, { type: i4.SmartGridComponent, selector: "smart-grid", inputs: ["smartGrid", "uuid", "dev"] }, { type: i5.SmartTreeComponent, selector: "smart-tree", inputs: ["treeStyle", "treeService"] }, { type: i6.UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
229
+ SmartComponentLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, deps: [{ token: i1.SmartformLayoutDefinitionService }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
230
+ SmartComponentLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: { smartComponentLayout: "smartComponentLayout", parentLayoutComponent: "parentLayoutComponent", parentSmartComponent: "parentSmartComponent" }, viewQueries: [{ propertyName: "smartFormList", predicate: ["form"], descendants: true }, { propertyName: "smartGridList", predicate: ["grid"], descendants: true }, { propertyName: "smartFilterList", predicate: ["filter"], descendants: true }, { propertyName: "toolbarList", predicate: ["toolbar"], descendants: true }, { propertyName: "expandableComponents", predicate: ExpandableSectionComponent, descendants: true }, { propertyName: "components", predicate: SmartComponentLayoutComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n <smart-expandable-section\r\n *ngIf=\"expandableSection\"\r\n [data]=\"expandableSection\"\r\n ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n <div\r\n *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n >\r\n <smart-component-layout\r\n *ngFor=\"let layout of smartComponentLayout?.components\"\r\n [parentSmartComponent]=\"parentSmartComponent\"\r\n [parentLayoutComponent]=\"this\"\r\n [smartComponentLayout]=\"layout\"\r\n ></smart-component-layout>\r\n </div>\r\n <smartform *ngIf=\"smartForm\" #form [smartForm]=\"smartForm\"></smartform>\r\n <smart-grid *ngIf=\"smartGrid\" #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n <smart-ui-action-toolbar *ngIf=\"!!toolbarId\" #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n", styles: [".horizontal{display:flex;flex-direction:row}.vertical{display:flex;flex-direction:column}\n"], components: [{ type: i2.ExpandableSectionComponent, selector: "smart-expandable-section", inputs: ["data", "index"] }, { type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: ["smartComponentLayout", "parentLayoutComponent", "parentSmartComponent"] }, { type: i3.SmartformComponent, selector: "smartform", inputs: ["smartForm"] }, { type: i4.SmartGridComponent, selector: "smart-grid", inputs: ["smartGrid", "uuid", "dev"] }, { type: i5.SmartTreeComponent, selector: "smart-tree", inputs: ["treeStyle", "treeService"] }, { type: i6.UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
199
231
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, decorators: [{
200
232
  type: Component,
201
- args: [{ selector: 'smart-component-layout', template: "<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n <smart-expandable-section\r\n *ngIf=\"expandableSection\"\r\n [data]=\"expandableSection\"\r\n ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n <div\r\n *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n >\r\n <smart-component-layout\r\n *ngFor=\"let layout of smartComponentLayout?.components\"\r\n [smartComponentLayout]=\"layout\"\r\n ></smart-component-layout>\r\n </div>\r\n <smartform #form [smartForm]=\"smartForm\"></smartform>\r\n <smart-grid #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n <smart-ui-action-toolbar #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n", styles: [".horizontal{display:flex;flex-direction:row}.vertical{display:flex;flex-direction:column}\n"] }]
202
- }], ctorParameters: function () { return [{ type: i1.SmartformLayoutDefinitionService }]; }, propDecorators: { smartComponentLayout: [{
233
+ args: [{ selector: 'smart-component-layout', template: "<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n <smart-expandable-section\r\n *ngIf=\"expandableSection\"\r\n [data]=\"expandableSection\"\r\n ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n <div\r\n *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n >\r\n <smart-component-layout\r\n *ngFor=\"let layout of smartComponentLayout?.components\"\r\n [parentSmartComponent]=\"parentSmartComponent\"\r\n [parentLayoutComponent]=\"this\"\r\n [smartComponentLayout]=\"layout\"\r\n ></smart-component-layout>\r\n </div>\r\n <smartform *ngIf=\"smartForm\" #form [smartForm]=\"smartForm\"></smartform>\r\n <smart-grid *ngIf=\"smartGrid\" #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n <smart-ui-action-toolbar *ngIf=\"!!toolbarId\" #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n", styles: [".horizontal{display:flex;flex-direction:row}.vertical{display:flex;flex-direction:column}\n"] }]
234
+ }], ctorParameters: function () { return [{ type: i1.SmartformLayoutDefinitionService }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { smartComponentLayout: [{
235
+ type: Input
236
+ }], parentLayoutComponent: [{
237
+ type: Input
238
+ }], parentSmartComponent: [{
203
239
  type: Input
204
240
  }], smartFormList: [{
205
241
  type: ViewChildren,
@@ -213,8 +249,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
213
249
  }], toolbarList: [{
214
250
  type: ViewChildren,
215
251
  args: ['toolbar']
252
+ }], expandableComponents: [{
253
+ type: ViewChildren,
254
+ args: [ExpandableSectionComponent]
216
255
  }], components: [{
217
256
  type: ViewChildren,
218
257
  args: [SmartComponentLayoutComponent]
219
258
  }] } });
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-component-layout.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-component-layout/smart-component-layout.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-component-layout/smart-component-layout.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,KAAK,EAOL,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,aAAa,EACb,mBAAmB,EACnB,eAAe,GAEhB,MAAM,OAAO,CAAC;AACf,OAAO,EAEL,wBAAwB,GAGzB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EACL,gBAAgB,EAGhB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAIhC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;;;;AAQ1C,MAAM,OAAO,6BAA6B;IAmCxC,YAAoB,aAA+C;QAA/C,kBAAa,GAAb,aAAa,CAAkC;QAlCzD,cAAS,GAAkB,IAAI,OAAO,EAAE,CAAC;QAwBnD,cAAS,GAAY,qBAAqB,CAAC;IAU2B,CAAC;IAEvE,eAAe;QACb,IAAI,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE;YAC7B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;SAClD;QACD,IAAI,CAAC,aAAa,CAAC,OAAO;aACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,IAAmC,EAAE,EAAE;YACjD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE;YAC7B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;SAClD;QACD,IAAI,CAAC,aAAa,CAAC,OAAO;aACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,IAAmC,EAAE,EAAE;YACjD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,eAAe,CAAC,OAAO;aACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,IAAqC,EAAE,EAAE;YACnD,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE;gBAC9B,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC;gBACvC,IAAI,CAAC,UAAU,EAAE,CAAC;aACnB;QACH,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE;YAC3B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;SACnD;QACD,IAAI,CAAC,WAAW,CAAC,OAAO;aACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,IAAyC,EAAE,EAAE;YACvD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC7B,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,oBAAoB,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAAC,YAAY,CAAC;QAEzE,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC7B,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,oBAAoB,EAAE,eAAsB,CAAC;QAChE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;QAC7B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC;QAEhD,IAAI,CAAC,oBAAoB,EAAE,SAAS,CAAC;QAErC,IAAI,IAAI,CAAC,oBAAoB,EAAE,UAAU,EAAE;YACzC,IAAI,CAAC,0BAA0B,EAAE,CAAC;SACnC;aAAM,IAAI,IAAI,CAAC,oBAAoB,EAAE,IAAI,KAAK,aAAa,CAAC,IAAI,EAAE;YACjE,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;aAAM,IAAI,IAAI,CAAC,oBAAoB,EAAE,IAAI,KAAK,aAAa,CAAC,MAAM,EAAE;YACnE,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,KAAK,mBAAmB,CAAC,IAAI,EAAE;gBACvE,IAAI,CAAC,aAAa,EAAE,CAAC;aACtB;iBAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,KAAK,mBAAmB,CAAC,MAAM,EAAE;gBAChF,IAAI,CAAC,eAAe,EAAE,CAAC;aACxB;iBAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,KAAK,mBAAmB,CAAC,IAAI,EAAE;gBAC9E,IAAI,CAAC,aAAa,EAAE,CAAC;aACtB;iBAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,KAAK,mBAAmB,CAAC,OAAO,EAAE;gBACjF,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACzB;YACD,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAAI;QACF,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,0BAA0B;QACxB,IAAI,IAAI,GAAmC,EAAE,GAAG,IAAI,CAAC,oBAAqB,EAAE,CAAC;QAC7E,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAExB,IAAI,CAAC,iBAAiB,GAAG;YACvB,KAAK,EAAE,IAAI,CAAC,oBAAoB,EAAE,sBAAsB,IAAI,EAAE;YAC9D,IAAI;YACJ,SAAS,EAAE,sBAAsB;YACjC,eAAe,EAAE,6BAA6B;SAC/C,CAAC;IACJ,CAAC;IAED,aAAa;QACX,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;YACxC,iBAAiB,EAAE,IAAI,CAAC,oBAAoB,EAAE,IAAI;SACnD,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,GAAG;YACf,SAAS,EAAE,IAAI,CAAC,aAAa,EAAE;YAC/B,cAAc,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK;YAClC,OAAO;SACR,CAAC;QAEF,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,oBAAoB,EAAE,SAAS,EAAE;YACxC,OAAO,IAAI,CAAC,oBAAoB,EAAE,SAAS,KAAK,eAAe,CAAC,UAAU;gBACxE,CAAC,CAAC,wBAAwB,CAAC,GAAG;gBAC9B,CAAC,CAAC,wBAAwB,CAAC,GAAG,CAAC;SAClC;QACD,OAAO,wBAAwB,CAAC,GAAG,CAAC;IACtC,CAAC;IAED,gBAAgB,CAAC,IAAwB;QACvC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC5B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC7C,IAAI,CAAC,MAAM,EAAE,OAAO;YAClB,iCAAiC;YACjC,QAAQ,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EACxB,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,kBAAkB,CACxB,CAAC;SACH;IACH,CAAC;IAED,MAAM,CAAC,MAAc;QACnB,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,MAAM,UAAU,GAAG,gEAAgE,CAAC;QACpF,MAAM,gBAAgB,GAAG,UAAU,CAAC,MAAM,CAAC;QAC3C,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,OAAO,OAAO,GAAG,MAAM,EAAE;YACvB,MAAM,IAAI,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,gBAAgB,CAAC,CAAC,CAAC;YAC1E,OAAO,IAAI,CAAC,CAAC;SACd;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,SAAS,GAAG;YACf,cAAc,EAAE,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAW;YAC9D,SAAS,EAAE;gBACT,IAAI,EAAE,EAAE;aACT;YACD,OAAO,EAAE;gBACP,eAAe,EAAE,gBAAgB,CAAC,UAAU;aAC7C;YACD,SAAS,EAAE,cAAc,CAAC,KAAK;YAC/B,SAAS,EAAE,IAAI;SAChB,CAAC;QAEF,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED,gBAAgB,CAAC,IAAwB;QACvC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;YAC5B,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAC/B,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC7C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,OAAO,CACnC,IAAI,CAAC,SAAS,EACd;gBACE,eAAe,EAAE,gBAAgB,CAAC,UAAU;aAC7C,EACD,KAAK,EACL,IAAI,CAAC,kBAAkB,CACxB,CAAC;SACH;IACH,CAAC;IAED,mBAAmB,CAAC,IAA8B;QAChD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,GAAI,IAAI,CAAC,oBAAqB,CAAC,eAAuB,CAAC,SAAS,CAC9E,UAAU,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAC1B,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,yBAAyB,EAC5D,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAU,EAC7C,IAAI,CAAC,oBAAoB,CAC1B,CAAC;IACJ,CAAC;IAED,UAAU;QACR,OAAO;IACT,CAAC;IAED,aAAa;QACX,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;QAC5E,IAAI,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC;IACjC,CAAC;IAED,gBAAgB;QACd,IAAI,SAAS,GAAG,IAAI,CAAC,oBAAoB,EAAE,MAAM,EAAE,UAAU,CAAC;QAC9D,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE;YAChC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;SAC5B;IACH,CAAC;;0HAzPU,6BAA6B;8GAA7B,6BAA6B,wcAgC1B,6BAA6B,qECzE7C,whCAyBA,0ODgBa,6BAA6B;2FAA7B,6BAA6B;kBALzC,SAAS;+BACE,wBAAwB;uHAOzB,oBAAoB;sBAA5B,KAAK;gBAKN,aAAa;sBADZ,YAAY;uBAAC,MAAM;gBAMpB,aAAa;sBADZ,YAAY;uBAAC,MAAM;gBAMpB,eAAe;sBADd,YAAY;uBAAC,QAAQ;gBAMtB,WAAW;sBADV,YAAY;uBAAC,SAAS;gBAWvB,UAAU;sBADT,YAAY;uBAAC,6BAA6B","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  QueryList,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport {\r\n  ComponentType,\r\n  ComponentWidgetType,\r\n  LayoutDirection,\r\n  SmartComponentLayoutDefinition,\r\n} from './api';\r\nimport {\r\n  SmartForm,\r\n  SmartFormWidgetDirection,\r\n  SmartformComponent,\r\n  SmartformLayoutDefinitionService,\r\n} from '../smart-form/projects';\r\nimport {\r\n  GridUiActionType,\r\n  SmartGrid,\r\n  SmartGridComponent,\r\n  SmartLayoutDef,\r\n} from '../smart-grid/projects';\r\nimport { SmartFilter, SmartFilterComponent } from '../smart-filter/projects';\r\nimport { SmarttreeGenericService } from '../smart-tree/projects';\r\nimport { ExpandableSection } from '../smart-expandable-section/projects';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { UiActionToolbarComponent } from '../view-context/projects';\r\n\r\n@Component({\r\n  selector: 'smart-component-layout',\r\n  templateUrl: './smart-component-layout.component.html',\r\n  styleUrls: ['./smart-component-layout.component.css'],\r\n})\r\nexport class SmartComponentLayoutComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n  protected _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartComponentLayout?: SmartComponentLayoutDefinition;\r\n\r\n  uuid?: string;\r\n\r\n  @ViewChildren('form')\r\n  smartFormList!: QueryList<SmartformComponent>;\r\n  smartFormComponent?: SmartformComponent;\r\n  smartForm?: SmartForm;\r\n\r\n  @ViewChildren('grid')\r\n  smartGridList!: QueryList<SmartGridComponent>;\r\n  smartGridComponent?: SmartGridComponent;\r\n  smartGrid?: SmartGrid;\r\n\r\n  @ViewChildren('filter')\r\n  smartFilterList!: QueryList<SmartFilterComponent>;\r\n  smartFilterComponent?: SmartFilterComponent;\r\n  smartFilter?: SmartFilter;\r\n\r\n  @ViewChildren('toolbar')\r\n  toolbarList!: QueryList<UiActionToolbarComponent>;\r\n  toolbar?: UiActionToolbarComponent;\r\n  toolbarId?: string = 'not_initialized_yet';\r\n\r\n  parent?: any; //SmartComponent<any>\r\n  treeService?: SmarttreeGenericService;\r\n\r\n  expandableSection?: ExpandableSection<SmartComponentLayoutDefinition>;\r\n\r\n  @ViewChildren(SmartComponentLayoutComponent)\r\n  components!: QueryList<SmartComponentLayoutComponent>;\r\n\r\n  constructor(private layoutService: SmartformLayoutDefinitionService) {}\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.smartFormList?.first) {\r\n      this.setFormComponent(this.smartFormList?.first);\r\n    }\r\n    this.smartFormList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartformComponent>) => {\r\n        this.setFormComponent(list.first);\r\n      });\r\n\r\n    if (this.smartGridList?.first) {\r\n      this.setGridComponent(this.smartGridList?.first);\r\n    }\r\n    this.smartGridList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartGridComponent>) => {\r\n        this.setGridComponent(list.first);\r\n      });\r\n\r\n    this.smartFilterList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartFilterComponent>) => {\r\n        if (!this.smartFilterComponent) {\r\n          this.smartFilterComponent = list.first;\r\n          this.bindFilter();\r\n        }\r\n      });\r\n\r\n    if (this.toolbarList?.first) {\r\n      this.setToolbarComponent(this.toolbarList?.first);\r\n    }\r\n    this.toolbarList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<UiActionToolbarComponent>) => {\r\n        this.setToolbarComponent(list.first);\r\n      });\r\n\r\n    if (this.smartComponentLayout) {\r\n      this.setUp();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.smartComponentLayout = changes['smartComponentLayout'].currentValue;\r\n\r\n    if (this.smartComponentLayout) {\r\n      this.setUp();\r\n    }\r\n  }\r\n\r\n  private setUp(): void {\r\n    this.parent = this.smartComponentLayout?.parentComponent as any;\r\n    this.uuid = this.parent.uuid;\r\n    this.treeService = this.parent.smartTreeService;\r\n\r\n    this.smartComponentLayout?.direction;\r\n\r\n    if (this.smartComponentLayout?.expandable) {\r\n      this.constructExpandableSection();\r\n    } else if (this.smartComponentLayout?.type === ComponentType.FORM) {\r\n      this.constructForm();\r\n    } else if (this.smartComponentLayout?.type === ComponentType.WIDGET) {\r\n      if (this.smartComponentLayout.widget?.type === ComponentWidgetType.GRID) {\r\n        this.constructGrid();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.FILTER) {\r\n        this.constructFilter();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TREE) {\r\n        this.constructTree();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TOOLBAR) {\r\n        this.constructToolbar();\r\n      }\r\n      this.parent.initActions();\r\n    }\r\n  }\r\n\r\n  type(): typeof ComponentType {\r\n    return ComponentType;\r\n  }\r\n\r\n  constructExpandableSection(): void {\r\n    let data: SmartComponentLayoutDefinition = { ...this.smartComponentLayout! };\r\n    data.expandable = false;\r\n\r\n    this.expandableSection = {\r\n      title: this.smartComponentLayout?.expandableSectionLabel ?? '',\r\n      data,\r\n      inputName: 'smartComponentLayout',\r\n      customComponent: SmartComponentLayoutComponent,\r\n    };\r\n  }\r\n\r\n  constructForm(): void {\r\n    const widgets = this.layoutService.render({\r\n      layoutDefinitions: this.smartComponentLayout?.form,\r\n    });\r\n\r\n    this.smartForm = {\r\n      direction: this.getFormLayout(),\r\n      componentModel: this.parent?.model,\r\n      widgets,\r\n    };\r\n\r\n    this.bindForm();\r\n  }\r\n\r\n  getFormLayout(): SmartFormWidgetDirection {\r\n    if (this.smartComponentLayout?.direction) {\r\n      return this.smartComponentLayout?.direction === LayoutDirection.HORIZONTAL\r\n        ? SmartFormWidgetDirection.ROW\r\n        : SmartFormWidgetDirection.COL;\r\n    }\r\n    return SmartFormWidgetDirection.COL;\r\n  }\r\n\r\n  setFormComponent(comp: SmartformComponent) {\r\n    if (!this.smartFormComponent) {\r\n      this.smartFormComponent = comp;\r\n      this.bindForm();\r\n    }\r\n  }\r\n\r\n  bindForm(): void {\r\n    if (this.smartForm && this.smartFormComponent) {\r\n      this.parent?.addForm(\r\n        // unique identifier for the form\r\n        `form_${this.makeid(5)}`,\r\n        this.smartForm,\r\n        this.smartFormComponent\r\n      );\r\n    }\r\n  }\r\n\r\n  makeid(length: number) {\r\n    let result = '';\r\n    const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\r\n    const charactersLength = characters.length;\r\n    let counter = 0;\r\n    while (counter < length) {\r\n      result += characters.charAt(Math.floor(Math.random() * charactersLength));\r\n      counter += 1;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  constructGrid(): void {\r\n    this.smartGrid = {\r\n      gridIdentifier: this.smartComponentLayout?.widget?.identifier!,\r\n      gridModel: {\r\n        page: {},\r\n      },\r\n      options: {\r\n        rowUiActionType: GridUiActionType.POPUP_MENU,\r\n      },\r\n      layoutDef: SmartLayoutDef.TABLE,\r\n      paginator: true,\r\n    };\r\n\r\n    this.bindGrid();\r\n  }\r\n\r\n  setGridComponent(comp: SmartGridComponent) {\r\n    if (!this.smartGridComponent) {\r\n      this.smartGridComponent = comp;\r\n      this.bindGrid();\r\n    }\r\n  }\r\n\r\n  bindGrid(): void {\r\n    if (this.smartGrid && this.smartGridComponent) {\r\n      this.smartGrid = this.parent?.addGrid(\r\n        this.smartGrid,\r\n        {\r\n          rowUiActionType: GridUiActionType.POPUP_MENU,\r\n        },\r\n        false,\r\n        this.smartGridComponent\r\n      );\r\n    }\r\n  }\r\n\r\n  setToolbarComponent(comp: UiActionToolbarComponent) {\r\n    this.toolbar = comp;\r\n  }\r\n\r\n  constructFilter(): void {\r\n    this.smartFilter = (this.smartComponentLayout!.parentComponent as any).addFilter(\r\n      `filter_${this.makeid(5)}`,\r\n      this.smartComponentLayout?.widget?.filterExpressionFieldList,\r\n      this.smartComponentLayout?.widget?.filterType,\r\n      this.smartFilterComponent\r\n    );\r\n  }\r\n\r\n  bindFilter(): void {\r\n    // TODO\r\n  }\r\n\r\n  constructTree(): void {\r\n    this.parent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);\r\n    this.treeService?.initialize();\r\n  }\r\n\r\n  constructToolbar(): void {\r\n    let toolbarId = this.smartComponentLayout?.widget?.identifier;\r\n    if (this.toolbarId !== toolbarId) {\r\n      this.toolbarId = toolbarId;\r\n    }\r\n  }\r\n}\r\n","<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n  <smart-expandable-section\r\n    *ngIf=\"expandableSection\"\r\n    [data]=\"expandableSection\"\r\n  ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n  <div\r\n    *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n    [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n  >\r\n    <smart-component-layout\r\n      *ngFor=\"let layout of smartComponentLayout?.components\"\r\n      [smartComponentLayout]=\"layout\"\r\n    ></smart-component-layout>\r\n  </div>\r\n  <smartform #form [smartForm]=\"smartForm\"></smartform>\r\n  <smart-grid #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n  <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n  <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n  <smart-ui-action-toolbar #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n"]}
259
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-component-layout.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-component-layout/smart-component-layout.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-component-layout/smart-component-layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  QueryList,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  ViewChildren,\r\n} from '@angular/core';\r\nimport {\r\n  ComponentType,\r\n  ComponentWidgetType,\r\n  LayoutDirection,\r\n  SmartComponentLayoutDefinition,\r\n} from './api';\r\nimport {\r\n  SmartForm,\r\n  SmartFormWidgetDirection,\r\n  SmartformComponent,\r\n  SmartformLayoutDefinitionService,\r\n} from '../smart-form/projects';\r\nimport {\r\n  GridUiActionType,\r\n  SmartGrid,\r\n  SmartGridComponent,\r\n  SmartLayoutDef,\r\n} from '../smart-grid/projects';\r\nimport { SmartFilter, SmartFilterComponent } from '../smart-filter/projects';\r\nimport { SmarttreeGenericService } from '../smart-tree/projects';\r\nimport {\r\n  ExpandableSection,\r\n  ExpandableSectionComponent,\r\n} from '../smart-expandable-section/projects';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { UiActionToolbarComponent } from '../view-context/projects';\r\nimport { deepEqual } from 'fast-equals';\r\nimport { SmartComponentLayoutUtility } from './smart-component-layout-utility';\r\n\r\n@Component({\r\n  selector: 'smart-component-layout',\r\n  templateUrl: './smart-component-layout.component.html',\r\n  styleUrls: ['./smart-component-layout.component.css'],\r\n})\r\nexport class SmartComponentLayoutComponent implements AfterViewInit, OnDestroy, OnChanges {\r\n  protected _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartComponentLayout?: SmartComponentLayoutDefinition;\r\n  @Input() parentLayoutComponent?: SmartComponentLayoutComponent;\r\n  @Input() parentSmartComponent: any;\r\n\r\n  currentLayout?: SmartComponentLayoutDefinition;\r\n\r\n  uuid?: string;\r\n\r\n  @ViewChildren('form')\r\n  smartFormList!: QueryList<SmartformComponent>;\r\n  smartFormComponent?: SmartformComponent;\r\n  smartForm?: SmartForm;\r\n\r\n  @ViewChildren('grid')\r\n  smartGridList!: QueryList<SmartGridComponent>;\r\n  smartGridComponent?: SmartGridComponent;\r\n  smartGrid?: SmartGrid;\r\n\r\n  @ViewChildren('filter')\r\n  smartFilterList!: QueryList<SmartFilterComponent>;\r\n  smartFilterComponent?: SmartFilterComponent;\r\n  smartFilter?: SmartFilter;\r\n\r\n  @ViewChildren('toolbar')\r\n  toolbarList!: QueryList<UiActionToolbarComponent>;\r\n  toolbar?: UiActionToolbarComponent;\r\n  toolbarId?: string;\r\n\r\n  treeService?: SmarttreeGenericService;\r\n\r\n  expandableSection?: ExpandableSection<SmartComponentLayoutDefinition>;\r\n\r\n  @ViewChildren(ExpandableSectionComponent)\r\n  expandableComponents!: QueryList<ExpandableSectionComponent>;\r\n\r\n  @ViewChildren(SmartComponentLayoutComponent)\r\n  components!: QueryList<SmartComponentLayoutComponent>;\r\n\r\n  constructor(\r\n    private layoutService: SmartformLayoutDefinitionService,\r\n    private element?: ElementRef,\r\n    private renderer?: Renderer2\r\n  ) {}\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.smartFormList?.first) {\r\n      this.setFormComponent(this.smartFormList?.first);\r\n    }\r\n    this.smartFormList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartformComponent>) => {\r\n        this.setFormComponent(list.first);\r\n      });\r\n\r\n    if (this.smartGridList?.first) {\r\n      this.setGridComponent(this.smartGridList?.first);\r\n    }\r\n    this.smartGridList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartGridComponent>) => {\r\n        this.setGridComponent(list.first);\r\n      });\r\n\r\n    this.smartFilterList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<SmartFilterComponent>) => {\r\n        if (!this.smartFilterComponent) {\r\n          this.smartFilterComponent = list.first;\r\n          this.bindFilter();\r\n        }\r\n      });\r\n\r\n    if (this.toolbarList?.first) {\r\n      this.setToolbarComponent(this.toolbarList?.first);\r\n    }\r\n    this.toolbarList.changes\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe((list: QueryList<UiActionToolbarComponent>) => {\r\n        this.setToolbarComponent(list.first);\r\n      });\r\n    this.setUp();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.setUp();\r\n  }\r\n\r\n  private setUp(): void {\r\n    if (!this.parentSmartComponent || !this.smartComponentLayout) {\r\n      return;\r\n    }\r\n    if (deepEqual(this.smartComponentLayout, this.currentLayout)) {\r\n      // no layout change, keep current state\r\n      this.smartComponentLayout = this.currentLayout;\r\n      return;\r\n    }\r\n    // layout changed, render, but save current\r\n    // this.currentLayout = JSON.parse(JSON.stringify(this.smartComponentLayout));\r\n    this.currentLayout = this.smartComponentLayout;\r\n\r\n    this.uuid = this.parentSmartComponent.uuid;\r\n    this.treeService = this.parentSmartComponent.smartTreeService;\r\n\r\n    this.smartComponentLayout?.direction;\r\n\r\n    if (this.smartComponentLayout?.expandable) {\r\n      this.constructExpandableSection();\r\n    } else if (this.smartComponentLayout?.type === ComponentType.FORM) {\r\n      this.constructForm();\r\n    } else if (this.smartComponentLayout?.type === ComponentType.WIDGET) {\r\n      if (this.smartComponentLayout.widget?.type === ComponentWidgetType.GRID) {\r\n        this.constructGrid();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.FILTER) {\r\n        console.warn('ComponentWidgetType.FILTER is not supported');\r\n        // this.constructFilter();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TREE) {\r\n        this.constructTree();\r\n      } else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TOOLBAR) {\r\n        this.constructToolbar();\r\n      }\r\n      if (!this.parentLayoutComponent) {\r\n        // only top level component should call init actions\r\n        this.parentSmartComponent.initActions();\r\n      }\r\n    }\r\n\r\n    SmartComponentLayoutUtility.applyStyle(\r\n      this.smartComponentLayout.style,\r\n      this.element,\r\n      this.renderer\r\n    );\r\n  }\r\n\r\n  type(): typeof ComponentType {\r\n    return ComponentType;\r\n  }\r\n\r\n  constructExpandableSection(): void {\r\n    let data: SmartComponentLayoutDefinition = { ...this.smartComponentLayout! };\r\n    data.expandable = false;\r\n\r\n    this.expandableSection = {\r\n      title: this.smartComponentLayout?.expandableSectionLabel ?? '',\r\n      inputs: new Map<string, any>([\r\n        ['smartComponentLayout', data],\r\n        ['parentSmartComponent', this.parentSmartComponent],\r\n        ['parentLayoutComponent', this.parentLayoutComponent],\r\n      ]),\r\n      customComponent: SmartComponentLayoutComponent,\r\n    };\r\n  }\r\n\r\n  constructForm(): void {\r\n    const widgets = this.layoutService.render({\r\n      layoutDefinitions: this.smartComponentLayout?.form,\r\n    });\r\n\r\n    this.smartForm = {\r\n      direction: this.getFormLayout(),\r\n      componentModel: this.parentSmartComponent?.model,\r\n      widgets,\r\n    };\r\n\r\n    this.bindForm();\r\n  }\r\n\r\n  getFormLayout(): SmartFormWidgetDirection {\r\n    if (this.smartComponentLayout?.direction) {\r\n      return this.smartComponentLayout?.direction === LayoutDirection.HORIZONTAL\r\n        ? SmartFormWidgetDirection.ROW\r\n        : SmartFormWidgetDirection.COL;\r\n    }\r\n    return SmartFormWidgetDirection.COL;\r\n  }\r\n\r\n  setFormComponent(comp: SmartformComponent) {\r\n    if (!this.smartFormComponent) {\r\n      this.smartFormComponent = comp;\r\n      this.bindForm();\r\n    }\r\n  }\r\n\r\n  bindForm(): void {\r\n    if (this.parentSmartComponent?.useQueryLists) {\r\n      return;\r\n    }\r\n    if (this.smartForm && this.smartFormComponent) {\r\n      this.parentSmartComponent?.addForm(\r\n        // unique identifier for the form\r\n        `form_${this.makeid(5)}`,\r\n        this.smartForm,\r\n        this.smartFormComponent\r\n      );\r\n    }\r\n  }\r\n\r\n  makeid(length: number) {\r\n    let result = '';\r\n    const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\r\n    const charactersLength = characters.length;\r\n    let counter = 0;\r\n    while (counter < length) {\r\n      result += characters.charAt(Math.floor(Math.random() * charactersLength));\r\n      counter += 1;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  constructGrid(): void {\r\n    this.smartGrid = {\r\n      gridIdentifier: this.smartComponentLayout?.widget?.identifier!,\r\n      gridModel: {\r\n        page: {},\r\n      },\r\n      options: {\r\n        rowUiActionType: GridUiActionType.POPUP_MENU,\r\n      },\r\n      layoutDef: SmartLayoutDef.TABLE,\r\n      paginator: true,\r\n    };\r\n\r\n    this.bindGrid();\r\n  }\r\n\r\n  setGridComponent(comp: SmartGridComponent) {\r\n    if (!this.smartGridComponent) {\r\n      this.smartGridComponent = comp;\r\n      this.bindGrid();\r\n    }\r\n  }\r\n\r\n  bindGrid(): void {\r\n    if (this.parentSmartComponent?.useQueryLists) {\r\n      return;\r\n    }\r\n    if (this.smartGrid && this.smartGridComponent) {\r\n      this.smartGrid = this.parentSmartComponent?.addGrid(\r\n        this.smartGrid,\r\n        {\r\n          rowUiActionType: GridUiActionType.POPUP_MENU,\r\n        },\r\n        false,\r\n        this.smartGridComponent\r\n      );\r\n    }\r\n  }\r\n\r\n  setToolbarComponent(comp: UiActionToolbarComponent) {\r\n    this.toolbar = comp;\r\n  }\r\n\r\n  // NOT USED, DOESN'T WORK\r\n  // constructFilter(): void {\r\n  //   this.smartFilter = (this.smartComponentLayout!.parentComponent as any).addFilter(\r\n  //     `filter_${this.makeid(5)}`,\r\n  //     this.smartComponentLayout?.widget?.filterExpressionFieldList,\r\n  //     this.smartComponentLayout?.widget?.filterType,\r\n  //     this.smartFilterComponent\r\n  //   );\r\n  // }\r\n\r\n  bindFilter(): void {\r\n    // TODO\r\n  }\r\n\r\n  constructTree(): void {\r\n    if (this.parentSmartComponent?.useQueryLists) {\r\n      return;\r\n    }\r\n    this.parentSmartComponent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);\r\n    this.treeService?.initialize();\r\n  }\r\n\r\n  constructToolbar(): void {\r\n    let toolbarId = this.smartComponentLayout?.widget?.identifier;\r\n    if (this.toolbarId !== toolbarId) {\r\n      this.toolbarId = toolbarId;\r\n    }\r\n  }\r\n}\r\n","<div *ngIf=\"smartComponentLayout?.expandable; then expandable; else normal\"> </div>\r\n\r\n<ng-template #expandable>\r\n  <smart-expandable-section\r\n    *ngIf=\"expandableSection\"\r\n    [data]=\"expandableSection\"\r\n  ></smart-expandable-section>\r\n</ng-template>\r\n\r\n<ng-template #normal>\r\n  <div\r\n    *ngIf=\"smartComponentLayout?.type === type().CONTAINER\"\r\n    [ngClass]=\"smartComponentLayout?.direction ?? 'vertical'\"\r\n  >\r\n    <smart-component-layout\r\n      *ngFor=\"let layout of smartComponentLayout?.components\"\r\n      [parentSmartComponent]=\"parentSmartComponent\"\r\n      [parentLayoutComponent]=\"this\"\r\n      [smartComponentLayout]=\"layout\"\r\n    ></smart-component-layout>\r\n  </div>\r\n  <smartform *ngIf=\"smartForm\" #form [smartForm]=\"smartForm\"></smartform>\r\n  <smart-grid *ngIf=\"smartGrid\" #grid [smartGrid]=\"smartGrid\" [uuid]=\"uuid!\"></smart-grid>\r\n  <!-- <smart-filter #filter [filter]=\"smartFilter\"></smart-filter> -->\r\n  <smart-tree *ngIf=\"treeService\" [treeService]=\"treeService!\"></smart-tree>\r\n  <smart-ui-action-toolbar *ngIf=\"!!toolbarId\" #toolbar [id]=\"toolbarId\"></smart-ui-action-toolbar>\r\n</ng-template>\r\n"]}
@@ -1,7 +1,6 @@
1
1
  import { NgModule } from '@angular/core';
2
2
  import { MatCommonModule } from '@angular/material/core';
3
3
  import { BrowserModule } from '@angular/platform-browser';
4
- import { SmartformModule } from '../smart-form/smartform.module';
5
4
  import { SmartGridModule } from '../smart-grid/smart-grid.module';
6
5
  import { SmartExpandableSectionModule } from '../smart-expandable-section/smart-expandable-section.module';
7
6
  import { SmarttreeModule } from '../smart-tree/smarttree.module';
@@ -13,7 +12,6 @@ export class SmartComponentLayoutModule {
13
12
  SmartComponentLayoutModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
14
13
  SmartComponentLayoutModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutModule, declarations: [SmartComponentLayoutComponent], imports: [BrowserModule,
15
14
  MatCommonModule,
16
- SmartformModule,
17
15
  SmartGridModule,
18
16
  SmartExpandableSectionModule,
19
17
  SmarttreeModule,
@@ -21,7 +19,6 @@ SmartComponentLayoutModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.
21
19
  SmartComponentLayoutModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutModule, providers: [], imports: [[
22
20
  BrowserModule,
23
21
  MatCommonModule,
24
- SmartformModule,
25
22
  SmartGridModule,
26
23
  SmartExpandableSectionModule,
27
24
  SmarttreeModule,
@@ -34,7 +31,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
34
31
  imports: [
35
32
  BrowserModule,
36
33
  MatCommonModule,
37
- SmartformModule,
38
34
  SmartGridModule,
39
35
  SmartExpandableSectionModule,
40
36
  SmarttreeModule,
@@ -44,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
44
40
  providers: [],
45
41
  }]
46
42
  }] });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtY29tcG9uZW50LWxheW91dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1jb21wb25lbnQtbGF5b3V0L3NtYXJ0LWNvbXBvbmVudC1sYXlvdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQzNHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUNuRixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQzs7QUFnQm5GLE1BQU0sT0FBTywwQkFBMEI7O3VIQUExQiwwQkFBMEI7d0hBQTFCLDBCQUEwQixpQkFidEIsNkJBQTZCLGFBRTFDLGFBQWE7UUFDYixlQUFlO1FBQ2YsZUFBZTtRQUNmLGVBQWU7UUFDZiw0QkFBNEI7UUFDNUIsZUFBZTtRQUNmLHNCQUFzQixhQUVkLDZCQUE2Qjt3SEFHNUIsMEJBQTBCLGFBRjFCLEVBQUUsWUFWSjtZQUNQLGFBQWE7WUFDYixlQUFlO1lBQ2YsZUFBZTtZQUNmLGVBQWU7WUFDZiw0QkFBNEI7WUFDNUIsZUFBZTtZQUNmLHNCQUFzQjtTQUN2QjsyRkFJVSwwQkFBMEI7a0JBZHRDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsNkJBQTZCLENBQUM7b0JBQzdDLE9BQU8sRUFBRTt3QkFDUCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixlQUFlO3dCQUNmLDRCQUE0Qjt3QkFDNUIsZUFBZTt3QkFDZixzQkFBc0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRSxDQUFDLDZCQUE2QixDQUFDO29CQUN4QyxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xyXG5pbXBvcnQgeyBCcm93c2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IFNtYXJ0Zm9ybU1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vc21hcnRmb3JtLm1vZHVsZSc7XHJcbmltcG9ydCB7IFNtYXJ0R3JpZE1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWdyaWQvc21hcnQtZ3JpZC5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydEV4cGFuZGFibGVTZWN0aW9uTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtZXhwYW5kYWJsZS1zZWN0aW9uL3NtYXJ0LWV4cGFuZGFibGUtc2VjdGlvbi5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydHRyZWVNb2R1bGUgfSBmcm9tICcuLi9zbWFydC10cmVlL3NtYXJ0dHJlZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydENvbXBvbmVudExheW91dENvbXBvbmVudCB9IGZyb20gJy4vc21hcnQtY29tcG9uZW50LWxheW91dC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBTbWFydFZpZXdDb250ZXh0TW9kdWxlIH0gZnJvbSAnLi4vdmlldy1jb250ZXh0L3NtYXJ0LXZpZXctY29udGV4dC5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtTbWFydENvbXBvbmVudExheW91dENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQnJvd3Nlck1vZHVsZSxcclxuICAgIE1hdENvbW1vbk1vZHVsZSxcclxuICAgIFNtYXJ0Zm9ybU1vZHVsZSxcclxuICAgIFNtYXJ0R3JpZE1vZHVsZSxcclxuICAgIFNtYXJ0RXhwYW5kYWJsZVNlY3Rpb25Nb2R1bGUsXHJcbiAgICBTbWFydHRyZWVNb2R1bGUsXHJcbiAgICBTbWFydFZpZXdDb250ZXh0TW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1NtYXJ0Q29tcG9uZW50TGF5b3V0Q29tcG9uZW50XSxcclxuICBwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU21hcnRDb21wb25lbnRMYXlvdXRNb2R1bGUge31cclxuIl19
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtY29tcG9uZW50LWxheW91dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1jb21wb25lbnQtbGF5b3V0L3NtYXJ0LWNvbXBvbmVudC1sYXlvdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDM0csT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDOztBQWVuRixNQUFNLE9BQU8sMEJBQTBCOzt1SEFBMUIsMEJBQTBCO3dIQUExQiwwQkFBMEIsaUJBWnRCLDZCQUE2QixhQUUxQyxhQUFhO1FBQ2IsZUFBZTtRQUNmLGVBQWU7UUFDZiw0QkFBNEI7UUFDNUIsZUFBZTtRQUNmLHNCQUFzQixhQUVkLDZCQUE2Qjt3SEFHNUIsMEJBQTBCLGFBRjFCLEVBQUUsWUFUSjtZQUNQLGFBQWE7WUFDYixlQUFlO1lBQ2YsZUFBZTtZQUNmLDRCQUE0QjtZQUM1QixlQUFlO1lBQ2Ysc0JBQXNCO1NBQ3ZCOzJGQUlVLDBCQUEwQjtrQkFidEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztvQkFDN0MsT0FBTyxFQUFFO3dCQUNQLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixlQUFlO3dCQUNmLDRCQUE0Qjt3QkFDNUIsZUFBZTt3QkFDZixzQkFBc0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRSxDQUFDLDZCQUE2QixDQUFDO29CQUN4QyxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xyXG5pbXBvcnQgeyBCcm93c2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IFNtYXJ0R3JpZE1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWdyaWQvc21hcnQtZ3JpZC5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydEV4cGFuZGFibGVTZWN0aW9uTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtZXhwYW5kYWJsZS1zZWN0aW9uL3NtYXJ0LWV4cGFuZGFibGUtc2VjdGlvbi5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydHRyZWVNb2R1bGUgfSBmcm9tICcuLi9zbWFydC10cmVlL3NtYXJ0dHJlZS5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTbWFydENvbXBvbmVudExheW91dENvbXBvbmVudCB9IGZyb20gJy4vc21hcnQtY29tcG9uZW50LWxheW91dC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBTbWFydFZpZXdDb250ZXh0TW9kdWxlIH0gZnJvbSAnLi4vdmlldy1jb250ZXh0L3NtYXJ0LXZpZXctY29udGV4dC5tb2R1bGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtTbWFydENvbXBvbmVudExheW91dENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQnJvd3Nlck1vZHVsZSxcclxuICAgIE1hdENvbW1vbk1vZHVsZSxcclxuICAgIFNtYXJ0R3JpZE1vZHVsZSxcclxuICAgIFNtYXJ0RXhwYW5kYWJsZVNlY3Rpb25Nb2R1bGUsXHJcbiAgICBTbWFydHRyZWVNb2R1bGUsXHJcbiAgICBTbWFydFZpZXdDb250ZXh0TW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1NtYXJ0Q29tcG9uZW50TGF5b3V0Q29tcG9uZW50XSxcclxuICBwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU21hcnRDb21wb25lbnRMYXlvdXRNb2R1bGUge31cclxuIl19
@@ -13,4 +13,4 @@ export var SmartActionType;
13
13
  SmartActionType[SmartActionType["SAVE"] = 5] = "SAVE";
14
14
  SmartActionType[SmartActionType["OK"] = 6] = "OK";
15
15
  })(SmartActionType || (SmartActionType = {}));
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1kaWFsb2cvc21hcnRkaWFsb2cubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0E7Ozs7R0FJRztBQUNILE1BQU0sQ0FBTixJQUFZLGVBUVg7QUFSRCxXQUFZLGVBQWU7SUFDekIsbURBQUcsQ0FBQTtJQUNILHlEQUFNLENBQUE7SUFDTix5REFBTSxDQUFBO0lBQ04seURBQU0sQ0FBQTtJQUNOLHlEQUFNLENBQUE7SUFDTixxREFBSSxDQUFBO0lBQ0osaURBQUUsQ0FBQTtBQUNKLENBQUMsRUFSVyxlQUFlLEtBQWYsZUFBZSxRQVExQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNtYXJ0Rm9ybSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vcHJvamVjdHMnO1xyXG5pbXBvcnQgeyBTbWFydFRhYmxlIH0gZnJvbSAnLi4vc21hcnQtdGFibGUvcHJvamVjdHMnO1xyXG5cclxuLyoqXHJcbiAqIFRoaXMgaW50ZXJmYWNlIGRlZmluZXMgdGhlIHNpemUgb2YgYSBkaWFsb2cuXHJcbiAqXHJcbiAqIEBhdXRob3IgUm9sYW5kIEbDqW55ZXNcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgU21hcnREaWFsb2dTaXplIHtcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBoZWlnaHQ/OiBudW1iZXI7XHJcbiAgZnVsbFNjcmVlbj86IGJvb2xlYW47XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBUaGlzIGVudW0gaGVscHMgdG8gZGVmaW5lIHRoZSBhY3Rpb24gb2YgYSBkaWFsb2cuXHJcbiAqXHJcbiAqIEBhdXRob3IgUm9sYW5kIEbDqW55ZXNcclxuICovXHJcbmV4cG9ydCBlbnVtIFNtYXJ0QWN0aW9uVHlwZSB7XHJcbiAgQURELFxyXG4gIENSRUFURSxcclxuICBVUERBVEUsXHJcbiAgUkVNT1ZFLFxyXG4gIERFTEVURSxcclxuICBTQVZFLFxyXG4gIE9LLFxyXG59XHJcblxyXG4vKipcclxuICogVGhpcyBpbnRlcmZhY2UgZGVzY3JpYmVzIHRoZSBjb250ZW50IG9mIGEgZGlhbG9nLlxyXG4gKlxyXG4gKiBAYXV0aG9yIFJvbGFuZCBGw6lueWVzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0Q29udGVudCB7XHJcbiAgdGl0bGU6IHN0cmluZztcclxuICBkZXNjcmlwdGlvbj86IHN0cmluZztcclxufVxyXG5cclxuLyoqXHJcbiAqIFdpdGggdGhpcyBpbnRlcmZhY2UgYW55IGtpbmQgb2YgZGlhbG9ncyBjYW4gYmUgZWFzaWx5IGNyZWF0ZWQuXHJcbiAqXHJcbiAqIFlvdSBtdXN0IGNsb3NlIHRoZSBkaWFsb2cgbWFudWFsbHkhXHJcbiAqXHJcbiAqIEBwYXJhbSBzaXplIFJlcXVpcmVkLiBZb3UgY2FuIGRlZmluZSB0aGUgZGVzaXJlZCBzaXplIG9mIHRoZSBkaWFsb2dcclxuICogQHBhcmFtIGFjdGlvblR5cGUgUmVxdWlyZWQuIFRoZSBtYWluIGFjdGlvbiB0eXBlIG9mIHRoZSBkaWFsb2dcclxuICogQHBhcmFtIGNvbnRlbnQgUmVxdWlyZWQuIERlZmluZXMgdGhlIHRpdGxlIGFuZCB0aGUgZGVzY3JpcHRpb24gb2YgdGhlIGRpYWxvZ1xyXG4gKiBAcGFyYW0gZm9ybSBOb3QgcmVxdWlyZWQuIFlvdSBjYW4gcHJlc2VudCBhIGN1c3RvbSBhbmQgZHluYW1pYyBmb3JtLlxyXG4gKiBAcGFyYW0gdGFibGUgTm90IHJlcXVpcmVkLiBZb3UgY2FuIHByZXNlbnQgYSBjdXN0b20gdGFibGUuXHJcbiAqIEBwYXJhbSBva0NhbGxiYWNrIE5vdCByZXF1aXJlZC4gQSBjdXN0b20gY2FsbGJhY2sgZnVuY3Rpb24uXHJcbiAqIEBwYXJhbSBjbG9zZUNhbGxiYWNrIE5vdCByZXF1aXJlZC4gQSBjdXN0b20gY2FsbGJhY2sgZnVuY3Rpb24uXHJcbiAqIEBwYXJhbSBhY3Rpb25DYWxsYmFjayBSZXF1aXJlZC4gQSBjdXN0b20gYWN0aW9uIGNhbGxiYWNrIGZ1bmN0aW9uLlxyXG4gKiBAcGFyYW0gYWN0aW9uTGFiZWwgUmVxdWlyZWQuIFRoZSBuYW1lIG9mIHRoZSBhY3Rpb24gYnV0dG9uLlxyXG4gKlxyXG4gKiBAYXV0aG9yIFJvbGFuZCBGw6lueWVzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0RGlhbG9nRGF0YSB7XHJcbiAgc2l6ZTogU21hcnREaWFsb2dTaXplO1xyXG4gIGNvbnRlbnQ6IFNtYXJ0Q29udGVudDtcclxuICBjdXN0b21Db21wb25lbnQ/OiBhbnk7XHJcbiAgY3VzdG9tQ29tcG9uZW50SW5wdXRzPzogYW55O1xyXG4gIGFjdGlvblR5cGU/OiBTbWFydEFjdGlvblR5cGU7XHJcbiAgZm9ybT86IFNtYXJ0Rm9ybTtcclxuICB0YWJsZT86IFNtYXJ0VGFibGU8YW55PjtcclxuICBva0NhbGxiYWNrPzogKCkgPT4gdm9pZDtcclxuICBjYW5jZWxDYWxsYmFjaz86IChhcmdzOiBhbnlbXSkgPT4gdm9pZDtcclxuICBjbG9zZUNhbGxiYWNrPzogKGFyZ3M6IGFueVtdKSA9PiB2b2lkO1xyXG4gIGFjdGlvbkNhbGxiYWNrPzogKGFyZ3M6IGFueVtdKSA9PiB2b2lkO1xyXG4gIGFjdGlvbkxhYmVsPzogc3RyaW5nO1xyXG4gIG91dGxldHM/OiBhbnk7XHJcbn1cclxuIl19
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi9zbWFydC1kaWFsb2cvc21hcnRkaWFsb2cubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0E7Ozs7R0FJRztBQUNILE1BQU0sQ0FBTixJQUFZLGVBUVg7QUFSRCxXQUFZLGVBQWU7SUFDekIsbURBQUcsQ0FBQTtJQUNILHlEQUFNLENBQUE7SUFDTix5REFBTSxDQUFBO0lBQ04seURBQU0sQ0FBQTtJQUNOLHlEQUFNLENBQUE7SUFDTixxREFBSSxDQUFBO0lBQ0osaURBQUUsQ0FBQTtBQUNKLENBQUMsRUFSVyxlQUFlLEtBQWYsZUFBZSxRQVExQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNtYXJ0Rm9ybSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vc21hcnRmb3JtLm1vZGVsJztcclxuaW1wb3J0IHsgU21hcnRUYWJsZSB9IGZyb20gJy4uL3NtYXJ0LXRhYmxlL3NtYXJ0dGFibGUubW9kZWwnO1xyXG5cclxuLyoqXHJcbiAqIFRoaXMgaW50ZXJmYWNlIGRlZmluZXMgdGhlIHNpemUgb2YgYSBkaWFsb2cuXHJcbiAqXHJcbiAqIEBhdXRob3IgUm9sYW5kIEbDqW55ZXNcclxuICovXHJcbmV4cG9ydCBpbnRlcmZhY2UgU21hcnREaWFsb2dTaXplIHtcclxuICB3aWR0aD86IG51bWJlcjtcclxuICBoZWlnaHQ/OiBudW1iZXI7XHJcbiAgZnVsbFNjcmVlbj86IGJvb2xlYW47XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBUaGlzIGVudW0gaGVscHMgdG8gZGVmaW5lIHRoZSBhY3Rpb24gb2YgYSBkaWFsb2cuXHJcbiAqXHJcbiAqIEBhdXRob3IgUm9sYW5kIEbDqW55ZXNcclxuICovXHJcbmV4cG9ydCBlbnVtIFNtYXJ0QWN0aW9uVHlwZSB7XHJcbiAgQURELFxyXG4gIENSRUFURSxcclxuICBVUERBVEUsXHJcbiAgUkVNT1ZFLFxyXG4gIERFTEVURSxcclxuICBTQVZFLFxyXG4gIE9LLFxyXG59XHJcblxyXG4vKipcclxuICogVGhpcyBpbnRlcmZhY2UgZGVzY3JpYmVzIHRoZSBjb250ZW50IG9mIGEgZGlhbG9nLlxyXG4gKlxyXG4gKiBAYXV0aG9yIFJvbGFuZCBGw6lueWVzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0Q29udGVudCB7XHJcbiAgdGl0bGU6IHN0cmluZztcclxuICBkZXNjcmlwdGlvbj86IHN0cmluZztcclxufVxyXG5cclxuLyoqXHJcbiAqIFdpdGggdGhpcyBpbnRlcmZhY2UgYW55IGtpbmQgb2YgZGlhbG9ncyBjYW4gYmUgZWFzaWx5IGNyZWF0ZWQuXHJcbiAqXHJcbiAqIFlvdSBtdXN0IGNsb3NlIHRoZSBkaWFsb2cgbWFudWFsbHkhXHJcbiAqXHJcbiAqIEBwYXJhbSBzaXplIFJlcXVpcmVkLiBZb3UgY2FuIGRlZmluZSB0aGUgZGVzaXJlZCBzaXplIG9mIHRoZSBkaWFsb2dcclxuICogQHBhcmFtIGFjdGlvblR5cGUgUmVxdWlyZWQuIFRoZSBtYWluIGFjdGlvbiB0eXBlIG9mIHRoZSBkaWFsb2dcclxuICogQHBhcmFtIGNvbnRlbnQgUmVxdWlyZWQuIERlZmluZXMgdGhlIHRpdGxlIGFuZCB0aGUgZGVzY3JpcHRpb24gb2YgdGhlIGRpYWxvZ1xyXG4gKiBAcGFyYW0gZm9ybSBOb3QgcmVxdWlyZWQuIFlvdSBjYW4gcHJlc2VudCBhIGN1c3RvbSBhbmQgZHluYW1pYyBmb3JtLlxyXG4gKiBAcGFyYW0gdGFibGUgTm90IHJlcXVpcmVkLiBZb3UgY2FuIHByZXNlbnQgYSBjdXN0b20gdGFibGUuXHJcbiAqIEBwYXJhbSBva0NhbGxiYWNrIE5vdCByZXF1aXJlZC4gQSBjdXN0b20gY2FsbGJhY2sgZnVuY3Rpb24uXHJcbiAqIEBwYXJhbSBjbG9zZUNhbGxiYWNrIE5vdCByZXF1aXJlZC4gQSBjdXN0b20gY2FsbGJhY2sgZnVuY3Rpb24uXHJcbiAqIEBwYXJhbSBhY3Rpb25DYWxsYmFjayBSZXF1aXJlZC4gQSBjdXN0b20gYWN0aW9uIGNhbGxiYWNrIGZ1bmN0aW9uLlxyXG4gKiBAcGFyYW0gYWN0aW9uTGFiZWwgUmVxdWlyZWQuIFRoZSBuYW1lIG9mIHRoZSBhY3Rpb24gYnV0dG9uLlxyXG4gKlxyXG4gKiBAYXV0aG9yIFJvbGFuZCBGw6lueWVzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFNtYXJ0RGlhbG9nRGF0YSB7XHJcbiAgc2l6ZTogU21hcnREaWFsb2dTaXplO1xyXG4gIGNvbnRlbnQ6IFNtYXJ0Q29udGVudDtcclxuICBjdXN0b21Db21wb25lbnQ/OiBhbnk7XHJcbiAgY3VzdG9tQ29tcG9uZW50SW5wdXRzPzogYW55O1xyXG4gIGFjdGlvblR5cGU/OiBTbWFydEFjdGlvblR5cGU7XHJcbiAgZm9ybT86IFNtYXJ0Rm9ybTtcclxuICB0YWJsZT86IFNtYXJ0VGFibGU8YW55PjtcclxuICBva0NhbGxiYWNrPzogKCkgPT4gdm9pZDtcclxuICBjYW5jZWxDYWxsYmFjaz86IChhcmdzOiBhbnlbXSkgPT4gdm9pZDtcclxuICBjbG9zZUNhbGxiYWNrPzogKGFyZ3M6IGFueVtdKSA9PiB2b2lkO1xyXG4gIGFjdGlvbkNhbGxiYWNrPzogKGFyZ3M6IGFueVtdKSA9PiB2b2lkO1xyXG4gIGFjdGlvbkxhYmVsPzogc3RyaW5nO1xyXG4gIG91dGxldHM/OiBhbnk7XHJcbn1cclxuIl19
@@ -4,9 +4,9 @@ import { MatDialogModule } from '@angular/material/dialog';
4
4
  import { MatIconModule } from '@angular/material/icon';
5
5
  import { MatCommonModule } from '@angular/material/core';
6
6
  import { BrowserModule } from '@angular/platform-browser';
7
- import { SmartformModule } from '../smart-form/projects';
8
7
  import { SmarttableModule } from '../smart-table/projects';
9
8
  import { SmartIconModule } from '../smart-icon/projects';
9
+ import { SmartViewContextModule } from '../view-context/smart-view-context.module';
10
10
  import * as i0 from "@angular/core";
11
11
  export class SmartdialogModule {
12
12
  }
@@ -15,7 +15,7 @@ SmartdialogModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versi
15
15
  MatDialogModule,
16
16
  MatCommonModule,
17
17
  MatIconModule,
18
- SmartformModule,
18
+ SmartViewContextModule,
19
19
  SmarttableModule,
20
20
  SmartIconModule], exports: [SmartDialog] });
21
21
  SmartdialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartdialogModule, providers: [], imports: [[
@@ -23,7 +23,7 @@ SmartdialogModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versi
23
23
  MatDialogModule,
24
24
  MatCommonModule,
25
25
  MatIconModule,
26
- SmartformModule,
26
+ SmartViewContextModule,
27
27
  SmarttableModule,
28
28
  SmartIconModule,
29
29
  ]] });
@@ -36,7 +36,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
36
36
  MatDialogModule,
37
37
  MatCommonModule,
38
38
  MatIconModule,
39
- SmartformModule,
39
+ SmartViewContextModule,
40
40
  SmarttableModule,
41
41
  SmartIconModule,
42
42
  ],
@@ -45,4 +45,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
45
45
  providers: [],
46
46
  }]
47
47
  }] });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtZGlhbG9nL3NtYXJ0ZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFpQnpELE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFkYixXQUFXLGFBRXhCLGFBQWE7UUFDYixlQUFlO1FBQ2YsZUFBZTtRQUNmLGFBQWE7UUFDYixlQUFlO1FBQ2YsZ0JBQWdCO1FBQ2hCLGVBQWUsYUFFUCxXQUFXOytHQUlWLGlCQUFpQixhQUZqQixFQUFFLFlBWEo7WUFDUCxhQUFhO1lBQ2IsZUFBZTtZQUNmLGVBQWU7WUFDZixhQUFhO1lBQ2IsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixlQUFlO1NBQ2hCOzJGQUtVLGlCQUFpQjtrQkFmN0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxXQUFXLENBQUM7b0JBQzNCLE9BQU8sRUFBRTt3QkFDUCxhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZ0JBQWdCO3dCQUNoQixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxXQUFXLENBQUM7b0JBQ3RCLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixFQUFFLGdCQUFnQixDQUFDO29CQUNuRCxTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE5nTW9kdWxlLCBOT19FUlJPUlNfU0NIRU1BIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNtYXJ0RGlhbG9nIH0gZnJvbSAnLi9zbWFydGRpYWxvZy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcbmltcG9ydCB7IE1hdENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xyXG5pbXBvcnQgeyBCcm93c2VyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IFNtYXJ0Zm9ybU1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LWZvcm0vcHJvamVjdHMnO1xyXG5pbXBvcnQgeyBTbWFydHRhYmxlTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtdGFibGUvcHJvamVjdHMnO1xyXG5pbXBvcnQgeyBTbWFydEljb25Nb2R1bGUgfSBmcm9tICcuLi9zbWFydC1pY29uL3Byb2plY3RzJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbU21hcnREaWFsb2ddLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIEJyb3dzZXJNb2R1bGUsXHJcbiAgICBNYXREaWFsb2dNb2R1bGUsXHJcbiAgICBNYXRDb21tb25Nb2R1bGUsXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgU21hcnRmb3JtTW9kdWxlLFxyXG4gICAgU21hcnR0YWJsZU1vZHVsZSxcclxuICAgIFNtYXJ0SWNvbk1vZHVsZSxcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtTbWFydERpYWxvZ10sXHJcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE5PX0VSUk9SU19TQ0hFTUFdLFxyXG4gIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTbWFydGRpYWxvZ01vZHVsZSB7fVxyXG4iXX0=
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRkaWFsb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc21hcnQtbmctY2xpZW50L3NyYy9saWIvc21hcnQtZGlhbG9nL3NtYXJ0ZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDOztBQWlCbkYsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQWRiLFdBQVcsYUFFeEIsYUFBYTtRQUNiLGVBQWU7UUFDZixlQUFlO1FBQ2YsYUFBYTtRQUNiLHNCQUFzQjtRQUN0QixnQkFBZ0I7UUFDaEIsZUFBZSxhQUVQLFdBQVc7K0dBSVYsaUJBQWlCLGFBRmpCLEVBQUUsWUFYSjtZQUNQLGFBQWE7WUFDYixlQUFlO1lBQ2YsZUFBZTtZQUNmLGFBQWE7WUFDYixzQkFBc0I7WUFDdEIsZ0JBQWdCO1lBQ2hCLGVBQWU7U0FDaEI7MkZBS1UsaUJBQWlCO2tCQWY3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLFdBQVcsQ0FBQztvQkFDM0IsT0FBTyxFQUFFO3dCQUNQLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGFBQWE7d0JBQ2Isc0JBQXNCO3dCQUN0QixnQkFBZ0I7d0JBQ2hCLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRSxDQUFDLFdBQVcsQ0FBQztvQkFDdEIsT0FBTyxFQUFFLENBQUMsc0JBQXNCLEVBQUUsZ0JBQWdCLENBQUM7b0JBQ25ELFNBQVMsRUFBRSxFQUFFO2lCQUNkIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgTmdNb2R1bGUsIE5PX0VSUk9SU19TQ0hFTUEgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU21hcnREaWFsb2cgfSBmcm9tICcuL3NtYXJ0ZGlhbG9nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdERpYWxvZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgTWF0Q29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XHJcbmltcG9ydCB7IEJyb3dzZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcclxuaW1wb3J0IHsgU21hcnR0YWJsZU1vZHVsZSB9IGZyb20gJy4uL3NtYXJ0LXRhYmxlL3Byb2plY3RzJztcclxuaW1wb3J0IHsgU21hcnRJY29uTW9kdWxlIH0gZnJvbSAnLi4vc21hcnQtaWNvbi9wcm9qZWN0cyc7XHJcbmltcG9ydCB7IFNtYXJ0Vmlld0NvbnRleHRNb2R1bGUgfSBmcm9tICcuLi92aWV3LWNvbnRleHQvc21hcnQtdmlldy1jb250ZXh0Lm1vZHVsZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1NtYXJ0RGlhbG9nXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBCcm93c2VyTW9kdWxlLFxyXG4gICAgTWF0RGlhbG9nTW9kdWxlLFxyXG4gICAgTWF0Q29tbW9uTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIFNtYXJ0Vmlld0NvbnRleHRNb2R1bGUsXHJcbiAgICBTbWFydHRhYmxlTW9kdWxlLFxyXG4gICAgU21hcnRJY29uTW9kdWxlLFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1NtYXJ0RGlhbG9nXSxcclxuICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgTk9fRVJST1JTX1NDSEVNQV0sXHJcbiAgcHJvdmlkZXJzOiBbXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFNtYXJ0ZGlhbG9nTW9kdWxlIHt9XHJcbiJdfQ==
@@ -34,12 +34,18 @@ export class ExpandableSectionComponent {
34
34
  ['sectionIndex', this.index],
35
35
  ]));
36
36
  }
37
- this.componentRef = this.cfService.createComponent(this.vcRef, this.data.customComponent, new Map([
38
- [this.data.inputName ?? '', this.data.data],
37
+ let inputs = new Map([
39
38
  ['stateChange', this.stateChange],
40
39
  ['index', this.data.index],
41
40
  ['sectionIndex', this.index],
42
- ]));
41
+ ]);
42
+ if (this.data.inputName) {
43
+ inputs.set(this.data.inputName, this.data.data);
44
+ }
45
+ if (this.data.inputs) {
46
+ this.data.inputs.forEach((v, k) => inputs.set(k, v));
47
+ }
48
+ this.componentRef = this.cfService.createComponent(this.vcRef, this.data.customComponent, inputs);
43
49
  }
44
50
  action(button, event) {
45
51
  event.stopPropagation();
@@ -64,10 +70,10 @@ export class ExpandableSectionComponent {
64
70
  }
65
71
  }
66
72
  ExpandableSectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ExpandableSectionComponent, deps: [{ token: i1.ComponentFactoryService }], target: i0.ɵɵFactoryTarget.Component });
67
- ExpandableSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ExpandableSectionComponent, selector: "smart-expandable-section", inputs: { data: "data", index: "index" }, viewQueries: [{ propertyName: "vcRef", first: true, predicate: ["renderComponent"], descendants: true, read: ViewContainerRef }, { propertyName: "vcRefheader", first: true, predicate: ["headerComponent"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n <mat-expansion-panel\r\n [expanded]=\"data.isExpanded\"\r\n (opened)=\"onStateChange(true)\"\r\n (closed)=\"onStateChange(false)\"\r\n >\r\n <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n <ng-template #headerComponent></ng-template>\r\n </mat-expansion-panel-header>\r\n <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n <div class=\"btn-container\" *ngIf=\"data.button\">\r\n <button\r\n *ngIf=\"data.button.type === type().BUTTON\"\r\n class=\"btn\"\r\n (click)=\"action(data.button, $event)\"\r\n mat-stroked-button\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition ||\r\n data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n {{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <button\r\n *ngIf=\"data.button.type === type().MENU\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"$event.stopPropagation()\"\r\n color=\"{{ data.button.color }}\"\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition ||\r\n data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon\r\n >{{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button\r\n *ngFor=\"let button of data.button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, button, data.index)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n button.icon &&\r\n (!button.iconPosition || button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"button.icon\"\r\n ></smart-icon\r\n >{{ button.label }}\r\n <smart-icon\r\n *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n [icon]=\"button.icon\"\r\n ></smart-icon>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n </mat-expansion-panel-header>\r\n <ng-template #renderComponent></ng-template>\r\n </mat-expansion-panel>\r\n</div>\r\n", styles: [".section-container{margin-bottom:50px}:host::ng-deep .mat-expansion-panel-header{background:var(--primary-lighter-color)}:host::ng-deep .mat-expansion-panel-header-title{color:var(--primary-color)}:host::ng-deep .btn-container{margin:1em 3em 1em 1em}:host::ng-deep .btn{border-radius:24px}\n"], components: [{ type: i2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { type: i2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { type: i5.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatExpansionPanelTitle, selector: "mat-panel-title" }, { type: i5.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
73
+ ExpandableSectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ExpandableSectionComponent, selector: "smart-expandable-section", inputs: { data: "data", index: "index" }, viewQueries: [{ propertyName: "vcRef", first: true, predicate: ["renderComponent"], descendants: true, read: ViewContainerRef }, { propertyName: "vcRefheader", first: true, predicate: ["headerComponent"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n <mat-expansion-panel\r\n [expanded]=\"data.isExpanded\"\r\n (opened)=\"onStateChange(true)\"\r\n (closed)=\"onStateChange(false)\"\r\n [disabled]=\"!!data.isDisabled\"\r\n >\r\n <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n <ng-template #headerComponent></ng-template>\r\n </mat-expansion-panel-header>\r\n <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n <div class=\"btn-container\" *ngIf=\"data.button\">\r\n <button\r\n *ngIf=\"data.button.type === type().BUTTON\"\r\n class=\"btn\"\r\n (click)=\"action(data.button, $event)\"\r\n mat-stroked-button\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition || data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n {{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <button\r\n *ngIf=\"data.button.type === type().MENU\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"$event.stopPropagation()\"\r\n color=\"{{ data.button.color }}\"\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition || data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon\r\n >{{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button\r\n *ngFor=\"let button of data.button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, button, data.index)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n button.icon && (!button.iconPosition || button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"button.icon\"\r\n ></smart-icon\r\n >{{ button.label }}\r\n <smart-icon\r\n *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n [icon]=\"button.icon\"\r\n ></smart-icon>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n </mat-expansion-panel-header>\r\n <ng-template #renderComponent></ng-template>\r\n </mat-expansion-panel>\r\n</div>\r\n", styles: [".section-container{margin-bottom:50px}:host::ng-deep .mat-expansion-panel-header{background:var(--primary-lighter-color)}:host::ng-deep .mat-expansion-panel-header-title{color:var(--primary-color)}:host::ng-deep .btn-container{margin:1em 3em 1em 1em}:host::ng-deep .btn{border-radius:24px}\n"], components: [{ type: i2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { type: i2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { type: i5.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatExpansionPanelTitle, selector: "mat-panel-title" }, { type: i5.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
68
74
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ExpandableSectionComponent, decorators: [{
69
75
  type: Component,
70
- args: [{ selector: 'smart-expandable-section', template: "<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n <mat-expansion-panel\r\n [expanded]=\"data.isExpanded\"\r\n (opened)=\"onStateChange(true)\"\r\n (closed)=\"onStateChange(false)\"\r\n >\r\n <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n <ng-template #headerComponent></ng-template>\r\n </mat-expansion-panel-header>\r\n <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n <div class=\"btn-container\" *ngIf=\"data.button\">\r\n <button\r\n *ngIf=\"data.button.type === type().BUTTON\"\r\n class=\"btn\"\r\n (click)=\"action(data.button, $event)\"\r\n mat-stroked-button\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition ||\r\n data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n {{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <button\r\n *ngIf=\"data.button.type === type().MENU\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"$event.stopPropagation()\"\r\n color=\"{{ data.button.color }}\"\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition ||\r\n data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon\r\n >{{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button\r\n *ngFor=\"let button of data.button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, button, data.index)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n button.icon &&\r\n (!button.iconPosition || button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"button.icon\"\r\n ></smart-icon\r\n >{{ button.label }}\r\n <smart-icon\r\n *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n [icon]=\"button.icon\"\r\n ></smart-icon>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n </mat-expansion-panel-header>\r\n <ng-template #renderComponent></ng-template>\r\n </mat-expansion-panel>\r\n</div>\r\n", styles: [".section-container{margin-bottom:50px}:host::ng-deep .mat-expansion-panel-header{background:var(--primary-lighter-color)}:host::ng-deep .mat-expansion-panel-header-title{color:var(--primary-color)}:host::ng-deep .btn-container{margin:1em 3em 1em 1em}:host::ng-deep .btn{border-radius:24px}\n"] }]
76
+ args: [{ selector: 'smart-expandable-section', template: "<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n <mat-expansion-panel\r\n [expanded]=\"data.isExpanded\"\r\n (opened)=\"onStateChange(true)\"\r\n (closed)=\"onStateChange(false)\"\r\n [disabled]=\"!!data.isDisabled\"\r\n >\r\n <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n <ng-template #headerComponent></ng-template>\r\n </mat-expansion-panel-header>\r\n <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n <div class=\"btn-container\" *ngIf=\"data.button\">\r\n <button\r\n *ngIf=\"data.button.type === type().BUTTON\"\r\n class=\"btn\"\r\n (click)=\"action(data.button, $event)\"\r\n mat-stroked-button\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition || data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n {{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <button\r\n *ngIf=\"data.button.type === type().MENU\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"$event.stopPropagation()\"\r\n color=\"{{ data.button.color }}\"\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n data.button.icon &&\r\n (!data.button.iconPosition || data.button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon\r\n >{{ data.button.label }}\r\n <smart-icon\r\n *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n [icon]=\"data.button.icon\"\r\n ></smart-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button\r\n *ngFor=\"let button of data.button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, button, data.index)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"\r\n button.icon && (!button.iconPosition || button.iconPosition === position().PRE)\r\n \"\r\n [icon]=\"button.icon\"\r\n ></smart-icon\r\n >{{ button.label }}\r\n <smart-icon\r\n *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n [icon]=\"button.icon\"\r\n ></smart-icon>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n </mat-expansion-panel-header>\r\n <ng-template #renderComponent></ng-template>\r\n </mat-expansion-panel>\r\n</div>\r\n", styles: [".section-container{margin-bottom:50px}:host::ng-deep .mat-expansion-panel-header{background:var(--primary-lighter-color)}:host::ng-deep .mat-expansion-panel-header-title{color:var(--primary-color)}:host::ng-deep .btn-container{margin:1em 3em 1em 1em}:host::ng-deep .btn{border-radius:24px}\n"] }]
71
77
  }], ctorParameters: function () { return [{ type: i1.ComponentFactoryService }]; }, propDecorators: { data: [{
72
78
  type: Input
73
79
  }], index: [{
@@ -79,4 +85,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
79
85
  type: ViewChild,
80
86
  args: ['headerComponent', { read: ViewContainerRef }]
81
87
  }] } });
82
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expandable-section.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-expandable-section/expandable-section.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-expandable-section/expandable-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, Input, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport {\r\n  ExpandableSection,\r\n  ExpandableSectionButton,\r\n  ExpandableSectionButtonIconPosition,\r\n  ExpandableSectionButtonType,\r\n} from './expandable-section.model';\r\nimport { ComponentFactoryService } from '../component-factory-service/projects';\r\n\r\n@Component({\r\n  selector: 'smart-expandable-section',\r\n  templateUrl: './expandable-section.component.html',\r\n  styleUrls: ['./expandable-section.component.css'],\r\n})\r\nexport class ExpandableSectionComponent implements OnInit {\r\n  @Input() data!: ExpandableSection<any>;\r\n  @Input() index?: number;\r\n\r\n  @ViewChild('renderComponent', { read: ViewContainerRef })\r\n  vcRef?: ViewContainerRef;\r\n  componentRef?: ComponentRef<any>;\r\n\r\n  @ViewChild('headerComponent', { read: ViewContainerRef })\r\n  vcRefheader?: ViewContainerRef;\r\n\r\n  stateChange: Subject<ExpandableSection<any>> = new Subject();\r\n\r\n  constructor(private cfService: ComponentFactoryService) {}\r\n\r\n  onStateChange(isOpened: boolean): void {\r\n    this.data.isExpanded = isOpened;\r\n    this.stateChange.next(this.data);\r\n    if (this.data.stateChanged) {\r\n      this.data.stateChanged.next({\r\n        data: this.data.data,\r\n        isExpanded: isOpened,\r\n        index: this.data.index,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngAfterViewInit() {\r\n    if (this.data.headerComponent) {\r\n      this.cfService.createComponent(\r\n        this.vcRefheader!,\r\n        this.data.headerComponent,\r\n        new Map<string, any>([\r\n          [this.data.headerInputName ?? '', this.data.headerData],\r\n          ['stateChange', this.stateChange],\r\n          ['index', this.data.index],\r\n          ['sectionIndex', this.index],\r\n        ])\r\n      );\r\n    }\r\n    this.componentRef = this.cfService.createComponent(\r\n      this.vcRef!,\r\n      this.data.customComponent,\r\n      new Map<string, any>([\r\n        [this.data.inputName ?? '', this.data.data],\r\n        ['stateChange', this.stateChange],\r\n        ['index', this.data.index],\r\n        ['sectionIndex', this.index],\r\n      ])\r\n    );\r\n  }\r\n\r\n  action(button: ExpandableSectionButton, event: any) {\r\n    event.stopPropagation();\r\n    if (!button.callback) {\r\n      throw new Error(\r\n        `Button with name ${button.label} or icon ${button.icon} does not have a callback!`\r\n      );\r\n    }\r\n\r\n    button.callback(button.args);\r\n  }\r\n\r\n  setExpanded() {}\r\n\r\n  type(): typeof ExpandableSectionButtonType {\r\n    return ExpandableSectionButtonType;\r\n  }\r\n  position(): typeof ExpandableSectionButtonIconPosition {\r\n    return ExpandableSectionButtonIconPosition;\r\n  }\r\n\r\n  customButtonClicked(event: any, button: ExpandableSectionButton, element: any) {\r\n    event.stopPropagation();\r\n\r\n    if (!button.callback) {\r\n      throw new Error(\r\n        `Button with name ${button.label} or icon ${button.icon} does not have a callback!`\r\n      );\r\n    }\r\n    button.callback(button.args, element);\r\n  }\r\n}\r\n","<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n    <mat-expansion-panel\r\n        [expanded]=\"data.isExpanded\"\r\n        (opened)=\"onStateChange(true)\"\r\n        (closed)=\"onStateChange(false)\"\r\n    >\r\n        <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n            <ng-template #headerComponent></ng-template>\r\n        </mat-expansion-panel-header>\r\n        <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n            <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n            <div class=\"btn-container\" *ngIf=\"data.button\">\r\n                <button\r\n                    *ngIf=\"data.button.type === type().BUTTON\"\r\n                    class=\"btn\"\r\n                    (click)=\"action(data.button, $event)\"\r\n                    mat-stroked-button\r\n                >\r\n                    <smart-icon\r\n                        *ngIf=\"\r\n                            data.button.icon &&\r\n                            (!data.button.iconPosition ||\r\n                                data.button.iconPosition === position().PRE)\r\n                        \"\r\n                        [icon]=\"data.button.icon\"\r\n                    ></smart-icon>\r\n                    {{ data.button.label }}\r\n                    <smart-icon\r\n                        *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n                        [icon]=\"data.button.icon\"\r\n                    ></smart-icon>\r\n                </button>\r\n                <button\r\n                    *ngIf=\"data.button.type === type().MENU\"\r\n                    mat-button\r\n                    [matMenuTriggerFor]=\"menu\"\r\n                    (click)=\"$event.stopPropagation()\"\r\n                    color=\"{{ data.button.color }}\"\r\n                >\r\n                    <smart-icon\r\n                        *ngIf=\"\r\n                            data.button.icon &&\r\n                            (!data.button.iconPosition ||\r\n                                data.button.iconPosition === position().PRE)\r\n                        \"\r\n                        [icon]=\"data.button.icon\"\r\n                    ></smart-icon\r\n                    >{{ data.button.label }}\r\n                    <smart-icon\r\n                        *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n                        [icon]=\"data.button.icon\"\r\n                    ></smart-icon>\r\n                </button>\r\n                <mat-menu #menu=\"matMenu\">\r\n                    <button\r\n                        *ngFor=\"let button of data.button.menuItemButtons\"\r\n                        (click)=\"customButtonClicked($event, button, data.index)\"\r\n                        mat-menu-item\r\n                    >\r\n                        <smart-icon\r\n                            *ngIf=\"\r\n                                button.icon &&\r\n                                (!button.iconPosition || button.iconPosition === position().PRE)\r\n                            \"\r\n                            [icon]=\"button.icon\"\r\n                        ></smart-icon\r\n                        >{{ button.label }}\r\n                        <smart-icon\r\n                            *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n                            [icon]=\"button.icon\"\r\n                        ></smart-icon>\r\n                    </button>\r\n                </mat-menu>\r\n            </div>\r\n        </mat-expansion-panel-header>\r\n        <ng-template #renderComponent></ng-template>\r\n    </mat-expansion-panel>\r\n</div>\r\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expandable-section.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-expandable-section/expandable-section.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-expandable-section/expandable-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, Input, OnInit, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport {\r\n  ExpandableSection,\r\n  ExpandableSectionButton,\r\n  ExpandableSectionButtonIconPosition,\r\n  ExpandableSectionButtonType,\r\n} from './expandable-section.model';\r\nimport { ComponentFactoryService } from '../component-factory-service/projects';\r\n\r\n@Component({\r\n  selector: 'smart-expandable-section',\r\n  templateUrl: './expandable-section.component.html',\r\n  styleUrls: ['./expandable-section.component.css'],\r\n})\r\nexport class ExpandableSectionComponent implements OnInit {\r\n  @Input() data!: ExpandableSection<any>;\r\n  @Input() index?: number;\r\n\r\n  @ViewChild('renderComponent', { read: ViewContainerRef })\r\n  vcRef?: ViewContainerRef;\r\n  componentRef?: ComponentRef<any>;\r\n\r\n  @ViewChild('headerComponent', { read: ViewContainerRef })\r\n  vcRefheader?: ViewContainerRef;\r\n\r\n  stateChange: Subject<ExpandableSection<any>> = new Subject();\r\n\r\n  constructor(private cfService: ComponentFactoryService) {}\r\n\r\n  onStateChange(isOpened: boolean): void {\r\n    this.data.isExpanded = isOpened;\r\n    this.stateChange.next(this.data);\r\n    if (this.data.stateChanged) {\r\n      this.data.stateChanged.next({\r\n        data: this.data.data,\r\n        isExpanded: isOpened,\r\n        index: this.data.index,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngAfterViewInit() {\r\n    if (this.data.headerComponent) {\r\n      this.cfService.createComponent(\r\n        this.vcRefheader!,\r\n        this.data.headerComponent,\r\n        new Map<string, any>([\r\n          [this.data.headerInputName ?? '', this.data.headerData],\r\n          ['stateChange', this.stateChange],\r\n          ['index', this.data.index],\r\n          ['sectionIndex', this.index],\r\n        ])\r\n      );\r\n    }\r\n    let inputs = new Map<string, any>([\r\n      ['stateChange', this.stateChange],\r\n      ['index', this.data.index],\r\n      ['sectionIndex', this.index],\r\n    ]);\r\n    if (this.data.inputName) {\r\n      inputs.set(this.data.inputName, this.data.data);\r\n    }\r\n    if (this.data.inputs) {\r\n      this.data.inputs.forEach((v, k) => inputs.set(k, v));\r\n    }\r\n\r\n    this.componentRef = this.cfService.createComponent(\r\n      this.vcRef!,\r\n      this.data.customComponent,\r\n      inputs\r\n    );\r\n  }\r\n\r\n  action(button: ExpandableSectionButton, event: any) {\r\n    event.stopPropagation();\r\n    if (!button.callback) {\r\n      throw new Error(\r\n        `Button with name ${button.label} or icon ${button.icon} does not have a callback!`\r\n      );\r\n    }\r\n\r\n    button.callback(button.args);\r\n  }\r\n\r\n  setExpanded() {}\r\n\r\n  type(): typeof ExpandableSectionButtonType {\r\n    return ExpandableSectionButtonType;\r\n  }\r\n  position(): typeof ExpandableSectionButtonIconPosition {\r\n    return ExpandableSectionButtonIconPosition;\r\n  }\r\n\r\n  customButtonClicked(event: any, button: ExpandableSectionButton, element: any) {\r\n    event.stopPropagation();\r\n\r\n    if (!button.callback) {\r\n      throw new Error(\r\n        `Button with name ${button.label} or icon ${button.icon} does not have a callback!`\r\n      );\r\n    }\r\n    button.callback(button.args, element);\r\n  }\r\n}\r\n","<div class=\"section-container\" [ngClass]=\"data.cssClass ?? ''\">\r\n  <mat-expansion-panel\r\n    [expanded]=\"data.isExpanded\"\r\n    (opened)=\"onStateChange(true)\"\r\n    (closed)=\"onStateChange(false)\"\r\n    [disabled]=\"!!data.isDisabled\"\r\n  >\r\n    <mat-expansion-panel-header *ngIf=\"data.headerComponent\">\r\n      <ng-template #headerComponent></ng-template>\r\n    </mat-expansion-panel-header>\r\n    <mat-expansion-panel-header *ngIf=\"!data.headerComponent\">\r\n      <mat-panel-title> {{ data.title }} </mat-panel-title>\r\n      <div class=\"btn-container\" *ngIf=\"data.button\">\r\n        <button\r\n          *ngIf=\"data.button.type === type().BUTTON\"\r\n          class=\"btn\"\r\n          (click)=\"action(data.button, $event)\"\r\n          mat-stroked-button\r\n        >\r\n          <smart-icon\r\n            *ngIf=\"\r\n              data.button.icon &&\r\n              (!data.button.iconPosition || data.button.iconPosition === position().PRE)\r\n            \"\r\n            [icon]=\"data.button.icon\"\r\n          ></smart-icon>\r\n          {{ data.button.label }}\r\n          <smart-icon\r\n            *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n            [icon]=\"data.button.icon\"\r\n          ></smart-icon>\r\n        </button>\r\n        <button\r\n          *ngIf=\"data.button.type === type().MENU\"\r\n          mat-button\r\n          [matMenuTriggerFor]=\"menu\"\r\n          (click)=\"$event.stopPropagation()\"\r\n          color=\"{{ data.button.color }}\"\r\n        >\r\n          <smart-icon\r\n            *ngIf=\"\r\n              data.button.icon &&\r\n              (!data.button.iconPosition || data.button.iconPosition === position().PRE)\r\n            \"\r\n            [icon]=\"data.button.icon\"\r\n          ></smart-icon\r\n          >{{ data.button.label }}\r\n          <smart-icon\r\n            *ngIf=\"data.button.icon && data.button.iconPosition === position().POST\"\r\n            [icon]=\"data.button.icon\"\r\n          ></smart-icon>\r\n        </button>\r\n        <mat-menu #menu=\"matMenu\">\r\n          <button\r\n            *ngFor=\"let button of data.button.menuItemButtons\"\r\n            (click)=\"customButtonClicked($event, button, data.index)\"\r\n            mat-menu-item\r\n          >\r\n            <smart-icon\r\n              *ngIf=\"\r\n                button.icon && (!button.iconPosition || button.iconPosition === position().PRE)\r\n              \"\r\n              [icon]=\"button.icon\"\r\n            ></smart-icon\r\n            >{{ button.label }}\r\n            <smart-icon\r\n              *ngIf=\"button.icon && button.iconPosition === position().POST\"\r\n              [icon]=\"button.icon\"\r\n            ></smart-icon>\r\n          </button>\r\n        </mat-menu>\r\n      </div>\r\n    </mat-expansion-panel-header>\r\n    <ng-template #renderComponent></ng-template>\r\n  </mat-expansion-panel>\r\n</div>\r\n"]}