@smartbit4all/ng-client 3.3.163 → 3.3.164

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.
@@ -31,6 +31,7 @@ export class TableLayoutDefinerComponent {
31
31
  }
32
32
  ngOnDestroy() {
33
33
  this._destroy$.next();
34
+ this._destroy$.complete();
34
35
  }
35
36
  ngAfterViewInit() {
36
37
  this.subscibeForValueChange();
@@ -178,4 +179,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
178
179
  type: ViewChildren,
179
180
  args: ['forms']
180
181
  }] } });
181
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-layout-definer.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/smart-grid/components/table-layout-definer/table-layout-definer.component.ts","../../../../../../../projects/smart-ng-client/src/lib/smart-grid/components/table-layout-definer/table-layout-definer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { AfterViewInit, Component, Inject, OnDestroy, ViewChildren } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport {\r\n  SmartForm,\r\n  SmartFormWidgetDirection,\r\n  SmartFormWidgetType,\r\n  SmartformComponent,\r\n} from '../../../smart-form/projects';\r\nimport { Subject, take, takeUntil } from 'rxjs';\r\nimport { GridColumnMeta, GridUpdateData, GridView } from '../../api/grid-api';\r\nimport { SmartGridService } from '../../smart-grid.service';\r\nimport { SmartDialogData } from '../../../smart-dialog/projects';\r\n\r\nexport interface TableLayoutDefinerConfig {\r\n  uuid: string;\r\n  identifier: string;\r\n  view: GridView;\r\n  service: SmartGridService;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-table-layout-definer',\r\n  templateUrl: './table-layout-definer.component.html',\r\n  styleUrls: ['./table-layout-definer.component.css'],\r\n})\r\nexport class TableLayoutDefinerComponent implements AfterViewInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n  @ViewChildren('forms') formChildren?: SmartformComponent[];\r\n  forms?: SmartForm[];\r\n  view?: GridView;\r\n  private orderedColumnsAsObject: { [key: string]: string } = {};\r\n  disableSave: boolean = false;\r\n  alwaysShowColumns: string[] = [];\r\n  showAddBtn: boolean = true;\r\n\r\n  constructor(\r\n    @Inject(MAT_DIALOG_DATA) public data: SmartDialogData,\r\n    private dialogRef: MatDialogRef<TableLayoutDefinerComponent>\r\n  ) {\r\n    this.view = JSON.parse(JSON.stringify(data.customComponentInputs.config.view));\r\n    this.mapOrderedColumnsToObject();\r\n    this.constructForms();\r\n    this.getAlwaysShowColumns();\r\n    this.showAddBtn = !(this.forms!.length == this.getMaxColumnCount());\r\n  }\r\n\r\n  private getMaxColumnCount() {\r\n    return this.view!.descriptor!.columns.filter((col) => !col.alwaysHidden).length;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.subscibeForValueChange();\r\n  }\r\n\r\n  private subscibeForValueChange(): void {\r\n    this.formChildren?.forEach((comp: SmartformComponent) => {\r\n      comp.onValueChangeSubject?.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n        let updatedOrderedColumns = this.getUpdatedOrderedColumns();\r\n\r\n        let findDuplicates = updatedOrderedColumns.filter(\r\n          (item, index) => updatedOrderedColumns.indexOf(item) !== index\r\n        );\r\n\r\n        this.disableSave = findDuplicates.length > 0 || this.hasEmptyValue(updatedOrderedColumns);\r\n      });\r\n    });\r\n  }\r\n\r\n  hasEmptyValue(updatedOrderedColumns: string[]) {\r\n    return updatedOrderedColumns.some((value) => value.length === 0);\r\n  }\r\n\r\n  constructForms(): void {\r\n    this.forms = this.view!.orderedColumnNames.map((col: string, index: number) => {\r\n      let form: SmartForm = {\r\n        componentModel: { data: this.orderedColumnsAsObject },\r\n        direction: SmartFormWidgetDirection.COL,\r\n        useOnValueChangeEvent: true,\r\n        widgets: [\r\n          {\r\n            key: index.toString(),\r\n            label: '',\r\n            type: SmartFormWidgetType.SELECT,\r\n            valueList: this.view!.descriptor!.columns.filter((cm) => !cm.alwaysHidden).map(\r\n              (colMeta: GridColumnMeta) => {\r\n                return {\r\n                  key: '',\r\n                  label: colMeta.label,\r\n                  value: colMeta.propertyName,\r\n                  type: SmartFormWidgetType.ITEM,\r\n                };\r\n              }\r\n            ),\r\n          },\r\n        ],\r\n      };\r\n      return form;\r\n    });\r\n\r\n    setTimeout(() => {\r\n      this.subscibeForValueChange();\r\n    }, 1000);\r\n  }\r\n\r\n  addColumn(): void {\r\n    if (this.forms!.length < this.getMaxColumnCount()) {\r\n      this.view?.orderedColumnNames.push('');\r\n      this.orderedColumnsAsObject[this.view!.orderedColumnNames.length - 1] = '';\r\n      this.constructForms();\r\n      this.disableSave = true;\r\n    }\r\n    this.showAddBtn = this.forms!.length < this.getMaxColumnCount();\r\n  }\r\n\r\n  removeColumn(form: SmartForm): void {\r\n    let propertyName = this.orderedColumnsAsObject[form.widgets[0].key!];\r\n    let index = this.view!.orderedColumnNames.indexOf(propertyName);\r\n    if (index > -1) {\r\n      this.view?.orderedColumnNames.splice(index, 1);\r\n    }\r\n    this.mapOrderedColumnsToObject();\r\n    this.constructForms();\r\n    this.showAddBtn = this.forms!.length < this.getMaxColumnCount();\r\n  }\r\n\r\n  private getLabelFromColumnMeta(prop: string): string {\r\n    let label = this.view?.descriptor?.columns.find(\r\n      (value: GridColumnMeta) => value.propertyName === prop\r\n    )?.label;\r\n    return label ?? prop;\r\n  }\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    moveItemInArray(this.forms!, event.previousIndex, event.currentIndex);\r\n  }\r\n\r\n  getFormForCol(col: string): SmartForm {\r\n    let form: SmartForm = {\r\n      componentModel: { data: this.orderedColumnsAsObject },\r\n      direction: SmartFormWidgetDirection.COL,\r\n      widgets: [\r\n        {\r\n          key: col,\r\n          label: this.getLabelFromColumnMeta(col),\r\n          type: SmartFormWidgetType.SELECT,\r\n          valueList: this.view!.descriptor!.columns.map((colMeta: GridColumnMeta) => {\r\n            return {\r\n              key: '',\r\n              label: colMeta.label,\r\n              value: colMeta.propertyName,\r\n              type: SmartFormWidgetType.ITEM,\r\n            };\r\n          }),\r\n        },\r\n      ],\r\n    };\r\n    return form;\r\n  }\r\n\r\n  async submit(): Promise<void> {\r\n    this.view!.orderedColumnNames = this.getUpdatedOrderedColumns();\r\n    let config = this.data.customComponentInputs.config;\r\n\r\n    let updateData: GridUpdateData = {\r\n      orderByList: this.view!.orderByList,\r\n      orderedColumnNames: this.view!.orderedColumnNames,\r\n    };\r\n\r\n    await this.data.customComponentInputs.config.service.update(\r\n      config.uuid,\r\n      config.identifier,\r\n      updateData\r\n    );\r\n    this.dialogRef.close();\r\n  }\r\n\r\n  cancel(): void {\r\n    this.dialogRef.close();\r\n  }\r\n\r\n  private getUpdatedOrderedColumns() {\r\n    let updatedKeyOrder = this.forms!.map((form: SmartForm) => {\r\n      return form.widgets[0].key!;\r\n    });\r\n\r\n    this.formChildren?.forEach((comp: SmartformComponent) => comp.submitForm());\r\n\r\n    let updatedOrderedColumns = updatedKeyOrder!.map((value: string) => {\r\n      return this.orderedColumnsAsObject[value];\r\n    });\r\n    return updatedOrderedColumns;\r\n  }\r\n\r\n  private mapOrderedColumnsToObject(): void {\r\n    this.view?.orderedColumnNames.map((value: string, index: number) => {\r\n      this.orderedColumnsAsObject[index] = value;\r\n    });\r\n  }\r\n\r\n  private getAlwaysShowColumns(): void {\r\n    this.view?.descriptor?.columns.forEach((col: GridColumnMeta) => {\r\n      if (col.alwaysShow) {\r\n        this.alwaysShowColumns.push(col.propertyName);\r\n      }\r\n    });\r\n  }\r\n\r\n  isAlwaysShow(col: SmartForm) {\r\n    let key = col.widgets[0].key!;\r\n\r\n    if (this.alwaysShowColumns.includes(this.orderedColumnsAsObject[key])) {\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n}\r\n","<div class=\"edit-columns-container\">\r\n  <div class=\"example-list\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\r\n    <div class=\"column-meta-row\" *ngFor=\"let col of forms\" cdkDrag cdkDragLockAxis=\"y\">\r\n      <smart-icon color=\"primary\" icon=\"drag_handle\"></smart-icon>\r\n      <smartform class=\"form\" #forms [smartForm]=\"col\"></smartform>\r\n      <button\r\n        *ngIf=\"isAlwaysShow(col) && (view?.orderedColumnNames)!.length > 1\"\r\n        (click)=\"removeColumn(col)\"\r\n        mat-icon-button\r\n        color=\"primary\"\r\n      >\r\n        <mat-icon>delete_outline</mat-icon>\r\n      </button>\r\n    </div>\r\n  </div>\r\n  <div class=\"add-btn\" *ngIf=\"showAddBtn\">\r\n    <button mat-icon-button color=\"primary\" (click)=\"addColumn()\">\r\n      <mat-icon>add</mat-icon>\r\n    </button>\r\n  </div>\r\n  <div class=\"button-toolbar\">\r\n    <button mat-button color=\"primary\" (click)=\"cancel()\"> Mégsem </button>\r\n    <button mat-raised-button color=\"primary\" [disabled]=\"disableSave\" (click)=\"submit()\">\r\n      Mentés\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-layout-definer.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/smart-grid/components/table-layout-definer/table-layout-definer.component.ts","../../../../../../../projects/smart-ng-client/src/lib/smart-grid/components/table-layout-definer/table-layout-definer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { AfterViewInit, Component, Inject, OnDestroy, ViewChildren } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport {\r\n  SmartForm,\r\n  SmartFormWidgetDirection,\r\n  SmartFormWidgetType,\r\n  SmartformComponent,\r\n} from '../../../smart-form/projects';\r\nimport { Subject, take, takeUntil } from 'rxjs';\r\nimport { GridColumnMeta, GridUpdateData, GridView } from '../../api/grid-api';\r\nimport { SmartGridService } from '../../smart-grid.service';\r\nimport { SmartDialogData } from '../../../smart-dialog/projects';\r\n\r\nexport interface TableLayoutDefinerConfig {\r\n  uuid: string;\r\n  identifier: string;\r\n  view: GridView;\r\n  service: SmartGridService;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-table-layout-definer',\r\n  templateUrl: './table-layout-definer.component.html',\r\n  styleUrls: ['./table-layout-definer.component.css'],\r\n})\r\nexport class TableLayoutDefinerComponent implements AfterViewInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n  @ViewChildren('forms') formChildren?: SmartformComponent[];\r\n  forms?: SmartForm[];\r\n  view?: GridView;\r\n  private orderedColumnsAsObject: { [key: string]: string } = {};\r\n  disableSave: boolean = false;\r\n  alwaysShowColumns: string[] = [];\r\n  showAddBtn: boolean = true;\r\n\r\n  constructor(\r\n    @Inject(MAT_DIALOG_DATA) public data: SmartDialogData,\r\n    private dialogRef: MatDialogRef<TableLayoutDefinerComponent>\r\n  ) {\r\n    this.view = JSON.parse(JSON.stringify(data.customComponentInputs.config.view));\r\n    this.mapOrderedColumnsToObject();\r\n    this.constructForms();\r\n    this.getAlwaysShowColumns();\r\n    this.showAddBtn = !(this.forms!.length == this.getMaxColumnCount());\r\n  }\r\n\r\n  private getMaxColumnCount() {\r\n    return this.view!.descriptor!.columns.filter((col) => !col.alwaysHidden).length;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.subscibeForValueChange();\r\n  }\r\n\r\n  private subscibeForValueChange(): void {\r\n    this.formChildren?.forEach((comp: SmartformComponent) => {\r\n      comp.onValueChangeSubject?.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n        let updatedOrderedColumns = this.getUpdatedOrderedColumns();\r\n\r\n        let findDuplicates = updatedOrderedColumns.filter(\r\n          (item, index) => updatedOrderedColumns.indexOf(item) !== index\r\n        );\r\n\r\n        this.disableSave = findDuplicates.length > 0 || this.hasEmptyValue(updatedOrderedColumns);\r\n      });\r\n    });\r\n  }\r\n\r\n  hasEmptyValue(updatedOrderedColumns: string[]) {\r\n    return updatedOrderedColumns.some((value) => value.length === 0);\r\n  }\r\n\r\n  constructForms(): void {\r\n    this.forms = this.view!.orderedColumnNames.map((col: string, index: number) => {\r\n      let form: SmartForm = {\r\n        componentModel: { data: this.orderedColumnsAsObject },\r\n        direction: SmartFormWidgetDirection.COL,\r\n        useOnValueChangeEvent: true,\r\n        widgets: [\r\n          {\r\n            key: index.toString(),\r\n            label: '',\r\n            type: SmartFormWidgetType.SELECT,\r\n            valueList: this.view!.descriptor!.columns.filter((cm) => !cm.alwaysHidden).map(\r\n              (colMeta: GridColumnMeta) => {\r\n                return {\r\n                  key: '',\r\n                  label: colMeta.label,\r\n                  value: colMeta.propertyName,\r\n                  type: SmartFormWidgetType.ITEM,\r\n                };\r\n              }\r\n            ),\r\n          },\r\n        ],\r\n      };\r\n      return form;\r\n    });\r\n\r\n    setTimeout(() => {\r\n      this.subscibeForValueChange();\r\n    }, 1000);\r\n  }\r\n\r\n  addColumn(): void {\r\n    if (this.forms!.length < this.getMaxColumnCount()) {\r\n      this.view?.orderedColumnNames.push('');\r\n      this.orderedColumnsAsObject[this.view!.orderedColumnNames.length - 1] = '';\r\n      this.constructForms();\r\n      this.disableSave = true;\r\n    }\r\n    this.showAddBtn = this.forms!.length < this.getMaxColumnCount();\r\n  }\r\n\r\n  removeColumn(form: SmartForm): void {\r\n    let propertyName = this.orderedColumnsAsObject[form.widgets[0].key!];\r\n    let index = this.view!.orderedColumnNames.indexOf(propertyName);\r\n    if (index > -1) {\r\n      this.view?.orderedColumnNames.splice(index, 1);\r\n    }\r\n    this.mapOrderedColumnsToObject();\r\n    this.constructForms();\r\n    this.showAddBtn = this.forms!.length < this.getMaxColumnCount();\r\n  }\r\n\r\n  private getLabelFromColumnMeta(prop: string): string {\r\n    let label = this.view?.descriptor?.columns.find(\r\n      (value: GridColumnMeta) => value.propertyName === prop\r\n    )?.label;\r\n    return label ?? prop;\r\n  }\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    moveItemInArray(this.forms!, event.previousIndex, event.currentIndex);\r\n  }\r\n\r\n  getFormForCol(col: string): SmartForm {\r\n    let form: SmartForm = {\r\n      componentModel: { data: this.orderedColumnsAsObject },\r\n      direction: SmartFormWidgetDirection.COL,\r\n      widgets: [\r\n        {\r\n          key: col,\r\n          label: this.getLabelFromColumnMeta(col),\r\n          type: SmartFormWidgetType.SELECT,\r\n          valueList: this.view!.descriptor!.columns.map((colMeta: GridColumnMeta) => {\r\n            return {\r\n              key: '',\r\n              label: colMeta.label,\r\n              value: colMeta.propertyName,\r\n              type: SmartFormWidgetType.ITEM,\r\n            };\r\n          }),\r\n        },\r\n      ],\r\n    };\r\n    return form;\r\n  }\r\n\r\n  async submit(): Promise<void> {\r\n    this.view!.orderedColumnNames = this.getUpdatedOrderedColumns();\r\n    let config = this.data.customComponentInputs.config;\r\n\r\n    let updateData: GridUpdateData = {\r\n      orderByList: this.view!.orderByList,\r\n      orderedColumnNames: this.view!.orderedColumnNames,\r\n    };\r\n\r\n    await this.data.customComponentInputs.config.service.update(\r\n      config.uuid,\r\n      config.identifier,\r\n      updateData\r\n    );\r\n    this.dialogRef.close();\r\n  }\r\n\r\n  cancel(): void {\r\n    this.dialogRef.close();\r\n  }\r\n\r\n  private getUpdatedOrderedColumns() {\r\n    let updatedKeyOrder = this.forms!.map((form: SmartForm) => {\r\n      return form.widgets[0].key!;\r\n    });\r\n\r\n    this.formChildren?.forEach((comp: SmartformComponent) => comp.submitForm());\r\n\r\n    let updatedOrderedColumns = updatedKeyOrder!.map((value: string) => {\r\n      return this.orderedColumnsAsObject[value];\r\n    });\r\n    return updatedOrderedColumns;\r\n  }\r\n\r\n  private mapOrderedColumnsToObject(): void {\r\n    this.view?.orderedColumnNames.map((value: string, index: number) => {\r\n      this.orderedColumnsAsObject[index] = value;\r\n    });\r\n  }\r\n\r\n  private getAlwaysShowColumns(): void {\r\n    this.view?.descriptor?.columns.forEach((col: GridColumnMeta) => {\r\n      if (col.alwaysShow) {\r\n        this.alwaysShowColumns.push(col.propertyName);\r\n      }\r\n    });\r\n  }\r\n\r\n  isAlwaysShow(col: SmartForm) {\r\n    let key = col.widgets[0].key!;\r\n\r\n    if (this.alwaysShowColumns.includes(this.orderedColumnsAsObject[key])) {\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n}\r\n","<div class=\"edit-columns-container\">\r\n  <div class=\"example-list\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\r\n    <div class=\"column-meta-row\" *ngFor=\"let col of forms\" cdkDrag cdkDragLockAxis=\"y\">\r\n      <smart-icon color=\"primary\" icon=\"drag_handle\"></smart-icon>\r\n      <smartform class=\"form\" #forms [smartForm]=\"col\"></smartform>\r\n      <button\r\n        *ngIf=\"isAlwaysShow(col) && (view?.orderedColumnNames)!.length > 1\"\r\n        (click)=\"removeColumn(col)\"\r\n        mat-icon-button\r\n        color=\"primary\"\r\n      >\r\n        <mat-icon>delete_outline</mat-icon>\r\n      </button>\r\n    </div>\r\n  </div>\r\n  <div class=\"add-btn\" *ngIf=\"showAddBtn\">\r\n    <button mat-icon-button color=\"primary\" (click)=\"addColumn()\">\r\n      <mat-icon>add</mat-icon>\r\n    </button>\r\n  </div>\r\n  <div class=\"button-toolbar\">\r\n    <button mat-button color=\"primary\" (click)=\"cancel()\"> Mégsem </button>\r\n    <button mat-raised-button color=\"primary\" [disabled]=\"disableSave\" (click)=\"submit()\">\r\n      Mentés\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -38,6 +38,7 @@ export class UiActionToolbarComponent {
38
38
  }
39
39
  ngOnDestroy() {
40
40
  this._destroy$.next();
41
+ this._destroy$.complete();
41
42
  }
42
43
  subscribeToLanguageChange() {
43
44
  this.languageChangedSubscription?.unsubscribe();
@@ -136,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
136
137
  }], id: [{
137
138
  type: Input
138
139
  }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action-toolbar.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-toolbar.component.ts","../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Injector,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport { TooltipPosition } from '@angular/material/tooltip';\r\nimport { Subject, Subscription, takeUntil } from 'rxjs';\r\nimport { IconPosition, UiActionTooltipTooltipPositionEnum } from '../api';\r\nimport { UiActionButtonType } from '../api/model/uiActionButtonType';\r\nimport { UiActionDescriptorService } from './ui-action.descriptor.service';\r\nimport { UiActionModel } from './ui-action.model';\r\nimport { UiActionService } from './ui-action.service';\r\n\r\n@Component({\r\n  selector: 'smart-ui-action-toolbar',\r\n  templateUrl: './ui-action-toolbar.component.html',\r\n  styleUrls: ['./ui-action-toolbar.component.css'],\r\n})\r\nexport class UiActionToolbarComponent implements OnInit, OnChanges, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  pressedButtonActive: boolean = true;\r\n\r\n  @Input() uiActionModels?: UiActionModel[];\r\n  @Input() uiActionDescriptorService?: UiActionDescriptorService;\r\n  @Input() id?: string;\r\n\r\n  uiActionModelsWithDescriptions?: UiActionModel[];\r\n\r\n  private manager!: UiActionDescriptorService;\r\n  private languageChangedSubscription?: Subscription;\r\n\r\n  constructor(private service: UiActionService, private inject: Injector) {\r\n    // Injects the basic UiActionDescriptorService provided by the AppModule\r\n    this.manager = inject.get(UiActionDescriptorService);\r\n\r\n    this.subscribeToLanguageChange();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // Overrides the basic UiActionDescriptorService with a custom one if there is one\r\n    if (this.uiActionDescriptorService) {\r\n      this.manager = this.uiActionDescriptorService;\r\n      this.subscribeToLanguageChange();\r\n    }\r\n\r\n    this.setUp();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['uiActionModels']) {\r\n      let uiActionModels = changes['uiActionModels'].currentValue;\r\n      if (uiActionModels) {\r\n        this.uiActionModels = uiActionModels;\r\n        this.setUp();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n  }\r\n\r\n  private subscribeToLanguageChange(): void {\r\n    this.languageChangedSubscription?.unsubscribe();\r\n\r\n    this.languageChangedSubscription = this.manager.languageChanged\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe(() => {\r\n        this.setUp();\r\n      });\r\n  }\r\n\r\n  async setUp(): Promise<void> {\r\n    if (this.uiActionModels) {\r\n      let uiActionModelsWithDescriptions = [];\r\n      for (const uiActionModel of this.uiActionModels) {\r\n        uiActionModel.descriptor = await this.manager.getActionDescriptor(uiActionModel.uiAction);\r\n        uiActionModelsWithDescriptions.push(uiActionModel);\r\n      }\r\n      this.uiActionModelsWithDescriptions = uiActionModelsWithDescriptions;\r\n    }\r\n  }\r\n\r\n  async onActionClicked(event: any, uiActionModel: UiActionModel): Promise<void> {\r\n    event.stopPropagation();\r\n\r\n    if (uiActionModel.uiAction.disabled) {\r\n      return;\r\n    }\r\n\r\n    if (this.pressedButtonActive) {\r\n      this.pressedButtonActive = false;\r\n\r\n      this.service.uiActionModel = uiActionModel;\r\n      let options = {\r\n        nodeId: uiActionModel.nodeId,\r\n        widgetId: uiActionModel.widgetId,\r\n      };\r\n\r\n      await this.service.execute(uiActionModel.uiAction, options);\r\n\r\n      this.pressedButtonActive = true;\r\n    }\r\n  }\r\n\r\n  onActionDoubleClicked(event: any, uiActionModel: UiActionModel): void {\r\n    event.stopPropagation();\r\n    // We do not handle double clicks\r\n  }\r\n\r\n  getType(uiActionModel: UiActionModel): string {\r\n    if (!uiActionModel.descriptor?.type) {\r\n      console.log(`Action button type unset: ${uiActionModel?.uiAction?.code}`);\r\n    }\r\n    switch (uiActionModel.descriptor?.type) {\r\n      case UiActionButtonType.NORMAL:\r\n        return 'mat-button';\r\n      case UiActionButtonType.FLAT:\r\n        return 'mat-flat-button';\r\n      case UiActionButtonType.RAISED:\r\n        return 'mat-raised-button';\r\n      case UiActionButtonType.STROKED:\r\n        return 'mat-stroked-button';\r\n      case UiActionButtonType.ICON:\r\n        return 'mat-icon-button';\r\n      case UiActionButtonType.MINI_FAB:\r\n        return 'mat-mini-fab';\r\n      case UiActionButtonType.FAB:\r\n        return 'mat-fab';\r\n      default:\r\n        console.log(`Unhandled action button type case: ${uiActionModel.descriptor?.type}`);\r\n        return `mat-button`;\r\n    }\r\n  }\r\n\r\n  iconPosition(): typeof IconPosition {\r\n    return IconPosition;\r\n  }\r\n\r\n  isOnlyIcon(uiActionModel: UiActionModel): boolean {\r\n    return (\r\n      uiActionModel.descriptor?.type === UiActionButtonType.ICON ||\r\n      uiActionModel.descriptor?.type === UiActionButtonType.MINI_FAB ||\r\n      uiActionModel.descriptor?.type === UiActionButtonType.FAB\r\n    );\r\n  }\r\n\r\n  getTooltipPos(pos?: UiActionTooltipTooltipPositionEnum): TooltipPosition {\r\n    if (pos) {\r\n      return pos.toLowerCase() as TooltipPosition;\r\n    } else {\r\n      return 'before';\r\n    }\r\n  }\r\n\r\n  getTooltipDelay(delay?: number): number {\r\n    return delay ? delay : 1000;\r\n  }\r\n\r\n  getTooltipHideDelay(delay?: number): number {\r\n    return delay ? delay : 2000;\r\n  }\r\n}\r\n","<div class=\"uiActionButtonsContainer\">\r\n  <button\r\n    *ngFor=\"let uiActionModel of uiActionModelsWithDescriptions\"\r\n    mat-button\r\n    [smartTooltip]=\"uiActionModel?.descriptor?.tooltip!\"\r\n    [ngClass]=\"getType(uiActionModel)\"\r\n    class=\"{{ uiActionModel.cssClass }}\"\r\n    [color]=\"uiActionModel.descriptor?.color\"\r\n    (click)=\"onActionClicked($event, uiActionModel)\"\r\n    [disabled]=\"!!uiActionModel.uiAction.disabled\"\r\n    (dblclick)=\"onActionDoubleClicked($event, uiActionModel)\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(uiActionModel); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"uiActionModel.descriptor?.icon\"\r\n        [icon]=\"uiActionModel.descriptor!.icon!\"\r\n        [color]=\"uiActionModel.descriptor?.iconColor ?? uiActionModel.descriptor?.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"\r\n          uiActionModel.descriptor?.icon &&\r\n          uiActionModel.descriptor?.iconPosition === iconPosition().PRE\r\n        \"\r\n        [icon]=\"uiActionModel.descriptor!.icon!\"\r\n        [color]=\"uiActionModel.descriptor?.iconColor ?? uiActionModel.descriptor?.color\"\r\n      ></smart-icon>\r\n      {{ uiActionModel.descriptor?.title }}\r\n      <smart-icon\r\n        *ngIf=\"\r\n          uiActionModel.descriptor?.icon &&\r\n          uiActionModel.descriptor?.iconPosition === iconPosition().POST\r\n        \"\r\n        [icon]=\"uiActionModel.descriptor!.icon!\"\r\n        [color]=\"uiActionModel.descriptor?.iconColor ?? uiActionModel.descriptor?.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n</div>\r\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action-toolbar.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-toolbar.component.ts","../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Injector,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  SimpleChanges,\r\n} from '@angular/core';\r\nimport { TooltipPosition } from '@angular/material/tooltip';\r\nimport { Subject, Subscription, takeUntil } from 'rxjs';\r\nimport { IconPosition, UiActionTooltipTooltipPositionEnum } from '../api';\r\nimport { UiActionButtonType } from '../api/model/uiActionButtonType';\r\nimport { UiActionDescriptorService } from './ui-action.descriptor.service';\r\nimport { UiActionModel } from './ui-action.model';\r\nimport { UiActionService } from './ui-action.service';\r\n\r\n@Component({\r\n  selector: 'smart-ui-action-toolbar',\r\n  templateUrl: './ui-action-toolbar.component.html',\r\n  styleUrls: ['./ui-action-toolbar.component.css'],\r\n})\r\nexport class UiActionToolbarComponent implements OnInit, OnChanges, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  pressedButtonActive: boolean = true;\r\n\r\n  @Input() uiActionModels?: UiActionModel[];\r\n  @Input() uiActionDescriptorService?: UiActionDescriptorService;\r\n  @Input() id?: string;\r\n\r\n  uiActionModelsWithDescriptions?: UiActionModel[];\r\n\r\n  private manager!: UiActionDescriptorService;\r\n  private languageChangedSubscription?: Subscription;\r\n\r\n  constructor(private service: UiActionService, private inject: Injector) {\r\n    // Injects the basic UiActionDescriptorService provided by the AppModule\r\n    this.manager = inject.get(UiActionDescriptorService);\r\n\r\n    this.subscribeToLanguageChange();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // Overrides the basic UiActionDescriptorService with a custom one if there is one\r\n    if (this.uiActionDescriptorService) {\r\n      this.manager = this.uiActionDescriptorService;\r\n      this.subscribeToLanguageChange();\r\n    }\r\n\r\n    this.setUp();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['uiActionModels']) {\r\n      let uiActionModels = changes['uiActionModels'].currentValue;\r\n      if (uiActionModels) {\r\n        this.uiActionModels = uiActionModels;\r\n        this.setUp();\r\n      }\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  private subscribeToLanguageChange(): void {\r\n    this.languageChangedSubscription?.unsubscribe();\r\n\r\n    this.languageChangedSubscription = this.manager.languageChanged\r\n      .pipe(takeUntil(this._destroy$))\r\n      .subscribe(() => {\r\n        this.setUp();\r\n      });\r\n  }\r\n\r\n  async setUp(): Promise<void> {\r\n    if (this.uiActionModels) {\r\n      let uiActionModelsWithDescriptions = [];\r\n      for (const uiActionModel of this.uiActionModels) {\r\n        uiActionModel.descriptor = await this.manager.getActionDescriptor(uiActionModel.uiAction);\r\n        uiActionModelsWithDescriptions.push(uiActionModel);\r\n      }\r\n      this.uiActionModelsWithDescriptions = uiActionModelsWithDescriptions;\r\n    }\r\n  }\r\n\r\n  async onActionClicked(event: any, uiActionModel: UiActionModel): Promise<void> {\r\n    event.stopPropagation();\r\n\r\n    if (uiActionModel.uiAction.disabled) {\r\n      return;\r\n    }\r\n\r\n    if (this.pressedButtonActive) {\r\n      this.pressedButtonActive = false;\r\n\r\n      this.service.uiActionModel = uiActionModel;\r\n      let options = {\r\n        nodeId: uiActionModel.nodeId,\r\n        widgetId: uiActionModel.widgetId,\r\n      };\r\n\r\n      await this.service.execute(uiActionModel.uiAction, options);\r\n\r\n      this.pressedButtonActive = true;\r\n    }\r\n  }\r\n\r\n  onActionDoubleClicked(event: any, uiActionModel: UiActionModel): void {\r\n    event.stopPropagation();\r\n    // We do not handle double clicks\r\n  }\r\n\r\n  getType(uiActionModel: UiActionModel): string {\r\n    if (!uiActionModel.descriptor?.type) {\r\n      console.log(`Action button type unset: ${uiActionModel?.uiAction?.code}`);\r\n    }\r\n    switch (uiActionModel.descriptor?.type) {\r\n      case UiActionButtonType.NORMAL:\r\n        return 'mat-button';\r\n      case UiActionButtonType.FLAT:\r\n        return 'mat-flat-button';\r\n      case UiActionButtonType.RAISED:\r\n        return 'mat-raised-button';\r\n      case UiActionButtonType.STROKED:\r\n        return 'mat-stroked-button';\r\n      case UiActionButtonType.ICON:\r\n        return 'mat-icon-button';\r\n      case UiActionButtonType.MINI_FAB:\r\n        return 'mat-mini-fab';\r\n      case UiActionButtonType.FAB:\r\n        return 'mat-fab';\r\n      default:\r\n        console.log(`Unhandled action button type case: ${uiActionModel.descriptor?.type}`);\r\n        return `mat-button`;\r\n    }\r\n  }\r\n\r\n  iconPosition(): typeof IconPosition {\r\n    return IconPosition;\r\n  }\r\n\r\n  isOnlyIcon(uiActionModel: UiActionModel): boolean {\r\n    return (\r\n      uiActionModel.descriptor?.type === UiActionButtonType.ICON ||\r\n      uiActionModel.descriptor?.type === UiActionButtonType.MINI_FAB ||\r\n      uiActionModel.descriptor?.type === UiActionButtonType.FAB\r\n    );\r\n  }\r\n\r\n  getTooltipPos(pos?: UiActionTooltipTooltipPositionEnum): TooltipPosition {\r\n    if (pos) {\r\n      return pos.toLowerCase() as TooltipPosition;\r\n    } else {\r\n      return 'before';\r\n    }\r\n  }\r\n\r\n  getTooltipDelay(delay?: number): number {\r\n    return delay ? delay : 1000;\r\n  }\r\n\r\n  getTooltipHideDelay(delay?: number): number {\r\n    return delay ? delay : 2000;\r\n  }\r\n}\r\n","<div class=\"uiActionButtonsContainer\">\r\n  <button\r\n    *ngFor=\"let uiActionModel of uiActionModelsWithDescriptions\"\r\n    mat-button\r\n    [smartTooltip]=\"uiActionModel?.descriptor?.tooltip!\"\r\n    [ngClass]=\"getType(uiActionModel)\"\r\n    class=\"{{ uiActionModel.cssClass }}\"\r\n    [color]=\"uiActionModel.descriptor?.color\"\r\n    (click)=\"onActionClicked($event, uiActionModel)\"\r\n    [disabled]=\"!!uiActionModel.uiAction.disabled\"\r\n    (dblclick)=\"onActionDoubleClicked($event, uiActionModel)\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(uiActionModel); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"uiActionModel.descriptor?.icon\"\r\n        [icon]=\"uiActionModel.descriptor!.icon!\"\r\n        [color]=\"uiActionModel.descriptor?.iconColor ?? uiActionModel.descriptor?.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"\r\n          uiActionModel.descriptor?.icon &&\r\n          uiActionModel.descriptor?.iconPosition === iconPosition().PRE\r\n        \"\r\n        [icon]=\"uiActionModel.descriptor!.icon!\"\r\n        [color]=\"uiActionModel.descriptor?.iconColor ?? uiActionModel.descriptor?.color\"\r\n      ></smart-icon>\r\n      {{ uiActionModel.descriptor?.title }}\r\n      <smart-icon\r\n        *ngIf=\"\r\n          uiActionModel.descriptor?.icon &&\r\n          uiActionModel.descriptor?.iconPosition === iconPosition().POST\r\n        \"\r\n        [icon]=\"uiActionModel.descriptor!.icon!\"\r\n        [color]=\"uiActionModel.descriptor?.iconColor ?? uiActionModel.descriptor?.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n</div>\r\n"]}
@@ -5138,6 +5138,7 @@ class UiActionToolbarComponent {
5138
5138
  }
5139
5139
  ngOnDestroy() {
5140
5140
  this._destroy$.next();
5141
+ this._destroy$.complete();
5141
5142
  }
5142
5143
  subscribeToLanguageChange() {
5143
5144
  var _a;
@@ -5742,6 +5743,7 @@ class SmartformwidgetComponent {
5742
5743
  }
5743
5744
  ngOnDestroy() {
5744
5745
  this._destroy$.next();
5746
+ this._destroy$.complete();
5745
5747
  }
5746
5748
  onKeydown() {
5747
5749
  this.isEnterPressed = true;
@@ -9791,6 +9793,7 @@ class TableLayoutDefinerComponent {
9791
9793
  }
9792
9794
  ngOnDestroy() {
9793
9795
  this._destroy$.next();
9796
+ this._destroy$.complete();
9794
9797
  }
9795
9798
  ngAfterViewInit() {
9796
9799
  this.subscibeForValueChange();