@smartbit4all/ng-client 3.3.91 → 3.3.93

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.
@@ -66,22 +66,24 @@ export class SmartformComponent {
66
66
  invalidFieldKeys: [],
67
67
  invalidFieldNames: [],
68
68
  };
69
- for (const control of Object.keys(this.form.controls)) {
70
- if (!this.form.controls[control].valid) {
71
- let widget = this.service.getSmartFormWidgetByKey(control);
72
- if (widget &&
73
- widget.type !== SmartFormWidgetType.CONTAINER &&
74
- widget.type !== SmartFormWidgetType.INDICATOR &&
75
- widget.type !== SmartFormWidgetType.LABEL &&
76
- widget.type !== SmartFormWidgetType.FILE_UPLOADER &&
77
- widget.type !== SmartFormWidgetType.IMAGE &&
78
- widget.type !== SmartFormWidgetType.DIVIDER &&
79
- widget.type !== SmartFormWidgetType.BUTTON &&
80
- widget.type !== SmartFormWidgetType.COMPONENT &&
81
- widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER &&
82
- !widget.isDisabled) {
83
- invalidFields.invalidFieldNames.push(widget.label);
84
- invalidFields.invalidFieldKeys.push(widget.key);
69
+ if (this.form) {
70
+ for (const control of Object.keys(this.form.controls)) {
71
+ if (!this.form.controls[control].valid) {
72
+ let widget = this.service.getSmartFormWidgetByKey(control);
73
+ if (widget &&
74
+ widget.type !== SmartFormWidgetType.CONTAINER &&
75
+ widget.type !== SmartFormWidgetType.INDICATOR &&
76
+ widget.type !== SmartFormWidgetType.LABEL &&
77
+ widget.type !== SmartFormWidgetType.FILE_UPLOADER &&
78
+ widget.type !== SmartFormWidgetType.IMAGE &&
79
+ widget.type !== SmartFormWidgetType.DIVIDER &&
80
+ widget.type !== SmartFormWidgetType.BUTTON &&
81
+ widget.type !== SmartFormWidgetType.COMPONENT &&
82
+ widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER &&
83
+ !widget.isDisabled) {
84
+ invalidFields.invalidFieldNames.push(widget.label);
85
+ invalidFields.invalidFieldKeys.push(widget.key);
86
+ }
85
87
  }
86
88
  }
87
89
  }
@@ -90,7 +92,7 @@ export class SmartformComponent {
90
92
  submitForm(validate = true) {
91
93
  if (validate) {
92
94
  this.smartForm.invalidFields = undefined;
93
- if (this.form.invalid) {
95
+ if (this.form && this.form.invalid) {
94
96
  for (const control of Object.keys(this.form.controls)) {
95
97
  this.form.controls[control].markAsTouched();
96
98
  this.form.controls[control].markAsDirty();
@@ -119,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
119
121
  }], ctorParameters: function () { return [{ type: i1.SmartFormService }]; }, propDecorators: { smartForm: [{
120
122
  type: Input
121
123
  }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAA+C,MAAM,eAAe,CAAC;AAE9F,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,wBAAwB,EAAE,mBAAmB,EAAE,MAAM,OAAO,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;;;;;;AASzD,MAAM,OAAO,kBAAkB;IAc7B,YAAoB,OAAyB;QAAzB,YAAO,GAAP,OAAO,CAAkB;QAbrC,cAAS,GAAkB,IAAI,OAAO,EAAE,CAAC;QAKjD,oBAAe,GAA2B,EAAE,CAAC;QAE7C,6BAAwB,GAAsC,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAI/F,cAAS,GAAG,wBAAwB,CAAC;IAEW,CAAC;IACjD,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC;QACnD,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IACD,QAAQ;QACN,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;QACD,IAAI,CAAC,aAAa,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACxD,CAAC;IAED,OAAO;QACL,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;IACpC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;SACpD;QAED,IAAI,IAAI,CAAC,SAAS,CAAC,qBAAqB,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE;YACtE,IAAI,CAAC,oBAAoB,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAC9D;QAED,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACxC,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;QAChC,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE;YAC9D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;SAC/C;QACD,IAAI,CAAC,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,yBAAyB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACtF,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;QAEvC,IAAI,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE;YACnC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBAC1F,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAU,CAAC,OAAO,CAAC,CAAC;YACzD,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;SACvD;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,gBAAgB;QACd,IAAI,aAAa,GAA2B;YAC1C,gBAAgB,EAAE,EAAE;YACpB,iBAAiB,EAAE,EAAE;SACtB,CAAC;QACF,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YACrD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE;gBACtC,IAAI,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;gBAC3D,IACE,MAAM;oBACN,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,SAAS;oBAC7C,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,SAAS;oBAC7C,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,KAAK;oBACzC,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,aAAa;oBACjD,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,KAAK;oBACzC,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,OAAO;oBAC3C,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,MAAM;oBAC1C,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,SAAS;oBAC7C,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,cAAc;oBAClD,CAAC,MAAM,CAAC,UAAU,EAClB;oBACA,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBACnD,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;iBACjD;aACF;SACF;QACD,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,UAAU,CAAC,QAAQ,GAAG,IAAI;QACxB,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,SAAU,CAAC,aAAa,GAAG,SAAS,CAAC;YAE1C,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;gBACrB,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;oBACrD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,CAAC;oBAC5C,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;oBAC1C,+CAA+C;iBAChD;gBAED,IAAI,CAAC,SAAU,CAAC,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACxD,OAAO,IAAI,CAAC,SAAU,CAAC;aACxB;SACF;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7C,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,IAAI,IAAI,CAAC,SAAU,CAAC,aAAa,EAAE;YACzD,IAAI,CAAC,SAAU,CAAC,aAAa,EAAE,CAAC;SACjC;IACH,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;;+GA3HU,kBAAkB;mGAAlB,kBAAkB,wEAFlB,CAAC,gBAAgB,CAAC,+CCb/B,80BAoBA;2FDLa,kBAAkB;kBAN9B,SAAS;+BACE,WAAW,aAGV,CAAC,gBAAgB,CAAC;uGAKpB,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { SmartFormWidgetDirection, SmartFormWidgetType } from './api';\r\nimport { SmartFormService } from './services/smartform.service';\r\nimport { SmartForm, SmartFormInvalidFields, SophisticatedValueChange } from './smartform.model';\r\nimport { SmartSubject } from '../smart-subject/projects';\r\nimport { SmartFormWidget } from './projects';\r\n\r\n@Component({\r\n  selector: 'smartform',\r\n  templateUrl: './smartform.component.html',\r\n  styleUrls: ['./smartform.component.css'],\r\n  providers: [SmartFormService],\r\n})\r\nexport class SmartformComponent implements OnInit, OnDestroy, OnChanges {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartForm?: SmartForm;\r\n  onBlurSubject?: Subject<any>;\r\n  onValueChangeSubject?: Subject<any>;\r\n  originalWidgets: SmartFormWidget<any>[] = [];\r\n\r\n  sophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(this._destroy$);\r\n\r\n  form!: FormGroup;\r\n\r\n  direction = SmartFormWidgetDirection;\r\n\r\n  constructor(private service: SmartFormService) {}\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.smartForm = changes['smartForm'].currentValue;\r\n    this.originalWidgets = [];\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n  }\r\n  ngOnInit(): void {\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n    this.onBlurSubject = new SmartSubject(this._destroy$);\r\n  }\r\n\r\n  refresh(): void {\r\n    this.service.setValuesFromModel();\r\n  }\r\n\r\n  constructForm(): void {\r\n    if (!this.smartForm) {\r\n      throw new Error('Smartform has not been defined!');\r\n    }\r\n\r\n    if (this.smartForm.useOnValueChangeEvent && !this.onValueChangeSubject) {\r\n      this.onValueChangeSubject = new SmartSubject(this._destroy$);\r\n    }\r\n\r\n    this.service.smartForm = this.smartForm;\r\n    this.service.setValuesFromModel();\r\n    this.service.applyConstraints();\r\n    if (!this.originalWidgets || this.originalWidgets.length === 0) {\r\n      this.originalWidgets = this.smartForm.widgets;\r\n    }\r\n    this.smartForm.widgets = this.service.filterWidgetsByVisibility(this.originalWidgets);\r\n    this.form = this.service.toFormGroup();\r\n\r\n    if (this.smartForm.translateService) {\r\n      this.smartForm.translateService.onLangChange.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n        this.service.translateWidgets(this.smartForm!.widgets);\r\n      });\r\n      this.service.translateWidgets(this.smartForm.widgets);\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  getForm(): FormGroup {\r\n    return this.form;\r\n  }\r\n\r\n  getInvalidFields(): SmartFormInvalidFields {\r\n    let invalidFields: SmartFormInvalidFields = {\r\n      invalidFieldKeys: [],\r\n      invalidFieldNames: [],\r\n    };\r\n    for (const control of Object.keys(this.form.controls)) {\r\n      if (!this.form.controls[control].valid) {\r\n        let widget = this.service.getSmartFormWidgetByKey(control);\r\n        if (\r\n          widget &&\r\n          widget.type !== SmartFormWidgetType.CONTAINER &&\r\n          widget.type !== SmartFormWidgetType.INDICATOR &&\r\n          widget.type !== SmartFormWidgetType.LABEL &&\r\n          widget.type !== SmartFormWidgetType.FILE_UPLOADER &&\r\n          widget.type !== SmartFormWidgetType.IMAGE &&\r\n          widget.type !== SmartFormWidgetType.DIVIDER &&\r\n          widget.type !== SmartFormWidgetType.BUTTON &&\r\n          widget.type !== SmartFormWidgetType.COMPONENT &&\r\n          widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER &&\r\n          !widget.isDisabled\r\n        ) {\r\n          invalidFields.invalidFieldNames.push(widget.label);\r\n          invalidFields.invalidFieldKeys.push(widget.key);\r\n        }\r\n      }\r\n    }\r\n    return invalidFields;\r\n  }\r\n\r\n  submitForm(validate = true): SmartForm {\r\n    if (validate) {\r\n      this.smartForm!.invalidFields = undefined;\r\n\r\n      if (this.form.invalid) {\r\n        for (const control of Object.keys(this.form.controls)) {\r\n          this.form.controls[control].markAsTouched();\r\n          this.form.controls[control].markAsDirty();\r\n          // this.form.controls[control].setValue(value);\r\n        }\r\n\r\n        this.smartForm!.invalidFields = this.getInvalidFields();\r\n        return this.smartForm!;\r\n      }\r\n    }\r\n    return this.service.toSmartForm(this.form);\r\n  }\r\n\r\n  keyDownFunction(event: any): void {\r\n    if (event.keyCode === 13 && this.smartForm!.submitOnEnter) {\r\n      this.smartForm!.submitOnEnter();\r\n    }\r\n  }\r\n\r\n  getModel(): any {\r\n    return this.service.getModel(this.form);\r\n  }\r\n}\r\n","<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n  <h2 *ngIf=\"smartForm.name\">\r\n    {{ smartForm.name }}\r\n  </h2>\r\n  <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n    <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n      <smartformwidget\r\n        *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n        [widgetInstance]=\"widget\"\r\n        [form]=\"form\"\r\n        class=\"grid-item\"\r\n        [onBlur]=\"onBlurSubject\"\r\n        [onValueChange]=\"onValueChangeSubject\"\r\n        [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n        class=\"{{ widget.key }}\"\r\n        [labelColor]=\"smartForm.labelTheme\"\r\n      ></smartformwidget>\r\n    </div>\r\n  </div>\r\n</form>\r\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartform.component.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.ts","../../../../../projects/smart-ng-client/src/lib/smart-form/smartform.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { SmartFormWidgetDirection, SmartFormWidgetType } from './api';\r\nimport { SmartFormService } from './services/smartform.service';\r\nimport { SmartForm, SmartFormInvalidFields, SophisticatedValueChange } from './smartform.model';\r\nimport { SmartSubject } from '../smart-subject/projects';\r\nimport { SmartFormWidget } from './projects';\r\n\r\n@Component({\r\n  selector: 'smartform',\r\n  templateUrl: './smartform.component.html',\r\n  styleUrls: ['./smartform.component.css'],\r\n  providers: [SmartFormService],\r\n})\r\nexport class SmartformComponent implements OnInit, OnDestroy, OnChanges {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() smartForm?: SmartForm;\r\n  onBlurSubject?: Subject<any>;\r\n  onValueChangeSubject?: Subject<any>;\r\n  originalWidgets: SmartFormWidget<any>[] = [];\r\n\r\n  sophisticatedValueChange: Subject<SophisticatedValueChange> = new SmartSubject(this._destroy$);\r\n\r\n  form!: FormGroup;\r\n\r\n  direction = SmartFormWidgetDirection;\r\n\r\n  constructor(private service: SmartFormService) {}\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.smartForm = changes['smartForm'].currentValue;\r\n    this.originalWidgets = [];\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n  }\r\n  ngOnInit(): void {\r\n    if (this.smartForm) {\r\n      this.constructForm();\r\n    }\r\n    this.onBlurSubject = new SmartSubject(this._destroy$);\r\n  }\r\n\r\n  refresh(): void {\r\n    this.service.setValuesFromModel();\r\n  }\r\n\r\n  constructForm(): void {\r\n    if (!this.smartForm) {\r\n      throw new Error('Smartform has not been defined!');\r\n    }\r\n\r\n    if (this.smartForm.useOnValueChangeEvent && !this.onValueChangeSubject) {\r\n      this.onValueChangeSubject = new SmartSubject(this._destroy$);\r\n    }\r\n\r\n    this.service.smartForm = this.smartForm;\r\n    this.service.setValuesFromModel();\r\n    this.service.applyConstraints();\r\n    if (!this.originalWidgets || this.originalWidgets.length === 0) {\r\n      this.originalWidgets = this.smartForm.widgets;\r\n    }\r\n    this.smartForm.widgets = this.service.filterWidgetsByVisibility(this.originalWidgets);\r\n    this.form = this.service.toFormGroup();\r\n\r\n    if (this.smartForm.translateService) {\r\n      this.smartForm.translateService.onLangChange.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n        this.service.translateWidgets(this.smartForm!.widgets);\r\n      });\r\n      this.service.translateWidgets(this.smartForm.widgets);\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  getForm(): FormGroup {\r\n    return this.form;\r\n  }\r\n\r\n  getInvalidFields(): SmartFormInvalidFields {\r\n    let invalidFields: SmartFormInvalidFields = {\r\n      invalidFieldKeys: [],\r\n      invalidFieldNames: [],\r\n    };\r\n    if (this.form) {\r\n      for (const control of Object.keys(this.form.controls)) {\r\n        if (!this.form.controls[control].valid) {\r\n          let widget = this.service.getSmartFormWidgetByKey(control);\r\n          if (\r\n            widget &&\r\n            widget.type !== SmartFormWidgetType.CONTAINER &&\r\n            widget.type !== SmartFormWidgetType.INDICATOR &&\r\n            widget.type !== SmartFormWidgetType.LABEL &&\r\n            widget.type !== SmartFormWidgetType.FILE_UPLOADER &&\r\n            widget.type !== SmartFormWidgetType.IMAGE &&\r\n            widget.type !== SmartFormWidgetType.DIVIDER &&\r\n            widget.type !== SmartFormWidgetType.BUTTON &&\r\n            widget.type !== SmartFormWidgetType.COMPONENT &&\r\n            widget.type !== SmartFormWidgetType.YOUTUBE_PLAYER &&\r\n            !widget.isDisabled\r\n          ) {\r\n            invalidFields.invalidFieldNames.push(widget.label);\r\n            invalidFields.invalidFieldKeys.push(widget.key);\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return invalidFields;\r\n  }\r\n\r\n  submitForm(validate = true): SmartForm {\r\n    if (validate) {\r\n      this.smartForm!.invalidFields = undefined;\r\n\r\n      if (this.form && this.form.invalid) {\r\n        for (const control of Object.keys(this.form.controls)) {\r\n          this.form.controls[control].markAsTouched();\r\n          this.form.controls[control].markAsDirty();\r\n          // this.form.controls[control].setValue(value);\r\n        }\r\n\r\n        this.smartForm!.invalidFields = this.getInvalidFields();\r\n        return this.smartForm!;\r\n      }\r\n    }\r\n    return this.service.toSmartForm(this.form);\r\n  }\r\n\r\n  keyDownFunction(event: any): void {\r\n    if (event.keyCode === 13 && this.smartForm!.submitOnEnter) {\r\n      this.smartForm!.submitOnEnter();\r\n    }\r\n  }\r\n\r\n  getModel(): any {\r\n    return this.service.getModel(this.form);\r\n  }\r\n}\r\n","<form *ngIf=\"smartForm\" (keydown)=\"keyDownFunction($event)\" [formGroup]=\"form\" class=\"flex form\">\r\n  <h2 *ngIf=\"smartForm.name\">\r\n    {{ smartForm.name }}\r\n  </h2>\r\n  <div [ngClass]=\"smartForm.direction === direction.ROW ? 'row' : 'col'\">\r\n    <div *ngFor=\"let widget of smartForm.widgets\" class=\"item\">\r\n      <smartformwidget\r\n        *ngIf=\"widget.isVisible === undefined ? true : widget.isVisible\"\r\n        [widgetInstance]=\"widget\"\r\n        [form]=\"form\"\r\n        class=\"grid-item\"\r\n        [onBlur]=\"onBlurSubject\"\r\n        [onValueChange]=\"onValueChangeSubject\"\r\n        [sophisticatedValueChange]=\"sophisticatedValueChange\"\r\n        class=\"{{ widget.key }}\"\r\n        [labelColor]=\"smartForm.labelTheme\"\r\n      ></smartformwidget>\r\n    </div>\r\n  </div>\r\n</form>\r\n"]}
@@ -165,4 +165,4 @@ export class SmartTable {
165
165
  }
166
166
  }
167
167
  }
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smarttable.model.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-table/smarttable.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\r\nimport { ThemePalette } from '@angular/material/core';\r\nimport { UiAction, UiActionDescriptor } from '../view-context/api';\r\n\r\nexport enum SmartTableType {\r\n  INHERITED = 'Inherited',\r\n  CHECK_BOX = 'CheckBox',\r\n  ROW_SELECT = 'RowSelect',\r\n}\r\n\r\nexport interface SmartTableOption {\r\n  label: string;\r\n  icon?: string;\r\n  callback: (id: string) => any;\r\n}\r\n\r\nexport enum SmartTableHeaderPropertyType {\r\n  DATE,\r\n  TIME,\r\n  DATETIME,\r\n  ICON,\r\n}\r\n\r\nexport interface SmartTableHeaderIcons {\r\n  icon: string;\r\n  color: ThemePalette;\r\n  showIconIfValueEqualsWithString?: string;\r\n  showIconIfValueEqualsWithNumber?: number;\r\n  showIconIfValueSmallerThanNumber?: number;\r\n  showIconIfValueBiggerThanNumber?: number;\r\n  showIconIfValueBoolean?: boolean;\r\n  showIconIfValueNull?: any;\r\n}\r\n\r\nexport interface SmartTableHeaderProperties {\r\n  type: SmartTableHeaderPropertyType;\r\n  dateFormat?: string;\r\n  icons?: SmartTableHeaderIcons[];\r\n}\r\n\r\nexport interface SmartTableIcon {\r\n  icon: string;\r\n  color?: ThemePalette;\r\n  cssClass?: string;\r\n}\r\n\r\nexport interface SmartTableHeader {\r\n  propertyName: string;\r\n  label: string;\r\n  isHidden?: boolean;\r\n  properties?: SmartTableHeaderProperties;\r\n  buttons?: SmartTableButton[];\r\n  icon?: SmartTableIcon;\r\n  translator?: ((value: string) => string) | ((value: string) => Promise<string>);\r\n  showCheckboxInHeader?: boolean | undefined;\r\n  order?: SmartTableOrder;\r\n  orderNumber?: number;\r\n  isSortable?: boolean;\r\n}\r\n\r\nexport enum SmartTableOrder {\r\n  ASC = 'ASC',\r\n  DESC = 'DESC',\r\n}\r\n\r\nexport interface SmartTableButton {\r\n  icon?: string;\r\n  label?: string;\r\n  color?: ThemePalette;\r\n  code?: string;\r\n  type: SmartTableButtonType;\r\n  menuItemButtons?: SmartTableButton[];\r\n  menuItemButtonsPropertyName?: string;\r\n  translator?: (uiAction: UiAction) => UiActionDescriptor;\r\n  callback?: (...args: any[]) => any;\r\n  args?: any[];\r\n  showButtonIf?: (row: any) => boolean;\r\n}\r\n\r\nexport enum SmartTableButtonType {\r\n  MENU = 'MENU',\r\n  ICON = 'ICON',\r\n  NORMAL = 'NORMAL',\r\n  RAISED = 'RAISED',\r\n  SEPARATOR = 'SEPARATOR',\r\n}\r\n\r\nexport enum SmartTableOptionButtonDirection {\r\n  HORIZONTAL,\r\n  VERTICAL,\r\n}\r\n\r\nexport declare type SmartTableInterfaceType<T> =\r\n  | SmartTableInterface<T>\r\n  | SmartTableGridInterface<T>;\r\n\r\nexport enum SmartTableInterfaceTypeEnum {\r\n  NORMAL,\r\n  GRID,\r\n}\r\n\r\nexport interface SmartTableInterface<T> {\r\n  type: SmartTableInterfaceTypeEnum.NORMAL;\r\n  title?: string;\r\n  tableHeaders?: string[];\r\n  customSmartTableHeaders?: SmartTableHeader[];\r\n  customTableHeaders?: string[];\r\n  tableRows: T[];\r\n  tableType: SmartTableType;\r\n  options?: SmartTableOption[];\r\n  tableOptionButtonDirection?: SmartTableOptionButtonDirection;\r\n  onRowClick?: (row: T) => void;\r\n  onRowDoubleClick?: (row: T) => void;\r\n  defaultActionCodes?: string[];\r\n  defaultActions?: SmartTableButton[];\r\n  highlightOnRowClick?: boolean;\r\n  highlightClass?: string;\r\n  hover?: boolean;\r\n  expandable?: boolean;\r\n  expandedComponent?: any;\r\n  asyncOnExpand?: boolean;\r\n  sortIconAsc?: string;\r\n  sortIconDesc?: string;\r\n  sortIconNeutral?: string;\r\n  sortable?: boolean;\r\n  maxNumOfSelectableRows?: number;\r\n  selectionProperty?: string;\r\n  isMultiple?: boolean;\r\n  selection?: SelectionModel<any>;\r\n  showCheckboxInHeader?: boolean;\r\n  isRowDisabledPropertyName?: string;\r\n  selectablePropertyName?: string;\r\n  onSelection?: (row: any) => Promise<void>;\r\n  onAllSelection?: (selected: boolean) => Promise<void>;\r\n  rowExpander?: SmartTableRowExpander<T>;\r\n  highlightProperty?: string;\r\n}\r\nexport interface SmartTableGridInterface<T> {\r\n  type: SmartTableInterfaceTypeEnum.GRID;\r\n  customSmartTableHeaders?: SmartTableHeader[];\r\n  tableType: SmartTableType;\r\n  options?: SmartTableOption[];\r\n  tableOptionButtonDirection?: SmartTableOptionButtonDirection;\r\n  onRowClick?: (row: T) => void;\r\n  onRowDoubleClick?: (row: T) => void;\r\n  defaultActionCodes?: string[];\r\n  defaultActions?: SmartTableButton[];\r\n  highlightOnRowClick?: boolean;\r\n  highlightClass?: string;\r\n  hover?: boolean;\r\n  sortIconAsc?: string;\r\n  sortIconDesc?: string;\r\n  sortIconNeutral?: string;\r\n  sortable?: boolean;\r\n  maxNumOfSelectableRows?: number;\r\n  selectionProperty?: string;\r\n  isMultiple?: boolean;\r\n  selection?: SelectionModel<any>;\r\n  showCheckboxInHeader?: boolean;\r\n  isRowDisabledPropertyName?: string;\r\n  selectablePropertyName?: string;\r\n  onSelection?: (row: any) => Promise<void>;\r\n  onAllSelection?: (selected: boolean) => Promise<void>;\r\n  asyncOnExpand?: boolean;\r\n  rowExpander?: SmartTableRowExpander<T>;\r\n  highlightProperty?: string;\r\n}\r\n\r\nexport interface SmartTableRowExpander<T> {\r\n  expand(rowId: number): T;\r\n  expandAsync(rowId: number): Promise<T>;\r\n}\r\n\r\nexport class SmartTable<T> implements SmartTableInterface<T> {\r\n  type: SmartTableInterfaceTypeEnum.NORMAL = SmartTableInterfaceTypeEnum.NORMAL;\r\n  title?: string | undefined;\r\n  tableHeaders: string[];\r\n  customSmartTableHeaders?: SmartTableHeader[];\r\n  customTableHeaders!: string[];\r\n  tableRows: T[];\r\n  tableType: SmartTableType;\r\n  selection?: SelectionModel<any>;\r\n  isMultiple?: boolean;\r\n  options?: SmartTableOption[];\r\n  tableOptionButtonDirection?: SmartTableOptionButtonDirection;\r\n  onRowClick?: (row: T) => void;\r\n  onRowDoubleClick?: (row: T) => void;\r\n  defaultActionCodes?: string[];\r\n  defaultActions?: SmartTableButton[];\r\n  highlightOnRowClick?: boolean;\r\n  highlightClass?: string;\r\n  hover?: boolean;\r\n  expandable?: boolean;\r\n  expandedComponent?: any;\r\n  asyncOnExpand?: boolean;\r\n  sortIconAsc?: string;\r\n  sortIconDesc?: string;\r\n  sortIconNeutral?: string;\r\n  sortable?: boolean;\r\n  maxNumOfSelectableRows?: number;\r\n  selectionProperty?: string;\r\n  isRowDisabledPropertyName?: string;\r\n  selectablePropertyName?: string;\r\n  onSelection?: (row: any) => Promise<void>;\r\n  onAllSelection?: (selected: boolean) => Promise<void>;\r\n  rowExpander?: SmartTableRowExpander<T>;\r\n  highlightProperty?: string;\r\n\r\n  constructor(config: SmartTableInterface<T>) {\r\n    this.expandable = config.expandable;\r\n    this.expandedComponent = config.expandedComponent;\r\n    this.asyncOnExpand = config.asyncOnExpand;\r\n    this.highlightProperty = config.highlightProperty;\r\n\r\n    this.customSmartTableHeaders = config.customSmartTableHeaders;\r\n\r\n    if (this.expandable) {\r\n      this.customSmartTableHeaders?.push({\r\n        label: '',\r\n        propertyName: 'expand',\r\n      });\r\n    }\r\n    this.tableType = config.tableType;\r\n\r\n    if (this.tableType === SmartTableType.CHECK_BOX) {\r\n      this.customSmartTableHeaders = [\r\n        {\r\n          label: '',\r\n          propertyName: 'select',\r\n          showCheckboxInHeader:\r\n            typeof config.showCheckboxInHeader === 'undefined' ? true : config.showCheckboxInHeader,\r\n        },\r\n        ...this.customSmartTableHeaders!,\r\n      ];\r\n    }\r\n    if (\r\n      this.tableType === SmartTableType.CHECK_BOX ||\r\n      this.tableType === SmartTableType.ROW_SELECT\r\n    ) {\r\n      this.isMultiple = config.isMultiple;\r\n\r\n      this.selectionProperty = config.selectionProperty;\r\n      this.selection = config.selection ?? new SelectionModel<T>(this.isMultiple, []);\r\n    }\r\n\r\n    this.tableHeaders = this.getPropertyNamesDeeply(config.tableRows[0]);\r\n\r\n    this.setTableHeaders();\r\n\r\n    this.tableRows = config.tableRows;\r\n    this.title = config.title;\r\n    this.options = config.options;\r\n    this.tableOptionButtonDirection = config.tableOptionButtonDirection;\r\n    this.onRowClick = config.onRowClick;\r\n    this.onRowDoubleClick = config.onRowDoubleClick;\r\n    this.defaultActions = config.defaultActions;\r\n    this.defaultActionCodes = config.defaultActionCodes;\r\n    this.highlightOnRowClick = config.highlightOnRowClick;\r\n    this.highlightClass = config.highlightClass;\r\n    this.hover = config.hover;\r\n    this.sortIconAsc = config.sortIconAsc;\r\n    this.sortIconDesc = config.sortIconDesc;\r\n    this.sortIconNeutral = config.sortIconNeutral;\r\n    this.sortable = config.sortable;\r\n    this.maxNumOfSelectableRows = config.maxNumOfSelectableRows;\r\n    this.isRowDisabledPropertyName = config.isRowDisabledPropertyName;\r\n    this.selectablePropertyName = config.selectablePropertyName;\r\n    this.onSelection = config.onSelection;\r\n    this.onAllSelection = config.onAllSelection;\r\n    this.rowExpander = config.rowExpander;\r\n\r\n    this.pushOptions();\r\n  }\r\n\r\n  getPropertyNamesDeeply(element: any): string[] {\r\n    if (element === undefined) {\r\n      return [];\r\n    }\r\n    let properties = Object.keys(element);\r\n    properties.forEach((property) => {\r\n      if (\r\n        element === undefined ||\r\n        typeof element[property] === 'string' ||\r\n        typeof element[property] === 'boolean' ||\r\n        typeof element[property] === 'number' ||\r\n        element[property] === undefined ||\r\n        element[property] === null ||\r\n        !element[property] ||\r\n        !element\r\n      ) {\r\n        return;\r\n      }\r\n      let innerProperties = this.getPropertyNamesDeeply(element[property]);\r\n      properties.push(...innerProperties);\r\n    });\r\n    return properties;\r\n  }\r\n\r\n  getValueDeeply(model: any, key: string): any {\r\n    let splittedKey = key.split('.');\r\n    let value: any;\r\n\r\n    splittedKey.forEach((k: string) => {\r\n      if (!value) {\r\n        value = model[k];\r\n      } else {\r\n        if (value === undefined) {\r\n          return undefined;\r\n        } else if (value[k] === undefined || value[k] === null || !value) {\r\n          value = '';\r\n          return value;\r\n        } else {\r\n          value = value[k];\r\n        }\r\n      }\r\n    });\r\n    return value;\r\n  }\r\n\r\n  pushOptions(): void {\r\n    if (this.options && this.options.length) {\r\n      this.tableHeaders.push('options');\r\n    }\r\n  }\r\n\r\n  setTableHeaders(): void {\r\n    if (this.customSmartTableHeaders && this.customSmartTableHeaders.length) {\r\n      let originalHeaders = this.tableHeaders;\r\n      this.tableHeaders = [];\r\n      this.customTableHeaders = [];\r\n      this.customSmartTableHeaders.forEach((tableHeader) => {\r\n        let propertyNames = tableHeader.propertyName.split('.');\r\n        if (\r\n          propertyNames.filter((property) => originalHeaders.includes(property)) &&\r\n          !tableHeader.isHidden\r\n        ) {\r\n          this.tableHeaders.push(tableHeader.propertyName);\r\n          this.customTableHeaders.push(tableHeader.label);\r\n        } else if (\r\n          tableHeader.buttons ||\r\n          tableHeader.icon ||\r\n          tableHeader.propertyName === 'expand' ||\r\n          tableHeader.propertyName === 'select'\r\n        ) {\r\n          this.tableHeaders.push(tableHeader.propertyName);\r\n          this.customTableHeaders.push(tableHeader.label);\r\n        }\r\n      });\r\n    } else {\r\n      this.customTableHeaders = this.tableHeaders;\r\n    }\r\n  }\r\n}\r\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smarttable.model.js","sourceRoot":"","sources":["../../../../../projects/smart-ng-client/src/lib/smart-table/smarttable.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\r\nimport { ThemePalette } from '@angular/material/core';\r\nimport { UiAction, UiActionDescriptor } from '../view-context/api';\r\n\r\nexport enum SmartTableType {\r\n  INHERITED = 'Inherited',\r\n  CHECK_BOX = 'CheckBox',\r\n  ROW_SELECT = 'RowSelect',\r\n}\r\n\r\nexport interface SmartTableOption {\r\n  label: string;\r\n  icon?: string;\r\n  callback: (id: string) => any;\r\n}\r\n\r\nexport enum SmartTableHeaderPropertyType {\r\n  DATE,\r\n  TIME,\r\n  DATETIME,\r\n  ICON,\r\n}\r\n\r\nexport interface SmartTableHeaderIcons {\r\n  icon: string;\r\n  color: ThemePalette;\r\n  showIconIfValueEqualsWithString?: string;\r\n  showIconIfValueEqualsWithNumber?: number;\r\n  showIconIfValueSmallerThanNumber?: number;\r\n  showIconIfValueBiggerThanNumber?: number;\r\n  showIconIfValueBoolean?: boolean;\r\n  showIconIfValueNull?: any;\r\n}\r\n\r\nexport interface SmartTableHeaderProperties {\r\n  type: SmartTableHeaderPropertyType;\r\n  dateFormat?: string;\r\n  icons?: SmartTableHeaderIcons[];\r\n  toolTipColumn?: string;\r\n}\r\n\r\nexport interface SmartTableIcon {\r\n  icon: string;\r\n  color?: ThemePalette;\r\n  cssClass?: string;\r\n}\r\n\r\nexport interface SmartTableHeader {\r\n  propertyName: string;\r\n  label: string;\r\n  isHidden?: boolean;\r\n  properties?: SmartTableHeaderProperties;\r\n  buttons?: SmartTableButton[];\r\n  icon?: SmartTableIcon;\r\n  translator?: ((value: string) => string) | ((value: string) => Promise<string>);\r\n  showCheckboxInHeader?: boolean | undefined;\r\n  order?: SmartTableOrder;\r\n  orderNumber?: number;\r\n  isSortable?: boolean;\r\n}\r\n\r\nexport enum SmartTableOrder {\r\n  ASC = 'ASC',\r\n  DESC = 'DESC',\r\n}\r\n\r\nexport interface SmartTableButton {\r\n  icon?: string;\r\n  label?: string;\r\n  color?: ThemePalette;\r\n  code?: string;\r\n  type: SmartTableButtonType;\r\n  menuItemButtons?: SmartTableButton[];\r\n  menuItemButtonsPropertyName?: string;\r\n  translator?: (uiAction: UiAction) => UiActionDescriptor;\r\n  callback?: (...args: any[]) => any;\r\n  args?: any[];\r\n  showButtonIf?: (row: any) => boolean;\r\n}\r\n\r\nexport enum SmartTableButtonType {\r\n  MENU = 'MENU',\r\n  ICON = 'ICON',\r\n  NORMAL = 'NORMAL',\r\n  RAISED = 'RAISED',\r\n  SEPARATOR = 'SEPARATOR',\r\n}\r\n\r\nexport enum SmartTableOptionButtonDirection {\r\n  HORIZONTAL,\r\n  VERTICAL,\r\n}\r\n\r\nexport declare type SmartTableInterfaceType<T> =\r\n  | SmartTableInterface<T>\r\n  | SmartTableGridInterface<T>;\r\n\r\nexport enum SmartTableInterfaceTypeEnum {\r\n  NORMAL,\r\n  GRID,\r\n}\r\n\r\nexport interface SmartTableInterface<T> {\r\n  type: SmartTableInterfaceTypeEnum.NORMAL;\r\n  title?: string;\r\n  tableHeaders?: string[];\r\n  customSmartTableHeaders?: SmartTableHeader[];\r\n  customTableHeaders?: string[];\r\n  tableRows: T[];\r\n  tableType: SmartTableType;\r\n  options?: SmartTableOption[];\r\n  tableOptionButtonDirection?: SmartTableOptionButtonDirection;\r\n  onRowClick?: (row: T) => void;\r\n  onRowDoubleClick?: (row: T) => void;\r\n  defaultActionCodes?: string[];\r\n  defaultActions?: SmartTableButton[];\r\n  highlightOnRowClick?: boolean;\r\n  highlightClass?: string;\r\n  hover?: boolean;\r\n  expandable?: boolean;\r\n  expandedComponent?: any;\r\n  asyncOnExpand?: boolean;\r\n  sortIconAsc?: string;\r\n  sortIconDesc?: string;\r\n  sortIconNeutral?: string;\r\n  sortable?: boolean;\r\n  maxNumOfSelectableRows?: number;\r\n  selectionProperty?: string;\r\n  isMultiple?: boolean;\r\n  selection?: SelectionModel<any>;\r\n  showCheckboxInHeader?: boolean;\r\n  isRowDisabledPropertyName?: string;\r\n  selectablePropertyName?: string;\r\n  onSelection?: (row: any) => Promise<void>;\r\n  onAllSelection?: (selected: boolean) => Promise<void>;\r\n  rowExpander?: SmartTableRowExpander<T>;\r\n  highlightProperty?: string;\r\n}\r\nexport interface SmartTableGridInterface<T> {\r\n  type: SmartTableInterfaceTypeEnum.GRID;\r\n  customSmartTableHeaders?: SmartTableHeader[];\r\n  tableType: SmartTableType;\r\n  options?: SmartTableOption[];\r\n  tableOptionButtonDirection?: SmartTableOptionButtonDirection;\r\n  onRowClick?: (row: T) => void;\r\n  onRowDoubleClick?: (row: T) => void;\r\n  defaultActionCodes?: string[];\r\n  defaultActions?: SmartTableButton[];\r\n  highlightOnRowClick?: boolean;\r\n  highlightClass?: string;\r\n  hover?: boolean;\r\n  sortIconAsc?: string;\r\n  sortIconDesc?: string;\r\n  sortIconNeutral?: string;\r\n  sortable?: boolean;\r\n  maxNumOfSelectableRows?: number;\r\n  selectionProperty?: string;\r\n  isMultiple?: boolean;\r\n  selection?: SelectionModel<any>;\r\n  showCheckboxInHeader?: boolean;\r\n  isRowDisabledPropertyName?: string;\r\n  selectablePropertyName?: string;\r\n  onSelection?: (row: any) => Promise<void>;\r\n  onAllSelection?: (selected: boolean) => Promise<void>;\r\n  asyncOnExpand?: boolean;\r\n  rowExpander?: SmartTableRowExpander<T>;\r\n  highlightProperty?: string;\r\n}\r\n\r\nexport interface SmartTableRowExpander<T> {\r\n  expand(rowId: number): T;\r\n  expandAsync(rowId: number): Promise<T>;\r\n}\r\n\r\nexport class SmartTable<T> implements SmartTableInterface<T> {\r\n  type: SmartTableInterfaceTypeEnum.NORMAL = SmartTableInterfaceTypeEnum.NORMAL;\r\n  title?: string | undefined;\r\n  tableHeaders: string[];\r\n  customSmartTableHeaders?: SmartTableHeader[];\r\n  customTableHeaders!: string[];\r\n  tableRows: T[];\r\n  tableType: SmartTableType;\r\n  selection?: SelectionModel<any>;\r\n  isMultiple?: boolean;\r\n  options?: SmartTableOption[];\r\n  tableOptionButtonDirection?: SmartTableOptionButtonDirection;\r\n  onRowClick?: (row: T) => void;\r\n  onRowDoubleClick?: (row: T) => void;\r\n  defaultActionCodes?: string[];\r\n  defaultActions?: SmartTableButton[];\r\n  highlightOnRowClick?: boolean;\r\n  highlightClass?: string;\r\n  hover?: boolean;\r\n  expandable?: boolean;\r\n  expandedComponent?: any;\r\n  asyncOnExpand?: boolean;\r\n  sortIconAsc?: string;\r\n  sortIconDesc?: string;\r\n  sortIconNeutral?: string;\r\n  sortable?: boolean;\r\n  maxNumOfSelectableRows?: number;\r\n  selectionProperty?: string;\r\n  isRowDisabledPropertyName?: string;\r\n  selectablePropertyName?: string;\r\n  onSelection?: (row: any) => Promise<void>;\r\n  onAllSelection?: (selected: boolean) => Promise<void>;\r\n  rowExpander?: SmartTableRowExpander<T>;\r\n  highlightProperty?: string;\r\n\r\n  constructor(config: SmartTableInterface<T>) {\r\n    this.expandable = config.expandable;\r\n    this.expandedComponent = config.expandedComponent;\r\n    this.asyncOnExpand = config.asyncOnExpand;\r\n    this.highlightProperty = config.highlightProperty;\r\n\r\n    this.customSmartTableHeaders = config.customSmartTableHeaders;\r\n\r\n    if (this.expandable) {\r\n      this.customSmartTableHeaders?.push({\r\n        label: '',\r\n        propertyName: 'expand',\r\n      });\r\n    }\r\n    this.tableType = config.tableType;\r\n\r\n    if (this.tableType === SmartTableType.CHECK_BOX) {\r\n      this.customSmartTableHeaders = [\r\n        {\r\n          label: '',\r\n          propertyName: 'select',\r\n          showCheckboxInHeader:\r\n            typeof config.showCheckboxInHeader === 'undefined' ? true : config.showCheckboxInHeader,\r\n        },\r\n        ...this.customSmartTableHeaders!,\r\n      ];\r\n    }\r\n    if (\r\n      this.tableType === SmartTableType.CHECK_BOX ||\r\n      this.tableType === SmartTableType.ROW_SELECT\r\n    ) {\r\n      this.isMultiple = config.isMultiple;\r\n\r\n      this.selectionProperty = config.selectionProperty;\r\n      this.selection = config.selection ?? new SelectionModel<T>(this.isMultiple, []);\r\n    }\r\n\r\n    this.tableHeaders = this.getPropertyNamesDeeply(config.tableRows[0]);\r\n\r\n    this.setTableHeaders();\r\n\r\n    this.tableRows = config.tableRows;\r\n    this.title = config.title;\r\n    this.options = config.options;\r\n    this.tableOptionButtonDirection = config.tableOptionButtonDirection;\r\n    this.onRowClick = config.onRowClick;\r\n    this.onRowDoubleClick = config.onRowDoubleClick;\r\n    this.defaultActions = config.defaultActions;\r\n    this.defaultActionCodes = config.defaultActionCodes;\r\n    this.highlightOnRowClick = config.highlightOnRowClick;\r\n    this.highlightClass = config.highlightClass;\r\n    this.hover = config.hover;\r\n    this.sortIconAsc = config.sortIconAsc;\r\n    this.sortIconDesc = config.sortIconDesc;\r\n    this.sortIconNeutral = config.sortIconNeutral;\r\n    this.sortable = config.sortable;\r\n    this.maxNumOfSelectableRows = config.maxNumOfSelectableRows;\r\n    this.isRowDisabledPropertyName = config.isRowDisabledPropertyName;\r\n    this.selectablePropertyName = config.selectablePropertyName;\r\n    this.onSelection = config.onSelection;\r\n    this.onAllSelection = config.onAllSelection;\r\n    this.rowExpander = config.rowExpander;\r\n\r\n    this.pushOptions();\r\n  }\r\n\r\n  getPropertyNamesDeeply(element: any): string[] {\r\n    if (element === undefined) {\r\n      return [];\r\n    }\r\n    let properties = Object.keys(element);\r\n    properties.forEach((property) => {\r\n      if (\r\n        element === undefined ||\r\n        typeof element[property] === 'string' ||\r\n        typeof element[property] === 'boolean' ||\r\n        typeof element[property] === 'number' ||\r\n        element[property] === undefined ||\r\n        element[property] === null ||\r\n        !element[property] ||\r\n        !element\r\n      ) {\r\n        return;\r\n      }\r\n      let innerProperties = this.getPropertyNamesDeeply(element[property]);\r\n      properties.push(...innerProperties);\r\n    });\r\n    return properties;\r\n  }\r\n\r\n  getValueDeeply(model: any, key: string): any {\r\n    let splittedKey = key.split('.');\r\n    let value: any;\r\n\r\n    splittedKey.forEach((k: string) => {\r\n      if (!value) {\r\n        value = model[k];\r\n      } else {\r\n        if (value === undefined) {\r\n          return undefined;\r\n        } else if (value[k] === undefined || value[k] === null || !value) {\r\n          value = '';\r\n          return value;\r\n        } else {\r\n          value = value[k];\r\n        }\r\n      }\r\n    });\r\n    return value;\r\n  }\r\n\r\n  pushOptions(): void {\r\n    if (this.options && this.options.length) {\r\n      this.tableHeaders.push('options');\r\n    }\r\n  }\r\n\r\n  setTableHeaders(): void {\r\n    if (this.customSmartTableHeaders && this.customSmartTableHeaders.length) {\r\n      let originalHeaders = this.tableHeaders;\r\n      this.tableHeaders = [];\r\n      this.customTableHeaders = [];\r\n      this.customSmartTableHeaders.forEach((tableHeader) => {\r\n        let propertyNames = tableHeader.propertyName.split('.');\r\n        if (\r\n          propertyNames.filter((property) => originalHeaders.includes(property)) &&\r\n          !tableHeader.isHidden\r\n        ) {\r\n          this.tableHeaders.push(tableHeader.propertyName);\r\n          this.customTableHeaders.push(tableHeader.label);\r\n        } else if (\r\n          tableHeader.buttons ||\r\n          tableHeader.icon ||\r\n          tableHeader.propertyName === 'expand' ||\r\n          tableHeader.propertyName === 'select'\r\n        ) {\r\n          this.tableHeaders.push(tableHeader.propertyName);\r\n          this.customTableHeaders.push(tableHeader.label);\r\n        }\r\n      });\r\n    } else {\r\n      this.customTableHeaders = this.tableHeaders;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -19,7 +19,7 @@ export class MaterialTableComponent extends Table {
19
19
  }
20
20
  }
21
21
  MaterialTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: MaterialTableComponent, deps: [{ token: i1.ComponentFactoryService }], target: i0.ɵɵFactoryTarget.Component });
22
- MaterialTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: MaterialTableComponent, selector: "lib-material-table", usesInheritance: true, ngImport: i0, template: "<table\r\n #myTable\r\n mat-table\r\n [dataSource]=\"smartTable.tableRows\"\r\n class=\"full-width\"\r\n multiTemplateDataRows\r\n>\r\n <!-- Column Descriptor -->\r\n <ng-container\r\n *ngFor=\"let header of smartTable.tableHeaders; let i = index\"\r\n matColumnDef=\"{{ header }}\"\r\n >\r\n <th mat-header-cell *matHeaderCellDef>\r\n <div\r\n *ngIf=\"header === 'icon' || header === 'img' || header === 'options' || header === 'button'\"\r\n ></div>\r\n <div *ngIf=\"header === 'select'\">\r\n <mat-checkbox\r\n *ngIf=\"smartTable.customSmartTableHeaders![i].showCheckboxInHeader\"\r\n (change)=\"$event ? toggleAllRows() : null\"\r\n [checked]=\"smartTable.selection!.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"smartTable.selection!.hasValue() && !isAllSelected()\"\r\n [aria-label]=\"checkboxLabel()\"\r\n >\r\n </mat-checkbox>\r\n <div *ngIf=\"!smartTable.customSmartTableHeaders![i].showCheckboxInHeader\">\r\n {{ smartTable.customTableHeaders[i] }}\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n header !== 'icon' &&\r\n header !== 'img' &&\r\n header !== 'options' &&\r\n header !== 'button' &&\r\n header !== 'select' &&\r\n header !== 'expand' &&\r\n header !== 'actions'\r\n \"\r\n >\r\n <div *ngIf=\"smartTable.sortable; then sortable; else notSortable\"></div>\r\n <ng-template #sortable>\r\n <button\r\n (click)=\"sortButtonClicked($event, smartTable.customSmartTableHeaders![i])\"\r\n *ngIf=\"smartTable.sortable && isSortable(smartTable.customSmartTableHeaders![i])\"\r\n mat-button\r\n class=\"sortableHeaderButton\"\r\n >\r\n {{ smartTable.customTableHeaders[i] }}\r\n <smart-icon\r\n class=\"sortableHeaderButtonIcon\"\r\n *ngIf=\"getSortIcon(header)\"\r\n title=\"sort\"\r\n [icon]=\"getSortIcon(header)!\"\r\n ></smart-icon>\r\n <smart-icon\r\n class=\"sortableHeaderButtonIcon\"\r\n *ngIf=\"hasSortNumIcon(header)\"\r\n title=\"sort\"\r\n [icon]=\"getSortNumIcon(header)\"\r\n ></smart-icon>\r\n </button>\r\n </ng-template>\r\n <ng-template #notSortable>\r\n {{ smartTable.customTableHeaders[i] }}\r\n </ng-template>\r\n </div>\r\n </th>\r\n <td mat-cell *matCellDef=\"let element\" [ngClass]=\"isDisabled(element) ? 'disabledRow' : ''\">\r\n <mat-checkbox\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].propertyName === 'select' &&\r\n !isDisabled(element)\r\n \"\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"\r\n $event\r\n ? setSelection(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n : null\r\n \"\r\n [disabled]=\"isDisabled(element)\"\r\n [checked]=\"\r\n smartTable.selection!.isSelected(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n \"\r\n [aria-label]=\"\r\n checkboxLabel(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n \"\r\n >\r\n </mat-checkbox>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].properties\r\n \"\r\n >\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATETIME\">\r\n {{\r\n getValue(element, header)\r\n | smartDateTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATE\">\r\n {{\r\n getValue(element, header)\r\n | smartDate : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().TIME\">\r\n {{\r\n getValue(element, header)\r\n | smartTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders[i].properties?.type === type().ICON &&\r\n smartTable.customSmartTableHeaders[i].properties?.icons?.length\r\n \"\r\n >\r\n <smart-icon\r\n [icon]=\"getIcon(getValue(element, header), i)!\"\r\n [color]=\"getColor(getValue(element, header), i)\"\r\n >\r\n </smart-icon>\r\n </div>\r\n </div>\r\n <div class=\"smart-table-icon-container\">\r\n <div *ngFor=\"let ir of getImageResourceIcons(element, header)\">\r\n <div [smartTooltip]=\"ir.tooltip!\" [ngStyle]=\"getImageResourceStyle(ir)\"\r\n ><smart-icon [icon]=\"ir.identifier!\" [color]=\"ir.color!\"> </smart-icon\r\n ></div>\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].buttons\"\r\n class=\"smart-table-buttons-col\"\r\n >\r\n <div *ngFor=\"let button of smartTable.customSmartTableHeaders[i].buttons\">\r\n <div *ngIf=\"showButton(button, element)\" [ngSwitch]=\"button.type\">\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.ICON\"\r\n mat-icon-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon title=\"{{ button.label }}\" [icon]=\"button.icon!\"></smart-icon>\r\n </button>\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.NORMAL\"\r\n mat-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n </button>\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.RAISED\"\r\n mat-raised-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n </button>\r\n <div *ngSwitchCase=\"smartTableButtonType.MENU\">\r\n <button\r\n *ngIf=\"showMenuButton(element, button)\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"customButtonClicked($event, button, element, undefined, true)\"\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n <!-- {{ button.label ?? (button.translator ? button.translator(element).title : '') }} -->\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <div *ngIf=\"button.menuItemButtons\">\r\n <button\r\n *ngFor=\"let btn of button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, btn, element, undefined, true)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"btn?.translator(btn)?.icon\"\r\n [icon]=\"btn!.translator!(btn)!.icon!\"\r\n ></smart-icon>\r\n {{ btn?.translator(btn)?.title }}\r\n </button>\r\n </div>\r\n <div *ngIf=\"button.menuItemButtonsPropertyName\">\r\n <div *ngFor=\"let btn of getValue(element, button.menuItemButtonsPropertyName)\">\r\n <button\r\n *ngIf=\"btn.code !== ACTION_SEPERATOR\"\r\n (click)=\"customButtonClicked($event, button, element, btn, true)\"\r\n mat-menu-item\r\n [smartTooltip]=\"\r\n btn?.descriptor?.tooltip\r\n ? btn?.descriptor?.tooltip\r\n : button.translator!(btn).tooltip\r\n \"\r\n >\r\n <div\r\n class=\"smart-table-icon-container\"\r\n [ngClass]=\"\r\n button.translator!(btn).iconPosition === 'POST' ? 'reversed' : ''\r\n \"\r\n ><smart-icon\r\n *ngIf=\"button.translator!(btn).icon\"\r\n [icon]=\"button.translator!(btn).icon!\"\r\n ></smart-icon>\r\n {{ button.translator!(btn).title }}</div\r\n >\r\n </button>\r\n <mat-divider *ngIf=\"btn.code === ACTION_SEPERATOR\"></mat-divider>\r\n </div>\r\n </div>\r\n </mat-menu>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].icon\">\r\n <smart-icon\r\n *ngIf=\"smartTable.customSmartTableHeaders[i].icon?.icon\"\r\n [ngClass]=\"smartTable.customSmartTableHeaders[i].icon?.cssClass ?? ''\"\r\n [color]=\"smartTable.customSmartTableHeaders[i].icon?.color\"\r\n [icon]=\"smartTable.customSmartTableHeaders[i].icon!.icon\"\r\n >\r\n </smart-icon>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].translator !== undefined\r\n \"\r\n >\r\n {{ smartTable.customSmartTableHeaders[i].translator!(getValue(element, header)) }}\r\n </div>\r\n <button\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].propertyName === 'expand'\r\n \"\r\n mat-icon-button\r\n aria-label=\"expand row\"\r\n (click)=\"onToggle(element, $event)\"\r\n >\r\n <smart-icon *ngIf=\"expandedElement !== element\" [icon]=\"'keyboard_arrow_down'\"></smart-icon>\r\n <smart-icon *ngIf=\"expandedElement === element\" [icon]=\"'keyboard_arrow_up'\"></smart-icon>\r\n </button>\r\n <div\r\n *ngIf=\"\r\n !smartTable.customSmartTableHeaders ||\r\n (smartTable.customSmartTableHeaders &&\r\n !smartTable.customSmartTableHeaders[i].properties &&\r\n !smartTable.customSmartTableHeaders[i].icon &&\r\n !smartTable.customSmartTableHeaders[i].buttons &&\r\n !smartTable.customSmartTableHeaders[i].translator &&\r\n !(smartTable.customSmartTableHeaders[i].propertyName === 'select') &&\r\n !(smartTable.customSmartTableHeaders[i].propertyName === 'expand'))\r\n \"\r\n >\r\n <smart-icon *ngIf=\"header === 'icon'\" [icon]=\"getValue(element, header)!\"> </smart-icon>\r\n <img\r\n *ngIf=\"header === 'img'\"\r\n [src]=\"getValue(element, header)\"\r\n alt=\"\"\r\n class=\"smarttableImg\"\r\n />\r\n <div\r\n *ngIf=\"\r\n header !== 'icon' &&\r\n header !== 'img' &&\r\n header !== 'option' &&\r\n header !== 'button' &&\r\n !isImageResource(element, header)\r\n \"\r\n [innerHtml]=\"getValue(element, header)\"\r\n ></div>\r\n </div>\r\n <div *ngIf=\"smartTable.defaultActionCodes && smartTable.defaultActionCodes.length > 0\">\r\n <lib-default-actions-popup\r\n #defaultActionMenu\r\n [buttons]=\"getDefaultActionsForRow(element)!\"\r\n [row]=\"element\"\r\n ></lib-default-actions-popup>\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <!-- Expanded Content Column - The detail row is made up of this one column that spans across all columns -->\r\n <ng-container matColumnDef=\"expandedDetail\">\r\n <td mat-cell *matCellDef=\"let element\" [attr.colspan]=\"smartTable.tableHeaders.length\">\r\n <div\r\n class=\"example-element-detail\"\r\n [@detailExpand]=\"element == expandedElement ? 'expanded' : 'collapsed'\"\r\n >\r\n <ng-template #expandedArea></ng-template>\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"smartTable.tableHeaders; sticky: true\"></tr>\r\n <tr\r\n mat-row\r\n *matRowDef=\"let element; columns: smartTable.tableHeaders\"\r\n class=\"example-element-row\"\r\n [class.example-expanded-row]=\"expandedElement === element\"\r\n [ngClass]=\"[\r\n isHighlighted(element) ? smartTable.highlightClass! : 'unselected',\r\n smartTable.hover ? 'smartTableRowHover' : '',\r\n isSelected(element) ? 'selected' : ''\r\n ]\"\r\n (click)=\"handleOnRowClick(element)\"\r\n (dblclick)=\"handleOnRowDoubleClick(element)\"\r\n ></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: ['expandedDetail']\" class=\"example-detail-row\"></tr>\r\n</table>\r\n", styles: [".full-width{width:100%}.smarttableImg{width:25px}.smartTableRowHover:hover{cursor:pointer}tr.example-detail-row{height:0}tr.example-element-row:not(.example-expanded-row):hover{background:whitesmoke}tr.example-element-row:not(.example-expanded-row):active{background:#efefef}.example-element-row td{border-bottom-width:0}.example-element-detail{overflow:hidden;display:flex;flex-direction:column}.example-element-diagram{min-width:80px;border:2px solid black;padding:8px;font-weight:lighter;margin:8px 0;height:104px}.example-element-symbol{font-weight:700;font-size:40px;line-height:normal}.example-element-description{padding:16px}.example-element-description-attribution{opacity:.5}.disabledRow{color:var(--disabled)}.disabledRow:hover{cursor:default}.smart-table-buttons-col{display:flex;flex-direction:row;justify-content:flex-end}.sortableHeaderButton{margin:0!important;padding:0!important;text-align:left!important}.selected{background-color:var(--primary-light-color)}.smart-table-icon-container{display:flex;flex-direction:row;justify-content:space-between;white-space:initial}.reversed{flex-direction:row-reverse;gap:1rem}:host ::ng-deep .mat-menu-item{line-height:normal!important}\n"], components: [{ type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { type: i6.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i6.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { type: i7.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { type: i8.DefaultActionsPopupComponent, selector: "lib-default-actions-popup", inputs: ["buttons", "row"] }, { type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }], directives: [{ type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatCellDef, selector: "[matCellDef]" }, { type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.SmartTooltipDirective, selector: "[smartTooltip]", inputs: ["smartTooltip"] }, { type: i9.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i6.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }], pipes: { "smartDateTime": i11.SmartDateTimePipe, "smartDate": i11.SmartDatePipe, "smartTime": i11.SmartTimePipe }, animations: [
22
+ MaterialTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: MaterialTableComponent, selector: "lib-material-table", usesInheritance: true, ngImport: i0, template: "<table\r\n #myTable\r\n mat-table\r\n [dataSource]=\"smartTable.tableRows\"\r\n class=\"full-width\"\r\n multiTemplateDataRows\r\n>\r\n <!-- Column Descriptor -->\r\n <ng-container\r\n *ngFor=\"let header of smartTable.tableHeaders; let i = index\"\r\n matColumnDef=\"{{ header }}\"\r\n >\r\n <th mat-header-cell *matHeaderCellDef>\r\n <div\r\n *ngIf=\"header === 'icon' || header === 'img' || header === 'options' || header === 'button'\"\r\n ></div>\r\n <div *ngIf=\"header === 'select'\">\r\n <mat-checkbox\r\n *ngIf=\"smartTable.customSmartTableHeaders![i].showCheckboxInHeader\"\r\n (change)=\"$event ? toggleAllRows() : null\"\r\n [checked]=\"smartTable.selection!.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"smartTable.selection!.hasValue() && !isAllSelected()\"\r\n [aria-label]=\"checkboxLabel()\"\r\n >\r\n </mat-checkbox>\r\n <div *ngIf=\"!smartTable.customSmartTableHeaders![i].showCheckboxInHeader\">\r\n {{ smartTable.customTableHeaders[i] }}\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n header !== 'icon' &&\r\n header !== 'img' &&\r\n header !== 'options' &&\r\n header !== 'button' &&\r\n header !== 'select' &&\r\n header !== 'expand' &&\r\n header !== 'actions'\r\n \"\r\n >\r\n <div *ngIf=\"smartTable.sortable; then sortable; else notSortable\"></div>\r\n <ng-template #sortable>\r\n <button\r\n (click)=\"sortButtonClicked($event, smartTable.customSmartTableHeaders![i])\"\r\n *ngIf=\"smartTable.sortable && isSortable(smartTable.customSmartTableHeaders![i])\"\r\n mat-button\r\n class=\"sortableHeaderButton\"\r\n >\r\n {{ smartTable.customTableHeaders[i] }}\r\n <smart-icon\r\n class=\"sortableHeaderButtonIcon\"\r\n *ngIf=\"getSortIcon(header)\"\r\n title=\"sort\"\r\n [icon]=\"getSortIcon(header)!\"\r\n ></smart-icon>\r\n <smart-icon\r\n class=\"sortableHeaderButtonIcon\"\r\n *ngIf=\"hasSortNumIcon(header)\"\r\n title=\"sort\"\r\n [icon]=\"getSortNumIcon(header)\"\r\n ></smart-icon>\r\n </button>\r\n </ng-template>\r\n <ng-template #notSortable>\r\n {{ smartTable.customTableHeaders[i] }}\r\n </ng-template>\r\n </div>\r\n </th>\r\n <td mat-cell *matCellDef=\"let element\" [ngClass]=\"isDisabled(element) ? 'disabledRow' : ''\">\r\n <mat-checkbox\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].propertyName === 'select' &&\r\n !isDisabled(element)\r\n \"\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"\r\n $event\r\n ? setSelection(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n : null\r\n \"\r\n [disabled]=\"isDisabled(element)\"\r\n [checked]=\"\r\n smartTable.selection!.isSelected(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n \"\r\n [aria-label]=\"\r\n checkboxLabel(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n \"\r\n >\r\n </mat-checkbox>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].properties\r\n \"\r\n >\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATETIME\">\r\n {{\r\n getValue(element, header)\r\n | smartDateTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATE\">\r\n {{\r\n getValue(element, header)\r\n | smartDate : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().TIME\">\r\n {{\r\n getValue(element, header)\r\n | smartTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders[i].properties?.type === type().ICON &&\r\n smartTable.customSmartTableHeaders[i].properties?.icons?.length\r\n \"\r\n >\r\n <smart-icon\r\n [smartTooltip]=\"getToolTip(element, i)\"\r\n [icon]=\"getIcon(getValue(element, header), i)!\"\r\n [color]=\"getColor(getValue(element, header), i)\"\r\n >\r\n </smart-icon>\r\n </div>\r\n </div>\r\n <div class=\"smart-table-icon-container\">\r\n <div *ngFor=\"let ir of getImageResourceIcons(element, header)\">\r\n <div [smartTooltip]=\"ir.tooltip!\" [ngStyle]=\"getImageResourceStyle(ir)\"\r\n ><smart-icon [icon]=\"ir.identifier!\" [color]=\"ir.color!\"> </smart-icon\r\n ></div>\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].buttons\"\r\n class=\"smart-table-buttons-col\"\r\n >\r\n <div *ngFor=\"let button of smartTable.customSmartTableHeaders[i].buttons\">\r\n <div *ngIf=\"showButton(button, element)\" [ngSwitch]=\"button.type\">\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.ICON\"\r\n mat-icon-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon title=\"{{ button.label }}\" [icon]=\"button.icon!\"></smart-icon>\r\n </button>\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.NORMAL\"\r\n mat-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n </button>\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.RAISED\"\r\n mat-raised-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n </button>\r\n <div *ngSwitchCase=\"smartTableButtonType.MENU\">\r\n <button\r\n *ngIf=\"showMenuButton(element, button)\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"customButtonClicked($event, button, element, undefined, true)\"\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n <!-- {{ button.label ?? (button.translator ? button.translator(element).title : '') }} -->\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <div *ngIf=\"button.menuItemButtons\">\r\n <button\r\n *ngFor=\"let btn of button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, btn, element, undefined, true)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"btn?.translator(btn)?.icon\"\r\n [icon]=\"btn!.translator!(btn)!.icon!\"\r\n ></smart-icon>\r\n {{ btn?.translator(btn)?.title }}\r\n </button>\r\n </div>\r\n <div *ngIf=\"button.menuItemButtonsPropertyName\">\r\n <div *ngFor=\"let btn of getValue(element, button.menuItemButtonsPropertyName)\">\r\n <button\r\n *ngIf=\"btn.code !== ACTION_SEPERATOR\"\r\n (click)=\"customButtonClicked($event, button, element, btn, true)\"\r\n mat-menu-item\r\n [smartTooltip]=\"\r\n btn?.descriptor?.tooltip\r\n ? btn?.descriptor?.tooltip\r\n : button.translator!(btn).tooltip\r\n \"\r\n >\r\n <div\r\n class=\"smart-table-icon-container\"\r\n [ngClass]=\"\r\n button.translator!(btn).iconPosition === 'POST' ? 'reversed' : ''\r\n \"\r\n ><smart-icon\r\n *ngIf=\"button.translator!(btn).icon\"\r\n [icon]=\"button.translator!(btn).icon!\"\r\n ></smart-icon>\r\n {{ button.translator!(btn).title }}</div\r\n >\r\n </button>\r\n <mat-divider *ngIf=\"btn.code === ACTION_SEPERATOR\"></mat-divider>\r\n </div>\r\n </div>\r\n </mat-menu>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].icon\">\r\n <smart-icon\r\n *ngIf=\"smartTable.customSmartTableHeaders[i].icon?.icon\"\r\n [ngClass]=\"smartTable.customSmartTableHeaders[i].icon?.cssClass ?? ''\"\r\n [color]=\"smartTable.customSmartTableHeaders[i].icon?.color\"\r\n [icon]=\"smartTable.customSmartTableHeaders[i].icon!.icon\"\r\n >\r\n </smart-icon>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].translator !== undefined\r\n \"\r\n >\r\n {{ smartTable.customSmartTableHeaders[i].translator!(getValue(element, header)) }}\r\n </div>\r\n <button\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].propertyName === 'expand'\r\n \"\r\n mat-icon-button\r\n aria-label=\"expand row\"\r\n (click)=\"onToggle(element, $event)\"\r\n >\r\n <smart-icon *ngIf=\"expandedElement !== element\" [icon]=\"'keyboard_arrow_down'\"></smart-icon>\r\n <smart-icon *ngIf=\"expandedElement === element\" [icon]=\"'keyboard_arrow_up'\"></smart-icon>\r\n </button>\r\n <div\r\n *ngIf=\"\r\n !smartTable.customSmartTableHeaders ||\r\n (smartTable.customSmartTableHeaders &&\r\n !smartTable.customSmartTableHeaders[i].properties &&\r\n !smartTable.customSmartTableHeaders[i].icon &&\r\n !smartTable.customSmartTableHeaders[i].buttons &&\r\n !smartTable.customSmartTableHeaders[i].translator &&\r\n !(smartTable.customSmartTableHeaders[i].propertyName === 'select') &&\r\n !(smartTable.customSmartTableHeaders[i].propertyName === 'expand'))\r\n \"\r\n >\r\n <smart-icon *ngIf=\"header === 'icon'\" [icon]=\"getValue(element, header)!\"> </smart-icon>\r\n <img\r\n *ngIf=\"header === 'img'\"\r\n [src]=\"getValue(element, header)\"\r\n alt=\"\"\r\n class=\"smarttableImg\"\r\n />\r\n <div\r\n *ngIf=\"\r\n header !== 'icon' &&\r\n header !== 'img' &&\r\n header !== 'option' &&\r\n header !== 'button' &&\r\n !isImageResource(element, header)\r\n \"\r\n [innerHtml]=\"getValue(element, header)\"\r\n ></div>\r\n </div>\r\n <div *ngIf=\"smartTable.defaultActionCodes && smartTable.defaultActionCodes.length > 0\">\r\n <lib-default-actions-popup\r\n #defaultActionMenu\r\n [buttons]=\"getDefaultActionsForRow(element)!\"\r\n [row]=\"element\"\r\n ></lib-default-actions-popup>\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <!-- Expanded Content Column - The detail row is made up of this one column that spans across all columns -->\r\n <ng-container matColumnDef=\"expandedDetail\">\r\n <td mat-cell *matCellDef=\"let element\" [attr.colspan]=\"smartTable.tableHeaders.length\">\r\n <div\r\n class=\"example-element-detail\"\r\n [@detailExpand]=\"element == expandedElement ? 'expanded' : 'collapsed'\"\r\n >\r\n <ng-template #expandedArea></ng-template>\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"smartTable.tableHeaders; sticky: true\"></tr>\r\n <tr\r\n mat-row\r\n *matRowDef=\"let element; columns: smartTable.tableHeaders\"\r\n class=\"example-element-row\"\r\n [class.example-expanded-row]=\"expandedElement === element\"\r\n [ngClass]=\"[\r\n isHighlighted(element) ? smartTable.highlightClass! : 'unselected',\r\n smartTable.hover ? 'smartTableRowHover' : '',\r\n isSelected(element) ? 'selected' : ''\r\n ]\"\r\n (click)=\"handleOnRowClick(element)\"\r\n (dblclick)=\"handleOnRowDoubleClick(element)\"\r\n ></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: ['expandedDetail']\" class=\"example-detail-row\"></tr>\r\n</table>\r\n", styles: [".full-width{width:100%}.smarttableImg{width:25px}.smartTableRowHover:hover{cursor:pointer}tr.example-detail-row{height:0}tr.example-element-row:not(.example-expanded-row):hover{background:whitesmoke}tr.example-element-row:not(.example-expanded-row):active{background:#efefef}.example-element-row td{border-bottom-width:0}.example-element-detail{overflow:hidden;display:flex;flex-direction:column}.example-element-diagram{min-width:80px;border:2px solid black;padding:8px;font-weight:lighter;margin:8px 0;height:104px}.example-element-symbol{font-weight:700;font-size:40px;line-height:normal}.example-element-description{padding:16px}.example-element-description-attribution{opacity:.5}.disabledRow{color:var(--disabled)}.disabledRow:hover{cursor:default}.smart-table-buttons-col{display:flex;flex-direction:row;justify-content:flex-end}.sortableHeaderButton{margin:0!important;padding:0!important;text-align:left!important}.selected{background-color:var(--primary-light-color)}.smart-table-icon-container{display:flex;flex-direction:row;justify-content:space-between;white-space:initial}.reversed{flex-direction:row-reverse;gap:1rem}:host ::ng-deep .mat-menu-item{line-height:normal!important}\n"], components: [{ type: i2.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { type: i6.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i6.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { type: i7.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { type: i8.DefaultActionsPopupComponent, selector: "lib-default-actions-popup", inputs: ["buttons", "row"] }, { type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }], directives: [{ type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { type: i2.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatCellDef, selector: "[matCellDef]" }, { type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.SmartTooltipDirective, selector: "[smartTooltip]", inputs: ["smartTooltip"] }, { type: i9.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i6.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }], pipes: { "smartDateTime": i11.SmartDateTimePipe, "smartDate": i11.SmartDatePipe, "smartTime": i11.SmartTimePipe }, animations: [
23
23
  trigger('detailExpand', [
24
24
  state('collapsed', style({ height: '0px', minHeight: '0' })),
25
25
  state('expanded', style({ height: '*' })),
@@ -34,6 +34,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
34
34
  state('expanded', style({ height: '*' })),
35
35
  transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),
36
36
  ]),
37
- ], template: "<table\r\n #myTable\r\n mat-table\r\n [dataSource]=\"smartTable.tableRows\"\r\n class=\"full-width\"\r\n multiTemplateDataRows\r\n>\r\n <!-- Column Descriptor -->\r\n <ng-container\r\n *ngFor=\"let header of smartTable.tableHeaders; let i = index\"\r\n matColumnDef=\"{{ header }}\"\r\n >\r\n <th mat-header-cell *matHeaderCellDef>\r\n <div\r\n *ngIf=\"header === 'icon' || header === 'img' || header === 'options' || header === 'button'\"\r\n ></div>\r\n <div *ngIf=\"header === 'select'\">\r\n <mat-checkbox\r\n *ngIf=\"smartTable.customSmartTableHeaders![i].showCheckboxInHeader\"\r\n (change)=\"$event ? toggleAllRows() : null\"\r\n [checked]=\"smartTable.selection!.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"smartTable.selection!.hasValue() && !isAllSelected()\"\r\n [aria-label]=\"checkboxLabel()\"\r\n >\r\n </mat-checkbox>\r\n <div *ngIf=\"!smartTable.customSmartTableHeaders![i].showCheckboxInHeader\">\r\n {{ smartTable.customTableHeaders[i] }}\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n header !== 'icon' &&\r\n header !== 'img' &&\r\n header !== 'options' &&\r\n header !== 'button' &&\r\n header !== 'select' &&\r\n header !== 'expand' &&\r\n header !== 'actions'\r\n \"\r\n >\r\n <div *ngIf=\"smartTable.sortable; then sortable; else notSortable\"></div>\r\n <ng-template #sortable>\r\n <button\r\n (click)=\"sortButtonClicked($event, smartTable.customSmartTableHeaders![i])\"\r\n *ngIf=\"smartTable.sortable && isSortable(smartTable.customSmartTableHeaders![i])\"\r\n mat-button\r\n class=\"sortableHeaderButton\"\r\n >\r\n {{ smartTable.customTableHeaders[i] }}\r\n <smart-icon\r\n class=\"sortableHeaderButtonIcon\"\r\n *ngIf=\"getSortIcon(header)\"\r\n title=\"sort\"\r\n [icon]=\"getSortIcon(header)!\"\r\n ></smart-icon>\r\n <smart-icon\r\n class=\"sortableHeaderButtonIcon\"\r\n *ngIf=\"hasSortNumIcon(header)\"\r\n title=\"sort\"\r\n [icon]=\"getSortNumIcon(header)\"\r\n ></smart-icon>\r\n </button>\r\n </ng-template>\r\n <ng-template #notSortable>\r\n {{ smartTable.customTableHeaders[i] }}\r\n </ng-template>\r\n </div>\r\n </th>\r\n <td mat-cell *matCellDef=\"let element\" [ngClass]=\"isDisabled(element) ? 'disabledRow' : ''\">\r\n <mat-checkbox\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].propertyName === 'select' &&\r\n !isDisabled(element)\r\n \"\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"\r\n $event\r\n ? setSelection(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n : null\r\n \"\r\n [disabled]=\"isDisabled(element)\"\r\n [checked]=\"\r\n smartTable.selection!.isSelected(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n \"\r\n [aria-label]=\"\r\n checkboxLabel(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n \"\r\n >\r\n </mat-checkbox>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].properties\r\n \"\r\n >\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATETIME\">\r\n {{\r\n getValue(element, header)\r\n | smartDateTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATE\">\r\n {{\r\n getValue(element, header)\r\n | smartDate : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().TIME\">\r\n {{\r\n getValue(element, header)\r\n | smartTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders[i].properties?.type === type().ICON &&\r\n smartTable.customSmartTableHeaders[i].properties?.icons?.length\r\n \"\r\n >\r\n <smart-icon\r\n [icon]=\"getIcon(getValue(element, header), i)!\"\r\n [color]=\"getColor(getValue(element, header), i)\"\r\n >\r\n </smart-icon>\r\n </div>\r\n </div>\r\n <div class=\"smart-table-icon-container\">\r\n <div *ngFor=\"let ir of getImageResourceIcons(element, header)\">\r\n <div [smartTooltip]=\"ir.tooltip!\" [ngStyle]=\"getImageResourceStyle(ir)\"\r\n ><smart-icon [icon]=\"ir.identifier!\" [color]=\"ir.color!\"> </smart-icon\r\n ></div>\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].buttons\"\r\n class=\"smart-table-buttons-col\"\r\n >\r\n <div *ngFor=\"let button of smartTable.customSmartTableHeaders[i].buttons\">\r\n <div *ngIf=\"showButton(button, element)\" [ngSwitch]=\"button.type\">\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.ICON\"\r\n mat-icon-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon title=\"{{ button.label }}\" [icon]=\"button.icon!\"></smart-icon>\r\n </button>\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.NORMAL\"\r\n mat-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n </button>\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.RAISED\"\r\n mat-raised-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n </button>\r\n <div *ngSwitchCase=\"smartTableButtonType.MENU\">\r\n <button\r\n *ngIf=\"showMenuButton(element, button)\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"customButtonClicked($event, button, element, undefined, true)\"\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n <!-- {{ button.label ?? (button.translator ? button.translator(element).title : '') }} -->\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <div *ngIf=\"button.menuItemButtons\">\r\n <button\r\n *ngFor=\"let btn of button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, btn, element, undefined, true)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"btn?.translator(btn)?.icon\"\r\n [icon]=\"btn!.translator!(btn)!.icon!\"\r\n ></smart-icon>\r\n {{ btn?.translator(btn)?.title }}\r\n </button>\r\n </div>\r\n <div *ngIf=\"button.menuItemButtonsPropertyName\">\r\n <div *ngFor=\"let btn of getValue(element, button.menuItemButtonsPropertyName)\">\r\n <button\r\n *ngIf=\"btn.code !== ACTION_SEPERATOR\"\r\n (click)=\"customButtonClicked($event, button, element, btn, true)\"\r\n mat-menu-item\r\n [smartTooltip]=\"\r\n btn?.descriptor?.tooltip\r\n ? btn?.descriptor?.tooltip\r\n : button.translator!(btn).tooltip\r\n \"\r\n >\r\n <div\r\n class=\"smart-table-icon-container\"\r\n [ngClass]=\"\r\n button.translator!(btn).iconPosition === 'POST' ? 'reversed' : ''\r\n \"\r\n ><smart-icon\r\n *ngIf=\"button.translator!(btn).icon\"\r\n [icon]=\"button.translator!(btn).icon!\"\r\n ></smart-icon>\r\n {{ button.translator!(btn).title }}</div\r\n >\r\n </button>\r\n <mat-divider *ngIf=\"btn.code === ACTION_SEPERATOR\"></mat-divider>\r\n </div>\r\n </div>\r\n </mat-menu>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].icon\">\r\n <smart-icon\r\n *ngIf=\"smartTable.customSmartTableHeaders[i].icon?.icon\"\r\n [ngClass]=\"smartTable.customSmartTableHeaders[i].icon?.cssClass ?? ''\"\r\n [color]=\"smartTable.customSmartTableHeaders[i].icon?.color\"\r\n [icon]=\"smartTable.customSmartTableHeaders[i].icon!.icon\"\r\n >\r\n </smart-icon>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].translator !== undefined\r\n \"\r\n >\r\n {{ smartTable.customSmartTableHeaders[i].translator!(getValue(element, header)) }}\r\n </div>\r\n <button\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].propertyName === 'expand'\r\n \"\r\n mat-icon-button\r\n aria-label=\"expand row\"\r\n (click)=\"onToggle(element, $event)\"\r\n >\r\n <smart-icon *ngIf=\"expandedElement !== element\" [icon]=\"'keyboard_arrow_down'\"></smart-icon>\r\n <smart-icon *ngIf=\"expandedElement === element\" [icon]=\"'keyboard_arrow_up'\"></smart-icon>\r\n </button>\r\n <div\r\n *ngIf=\"\r\n !smartTable.customSmartTableHeaders ||\r\n (smartTable.customSmartTableHeaders &&\r\n !smartTable.customSmartTableHeaders[i].properties &&\r\n !smartTable.customSmartTableHeaders[i].icon &&\r\n !smartTable.customSmartTableHeaders[i].buttons &&\r\n !smartTable.customSmartTableHeaders[i].translator &&\r\n !(smartTable.customSmartTableHeaders[i].propertyName === 'select') &&\r\n !(smartTable.customSmartTableHeaders[i].propertyName === 'expand'))\r\n \"\r\n >\r\n <smart-icon *ngIf=\"header === 'icon'\" [icon]=\"getValue(element, header)!\"> </smart-icon>\r\n <img\r\n *ngIf=\"header === 'img'\"\r\n [src]=\"getValue(element, header)\"\r\n alt=\"\"\r\n class=\"smarttableImg\"\r\n />\r\n <div\r\n *ngIf=\"\r\n header !== 'icon' &&\r\n header !== 'img' &&\r\n header !== 'option' &&\r\n header !== 'button' &&\r\n !isImageResource(element, header)\r\n \"\r\n [innerHtml]=\"getValue(element, header)\"\r\n ></div>\r\n </div>\r\n <div *ngIf=\"smartTable.defaultActionCodes && smartTable.defaultActionCodes.length > 0\">\r\n <lib-default-actions-popup\r\n #defaultActionMenu\r\n [buttons]=\"getDefaultActionsForRow(element)!\"\r\n [row]=\"element\"\r\n ></lib-default-actions-popup>\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <!-- Expanded Content Column - The detail row is made up of this one column that spans across all columns -->\r\n <ng-container matColumnDef=\"expandedDetail\">\r\n <td mat-cell *matCellDef=\"let element\" [attr.colspan]=\"smartTable.tableHeaders.length\">\r\n <div\r\n class=\"example-element-detail\"\r\n [@detailExpand]=\"element == expandedElement ? 'expanded' : 'collapsed'\"\r\n >\r\n <ng-template #expandedArea></ng-template>\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"smartTable.tableHeaders; sticky: true\"></tr>\r\n <tr\r\n mat-row\r\n *matRowDef=\"let element; columns: smartTable.tableHeaders\"\r\n class=\"example-element-row\"\r\n [class.example-expanded-row]=\"expandedElement === element\"\r\n [ngClass]=\"[\r\n isHighlighted(element) ? smartTable.highlightClass! : 'unselected',\r\n smartTable.hover ? 'smartTableRowHover' : '',\r\n isSelected(element) ? 'selected' : ''\r\n ]\"\r\n (click)=\"handleOnRowClick(element)\"\r\n (dblclick)=\"handleOnRowDoubleClick(element)\"\r\n ></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: ['expandedDetail']\" class=\"example-detail-row\"></tr>\r\n</table>\r\n", styles: [".full-width{width:100%}.smarttableImg{width:25px}.smartTableRowHover:hover{cursor:pointer}tr.example-detail-row{height:0}tr.example-element-row:not(.example-expanded-row):hover{background:whitesmoke}tr.example-element-row:not(.example-expanded-row):active{background:#efefef}.example-element-row td{border-bottom-width:0}.example-element-detail{overflow:hidden;display:flex;flex-direction:column}.example-element-diagram{min-width:80px;border:2px solid black;padding:8px;font-weight:lighter;margin:8px 0;height:104px}.example-element-symbol{font-weight:700;font-size:40px;line-height:normal}.example-element-description{padding:16px}.example-element-description-attribution{opacity:.5}.disabledRow{color:var(--disabled)}.disabledRow:hover{cursor:default}.smart-table-buttons-col{display:flex;flex-direction:row;justify-content:flex-end}.sortableHeaderButton{margin:0!important;padding:0!important;text-align:left!important}.selected{background-color:var(--primary-light-color)}.smart-table-icon-container{display:flex;flex-direction:row;justify-content:space-between;white-space:initial}.reversed{flex-direction:row-reverse;gap:1rem}:host ::ng-deep .mat-menu-item{line-height:normal!important}\n"] }]
37
+ ], template: "<table\r\n #myTable\r\n mat-table\r\n [dataSource]=\"smartTable.tableRows\"\r\n class=\"full-width\"\r\n multiTemplateDataRows\r\n>\r\n <!-- Column Descriptor -->\r\n <ng-container\r\n *ngFor=\"let header of smartTable.tableHeaders; let i = index\"\r\n matColumnDef=\"{{ header }}\"\r\n >\r\n <th mat-header-cell *matHeaderCellDef>\r\n <div\r\n *ngIf=\"header === 'icon' || header === 'img' || header === 'options' || header === 'button'\"\r\n ></div>\r\n <div *ngIf=\"header === 'select'\">\r\n <mat-checkbox\r\n *ngIf=\"smartTable.customSmartTableHeaders![i].showCheckboxInHeader\"\r\n (change)=\"$event ? toggleAllRows() : null\"\r\n [checked]=\"smartTable.selection!.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"smartTable.selection!.hasValue() && !isAllSelected()\"\r\n [aria-label]=\"checkboxLabel()\"\r\n >\r\n </mat-checkbox>\r\n <div *ngIf=\"!smartTable.customSmartTableHeaders![i].showCheckboxInHeader\">\r\n {{ smartTable.customTableHeaders[i] }}\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n header !== 'icon' &&\r\n header !== 'img' &&\r\n header !== 'options' &&\r\n header !== 'button' &&\r\n header !== 'select' &&\r\n header !== 'expand' &&\r\n header !== 'actions'\r\n \"\r\n >\r\n <div *ngIf=\"smartTable.sortable; then sortable; else notSortable\"></div>\r\n <ng-template #sortable>\r\n <button\r\n (click)=\"sortButtonClicked($event, smartTable.customSmartTableHeaders![i])\"\r\n *ngIf=\"smartTable.sortable && isSortable(smartTable.customSmartTableHeaders![i])\"\r\n mat-button\r\n class=\"sortableHeaderButton\"\r\n >\r\n {{ smartTable.customTableHeaders[i] }}\r\n <smart-icon\r\n class=\"sortableHeaderButtonIcon\"\r\n *ngIf=\"getSortIcon(header)\"\r\n title=\"sort\"\r\n [icon]=\"getSortIcon(header)!\"\r\n ></smart-icon>\r\n <smart-icon\r\n class=\"sortableHeaderButtonIcon\"\r\n *ngIf=\"hasSortNumIcon(header)\"\r\n title=\"sort\"\r\n [icon]=\"getSortNumIcon(header)\"\r\n ></smart-icon>\r\n </button>\r\n </ng-template>\r\n <ng-template #notSortable>\r\n {{ smartTable.customTableHeaders[i] }}\r\n </ng-template>\r\n </div>\r\n </th>\r\n <td mat-cell *matCellDef=\"let element\" [ngClass]=\"isDisabled(element) ? 'disabledRow' : ''\">\r\n <mat-checkbox\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].propertyName === 'select' &&\r\n !isDisabled(element)\r\n \"\r\n (click)=\"$event.stopPropagation()\"\r\n (change)=\"\r\n $event\r\n ? setSelection(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n : null\r\n \"\r\n [disabled]=\"isDisabled(element)\"\r\n [checked]=\"\r\n smartTable.selection!.isSelected(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n \"\r\n [aria-label]=\"\r\n checkboxLabel(\r\n smartTable.selectionProperty\r\n ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n : element\r\n )\r\n \"\r\n >\r\n </mat-checkbox>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].properties\r\n \"\r\n >\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATETIME\">\r\n {{\r\n getValue(element, header)\r\n | smartDateTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATE\">\r\n {{\r\n getValue(element, header)\r\n | smartDate : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().TIME\">\r\n {{\r\n getValue(element, header)\r\n | smartTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n }}\r\n </div>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders[i].properties?.type === type().ICON &&\r\n smartTable.customSmartTableHeaders[i].properties?.icons?.length\r\n \"\r\n >\r\n <smart-icon\r\n [smartTooltip]=\"getToolTip(element, i)\"\r\n [icon]=\"getIcon(getValue(element, header), i)!\"\r\n [color]=\"getColor(getValue(element, header), i)\"\r\n >\r\n </smart-icon>\r\n </div>\r\n </div>\r\n <div class=\"smart-table-icon-container\">\r\n <div *ngFor=\"let ir of getImageResourceIcons(element, header)\">\r\n <div [smartTooltip]=\"ir.tooltip!\" [ngStyle]=\"getImageResourceStyle(ir)\"\r\n ><smart-icon [icon]=\"ir.identifier!\" [color]=\"ir.color!\"> </smart-icon\r\n ></div>\r\n </div>\r\n </div>\r\n <div\r\n *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].buttons\"\r\n class=\"smart-table-buttons-col\"\r\n >\r\n <div *ngFor=\"let button of smartTable.customSmartTableHeaders[i].buttons\">\r\n <div *ngIf=\"showButton(button, element)\" [ngSwitch]=\"button.type\">\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.ICON\"\r\n mat-icon-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon title=\"{{ button.label }}\" [icon]=\"button.icon!\"></smart-icon>\r\n </button>\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.NORMAL\"\r\n mat-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n </button>\r\n <button\r\n (click)=\"customButtonClicked($event, button, element)\"\r\n *ngSwitchCase=\"smartTableButtonType.RAISED\"\r\n mat-raised-button\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n </button>\r\n <div *ngSwitchCase=\"smartTableButtonType.MENU\">\r\n <button\r\n *ngIf=\"showMenuButton(element, button)\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n (click)=\"customButtonClicked($event, button, element, undefined, true)\"\r\n color=\"{{ button.color }}\"\r\n >\r\n <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n <!-- {{ button.label ?? (button.translator ? button.translator(element).title : '') }} -->\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <div *ngIf=\"button.menuItemButtons\">\r\n <button\r\n *ngFor=\"let btn of button.menuItemButtons\"\r\n (click)=\"customButtonClicked($event, btn, element, undefined, true)\"\r\n mat-menu-item\r\n >\r\n <smart-icon\r\n *ngIf=\"btn?.translator(btn)?.icon\"\r\n [icon]=\"btn!.translator!(btn)!.icon!\"\r\n ></smart-icon>\r\n {{ btn?.translator(btn)?.title }}\r\n </button>\r\n </div>\r\n <div *ngIf=\"button.menuItemButtonsPropertyName\">\r\n <div *ngFor=\"let btn of getValue(element, button.menuItemButtonsPropertyName)\">\r\n <button\r\n *ngIf=\"btn.code !== ACTION_SEPERATOR\"\r\n (click)=\"customButtonClicked($event, button, element, btn, true)\"\r\n mat-menu-item\r\n [smartTooltip]=\"\r\n btn?.descriptor?.tooltip\r\n ? btn?.descriptor?.tooltip\r\n : button.translator!(btn).tooltip\r\n \"\r\n >\r\n <div\r\n class=\"smart-table-icon-container\"\r\n [ngClass]=\"\r\n button.translator!(btn).iconPosition === 'POST' ? 'reversed' : ''\r\n \"\r\n ><smart-icon\r\n *ngIf=\"button.translator!(btn).icon\"\r\n [icon]=\"button.translator!(btn).icon!\"\r\n ></smart-icon>\r\n {{ button.translator!(btn).title }}</div\r\n >\r\n </button>\r\n <mat-divider *ngIf=\"btn.code === ACTION_SEPERATOR\"></mat-divider>\r\n </div>\r\n </div>\r\n </mat-menu>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].icon\">\r\n <smart-icon\r\n *ngIf=\"smartTable.customSmartTableHeaders[i].icon?.icon\"\r\n [ngClass]=\"smartTable.customSmartTableHeaders[i].icon?.cssClass ?? ''\"\r\n [color]=\"smartTable.customSmartTableHeaders[i].icon?.color\"\r\n [icon]=\"smartTable.customSmartTableHeaders[i].icon!.icon\"\r\n >\r\n </smart-icon>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].translator !== undefined\r\n \"\r\n >\r\n {{ smartTable.customSmartTableHeaders[i].translator!(getValue(element, header)) }}\r\n </div>\r\n <button\r\n *ngIf=\"\r\n smartTable.customSmartTableHeaders &&\r\n smartTable.customSmartTableHeaders[i].propertyName === 'expand'\r\n \"\r\n mat-icon-button\r\n aria-label=\"expand row\"\r\n (click)=\"onToggle(element, $event)\"\r\n >\r\n <smart-icon *ngIf=\"expandedElement !== element\" [icon]=\"'keyboard_arrow_down'\"></smart-icon>\r\n <smart-icon *ngIf=\"expandedElement === element\" [icon]=\"'keyboard_arrow_up'\"></smart-icon>\r\n </button>\r\n <div\r\n *ngIf=\"\r\n !smartTable.customSmartTableHeaders ||\r\n (smartTable.customSmartTableHeaders &&\r\n !smartTable.customSmartTableHeaders[i].properties &&\r\n !smartTable.customSmartTableHeaders[i].icon &&\r\n !smartTable.customSmartTableHeaders[i].buttons &&\r\n !smartTable.customSmartTableHeaders[i].translator &&\r\n !(smartTable.customSmartTableHeaders[i].propertyName === 'select') &&\r\n !(smartTable.customSmartTableHeaders[i].propertyName === 'expand'))\r\n \"\r\n >\r\n <smart-icon *ngIf=\"header === 'icon'\" [icon]=\"getValue(element, header)!\"> </smart-icon>\r\n <img\r\n *ngIf=\"header === 'img'\"\r\n [src]=\"getValue(element, header)\"\r\n alt=\"\"\r\n class=\"smarttableImg\"\r\n />\r\n <div\r\n *ngIf=\"\r\n header !== 'icon' &&\r\n header !== 'img' &&\r\n header !== 'option' &&\r\n header !== 'button' &&\r\n !isImageResource(element, header)\r\n \"\r\n [innerHtml]=\"getValue(element, header)\"\r\n ></div>\r\n </div>\r\n <div *ngIf=\"smartTable.defaultActionCodes && smartTable.defaultActionCodes.length > 0\">\r\n <lib-default-actions-popup\r\n #defaultActionMenu\r\n [buttons]=\"getDefaultActionsForRow(element)!\"\r\n [row]=\"element\"\r\n ></lib-default-actions-popup>\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <!-- Expanded Content Column - The detail row is made up of this one column that spans across all columns -->\r\n <ng-container matColumnDef=\"expandedDetail\">\r\n <td mat-cell *matCellDef=\"let element\" [attr.colspan]=\"smartTable.tableHeaders.length\">\r\n <div\r\n class=\"example-element-detail\"\r\n [@detailExpand]=\"element == expandedElement ? 'expanded' : 'collapsed'\"\r\n >\r\n <ng-template #expandedArea></ng-template>\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"smartTable.tableHeaders; sticky: true\"></tr>\r\n <tr\r\n mat-row\r\n *matRowDef=\"let element; columns: smartTable.tableHeaders\"\r\n class=\"example-element-row\"\r\n [class.example-expanded-row]=\"expandedElement === element\"\r\n [ngClass]=\"[\r\n isHighlighted(element) ? smartTable.highlightClass! : 'unselected',\r\n smartTable.hover ? 'smartTableRowHover' : '',\r\n isSelected(element) ? 'selected' : ''\r\n ]\"\r\n (click)=\"handleOnRowClick(element)\"\r\n (dblclick)=\"handleOnRowDoubleClick(element)\"\r\n ></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: ['expandedDetail']\" class=\"example-detail-row\"></tr>\r\n</table>\r\n", styles: [".full-width{width:100%}.smarttableImg{width:25px}.smartTableRowHover:hover{cursor:pointer}tr.example-detail-row{height:0}tr.example-element-row:not(.example-expanded-row):hover{background:whitesmoke}tr.example-element-row:not(.example-expanded-row):active{background:#efefef}.example-element-row td{border-bottom-width:0}.example-element-detail{overflow:hidden;display:flex;flex-direction:column}.example-element-diagram{min-width:80px;border:2px solid black;padding:8px;font-weight:lighter;margin:8px 0;height:104px}.example-element-symbol{font-weight:700;font-size:40px;line-height:normal}.example-element-description{padding:16px}.example-element-description-attribution{opacity:.5}.disabledRow{color:var(--disabled)}.disabledRow:hover{cursor:default}.smart-table-buttons-col{display:flex;flex-direction:row;justify-content:flex-end}.sortableHeaderButton{margin:0!important;padding:0!important;text-align:left!important}.selected{background-color:var(--primary-light-color)}.smart-table-icon-container{display:flex;flex-direction:row;justify-content:space-between;white-space:initial}.reversed{flex-direction:row-reverse;gap:1rem}:host ::ng-deep .mat-menu-item{line-height:normal!important}\n"] }]
38
38
  }], ctorParameters: function () { return [{ type: i1.ComponentFactoryService }]; } });
39
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/smart-table/tables/material-table/material-table.component.ts","../../../../../../../projects/smart-ng-client/src/lib/smart-table/tables/material-table/material-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;;;;;AAejF,MAAM,OAAO,sBAAuB,SAAQ,KAAK;IAC/C,YAAY,SAAkC;QAC5C,KAAK,CAAC,SAAS,CAAC,CAAC;IACnB,CAAC;;mHAHU,sBAAsB;uGAAtB,sBAAsB,iFCjBnC,m8bA2UA,m3HDlUc;QACV,OAAO,CAAC,cAAc,EAAE;YACtB,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC,CAAC;YAC5D,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;YACzC,UAAU,CAAC,wBAAwB,EAAE,OAAO,CAAC,sCAAsC,CAAC,CAAC;SACtF,CAAC;KACH;2FAEU,sBAAsB;kBAZlC,SAAS;+BACE,oBAAoB,cAGlB;wBACV,OAAO,CAAC,cAAc,EAAE;4BACtB,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC5D,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;4BACzC,UAAU,CAAC,wBAAwB,EAAE,OAAO,CAAC,sCAAsC,CAAC,CAAC;yBACtF,CAAC;qBACH","sourcesContent":["import { Component } from '@angular/core';\r\nimport { Table } from '../table';\r\nimport { trigger, state, style, transition, animate } from '@angular/animations';\r\nimport { ComponentFactoryService } from '../../../component-factory-service/projects';\r\n\r\n@Component({\r\n  selector: 'lib-material-table',\r\n  templateUrl: './material-table.component.html',\r\n  styleUrls: ['./material-table.component.css'],\r\n  animations: [\r\n    trigger('detailExpand', [\r\n      state('collapsed', style({ height: '0px', minHeight: '0' })),\r\n      state('expanded', style({ height: '*' })),\r\n      transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),\r\n    ]),\r\n  ],\r\n})\r\nexport class MaterialTableComponent extends Table {\r\n  constructor(cfService: ComponentFactoryService) {\r\n    super(cfService);\r\n  }\r\n}\r\n","<table\r\n  #myTable\r\n  mat-table\r\n  [dataSource]=\"smartTable.tableRows\"\r\n  class=\"full-width\"\r\n  multiTemplateDataRows\r\n>\r\n  <!-- Column Descriptor -->\r\n  <ng-container\r\n    *ngFor=\"let header of smartTable.tableHeaders; let i = index\"\r\n    matColumnDef=\"{{ header }}\"\r\n  >\r\n    <th mat-header-cell *matHeaderCellDef>\r\n      <div\r\n        *ngIf=\"header === 'icon' || header === 'img' || header === 'options' || header === 'button'\"\r\n      ></div>\r\n      <div *ngIf=\"header === 'select'\">\r\n        <mat-checkbox\r\n          *ngIf=\"smartTable.customSmartTableHeaders![i].showCheckboxInHeader\"\r\n          (change)=\"$event ? toggleAllRows() : null\"\r\n          [checked]=\"smartTable.selection!.hasValue() && isAllSelected()\"\r\n          [indeterminate]=\"smartTable.selection!.hasValue() && !isAllSelected()\"\r\n          [aria-label]=\"checkboxLabel()\"\r\n        >\r\n        </mat-checkbox>\r\n        <div *ngIf=\"!smartTable.customSmartTableHeaders![i].showCheckboxInHeader\">\r\n          {{ smartTable.customTableHeaders[i] }}\r\n        </div>\r\n      </div>\r\n      <div\r\n        *ngIf=\"\r\n          header !== 'icon' &&\r\n          header !== 'img' &&\r\n          header !== 'options' &&\r\n          header !== 'button' &&\r\n          header !== 'select' &&\r\n          header !== 'expand' &&\r\n          header !== 'actions'\r\n        \"\r\n      >\r\n        <div *ngIf=\"smartTable.sortable; then sortable; else notSortable\"></div>\r\n        <ng-template #sortable>\r\n          <button\r\n            (click)=\"sortButtonClicked($event, smartTable.customSmartTableHeaders![i])\"\r\n            *ngIf=\"smartTable.sortable && isSortable(smartTable.customSmartTableHeaders![i])\"\r\n            mat-button\r\n            class=\"sortableHeaderButton\"\r\n          >\r\n            {{ smartTable.customTableHeaders[i] }}\r\n            <smart-icon\r\n              class=\"sortableHeaderButtonIcon\"\r\n              *ngIf=\"getSortIcon(header)\"\r\n              title=\"sort\"\r\n              [icon]=\"getSortIcon(header)!\"\r\n            ></smart-icon>\r\n            <smart-icon\r\n              class=\"sortableHeaderButtonIcon\"\r\n              *ngIf=\"hasSortNumIcon(header)\"\r\n              title=\"sort\"\r\n              [icon]=\"getSortNumIcon(header)\"\r\n            ></smart-icon>\r\n          </button>\r\n        </ng-template>\r\n        <ng-template #notSortable>\r\n          {{ smartTable.customTableHeaders[i] }}\r\n        </ng-template>\r\n      </div>\r\n    </th>\r\n    <td mat-cell *matCellDef=\"let element\" [ngClass]=\"isDisabled(element) ? 'disabledRow' : ''\">\r\n      <mat-checkbox\r\n        *ngIf=\"\r\n          smartTable.customSmartTableHeaders &&\r\n          smartTable.customSmartTableHeaders[i].propertyName === 'select' &&\r\n          !isDisabled(element)\r\n        \"\r\n        (click)=\"$event.stopPropagation()\"\r\n        (change)=\"\r\n          $event\r\n            ? setSelection(\r\n                smartTable.selectionProperty\r\n                  ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n                  : element\r\n              )\r\n            : null\r\n        \"\r\n        [disabled]=\"isDisabled(element)\"\r\n        [checked]=\"\r\n          smartTable.selection!.isSelected(\r\n            smartTable.selectionProperty\r\n              ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n              : element\r\n          )\r\n        \"\r\n        [aria-label]=\"\r\n          checkboxLabel(\r\n            smartTable.selectionProperty\r\n              ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n              : element\r\n          )\r\n        \"\r\n      >\r\n      </mat-checkbox>\r\n      <div\r\n        *ngIf=\"\r\n          smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].properties\r\n        \"\r\n      >\r\n        <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATETIME\">\r\n          {{\r\n            getValue(element, header)\r\n              | smartDateTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n          }}\r\n        </div>\r\n        <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATE\">\r\n          {{\r\n            getValue(element, header)\r\n              | smartDate : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n          }}\r\n        </div>\r\n        <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().TIME\">\r\n          {{\r\n            getValue(element, header)\r\n              | smartTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n          }}\r\n        </div>\r\n        <div\r\n          *ngIf=\"\r\n            smartTable.customSmartTableHeaders[i].properties?.type === type().ICON &&\r\n            smartTable.customSmartTableHeaders[i].properties?.icons?.length\r\n          \"\r\n        >\r\n          <smart-icon\r\n            [icon]=\"getIcon(getValue(element, header), i)!\"\r\n            [color]=\"getColor(getValue(element, header), i)\"\r\n          >\r\n          </smart-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"smart-table-icon-container\">\r\n        <div *ngFor=\"let ir of getImageResourceIcons(element, header)\">\r\n          <div [smartTooltip]=\"ir.tooltip!\" [ngStyle]=\"getImageResourceStyle(ir)\"\r\n            ><smart-icon [icon]=\"ir.identifier!\" [color]=\"ir.color!\"> </smart-icon\r\n          ></div>\r\n        </div>\r\n      </div>\r\n      <div\r\n        *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].buttons\"\r\n        class=\"smart-table-buttons-col\"\r\n      >\r\n        <div *ngFor=\"let button of smartTable.customSmartTableHeaders[i].buttons\">\r\n          <div *ngIf=\"showButton(button, element)\" [ngSwitch]=\"button.type\">\r\n            <button\r\n              (click)=\"customButtonClicked($event, button, element)\"\r\n              *ngSwitchCase=\"smartTableButtonType.ICON\"\r\n              mat-icon-button\r\n              color=\"{{ button.color }}\"\r\n            >\r\n              <smart-icon title=\"{{ button.label }}\" [icon]=\"button.icon!\"></smart-icon>\r\n            </button>\r\n            <button\r\n              (click)=\"customButtonClicked($event, button, element)\"\r\n              *ngSwitchCase=\"smartTableButtonType.NORMAL\"\r\n              mat-button\r\n              color=\"{{ button.color }}\"\r\n            >\r\n              <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n              {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n            </button>\r\n            <button\r\n              (click)=\"customButtonClicked($event, button, element)\"\r\n              *ngSwitchCase=\"smartTableButtonType.RAISED\"\r\n              mat-raised-button\r\n              color=\"{{ button.color }}\"\r\n            >\r\n              <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n              {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n            </button>\r\n            <div *ngSwitchCase=\"smartTableButtonType.MENU\">\r\n              <button\r\n                *ngIf=\"showMenuButton(element, button)\"\r\n                mat-button\r\n                [matMenuTriggerFor]=\"menu\"\r\n                (click)=\"customButtonClicked($event, button, element, undefined, true)\"\r\n                color=\"{{ button.color }}\"\r\n              >\r\n                <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n                <!-- {{ button.label ?? (button.translator ? button.translator(element).title : '') }} -->\r\n              </button>\r\n              <mat-menu #menu=\"matMenu\">\r\n                <div *ngIf=\"button.menuItemButtons\">\r\n                  <button\r\n                    *ngFor=\"let btn of button.menuItemButtons\"\r\n                    (click)=\"customButtonClicked($event, btn, element, undefined, true)\"\r\n                    mat-menu-item\r\n                  >\r\n                    <smart-icon\r\n                      *ngIf=\"btn?.translator(btn)?.icon\"\r\n                      [icon]=\"btn!.translator!(btn)!.icon!\"\r\n                    ></smart-icon>\r\n                    {{ btn?.translator(btn)?.title }}\r\n                  </button>\r\n                </div>\r\n                <div *ngIf=\"button.menuItemButtonsPropertyName\">\r\n                  <div *ngFor=\"let btn of getValue(element, button.menuItemButtonsPropertyName)\">\r\n                    <button\r\n                      *ngIf=\"btn.code !== ACTION_SEPERATOR\"\r\n                      (click)=\"customButtonClicked($event, button, element, btn, true)\"\r\n                      mat-menu-item\r\n                      [smartTooltip]=\"\r\n                        btn?.descriptor?.tooltip\r\n                          ? btn?.descriptor?.tooltip\r\n                          : button.translator!(btn).tooltip\r\n                      \"\r\n                    >\r\n                      <div\r\n                        class=\"smart-table-icon-container\"\r\n                        [ngClass]=\"\r\n                          button.translator!(btn).iconPosition === 'POST' ? 'reversed' : ''\r\n                        \"\r\n                        ><smart-icon\r\n                          *ngIf=\"button.translator!(btn).icon\"\r\n                          [icon]=\"button.translator!(btn).icon!\"\r\n                        ></smart-icon>\r\n                        {{ button.translator!(btn).title }}</div\r\n                      >\r\n                    </button>\r\n                    <mat-divider *ngIf=\"btn.code === ACTION_SEPERATOR\"></mat-divider>\r\n                  </div>\r\n                </div>\r\n              </mat-menu>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].icon\">\r\n        <smart-icon\r\n          *ngIf=\"smartTable.customSmartTableHeaders[i].icon?.icon\"\r\n          [ngClass]=\"smartTable.customSmartTableHeaders[i].icon?.cssClass ?? ''\"\r\n          [color]=\"smartTable.customSmartTableHeaders[i].icon?.color\"\r\n          [icon]=\"smartTable.customSmartTableHeaders[i].icon!.icon\"\r\n        >\r\n        </smart-icon>\r\n      </div>\r\n      <div\r\n        *ngIf=\"\r\n          smartTable.customSmartTableHeaders &&\r\n          smartTable.customSmartTableHeaders[i].translator !== undefined\r\n        \"\r\n      >\r\n        {{ smartTable.customSmartTableHeaders[i].translator!(getValue(element, header)) }}\r\n      </div>\r\n      <button\r\n        *ngIf=\"\r\n          smartTable.customSmartTableHeaders &&\r\n          smartTable.customSmartTableHeaders[i].propertyName === 'expand'\r\n        \"\r\n        mat-icon-button\r\n        aria-label=\"expand row\"\r\n        (click)=\"onToggle(element, $event)\"\r\n      >\r\n        <smart-icon *ngIf=\"expandedElement !== element\" [icon]=\"'keyboard_arrow_down'\"></smart-icon>\r\n        <smart-icon *ngIf=\"expandedElement === element\" [icon]=\"'keyboard_arrow_up'\"></smart-icon>\r\n      </button>\r\n      <div\r\n        *ngIf=\"\r\n          !smartTable.customSmartTableHeaders ||\r\n          (smartTable.customSmartTableHeaders &&\r\n            !smartTable.customSmartTableHeaders[i].properties &&\r\n            !smartTable.customSmartTableHeaders[i].icon &&\r\n            !smartTable.customSmartTableHeaders[i].buttons &&\r\n            !smartTable.customSmartTableHeaders[i].translator &&\r\n            !(smartTable.customSmartTableHeaders[i].propertyName === 'select') &&\r\n            !(smartTable.customSmartTableHeaders[i].propertyName === 'expand'))\r\n        \"\r\n      >\r\n        <smart-icon *ngIf=\"header === 'icon'\" [icon]=\"getValue(element, header)!\"> </smart-icon>\r\n        <img\r\n          *ngIf=\"header === 'img'\"\r\n          [src]=\"getValue(element, header)\"\r\n          alt=\"\"\r\n          class=\"smarttableImg\"\r\n        />\r\n        <div\r\n          *ngIf=\"\r\n            header !== 'icon' &&\r\n            header !== 'img' &&\r\n            header !== 'option' &&\r\n            header !== 'button' &&\r\n            !isImageResource(element, header)\r\n          \"\r\n          [innerHtml]=\"getValue(element, header)\"\r\n        ></div>\r\n      </div>\r\n      <div *ngIf=\"smartTable.defaultActionCodes && smartTable.defaultActionCodes.length > 0\">\r\n        <lib-default-actions-popup\r\n          #defaultActionMenu\r\n          [buttons]=\"getDefaultActionsForRow(element)!\"\r\n          [row]=\"element\"\r\n        ></lib-default-actions-popup>\r\n      </div>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <!-- Expanded Content Column - The detail row is made up of this one column that spans across all columns -->\r\n  <ng-container matColumnDef=\"expandedDetail\">\r\n    <td mat-cell *matCellDef=\"let element\" [attr.colspan]=\"smartTable.tableHeaders.length\">\r\n      <div\r\n        class=\"example-element-detail\"\r\n        [@detailExpand]=\"element == expandedElement ? 'expanded' : 'collapsed'\"\r\n      >\r\n        <ng-template #expandedArea></ng-template>\r\n      </div>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <tr mat-header-row *matHeaderRowDef=\"smartTable.tableHeaders; sticky: true\"></tr>\r\n  <tr\r\n    mat-row\r\n    *matRowDef=\"let element; columns: smartTable.tableHeaders\"\r\n    class=\"example-element-row\"\r\n    [class.example-expanded-row]=\"expandedElement === element\"\r\n    [ngClass]=\"[\r\n      isHighlighted(element) ? smartTable.highlightClass! : 'unselected',\r\n      smartTable.hover ? 'smartTableRowHover' : '',\r\n      isSelected(element) ? 'selected' : ''\r\n    ]\"\r\n    (click)=\"handleOnRowClick(element)\"\r\n    (dblclick)=\"handleOnRowDoubleClick(element)\"\r\n  ></tr>\r\n  <tr mat-row *matRowDef=\"let row; columns: ['expandedDetail']\" class=\"example-detail-row\"></tr>\r\n</table>\r\n"]}
39
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/smart-table/tables/material-table/material-table.component.ts","../../../../../../../projects/smart-ng-client/src/lib/smart-table/tables/material-table/material-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;;;;;;AAejF,MAAM,OAAO,sBAAuB,SAAQ,KAAK;IAC/C,YAAY,SAAkC;QAC5C,KAAK,CAAC,SAAS,CAAC,CAAC;IACnB,CAAC;;mHAHU,sBAAsB;uGAAtB,sBAAsB,iFCjBnC,4/bA4UA,m3HDnUc;QACV,OAAO,CAAC,cAAc,EAAE;YACtB,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC,CAAC;YAC5D,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;YACzC,UAAU,CAAC,wBAAwB,EAAE,OAAO,CAAC,sCAAsC,CAAC,CAAC;SACtF,CAAC;KACH;2FAEU,sBAAsB;kBAZlC,SAAS;+BACE,oBAAoB,cAGlB;wBACV,OAAO,CAAC,cAAc,EAAE;4BACtB,KAAK,CAAC,WAAW,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,EAAE,CAAC,CAAC;4BAC5D,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;4BACzC,UAAU,CAAC,wBAAwB,EAAE,OAAO,CAAC,sCAAsC,CAAC,CAAC;yBACtF,CAAC;qBACH","sourcesContent":["import { Component } from '@angular/core';\r\nimport { Table } from '../table';\r\nimport { trigger, state, style, transition, animate } from '@angular/animations';\r\nimport { ComponentFactoryService } from '../../../component-factory-service/projects';\r\n\r\n@Component({\r\n  selector: 'lib-material-table',\r\n  templateUrl: './material-table.component.html',\r\n  styleUrls: ['./material-table.component.css'],\r\n  animations: [\r\n    trigger('detailExpand', [\r\n      state('collapsed', style({ height: '0px', minHeight: '0' })),\r\n      state('expanded', style({ height: '*' })),\r\n      transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),\r\n    ]),\r\n  ],\r\n})\r\nexport class MaterialTableComponent extends Table {\r\n  constructor(cfService: ComponentFactoryService) {\r\n    super(cfService);\r\n  }\r\n}\r\n","<table\r\n  #myTable\r\n  mat-table\r\n  [dataSource]=\"smartTable.tableRows\"\r\n  class=\"full-width\"\r\n  multiTemplateDataRows\r\n>\r\n  <!-- Column Descriptor -->\r\n  <ng-container\r\n    *ngFor=\"let header of smartTable.tableHeaders; let i = index\"\r\n    matColumnDef=\"{{ header }}\"\r\n  >\r\n    <th mat-header-cell *matHeaderCellDef>\r\n      <div\r\n        *ngIf=\"header === 'icon' || header === 'img' || header === 'options' || header === 'button'\"\r\n      ></div>\r\n      <div *ngIf=\"header === 'select'\">\r\n        <mat-checkbox\r\n          *ngIf=\"smartTable.customSmartTableHeaders![i].showCheckboxInHeader\"\r\n          (change)=\"$event ? toggleAllRows() : null\"\r\n          [checked]=\"smartTable.selection!.hasValue() && isAllSelected()\"\r\n          [indeterminate]=\"smartTable.selection!.hasValue() && !isAllSelected()\"\r\n          [aria-label]=\"checkboxLabel()\"\r\n        >\r\n        </mat-checkbox>\r\n        <div *ngIf=\"!smartTable.customSmartTableHeaders![i].showCheckboxInHeader\">\r\n          {{ smartTable.customTableHeaders[i] }}\r\n        </div>\r\n      </div>\r\n      <div\r\n        *ngIf=\"\r\n          header !== 'icon' &&\r\n          header !== 'img' &&\r\n          header !== 'options' &&\r\n          header !== 'button' &&\r\n          header !== 'select' &&\r\n          header !== 'expand' &&\r\n          header !== 'actions'\r\n        \"\r\n      >\r\n        <div *ngIf=\"smartTable.sortable; then sortable; else notSortable\"></div>\r\n        <ng-template #sortable>\r\n          <button\r\n            (click)=\"sortButtonClicked($event, smartTable.customSmartTableHeaders![i])\"\r\n            *ngIf=\"smartTable.sortable && isSortable(smartTable.customSmartTableHeaders![i])\"\r\n            mat-button\r\n            class=\"sortableHeaderButton\"\r\n          >\r\n            {{ smartTable.customTableHeaders[i] }}\r\n            <smart-icon\r\n              class=\"sortableHeaderButtonIcon\"\r\n              *ngIf=\"getSortIcon(header)\"\r\n              title=\"sort\"\r\n              [icon]=\"getSortIcon(header)!\"\r\n            ></smart-icon>\r\n            <smart-icon\r\n              class=\"sortableHeaderButtonIcon\"\r\n              *ngIf=\"hasSortNumIcon(header)\"\r\n              title=\"sort\"\r\n              [icon]=\"getSortNumIcon(header)\"\r\n            ></smart-icon>\r\n          </button>\r\n        </ng-template>\r\n        <ng-template #notSortable>\r\n          {{ smartTable.customTableHeaders[i] }}\r\n        </ng-template>\r\n      </div>\r\n    </th>\r\n    <td mat-cell *matCellDef=\"let element\" [ngClass]=\"isDisabled(element) ? 'disabledRow' : ''\">\r\n      <mat-checkbox\r\n        *ngIf=\"\r\n          smartTable.customSmartTableHeaders &&\r\n          smartTable.customSmartTableHeaders[i].propertyName === 'select' &&\r\n          !isDisabled(element)\r\n        \"\r\n        (click)=\"$event.stopPropagation()\"\r\n        (change)=\"\r\n          $event\r\n            ? setSelection(\r\n                smartTable.selectionProperty\r\n                  ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n                  : element\r\n              )\r\n            : null\r\n        \"\r\n        [disabled]=\"isDisabled(element)\"\r\n        [checked]=\"\r\n          smartTable.selection!.isSelected(\r\n            smartTable.selectionProperty\r\n              ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n              : element\r\n          )\r\n        \"\r\n        [aria-label]=\"\r\n          checkboxLabel(\r\n            smartTable.selectionProperty\r\n              ? smartTable.getValueDeeply(element, smartTable.selectionProperty)\r\n              : element\r\n          )\r\n        \"\r\n      >\r\n      </mat-checkbox>\r\n      <div\r\n        *ngIf=\"\r\n          smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].properties\r\n        \"\r\n      >\r\n        <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATETIME\">\r\n          {{\r\n            getValue(element, header)\r\n              | smartDateTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n          }}\r\n        </div>\r\n        <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().DATE\">\r\n          {{\r\n            getValue(element, header)\r\n              | smartDate : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n          }}\r\n        </div>\r\n        <div *ngIf=\"smartTable.customSmartTableHeaders[i].properties?.type === type().TIME\">\r\n          {{\r\n            getValue(element, header)\r\n              | smartTime : smartTable.customSmartTableHeaders[i].properties?.dateFormat\r\n          }}\r\n        </div>\r\n        <div\r\n          *ngIf=\"\r\n            smartTable.customSmartTableHeaders[i].properties?.type === type().ICON &&\r\n            smartTable.customSmartTableHeaders[i].properties?.icons?.length\r\n          \"\r\n        >\r\n          <smart-icon\r\n            [smartTooltip]=\"getToolTip(element, i)\"\r\n            [icon]=\"getIcon(getValue(element, header), i)!\"\r\n            [color]=\"getColor(getValue(element, header), i)\"\r\n          >\r\n          </smart-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"smart-table-icon-container\">\r\n        <div *ngFor=\"let ir of getImageResourceIcons(element, header)\">\r\n          <div [smartTooltip]=\"ir.tooltip!\" [ngStyle]=\"getImageResourceStyle(ir)\"\r\n            ><smart-icon [icon]=\"ir.identifier!\" [color]=\"ir.color!\"> </smart-icon\r\n          ></div>\r\n        </div>\r\n      </div>\r\n      <div\r\n        *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].buttons\"\r\n        class=\"smart-table-buttons-col\"\r\n      >\r\n        <div *ngFor=\"let button of smartTable.customSmartTableHeaders[i].buttons\">\r\n          <div *ngIf=\"showButton(button, element)\" [ngSwitch]=\"button.type\">\r\n            <button\r\n              (click)=\"customButtonClicked($event, button, element)\"\r\n              *ngSwitchCase=\"smartTableButtonType.ICON\"\r\n              mat-icon-button\r\n              color=\"{{ button.color }}\"\r\n            >\r\n              <smart-icon title=\"{{ button.label }}\" [icon]=\"button.icon!\"></smart-icon>\r\n            </button>\r\n            <button\r\n              (click)=\"customButtonClicked($event, button, element)\"\r\n              *ngSwitchCase=\"smartTableButtonType.NORMAL\"\r\n              mat-button\r\n              color=\"{{ button.color }}\"\r\n            >\r\n              <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n              {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n            </button>\r\n            <button\r\n              (click)=\"customButtonClicked($event, button, element)\"\r\n              *ngSwitchCase=\"smartTableButtonType.RAISED\"\r\n              mat-raised-button\r\n              color=\"{{ button.color }}\"\r\n            >\r\n              <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n              {{ button.label ?? (button.translator ? button.translator(element).title : '') }}\r\n            </button>\r\n            <div *ngSwitchCase=\"smartTableButtonType.MENU\">\r\n              <button\r\n                *ngIf=\"showMenuButton(element, button)\"\r\n                mat-button\r\n                [matMenuTriggerFor]=\"menu\"\r\n                (click)=\"customButtonClicked($event, button, element, undefined, true)\"\r\n                color=\"{{ button.color }}\"\r\n              >\r\n                <smart-icon *ngIf=\"button.icon\" [icon]=\"button.icon\"></smart-icon>\r\n                <!-- {{ button.label ?? (button.translator ? button.translator(element).title : '') }} -->\r\n              </button>\r\n              <mat-menu #menu=\"matMenu\">\r\n                <div *ngIf=\"button.menuItemButtons\">\r\n                  <button\r\n                    *ngFor=\"let btn of button.menuItemButtons\"\r\n                    (click)=\"customButtonClicked($event, btn, element, undefined, true)\"\r\n                    mat-menu-item\r\n                  >\r\n                    <smart-icon\r\n                      *ngIf=\"btn?.translator(btn)?.icon\"\r\n                      [icon]=\"btn!.translator!(btn)!.icon!\"\r\n                    ></smart-icon>\r\n                    {{ btn?.translator(btn)?.title }}\r\n                  </button>\r\n                </div>\r\n                <div *ngIf=\"button.menuItemButtonsPropertyName\">\r\n                  <div *ngFor=\"let btn of getValue(element, button.menuItemButtonsPropertyName)\">\r\n                    <button\r\n                      *ngIf=\"btn.code !== ACTION_SEPERATOR\"\r\n                      (click)=\"customButtonClicked($event, button, element, btn, true)\"\r\n                      mat-menu-item\r\n                      [smartTooltip]=\"\r\n                        btn?.descriptor?.tooltip\r\n                          ? btn?.descriptor?.tooltip\r\n                          : button.translator!(btn).tooltip\r\n                      \"\r\n                    >\r\n                      <div\r\n                        class=\"smart-table-icon-container\"\r\n                        [ngClass]=\"\r\n                          button.translator!(btn).iconPosition === 'POST' ? 'reversed' : ''\r\n                        \"\r\n                        ><smart-icon\r\n                          *ngIf=\"button.translator!(btn).icon\"\r\n                          [icon]=\"button.translator!(btn).icon!\"\r\n                        ></smart-icon>\r\n                        {{ button.translator!(btn).title }}</div\r\n                      >\r\n                    </button>\r\n                    <mat-divider *ngIf=\"btn.code === ACTION_SEPERATOR\"></mat-divider>\r\n                  </div>\r\n                </div>\r\n              </mat-menu>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div *ngIf=\"smartTable.customSmartTableHeaders && smartTable.customSmartTableHeaders[i].icon\">\r\n        <smart-icon\r\n          *ngIf=\"smartTable.customSmartTableHeaders[i].icon?.icon\"\r\n          [ngClass]=\"smartTable.customSmartTableHeaders[i].icon?.cssClass ?? ''\"\r\n          [color]=\"smartTable.customSmartTableHeaders[i].icon?.color\"\r\n          [icon]=\"smartTable.customSmartTableHeaders[i].icon!.icon\"\r\n        >\r\n        </smart-icon>\r\n      </div>\r\n      <div\r\n        *ngIf=\"\r\n          smartTable.customSmartTableHeaders &&\r\n          smartTable.customSmartTableHeaders[i].translator !== undefined\r\n        \"\r\n      >\r\n        {{ smartTable.customSmartTableHeaders[i].translator!(getValue(element, header)) }}\r\n      </div>\r\n      <button\r\n        *ngIf=\"\r\n          smartTable.customSmartTableHeaders &&\r\n          smartTable.customSmartTableHeaders[i].propertyName === 'expand'\r\n        \"\r\n        mat-icon-button\r\n        aria-label=\"expand row\"\r\n        (click)=\"onToggle(element, $event)\"\r\n      >\r\n        <smart-icon *ngIf=\"expandedElement !== element\" [icon]=\"'keyboard_arrow_down'\"></smart-icon>\r\n        <smart-icon *ngIf=\"expandedElement === element\" [icon]=\"'keyboard_arrow_up'\"></smart-icon>\r\n      </button>\r\n      <div\r\n        *ngIf=\"\r\n          !smartTable.customSmartTableHeaders ||\r\n          (smartTable.customSmartTableHeaders &&\r\n            !smartTable.customSmartTableHeaders[i].properties &&\r\n            !smartTable.customSmartTableHeaders[i].icon &&\r\n            !smartTable.customSmartTableHeaders[i].buttons &&\r\n            !smartTable.customSmartTableHeaders[i].translator &&\r\n            !(smartTable.customSmartTableHeaders[i].propertyName === 'select') &&\r\n            !(smartTable.customSmartTableHeaders[i].propertyName === 'expand'))\r\n        \"\r\n      >\r\n        <smart-icon *ngIf=\"header === 'icon'\" [icon]=\"getValue(element, header)!\"> </smart-icon>\r\n        <img\r\n          *ngIf=\"header === 'img'\"\r\n          [src]=\"getValue(element, header)\"\r\n          alt=\"\"\r\n          class=\"smarttableImg\"\r\n        />\r\n        <div\r\n          *ngIf=\"\r\n            header !== 'icon' &&\r\n            header !== 'img' &&\r\n            header !== 'option' &&\r\n            header !== 'button' &&\r\n            !isImageResource(element, header)\r\n          \"\r\n          [innerHtml]=\"getValue(element, header)\"\r\n        ></div>\r\n      </div>\r\n      <div *ngIf=\"smartTable.defaultActionCodes && smartTable.defaultActionCodes.length > 0\">\r\n        <lib-default-actions-popup\r\n          #defaultActionMenu\r\n          [buttons]=\"getDefaultActionsForRow(element)!\"\r\n          [row]=\"element\"\r\n        ></lib-default-actions-popup>\r\n      </div>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <!-- Expanded Content Column - The detail row is made up of this one column that spans across all columns -->\r\n  <ng-container matColumnDef=\"expandedDetail\">\r\n    <td mat-cell *matCellDef=\"let element\" [attr.colspan]=\"smartTable.tableHeaders.length\">\r\n      <div\r\n        class=\"example-element-detail\"\r\n        [@detailExpand]=\"element == expandedElement ? 'expanded' : 'collapsed'\"\r\n      >\r\n        <ng-template #expandedArea></ng-template>\r\n      </div>\r\n    </td>\r\n  </ng-container>\r\n\r\n  <tr mat-header-row *matHeaderRowDef=\"smartTable.tableHeaders; sticky: true\"></tr>\r\n  <tr\r\n    mat-row\r\n    *matRowDef=\"let element; columns: smartTable.tableHeaders\"\r\n    class=\"example-element-row\"\r\n    [class.example-expanded-row]=\"expandedElement === element\"\r\n    [ngClass]=\"[\r\n      isHighlighted(element) ? smartTable.highlightClass! : 'unselected',\r\n      smartTable.hover ? 'smartTableRowHover' : '',\r\n      isSelected(element) ? 'selected' : ''\r\n    ]\"\r\n    (click)=\"handleOnRowClick(element)\"\r\n    (dblclick)=\"handleOnRowDoubleClick(element)\"\r\n  ></tr>\r\n  <tr mat-row *matRowDef=\"let row; columns: ['expandedDetail']\" class=\"example-detail-row\"></tr>\r\n</table>\r\n"]}