@smartbit4all/ng-client 3.3.123 → 3.3.125

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.
@@ -16,7 +16,6 @@ export class SmartComponentLayoutComponent {
16
16
  constructor(layoutService) {
17
17
  this.layoutService = layoutService;
18
18
  this._destroy$ = new Subject();
19
- this.toolbarId = 'not_initialized_yet';
20
19
  }
21
20
  ngAfterViewInit() {
22
21
  if (this.smartFormList?.first) {
@@ -81,7 +80,8 @@ export class SmartComponentLayoutComponent {
81
80
  this.constructGrid();
82
81
  }
83
82
  else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.FILTER) {
84
- this.constructFilter();
83
+ console.warn('ComponentWidgetType.FILTER is not supported');
84
+ // this.constructFilter();
85
85
  }
86
86
  else if (this.smartComponentLayout.widget?.type === ComponentWidgetType.TREE) {
87
87
  this.constructTree();
@@ -131,6 +131,9 @@ export class SmartComponentLayoutComponent {
131
131
  }
132
132
  }
133
133
  bindForm() {
134
+ if (this.parent?.useQueryLists) {
135
+ return;
136
+ }
134
137
  if (this.smartForm && this.smartFormComponent) {
135
138
  this.parent?.addForm(
136
139
  // unique identifier for the form
@@ -169,6 +172,9 @@ export class SmartComponentLayoutComponent {
169
172
  }
170
173
  }
171
174
  bindGrid() {
175
+ if (this.parent?.useQueryLists) {
176
+ return;
177
+ }
172
178
  if (this.smartGrid && this.smartGridComponent) {
173
179
  this.smartGrid = this.parent?.addGrid(this.smartGrid, {
174
180
  rowUiActionType: GridUiActionType.POPUP_MENU,
@@ -178,13 +184,22 @@ export class SmartComponentLayoutComponent {
178
184
  setToolbarComponent(comp) {
179
185
  this.toolbar = comp;
180
186
  }
181
- constructFilter() {
182
- this.smartFilter = this.smartComponentLayout.parentComponent.addFilter(`filter_${this.makeid(5)}`, this.smartComponentLayout?.widget?.filterExpressionFieldList, this.smartComponentLayout?.widget?.filterType, this.smartFilterComponent);
183
- }
187
+ // NOT USED, DOESN'T WORK
188
+ // constructFilter(): void {
189
+ // this.smartFilter = (this.smartComponentLayout!.parentComponent as any).addFilter(
190
+ // `filter_${this.makeid(5)}`,
191
+ // this.smartComponentLayout?.widget?.filterExpressionFieldList,
192
+ // this.smartComponentLayout?.widget?.filterType,
193
+ // this.smartFilterComponent
194
+ // );
195
+ // }
184
196
  bindFilter() {
185
197
  // TODO
186
198
  }
187
199
  constructTree() {
200
+ if (this.parent?.useQueryLists) {
201
+ return;
202
+ }
188
203
  this.parent.setUpDefaultTree(this.smartComponentLayout?.widget?.identifier);
189
204
  this.treeService?.initialize();
190
205
  }
@@ -221,4 +236,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
221
236
  type: ViewChildren,
222
237
  args: [SmartComponentLayoutComponent]
223
238
  }] } });
224
- //# 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\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(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        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 *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"]}
239
+ //# 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\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      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.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      [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"]}
@@ -13006,7 +13006,6 @@ class SmartComponentLayoutComponent {
13006
13006
  constructor(layoutService) {
13007
13007
  this.layoutService = layoutService;
13008
13008
  this._destroy$ = new Subject();
13009
- this.toolbarId = 'not_initialized_yet';
13010
13009
  }
13011
13010
  ngAfterViewInit() {
13012
13011
  var _a, _b, _c, _d, _e, _f;
@@ -13073,7 +13072,8 @@ class SmartComponentLayoutComponent {
13073
13072
  this.constructGrid();
13074
13073
  }
13075
13074
  else if (((_g = this.smartComponentLayout.widget) === null || _g === void 0 ? void 0 : _g.type) === ComponentWidgetType.FILTER) {
13076
- this.constructFilter();
13075
+ console.warn('ComponentWidgetType.FILTER is not supported');
13076
+ // this.constructFilter();
13077
13077
  }
13078
13078
  else if (((_h = this.smartComponentLayout.widget) === null || _h === void 0 ? void 0 : _h.type) === ComponentWidgetType.TREE) {
13079
13079
  this.constructTree();
@@ -13126,9 +13126,12 @@ class SmartComponentLayoutComponent {
13126
13126
  }
13127
13127
  }
13128
13128
  bindForm() {
13129
- var _a;
13129
+ var _a, _b;
13130
+ if ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13131
+ return;
13132
+ }
13130
13133
  if (this.smartForm && this.smartFormComponent) {
13131
- (_a = this.parent) === null || _a === void 0 ? void 0 : _a.addForm(
13134
+ (_b = this.parent) === null || _b === void 0 ? void 0 : _b.addForm(
13132
13135
  // unique identifier for the form
13133
13136
  `form_${this.makeid(5)}`, this.smartForm, this.smartFormComponent);
13134
13137
  }
@@ -13166,9 +13169,12 @@ class SmartComponentLayoutComponent {
13166
13169
  }
13167
13170
  }
13168
13171
  bindGrid() {
13169
- var _a;
13172
+ var _a, _b;
13173
+ if ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13174
+ return;
13175
+ }
13170
13176
  if (this.smartGrid && this.smartGridComponent) {
13171
- this.smartGrid = (_a = this.parent) === null || _a === void 0 ? void 0 : _a.addGrid(this.smartGrid, {
13177
+ this.smartGrid = (_b = this.parent) === null || _b === void 0 ? void 0 : _b.addGrid(this.smartGrid, {
13172
13178
  rowUiActionType: GridUiActionType.POPUP_MENU,
13173
13179
  }, false, this.smartGridComponent);
13174
13180
  }
@@ -13176,17 +13182,25 @@ class SmartComponentLayoutComponent {
13176
13182
  setToolbarComponent(comp) {
13177
13183
  this.toolbar = comp;
13178
13184
  }
13179
- constructFilter() {
13180
- var _a, _b, _c, _d;
13181
- this.smartFilter = this.smartComponentLayout.parentComponent.addFilter(`filter_${this.makeid(5)}`, (_b = (_a = this.smartComponentLayout) === null || _a === void 0 ? void 0 : _a.widget) === null || _b === void 0 ? void 0 : _b.filterExpressionFieldList, (_d = (_c = this.smartComponentLayout) === null || _c === void 0 ? void 0 : _c.widget) === null || _d === void 0 ? void 0 : _d.filterType, this.smartFilterComponent);
13182
- }
13185
+ // NOT USED, DOESN'T WORK
13186
+ // constructFilter(): void {
13187
+ // this.smartFilter = (this.smartComponentLayout!.parentComponent as any).addFilter(
13188
+ // `filter_${this.makeid(5)}`,
13189
+ // this.smartComponentLayout?.widget?.filterExpressionFieldList,
13190
+ // this.smartComponentLayout?.widget?.filterType,
13191
+ // this.smartFilterComponent
13192
+ // );
13193
+ // }
13183
13194
  bindFilter() {
13184
13195
  // TODO
13185
13196
  }
13186
13197
  constructTree() {
13187
- var _a, _b, _c;
13188
- this.parent.setUpDefaultTree((_b = (_a = this.smartComponentLayout) === null || _a === void 0 ? void 0 : _a.widget) === null || _b === void 0 ? void 0 : _b.identifier);
13189
- (_c = this.treeService) === null || _c === void 0 ? void 0 : _c.initialize();
13198
+ var _a, _b, _c, _d;
13199
+ if ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.useQueryLists) {
13200
+ return;
13201
+ }
13202
+ this.parent.setUpDefaultTree((_c = (_b = this.smartComponentLayout) === null || _b === void 0 ? void 0 : _b.widget) === null || _c === void 0 ? void 0 : _c.identifier);
13203
+ (_d = this.treeService) === null || _d === void 0 ? void 0 : _d.initialize();
13190
13204
  }
13191
13205
  constructToolbar() {
13192
13206
  var _a, _b;