@smartbit4all/ng-client 4.2.130 → 4.2.132

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.
@@ -39,12 +39,15 @@ export class TableLayoutDefinerComponent {
39
39
  subscibeForValueChange() {
40
40
  this.formChildren?.forEach((comp) => {
41
41
  comp.onValueChangeSubject?.pipe(takeUntil(this._destroy$)).subscribe(() => {
42
- let updatedOrderedColumns = this.getUpdatedOrderedColumns();
43
- let findDuplicates = updatedOrderedColumns.filter((item, index) => updatedOrderedColumns.indexOf(item) !== index);
44
- this.disableSave = findDuplicates.length > 0 || this.hasEmptyValue(updatedOrderedColumns);
42
+ this.isWidgetSavable();
45
43
  });
46
44
  });
47
45
  }
46
+ isWidgetSavable() {
47
+ let updatedOrderedColumns = this.getUpdatedOrderedColumns();
48
+ let findDuplicates = updatedOrderedColumns.filter((item, index) => updatedOrderedColumns.indexOf(item) !== index);
49
+ this.disableSave = findDuplicates?.length > 0 || this.hasEmptyValue(updatedOrderedColumns);
50
+ }
48
51
  hasEmptyValue(updatedOrderedColumns) {
49
52
  return updatedOrderedColumns.some((value) => value.length === 0);
50
53
  }
@@ -106,6 +109,7 @@ export class TableLayoutDefinerComponent {
106
109
  }));
107
110
  }
108
111
  this.constructForms();
112
+ this.isWidgetSavable();
109
113
  this.showAddBtn = this.forms.length < this.getMaxColumnCount();
110
114
  }
111
115
  getLabelFromColumnMeta(prop) {
@@ -192,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
192
196
  type: ViewChildren,
193
197
  args: ['forms']
194
198
  }] } });
195
- //# 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 && propertyName != '') {\r\n      this.view?.orderedColumnNames.splice(index, 1);\r\n      this.mapOrderedColumnsToObject();\r\n    } else {\r\n      this.view?.orderedColumnNames.splice(form.widgets[0].key as any, 1);\r\n      delete this.orderedColumnsAsObject[form.widgets[0].key!];\r\n\r\n      Object.entries(this.orderedColumnsAsObject)\r\n        .filter(([key]) => (key as any) > form.widgets[0].key!)\r\n        .map(([key]) => moveItemInArray(this.forms!, key as any, (key as any) - 1));\r\n\r\n      this.orderedColumnsAsObject = Object.fromEntries(\r\n        Object.entries(this.orderedColumnsAsObject).map(([key, value]) => {\r\n          if ((key as any) > form.widgets[0].key!) {\r\n            return [(key as any) - 1, value];\r\n          }\r\n          return [key, value];\r\n        })\r\n      );\r\n    }\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"]}
199
+ //# 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        this.isWidgetSavable();\r\n      });\r\n    });\r\n  }\r\n\r\n  isWidgetSavable() {\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  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 && propertyName != '') {\r\n      this.view?.orderedColumnNames.splice(index, 1);\r\n      this.mapOrderedColumnsToObject();\r\n    } else {\r\n      this.view?.orderedColumnNames.splice(form.widgets[0].key as any, 1);\r\n      delete this.orderedColumnsAsObject[form.widgets[0].key!];\r\n\r\n      Object.entries(this.orderedColumnsAsObject)\r\n        .filter(([key]) => (key as any) > form.widgets[0].key!)\r\n        .map(([key]) => moveItemInArray(this.forms!, key as any, (key as any) - 1));\r\n\r\n      this.orderedColumnsAsObject = Object.fromEntries(\r\n        Object.entries(this.orderedColumnsAsObject).map(([key, value]) => {\r\n          if ((key as any) > form.widgets[0].key!) {\r\n            return [(key as any) - 1, value];\r\n          }\r\n          return [key, value];\r\n        })\r\n      );\r\n    }\r\n    this.constructForms();\r\n    this.isWidgetSavable();\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"]}