@smartbit4all/ng-client 3.3.129 → 3.3.131

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.
@@ -4,6 +4,7 @@ import { SmartFormWidgetDirection, } from '../smart-form/projects';
4
4
  import { GridUiActionType, SmartLayoutDef, } from '../smart-grid/projects';
5
5
  import { ExpandableSectionComponent, } from '../smart-expandable-section/projects';
6
6
  import { Subject, takeUntil } from 'rxjs';
7
+ import { deepEqual } from 'fast-equals';
7
8
  import * as i0 from "@angular/core";
8
9
  import * as i1 from "../smart-form/projects";
9
10
  import * as i2 from "../smart-expandable-section/expandable-section.component";
@@ -50,24 +51,27 @@ export class SmartComponentLayoutComponent {
50
51
  .subscribe((list) => {
51
52
  this.setToolbarComponent(list.first);
52
53
  });
53
- if (this.smartComponentLayout) {
54
- this.setUp();
55
- }
54
+ this.setUp();
56
55
  }
57
56
  ngOnDestroy() {
58
57
  this._destroy$.next();
59
58
  this._destroy$.complete();
60
59
  }
61
60
  ngOnChanges(changes) {
62
- this.smartComponentLayout = changes['smartComponentLayout'].currentValue;
63
- if (this.smartComponentLayout) {
64
- this.setUp();
65
- }
61
+ this.setUp();
66
62
  }
67
63
  setUp() {
68
- this.parent = this.smartComponentLayout?.parentComponent;
69
- this.uuid = this.parent.uuid;
70
- this.treeService = this.parent.smartTreeService;
64
+ if (!this.parentSmartComponent || !this.smartComponentLayout) {
65
+ return;
66
+ }
67
+ if (deepEqual(this.smartComponentLayout, this.currentLayout)) {
68
+ // no layout change, keep current state
69
+ return;
70
+ }
71
+ // layout changed, render, but save current
72
+ this.currentLayout = JSON.parse(JSON.stringify(this.smartComponentLayout));
73
+ this.uuid = this.parentSmartComponent.uuid;
74
+ this.treeService = this.parentSmartComponent.smartTreeService;
71
75
  this.smartComponentLayout?.direction;
72
76
  if (this.smartComponentLayout?.expandable) {
73
77
  this.constructExpandableSection();
@@ -90,7 +94,8 @@ export class SmartComponentLayoutComponent {
90
94
  this.constructToolbar();
91
95
  }
92
96
  if (!this.parentLayoutComponent) {
93
- this.parent.initActions();
97
+ // only top level component should call init actions
98
+ this.parentSmartComponent.initActions();
94
99
  }
95
100
  }
96
101
  }
@@ -113,7 +118,7 @@ export class SmartComponentLayoutComponent {
113
118
  });
114
119
  this.smartForm = {
115
120
  direction: this.getFormLayout(),
116
- componentModel: this.parent?.model,
121
+ componentModel: this.parentSmartComponent?.model,
117
122
  widgets,
118
123
  };
119
124
  this.bindForm();
@@ -133,11 +138,11 @@ export class SmartComponentLayoutComponent {
133
138
  }
134
139
  }
135
140
  bindForm() {
136
- if (this.parent?.useQueryLists) {
141
+ if (this.parentSmartComponent?.useQueryLists) {
137
142
  return;
138
143
  }
139
144
  if (this.smartForm && this.smartFormComponent) {
140
- this.parent?.addForm(
145
+ this.parentSmartComponent?.addForm(
141
146
  // unique identifier for the form
142
147
  `form_${this.makeid(5)}`, this.smartForm, this.smartFormComponent);
143
148
  }
@@ -174,11 +179,11 @@ export class SmartComponentLayoutComponent {
174
179
  }
175
180
  }
176
181
  bindGrid() {
177
- if (this.parent?.useQueryLists) {
182
+ if (this.parentSmartComponent?.useQueryLists) {
178
183
  return;
179
184
  }
180
185
  if (this.smartGrid && this.smartGridComponent) {
181
- this.smartGrid = this.parent?.addGrid(this.smartGrid, {
186
+ this.smartGrid = this.parentSmartComponent?.addGrid(this.smartGrid, {
182
187
  rowUiActionType: GridUiActionType.POPUP_MENU,
183
188
  }, false, this.smartGridComponent);
184
189
  }
@@ -199,10 +204,10 @@ export class SmartComponentLayoutComponent {
199
204
  // TODO
200
205
  }
201
206
  constructTree() {
202
- if (this.parent?.useQueryLists) {
207
+ if (this.parentSmartComponent?.useQueryLists) {
203
208
  return;
204
209
  }
205
- this.parent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);
210
+ this.parentSmartComponent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);
206
211
  this.treeService?.initialize();
207
212
  }
208
213
  constructToolbar() {
@@ -213,14 +218,16 @@ export class SmartComponentLayoutComponent {
213
218
  }
214
219
  }
215
220
  SmartComponentLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, deps: [{ token: i1.SmartformLayoutDefinitionService }], target: i0.ɵɵFactoryTarget.Component });
216
- SmartComponentLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: { smartComponentLayout: "smartComponentLayout", parentLayoutComponent: "parentLayoutComponent" }, 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 [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"] }, { 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"] }] });
221
+ 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"] }] });
217
222
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, decorators: [{
218
223
  type: Component,
219
- 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 [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"] }]
224
+ 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"] }]
220
225
  }], ctorParameters: function () { return [{ type: i1.SmartformLayoutDefinitionService }]; }, propDecorators: { smartComponentLayout: [{
221
226
  type: Input
222
227
  }], parentLayoutComponent: [{
223
228
  type: Input
229
+ }], parentSmartComponent: [{
230
+ type: Input
224
231
  }], smartFormList: [{
225
232
  type: ViewChildren,
226
233
  args: ['form']
@@ -240,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
240
247
  type: ViewChildren,
241
248
  args: [SmartComponentLayoutComponent]
242
249
  }] } });
243
- //# 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  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 {\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\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\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  parent?: any; //SmartComponent<any>\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(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        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        this.parent.initActions();\r\n      }\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.parent?.useQueryLists) {\r\n      return;\r\n    }\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.parent?.useQueryLists) {\r\n      return;\r\n    }\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  // 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.parent?.useQueryLists) {\r\n      return;\r\n    }\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      [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"]}
250
+ //# 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  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 {\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\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(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    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      return;\r\n    }\r\n    // layout changed, render, but save current\r\n    this.currentLayout = JSON.parse(JSON.stringify(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\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.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"]}
@@ -13041,48 +13041,52 @@ class SmartComponentLayoutComponent {
13041
13041
  .subscribe((list) => {
13042
13042
  this.setToolbarComponent(list.first);
13043
13043
  });
13044
- if (this.smartComponentLayout) {
13045
- this.setUp();
13046
- }
13044
+ this.setUp();
13047
13045
  }
13048
13046
  ngOnDestroy() {
13049
13047
  this._destroy$.next();
13050
13048
  this._destroy$.complete();
13051
13049
  }
13052
13050
  ngOnChanges(changes) {
13053
- this.smartComponentLayout = changes['smartComponentLayout'].currentValue;
13054
- if (this.smartComponentLayout) {
13055
- this.setUp();
13056
- }
13051
+ this.setUp();
13057
13052
  }
13058
13053
  setUp() {
13059
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
13060
- this.parent = (_a = this.smartComponentLayout) === null || _a === void 0 ? void 0 : _a.parentComponent;
13061
- this.uuid = this.parent.uuid;
13062
- this.treeService = this.parent.smartTreeService;
13063
- (_b = this.smartComponentLayout) === null || _b === void 0 ? void 0 : _b.direction;
13064
- if ((_c = this.smartComponentLayout) === null || _c === void 0 ? void 0 : _c.expandable) {
13054
+ var _a, _b, _c, _d, _e, _f, _g, _h;
13055
+ if (!this.parentSmartComponent || !this.smartComponentLayout) {
13056
+ return;
13057
+ }
13058
+ if (deepEqual(this.smartComponentLayout, this.currentLayout)) {
13059
+ // no layout change, keep current state
13060
+ return;
13061
+ }
13062
+ // layout changed, render, but save current
13063
+ this.currentLayout = JSON.parse(JSON.stringify(this.smartComponentLayout));
13064
+ this.uuid = this.parentSmartComponent.uuid;
13065
+ this.treeService = this.parentSmartComponent.smartTreeService;
13066
+ (_a = this.smartComponentLayout) === null || _a === void 0 ? void 0 : _a.direction;
13067
+ if ((_b = this.smartComponentLayout) === null || _b === void 0 ? void 0 : _b.expandable) {
13065
13068
  this.constructExpandableSection();
13066
13069
  }
13067
- else if (((_d = this.smartComponentLayout) === null || _d === void 0 ? void 0 : _d.type) === ComponentType.FORM) {
13070
+ else if (((_c = this.smartComponentLayout) === null || _c === void 0 ? void 0 : _c.type) === ComponentType.FORM) {
13068
13071
  this.constructForm();
13069
13072
  }
13070
- else if (((_e = this.smartComponentLayout) === null || _e === void 0 ? void 0 : _e.type) === ComponentType.WIDGET) {
13071
- if (((_f = this.smartComponentLayout.widget) === null || _f === void 0 ? void 0 : _f.type) === ComponentWidgetType.GRID) {
13073
+ else if (((_d = this.smartComponentLayout) === null || _d === void 0 ? void 0 : _d.type) === ComponentType.WIDGET) {
13074
+ if (((_e = this.smartComponentLayout.widget) === null || _e === void 0 ? void 0 : _e.type) === ComponentWidgetType.GRID) {
13072
13075
  this.constructGrid();
13073
13076
  }
13074
- else if (((_g = this.smartComponentLayout.widget) === null || _g === void 0 ? void 0 : _g.type) === ComponentWidgetType.FILTER) {
13077
+ else if (((_f = this.smartComponentLayout.widget) === null || _f === void 0 ? void 0 : _f.type) === ComponentWidgetType.FILTER) {
13075
13078
  console.warn('ComponentWidgetType.FILTER is not supported');
13076
13079
  // this.constructFilter();
13077
13080
  }
13078
- else if (((_h = this.smartComponentLayout.widget) === null || _h === void 0 ? void 0 : _h.type) === ComponentWidgetType.TREE) {
13081
+ else if (((_g = this.smartComponentLayout.widget) === null || _g === void 0 ? void 0 : _g.type) === ComponentWidgetType.TREE) {
13079
13082
  this.constructTree();
13080
13083
  }
13081
- else if (((_j = this.smartComponentLayout.widget) === null || _j === void 0 ? void 0 : _j.type) === ComponentWidgetType.TOOLBAR) {
13084
+ else if (((_h = this.smartComponentLayout.widget) === null || _h === void 0 ? void 0 : _h.type) === ComponentWidgetType.TOOLBAR) {
13082
13085
  this.constructToolbar();
13083
13086
  }
13084
13087
  if (!this.parentLayoutComponent) {
13085
- this.parent.initActions();
13088
+ // only top level component should call init actions
13089
+ this.parentSmartComponent.initActions();
13086
13090
  }
13087
13091
  }
13088
13092
  }
@@ -13107,7 +13111,7 @@ class SmartComponentLayoutComponent {
13107
13111
  });
13108
13112
  this.smartForm = {
13109
13113
  direction: this.getFormLayout(),
13110
- componentModel: (_b = this.parent) === null || _b === void 0 ? void 0 : _b.model,
13114
+ componentModel: (_b = this.parentSmartComponent) === null || _b === void 0 ? void 0 : _b.model,
13111
13115
  widgets,
13112
13116
  };
13113
13117
  this.bindForm();
@@ -13129,11 +13133,11 @@ class SmartComponentLayoutComponent {
13129
13133
  }
13130
13134
  bindForm() {
13131
13135
  var _a, _b;
13132
- if ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13136
+ if ((_a = this.parentSmartComponent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13133
13137
  return;
13134
13138
  }
13135
13139
  if (this.smartForm && this.smartFormComponent) {
13136
- (_b = this.parent) === null || _b === void 0 ? void 0 : _b.addForm(
13140
+ (_b = this.parentSmartComponent) === null || _b === void 0 ? void 0 : _b.addForm(
13137
13141
  // unique identifier for the form
13138
13142
  `form_${this.makeid(5)}`, this.smartForm, this.smartFormComponent);
13139
13143
  }
@@ -13172,11 +13176,11 @@ class SmartComponentLayoutComponent {
13172
13176
  }
13173
13177
  bindGrid() {
13174
13178
  var _a, _b;
13175
- if ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13179
+ if ((_a = this.parentSmartComponent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13176
13180
  return;
13177
13181
  }
13178
13182
  if (this.smartGrid && this.smartGridComponent) {
13179
- this.smartGrid = (_b = this.parent) === null || _b === void 0 ? void 0 : _b.addGrid(this.smartGrid, {
13183
+ this.smartGrid = (_b = this.parentSmartComponent) === null || _b === void 0 ? void 0 : _b.addGrid(this.smartGrid, {
13180
13184
  rowUiActionType: GridUiActionType.POPUP_MENU,
13181
13185
  }, false, this.smartGridComponent);
13182
13186
  }
@@ -13198,10 +13202,10 @@ class SmartComponentLayoutComponent {
13198
13202
  }
13199
13203
  constructTree() {
13200
13204
  var _a, _b, _c, _d;
13201
- if ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13205
+ if ((_a = this.parentSmartComponent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13202
13206
  return;
13203
13207
  }
13204
- this.parent.setUpDefaultTree((_c = (_b = this.smartComponentLayout) === null || _b === void 0 ? void 0 : _b.widget) === null || _c === void 0 ? void 0 : _c.identifier);
13208
+ this.parentSmartComponent.setUpDefaultTree((_c = (_b = this.smartComponentLayout) === null || _b === void 0 ? void 0 : _b.widget) === null || _c === void 0 ? void 0 : _c.identifier);
13205
13209
  (_d = this.treeService) === null || _d === void 0 ? void 0 : _d.initialize();
13206
13210
  }
13207
13211
  constructToolbar() {
@@ -13213,14 +13217,16 @@ class SmartComponentLayoutComponent {
13213
13217
  }
13214
13218
  }
13215
13219
  SmartComponentLayoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, deps: [{ token: SmartformLayoutDefinitionService }], target: i0.ɵɵFactoryTarget.Component });
13216
- SmartComponentLayoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: { smartComponentLayout: "smartComponentLayout", parentLayoutComponent: "parentLayoutComponent" }, 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 [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: ExpandableSectionComponent, selector: "smart-expandable-section", inputs: ["data", "index"] }, { type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: ["smartComponentLayout", "parentLayoutComponent"] }, { type: SmartformComponent, selector: "smartform", inputs: ["smartForm"] }, { type: SmartGridComponent, selector: "smart-grid", inputs: ["smartGrid", "uuid", "dev"] }, { type: SmartTreeComponent, selector: "smart-tree", inputs: ["treeStyle", "treeService"] }, { type: UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
13220
+ 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: ExpandableSectionComponent, selector: "smart-expandable-section", inputs: ["data", "index"] }, { type: SmartComponentLayoutComponent, selector: "smart-component-layout", inputs: ["smartComponentLayout", "parentLayoutComponent", "parentSmartComponent"] }, { type: SmartformComponent, selector: "smartform", inputs: ["smartForm"] }, { type: SmartGridComponent, selector: "smart-grid", inputs: ["smartGrid", "uuid", "dev"] }, { type: SmartTreeComponent, selector: "smart-tree", inputs: ["treeStyle", "treeService"] }, { type: UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
13217
13221
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: SmartComponentLayoutComponent, decorators: [{
13218
13222
  type: Component,
13219
- 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 [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"] }]
13223
+ 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"] }]
13220
13224
  }], ctorParameters: function () { return [{ type: SmartformLayoutDefinitionService }]; }, propDecorators: { smartComponentLayout: [{
13221
13225
  type: Input
13222
13226
  }], parentLayoutComponent: [{
13223
13227
  type: Input
13228
+ }], parentSmartComponent: [{
13229
+ type: Input
13224
13230
  }], smartFormList: [{
13225
13231
  type: ViewChildren,
13226
13232
  args: ['form']
@@ -14593,18 +14599,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
14593
14599
  */
14594
14600
 
14595
14601
  class SmartComponentLayoutUtility {
14596
- static setParent(layout, parent) {
14597
- var _a;
14598
- layout.parentComponent = parent;
14599
- (_a = layout.components) === null || _a === void 0 ? void 0 : _a.forEach((l) => this.setParent(l, parent));
14600
- }
14601
- static compare(layout1, layout2) {
14602
- let l1 = Object.assign({}, layout1);
14603
- this.setParent(l1, null);
14604
- let l2 = Object.assign({}, layout2);
14605
- this.setParent(l2, null);
14606
- return deepEqual(l1, l2);
14607
- }
14608
14602
  static getForms(comp) {
14609
14603
  let result = [];
14610
14604
  if (comp.components) {
@@ -15154,8 +15148,6 @@ class SmartComponentApiClient {
15154
15148
  else {
15155
15149
  this.handleQueryList(this.getSmartComponentLayoutsQL(), (comp) => {
15156
15150
  if (comp.smartComponentLayout) {
15157
- // TODO maybe we should set comp.parent, not comp.smartComponentLayout.parentComponent..
15158
- SmartComponentLayoutUtility.setParent(comp.smartComponentLayout, this);
15159
15151
  this.initActions();
15160
15152
  }
15161
15153
  if (this.uuid && this.uuid !== comp.uuid)