@quadrel-enterprise-ui/framework 18.21.8 → 18.22.1

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.
@@ -10,9 +10,21 @@ import * as i5 from "@ngx-translate/core";
10
10
  export class QdTableEmptyStateComponent {
11
11
  emptyStateService;
12
12
  config;
13
+ translationParameter = {};
13
14
  constructor(emptyStateService) {
14
15
  this.emptyStateService = emptyStateService;
15
16
  }
17
+ ngOnInit() {
18
+ if (this.config?.i18nParameter)
19
+ this.translationParameter[this.config.i18nParameter.name] = this.config.i18nParameter.value;
20
+ }
21
+ ngOnChanges(changes) {
22
+ if (changes['config'] && this.config && this.config.i18nParameter) {
23
+ const newValue = changes['config'].currentValue.i18nParameter;
24
+ this.translationParameter = {};
25
+ this.translationParameter[newValue.name] = newValue.value;
26
+ }
27
+ }
16
28
  getI18n() {
17
29
  if (!this.emptyStateService.i18ns)
18
30
  console.warn('QD-UI | QdTable - No translations available.');
@@ -23,12 +35,12 @@ export class QdTableEmptyStateComponent {
23
35
  this.emptyStateService.emitAction();
24
36
  }
25
37
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTableEmptyStateComponent, deps: [{ token: i1.QdTableEmptyStateService }], target: i0.ɵɵFactoryTarget.Component });
26
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdTableEmptyStateComponent, selector: "qd-table-empty-state", inputs: { config: "config" }, ngImport: i0, template: "<p>{{ getI18n() + \".empty.content\" | translate }}</p>\n<button *ngIf=\"config?.action\" qdButton qdButtonLink icon=\"plusCircle\" color=\"primary\" (click)=\"handleClick()\">\n {{ getI18n() + \".empty.action\" | translate }}\n</button>\n", styles: [":host{display:block;padding:1.5rem;background:#fff}:host p{margin:0 0 .5rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i4.QdButtonLinkDirective, selector: "button[qdButtonLink], a[qdButtonLink], button[qd-button-link]" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
38
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdTableEmptyStateComponent, selector: "qd-table-empty-state", inputs: { config: "config" }, usesOnChanges: true, ngImport: i0, template: "<p>{{ getI18n() + \".empty.content\" | translate : translationParameter }}</p>\n<button *ngIf=\"config?.action\" qdButton qdButtonLink icon=\"plusCircle\" color=\"primary\" (click)=\"handleClick()\">\n {{ getI18n() + \".empty.action\" | translate }}\n</button>\n", styles: [":host{display:block;padding:1.5rem;background:#fff}:host p{margin:0 0 .5rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i4.QdButtonLinkDirective, selector: "button[qdButtonLink], a[qdButtonLink], button[qd-button-link]" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
27
39
  }
28
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTableEmptyStateComponent, decorators: [{
29
41
  type: Component,
30
- args: [{ selector: 'qd-table-empty-state', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p>{{ getI18n() + \".empty.content\" | translate }}</p>\n<button *ngIf=\"config?.action\" qdButton qdButtonLink icon=\"plusCircle\" color=\"primary\" (click)=\"handleClick()\">\n {{ getI18n() + \".empty.action\" | translate }}\n</button>\n", styles: [":host{display:block;padding:1.5rem;background:#fff}:host p{margin:0 0 .5rem}\n"] }]
42
+ args: [{ selector: 'qd-table-empty-state', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p>{{ getI18n() + \".empty.content\" | translate : translationParameter }}</p>\n<button *ngIf=\"config?.action\" qdButton qdButtonLink icon=\"plusCircle\" color=\"primary\" (click)=\"handleClick()\">\n {{ getI18n() + \".empty.action\" | translate }}\n</button>\n", styles: [":host{display:block;padding:1.5rem;background:#fff}:host p{margin:0 0 .5rem}\n"] }]
31
43
  }], ctorParameters: () => [{ type: i1.QdTableEmptyStateService }], propDecorators: { config: [{
32
44
  type: Input
33
45
  }] } });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtZW1wdHktc3RhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9xZC11aS9zcmMvbGliL3RhYmxlL2VtcHR5LXN0YXRlL3RhYmxlLWVtcHR5LXN0YXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi90YWJsZS9lbXB0eS1zdGF0ZS90YWJsZS1lbXB0eS1zdGF0ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxvQkFBb0I7QUFDcEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saUNBQWlDLENBQUM7Ozs7Ozs7QUFRM0UsTUFBTSxPQUFPLDBCQUEwQjtJQUdSO0lBRnBCLE1BQU0sQ0FBd0I7SUFFdkMsWUFBNkIsaUJBQTJDO1FBQTNDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBMEI7SUFBRyxDQUFDO0lBRTVFLE9BQU87UUFDTCxJQUFJLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUs7WUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLDhDQUE4QyxDQUFDLENBQUM7UUFFaEcsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUN0QixJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDdEMsQ0FBQzt1R0FkVSwwQkFBMEI7MkZBQTFCLDBCQUEwQiwwRkNYdkMsa1BBSUE7OzJGRE9hLDBCQUEwQjtrQkFOdEMsU0FBUzsrQkFDRSxzQkFBc0IsbUJBR2YsdUJBQXVCLENBQUMsTUFBTTs2RkFHdEMsTUFBTTtzQkFBZCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLXN0cmljdC1pZ25vcmVcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBRZFRhYmxlRW1wdHlTdGF0ZVZpZXcgfSBmcm9tICcuLi9tb2RlbC90YWJsZS1jb25maWcuaW50ZXJmYWNlJztcbmltcG9ydCB7IFFkVGFibGVFbXB0eVN0YXRlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2VtcHR5LXN0YXRlLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdxZC10YWJsZS1lbXB0eS1zdGF0ZScsXG4gIHRlbXBsYXRlVXJsOiAnLi90YWJsZS1lbXB0eS1zdGF0ZS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3RhYmxlLWVtcHR5LXN0YXRlLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFFkVGFibGVFbXB0eVN0YXRlQ29tcG9uZW50IHtcbiAgQElucHV0KCkgY29uZmlnOiBRZFRhYmxlRW1wdHlTdGF0ZVZpZXc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBlbXB0eVN0YXRlU2VydmljZTogUWRUYWJsZUVtcHR5U3RhdGVTZXJ2aWNlKSB7fVxuXG4gIGdldEkxOG4oKTogc3RyaW5nIHtcbiAgICBpZiAoIXRoaXMuZW1wdHlTdGF0ZVNlcnZpY2UuaTE4bnMpIGNvbnNvbGUud2FybignUUQtVUkgfCBRZFRhYmxlIC0gTm8gdHJhbnNsYXRpb25zIGF2YWlsYWJsZS4nKTtcblxuICAgIHJldHVybiB0aGlzLmVtcHR5U3RhdGVTZXJ2aWNlLmkxOG5zO1xuICB9XG5cbiAgaGFuZGxlQ2xpY2soKTogdm9pZCB7XG4gICAgdGhpcy5jb25maWcuaGFuZGxlcigpO1xuICAgIHRoaXMuZW1wdHlTdGF0ZVNlcnZpY2UuZW1pdEFjdGlvbigpO1xuICB9XG59XG4iLCI8cD57eyBnZXRJMThuKCkgKyBcIi5lbXB0eS5jb250ZW50XCIgfCB0cmFuc2xhdGUgfX08L3A+XG48YnV0dG9uICpuZ0lmPVwiY29uZmlnPy5hY3Rpb25cIiBxZEJ1dHRvbiBxZEJ1dHRvbkxpbmsgaWNvbj1cInBsdXNDaXJjbGVcIiBjb2xvcj1cInByaW1hcnlcIiAoY2xpY2spPVwiaGFuZGxlQ2xpY2soKVwiPlxuICB7eyBnZXRJMThuKCkgKyBcIi5lbXB0eS5hY3Rpb25cIiB8IHRyYW5zbGF0ZSB9fVxuPC9idXR0b24+XG4iXX0=
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtZW1wdHktc3RhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9xZC11aS9zcmMvbGliL3RhYmxlL2VtcHR5LXN0YXRlL3RhYmxlLWVtcHR5LXN0YXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi90YWJsZS9lbXB0eS1zdGF0ZS90YWJsZS1lbXB0eS1zdGF0ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxvQkFBb0I7QUFDcEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQW9DLE1BQU0sZUFBZSxDQUFDO0FBRTVHLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOzs7Ozs7O0FBUTNFLE1BQU0sT0FBTywwQkFBMEI7SUFLUjtJQUpwQixNQUFNLENBQXdCO0lBRXZDLG9CQUFvQixHQUE4QixFQUFFLENBQUM7SUFFckQsWUFBNkIsaUJBQTJDO1FBQTNDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBMEI7SUFBRyxDQUFDO0lBRTVFLFFBQVE7UUFDTixJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUUsYUFBYTtZQUM1QixJQUFJLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDO0lBQ2hHLENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ2xFLE1BQU0sUUFBUSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDO1lBQzlELElBQUksQ0FBQyxvQkFBb0IsR0FBRyxFQUFFLENBQUM7WUFDL0IsSUFBSSxDQUFDLG9CQUFvQixDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDO1FBQzVELENBQUM7SUFDSCxDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSztZQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsOENBQThDLENBQUMsQ0FBQztRQUVoRyxPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUM7SUFDdEMsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUN0QyxDQUFDO3VHQTdCVSwwQkFBMEI7MkZBQTFCLDBCQUEwQiwrR0NYdkMseVFBSUE7OzJGRE9hLDBCQUEwQjtrQkFOdEMsU0FBUzsrQkFDRSxzQkFBc0IsbUJBR2YsdUJBQXVCLENBQUMsTUFBTTs2RkFHdEMsTUFBTTtzQkFBZCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLXN0cmljdC1pZ25vcmVcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUWRUYWJsZUVtcHR5U3RhdGVWaWV3IH0gZnJvbSAnLi4vbW9kZWwvdGFibGUtY29uZmlnLmludGVyZmFjZSc7XG5pbXBvcnQgeyBRZFRhYmxlRW1wdHlTdGF0ZVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9lbXB0eS1zdGF0ZS5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncWQtdGFibGUtZW1wdHktc3RhdGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vdGFibGUtZW1wdHktc3RhdGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90YWJsZS1lbXB0eS1zdGF0ZS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBRZFRhYmxlRW1wdHlTdGF0ZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzIHtcbiAgQElucHV0KCkgY29uZmlnOiBRZFRhYmxlRW1wdHlTdGF0ZVZpZXc7XG5cbiAgdHJhbnNsYXRpb25QYXJhbWV0ZXI6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH0gPSB7fTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGVtcHR5U3RhdGVTZXJ2aWNlOiBRZFRhYmxlRW1wdHlTdGF0ZVNlcnZpY2UpIHt9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuY29uZmlnPy5pMThuUGFyYW1ldGVyKVxuICAgICAgdGhpcy50cmFuc2xhdGlvblBhcmFtZXRlclt0aGlzLmNvbmZpZy5pMThuUGFyYW1ldGVyLm5hbWVdID0gdGhpcy5jb25maWcuaTE4blBhcmFtZXRlci52YWx1ZTtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoY2hhbmdlc1snY29uZmlnJ10gJiYgdGhpcy5jb25maWcgJiYgdGhpcy5jb25maWcuaTE4blBhcmFtZXRlcikge1xuICAgICAgY29uc3QgbmV3VmFsdWUgPSBjaGFuZ2VzWydjb25maWcnXS5jdXJyZW50VmFsdWUuaTE4blBhcmFtZXRlcjtcbiAgICAgIHRoaXMudHJhbnNsYXRpb25QYXJhbWV0ZXIgPSB7fTtcbiAgICAgIHRoaXMudHJhbnNsYXRpb25QYXJhbWV0ZXJbbmV3VmFsdWUubmFtZV0gPSBuZXdWYWx1ZS52YWx1ZTtcbiAgICB9XG4gIH1cblxuICBnZXRJMThuKCk6IHN0cmluZyB7XG4gICAgaWYgKCF0aGlzLmVtcHR5U3RhdGVTZXJ2aWNlLmkxOG5zKSBjb25zb2xlLndhcm4oJ1FELVVJIHwgUWRUYWJsZSAtIE5vIHRyYW5zbGF0aW9ucyBhdmFpbGFibGUuJyk7XG5cbiAgICByZXR1cm4gdGhpcy5lbXB0eVN0YXRlU2VydmljZS5pMThucztcbiAgfVxuXG4gIGhhbmRsZUNsaWNrKCk6IHZvaWQge1xuICAgIHRoaXMuY29uZmlnLmhhbmRsZXIoKTtcbiAgICB0aGlzLmVtcHR5U3RhdGVTZXJ2aWNlLmVtaXRBY3Rpb24oKTtcbiAgfVxufVxuIiwiPHA+e3sgZ2V0STE4bigpICsgXCIuZW1wdHkuY29udGVudFwiIHwgdHJhbnNsYXRlIDogdHJhbnNsYXRpb25QYXJhbWV0ZXIgfX08L3A+XG48YnV0dG9uICpuZ0lmPVwiY29uZmlnPy5hY3Rpb25cIiBxZEJ1dHRvbiBxZEJ1dHRvbkxpbmsgaWNvbj1cInBsdXNDaXJjbGVcIiBjb2xvcj1cInByaW1hcnlcIiAoY2xpY2spPVwiaGFuZGxlQ2xpY2soKVwiPlxuICB7eyBnZXRJMThuKCkgKyBcIi5lbXB0eS5hY3Rpb25cIiB8IHRyYW5zbGF0ZSB9fVxuPC9idXR0b24+XG4iXX0=
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-config.interface.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/table/model/table-config.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { Observable } from 'rxjs';\nimport { QdBreakpoint } from '../../core/model/breakpoint.interface';\nimport { QdSortDirection } from './sort-direction.enum';\nimport {\n  QdTableConfigGroup,\n  QdTableConfigSelection,\n  QdTablePrimaryAction,\n  QdTableSecondaryAction\n} from './table-config-actions.interface';\nimport { QdTableConfigColumnType } from './table-config-content.interface';\n\n/**\n * Describes which column is filling the table's width.\n * In \"harmonized\" mode the whitespace will be distributed evenly, considering the width of each column.\n */\nexport type QdTableFillingColumn = 'main' | 'last' | 'harmonized' | 'none';\n\n/**\n * @description Configuration Model for Qd-Tables. The generic type defines the table columns keys.\n */\nexport interface QdTableConfig<T extends string> {\n  /**\n   * @description Defines the columns of the table.\n   */\n  columns: QdTableConfigColumn<T>[];\n\n  /**\n   * @description Configures the behavior of the groups in the tree view.\n   * @deprecated use qd-tree instead\n   */\n  group?: QdTableConfigGroup;\n\n  /**\n   * @description Activates a pagination\n   *\n   * * @default: false\n   * * @deprecated\n   */\n  hasPagination?: boolean;\n\n  /**\n   * @description Activates a pagination with configurable available page sizes\n   */\n  pagination?: true | QdTablePagination;\n\n  /**\n   * @description Sets an alternative view if no elements are available in QdTableData\n   */\n  emptyStateView?: QdTableEmptyStateView;\n\n  /**\n   * @description Defines a list of secondary actions that can be executed per Click/Tab of an item in the menu.\n   *\n   * * @example\n   * This is how the two actions \"edit\" and \"delete\" are created.\n   * ```ts\n   * secondaryActions: [\n   *    {\n   *      type: 'edit',\n   *      handler: rowData => doSomethingWith(rowData)\n   *    },\n   *    {\n   *      type: 'delete',\n   *      isDisabled: true,\n   *      handler: rowData => doSomethingWith(rowData)\n   *    }\n   * ]\n   * ```\n   */\n  secondaryActions?: QdTableSecondaryAction<T>[];\n\n  /**\n   * @description Defines the primary action that can be executed by clicking on a row.\n   *\n   * @example\n   * You provide a primary action like this.\n   * ``ts\n   * primaryAction: {\n   *   handler: row => openModal(row)\n   * }\n   */\n  primaryAction?: QdTablePrimaryAction<T>;\n\n  /**\n   * @description Configures selection options for table rows.\n   *\n   * * @example\n   * This creates a \"multiSelect\".\n   * ```ts\n   * selection: {\n   *    type: 'multiSelect',\n   *    handler: selectedRows => doSomethingWith(selectedRows)\n   * }\n   * ```\n   */\n  selection?: QdTableConfigSelection<T>;\n\n  /**\n   * @description Sets the translation keys (plural) for the table headings and more, as the 'context' for instance.\n   *\n   * * @example: \"i18n.my.table.<column>\".\n   *\n   * If none exits, the value is rendered without translation.\n   */\n  i18ns?: string;\n\n  /**\n   * @description Turns a specified column into a main column. Main Columns have different presentation properties.\n   *\n   * * @default: columns[0].column\n   */\n  mainColumn?: T;\n\n  /**\n   * @description By default the main column fills the remaining width so that the table has a width of 100%.\n   * By setting this property the main column will have content width.\n   *\n   * * @default: false\n   * * @deprecated\n   */\n  mainColumnNotFillingWidth?: boolean;\n\n  /**\n   * @description Usually the table fills 100% of the width.\n   *\n   * This value defines which column fills the space in the table to its full width.\n   * In \"harmonized\" mode the whitespace will be distributed evenly, considering the width of each column.\n   * If the value \"none\" is used, the table can be less than 100% in width.\n   *\n   * Find out more in the related type \"QdTableConfig<T>['mainColumn']\".\n   *\n   * * @default: 'main'\n   */\n  whichColumnFillsWidth?: QdTableFillingColumn;\n\n  /**\n   * @description Enables \"viewonly\" mode for the table.\n   *\n   * When set to `true`, the table displays its content as read-only.\n   * Combined with `secondaryActions`, this can be used to selectively show or hide secondary actions\n   * based on the operation mode (`'view'` or `'edit'`) used in the Quadrel framework.\n   *\n   * * If `viewonly` is explicitly set, it overrides the global operation mode\n   * (which is normally controlled through external events).\n   * This gives you full control: for example, setting `viewonly: false` will allow edit actions to be shown,\n   * even if the global mode would normally hide them.\n   *\n   * * @default false\n   */\n  viewonly?: boolean;\n\n  /**\n   * @description Sets the maximum number of columns over the breakpoints.\n   *\n   * * @default: { xs: 1, sm: 2, md: 4, lg: 6, xl: 8, xxl: 10 }\n   *\n   * * @example\n   * ```ts\n   * { xs: 1, sm: 2, md: 4, lg: 6, xl: 8, xxl: 10 }\n   * ```\n   */\n  columnMapping?: { [key in QdBreakpoint]?: QdMaxColumnsCount };\n\n  /**\n   * @description Observable to trigger a table refresh from outside.\n   *\n   * - `number` sets the page index to refresh.\n   * - `undefined` triggers a general refresh (current page stays the same).\n   *\n   * @example\n   * ```ts\n   * refresh$.next();      // refresh current page\n   * refresh$.next(0);     // refresh and go to first page\n   * ```\n   */\n  refresh?: Observable<number | undefined>;\n\n  /**\n   * @description Determines if the table should refresh when the language is changed.\n   *\n   * * @default: false\n   */\n  refreshOnLanguageChange?: boolean;\n\n  /**\n   * @description When this flag is set, the table will be refreshed for every RESOURCE_UPDATED event\n   * with a path that matches the table uid.\n   * Important: You have to create the connection to the SSE backend service on your own with the QdPushEventsService\n   * (connect method).\n   */\n  refreshOnPushEvent?: boolean;\n\n  /**\n   * @description Sets a unique identifier for the table. Used as key to hold in NgRx store.\n   *\n   * * @default: random RFC 4122 Identifier\n   */\n  uid?: string;\n}\n\ninterface QdTableConfigColumnBase<T> {\n  /**\n   * @description Defines the key of the column.\n   */\n  column: T;\n\n  /**\n   * @description Makes the column sortable. If this key has been defined, the sorting will be turned on.\n   */\n  sort?: QdTableConfigColumnSort;\n\n  /**\n   * @description Defines the breakpoint at which the column is hidden. Use for mobile devices.\n   */\n  hiddenAt?: QdBreakpoint;\n}\n\n/**\n * @description Configuration for sorting\n */\nexport interface QdTableConfigColumnSort {\n  /**\n   * @description Sorting can be deactivated here.\n   *\n   * * @default: false\n   */\n  isDisabled?: boolean;\n\n  /**\n   * @description The direction of sorting.\n   *\n   * * @default: QdSortDirection.NONE\n   */\n  direction?: QdSortDirection;\n}\n\n/**\n * @description Maximum number of columns depending on the current breakpoint.\n *\n * * @default: { xs: 1, sm: 2, md: 4, lg: 6, xl: 8, xxl: 10 }\n */\ntype QdMaxColumnsCount = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15;\n\nexport type QdTableConfigColumn<T> = QdTableConfigColumnType & QdTableConfigColumnBase<T>;\n\n/**\n * @description Configuration model for pagination\n */\nexport interface QdTablePagination {\n  /**\n   * @description Initial pagination page size\n   *\n   * * @default 25\n   */\n  pageSizeDefault?: number;\n\n  /**\n   * @description List of available pagination page sizes\n   *\n   * * @example [25, 50, 100]\n   */\n  pageSizes?: number[];\n\n  /**\n   * @description Activates the first & last buttons for quick navigation\n   *\n   * * @default: false\n   */\n  hasFirstLastPageNavigation?: boolean;\n}\n\n/**\n * @description Configuration model for empty state view\n */\nexport interface QdTableEmptyStateView {\n  /**\n   * @description Toggles the empty view off, if set to \"true\".\n   *\n   * * @default: false\n   */\n  disabled?: boolean;\n\n  /**\n   * @description Renders a call-to-action button.\n   *\n   * * @default: false\n   */\n  action?: boolean;\n\n  /**\n   * @description Defines a handler that is triggered by a click/tap on the call-to-action button.\n   * Will only be triggered if \"action\" is set to \"true\n   */\n  handler?: () => void;\n}\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-config.interface.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/table/model/table-config.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { Observable } from 'rxjs';\nimport { QdBreakpoint } from '../../core/model/breakpoint.interface';\nimport { QdSortDirection } from './sort-direction.enum';\nimport {\n  QdTableConfigGroup,\n  QdTableConfigSelection,\n  QdTablePrimaryAction,\n  QdTableSecondaryAction\n} from './table-config-actions.interface';\nimport { QdTableConfigColumnType } from './table-config-content.interface';\n\n/**\n * Describes which column is filling the table's width.\n * In \"harmonized\" mode the whitespace will be distributed evenly, considering the width of each column.\n */\nexport type QdTableFillingColumn = 'main' | 'last' | 'harmonized' | 'none';\n\n/**\n * @description Configuration Model for Qd-Tables. The generic type defines the table columns keys.\n */\nexport interface QdTableConfig<T extends string> {\n  /**\n   * @description Defines the columns of the table.\n   */\n  columns: QdTableConfigColumn<T>[];\n\n  /**\n   * @description Configures the behavior of the groups in the tree view.\n   * @deprecated use qd-tree instead\n   */\n  group?: QdTableConfigGroup;\n\n  /**\n   * @description Activates a pagination\n   *\n   * * @default: false\n   * * @deprecated\n   */\n  hasPagination?: boolean;\n\n  /**\n   * @description Activates a pagination with configurable available page sizes\n   */\n  pagination?: true | QdTablePagination;\n\n  /**\n   * @description Sets an alternative view if no elements are available in QdTableData\n   */\n  emptyStateView?: QdTableEmptyStateView;\n\n  /**\n   * @description Defines a list of secondary actions that can be executed per Click/Tab of an item in the menu.\n   *\n   * * @example\n   * This is how the two actions \"edit\" and \"delete\" are created.\n   * ```ts\n   * secondaryActions: [\n   *    {\n   *      type: 'edit',\n   *      handler: rowData => doSomethingWith(rowData)\n   *    },\n   *    {\n   *      type: 'delete',\n   *      isDisabled: true,\n   *      handler: rowData => doSomethingWith(rowData)\n   *    }\n   * ]\n   * ```\n   */\n  secondaryActions?: QdTableSecondaryAction<T>[];\n\n  /**\n   * @description Defines the primary action that can be executed by clicking on a row.\n   *\n   * @example\n   * You provide a primary action like this.\n   * ``ts\n   * primaryAction: {\n   *   handler: row => openModal(row)\n   * }\n   */\n  primaryAction?: QdTablePrimaryAction<T>;\n\n  /**\n   * @description Configures selection options for table rows.\n   *\n   * * @example\n   * This creates a \"multiSelect\".\n   * ```ts\n   * selection: {\n   *    type: 'multiSelect',\n   *    handler: selectedRows => doSomethingWith(selectedRows)\n   * }\n   * ```\n   */\n  selection?: QdTableConfigSelection<T>;\n\n  /**\n   * @description Sets the translation keys (plural) for the table headings and more, as the 'context' for instance.\n   *\n   * * @example: \"i18n.my.table.<column>\".\n   *\n   * If none exits, the value is rendered without translation.\n   */\n  i18ns?: string;\n\n  /**\n   * @description Turns a specified column into a main column. Main Columns have different presentation properties.\n   *\n   * * @default: columns[0].column\n   */\n  mainColumn?: T;\n\n  /**\n   * @description By default the main column fills the remaining width so that the table has a width of 100%.\n   * By setting this property the main column will have content width.\n   *\n   * * @default: false\n   * * @deprecated\n   */\n  mainColumnNotFillingWidth?: boolean;\n\n  /**\n   * @description Usually the table fills 100% of the width.\n   *\n   * This value defines which column fills the space in the table to its full width.\n   * In \"harmonized\" mode the whitespace will be distributed evenly, considering the width of each column.\n   * If the value \"none\" is used, the table can be less than 100% in width.\n   *\n   * Find out more in the related type \"QdTableConfig<T>['mainColumn']\".\n   *\n   * * @default: 'main'\n   */\n  whichColumnFillsWidth?: QdTableFillingColumn;\n\n  /**\n   * @description Enables \"viewonly\" mode for the table.\n   *\n   * When set to `true`, the table displays its content as read-only.\n   * Combined with `secondaryActions`, this can be used to selectively show or hide secondary actions\n   * based on the operation mode (`'view'` or `'edit'`) used in the Quadrel framework.\n   *\n   * * If `viewonly` is explicitly set, it overrides the global operation mode\n   * (which is normally controlled through external events).\n   * This gives you full control: for example, setting `viewonly: false` will allow edit actions to be shown,\n   * even if the global mode would normally hide them.\n   *\n   * * @default false\n   */\n  viewonly?: boolean;\n\n  /**\n   * @description Sets the maximum number of columns over the breakpoints.\n   *\n   * * @default: { xs: 1, sm: 2, md: 4, lg: 6, xl: 8, xxl: 10 }\n   *\n   * * @example\n   * ```ts\n   * { xs: 1, sm: 2, md: 4, lg: 6, xl: 8, xxl: 10 }\n   * ```\n   */\n  columnMapping?: { [key in QdBreakpoint]?: QdMaxColumnsCount };\n\n  /**\n   * @description Observable to trigger a table refresh from outside.\n   *\n   * - `number` sets the page index to refresh.\n   * - `undefined` triggers a general refresh (current page stays the same).\n   *\n   * @example\n   * ```ts\n   * refresh$.next();      // refresh current page\n   * refresh$.next(0);     // refresh and go to first page\n   * ```\n   */\n  refresh?: Observable<number | undefined>;\n\n  /**\n   * @description Determines if the table should refresh when the language is changed.\n   *\n   * * @default: false\n   */\n  refreshOnLanguageChange?: boolean;\n\n  /**\n   * @description When this flag is set, the table will be refreshed for every RESOURCE_UPDATED event\n   * with a path that matches the table uid.\n   * Important: You have to create the connection to the SSE backend service on your own with the QdPushEventsService\n   * (connect method).\n   */\n  refreshOnPushEvent?: boolean;\n\n  /**\n   * @description Sets a unique identifier for the table. Used as key to hold in NgRx store.\n   *\n   * * @default: random RFC 4122 Identifier\n   */\n  uid?: string;\n}\n\ninterface QdTableConfigColumnBase<T> {\n  /**\n   * @description Defines the key of the column.\n   */\n  column: T;\n\n  /**\n   * @description Makes the column sortable. If this key has been defined, the sorting will be turned on.\n   */\n  sort?: QdTableConfigColumnSort;\n\n  /**\n   * @description Defines the breakpoint at which the column is hidden. Use for mobile devices.\n   */\n  hiddenAt?: QdBreakpoint;\n}\n\n/**\n * @description Configuration for sorting\n */\nexport interface QdTableConfigColumnSort {\n  /**\n   * @description Sorting can be deactivated here.\n   *\n   * * @default: false\n   */\n  isDisabled?: boolean;\n\n  /**\n   * @description The direction of sorting.\n   *\n   * * @default: QdSortDirection.NONE\n   */\n  direction?: QdSortDirection;\n}\n\n/**\n * @description Maximum number of columns depending on the current breakpoint.\n *\n * * @default: { xs: 1, sm: 2, md: 4, lg: 6, xl: 8, xxl: 10 }\n */\ntype QdMaxColumnsCount = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15;\n\nexport type QdTableConfigColumn<T> = QdTableConfigColumnType & QdTableConfigColumnBase<T>;\n\n/**\n * @description Configuration model for pagination\n */\nexport interface QdTablePagination {\n  /**\n   * @description Initial pagination page size\n   *\n   * * @default 25\n   */\n  pageSizeDefault?: number;\n\n  /**\n   * @description List of available pagination page sizes\n   *\n   * * @example [25, 50, 100]\n   */\n  pageSizes?: number[];\n\n  /**\n   * @description Activates the first & last buttons for quick navigation\n   *\n   * * @default: false\n   */\n  hasFirstLastPageNavigation?: boolean;\n}\n\n/**\n * @description Configuration model for empty state view\n */\nexport interface QdTableEmptyStateView {\n  /**\n   * @description Toggles the empty view off, if set to \"true\".\n   *\n   * * @default: false\n   */\n  disabled?: boolean;\n\n  /**\n   * @description Renders a call-to-action button.\n   *\n   * * @default: false\n   */\n  action?: boolean;\n\n  /**\n   * @description Defines a handler that is triggered by a click/tap on the call-to-action button.\n   * Will only be triggered if \"action\" is set to \"true\n   */\n  handler?: () => void;\n\n  /**\n   * @description Optional internationalization configuration parameter.\n   *\n   * This object specifies a key-value pair used for dynamic translations\n   * within the component. It allows developers to set a custom parameter\n   * name and corresponding value that is injected into translation string.\n   *\n   */\n  i18nParameter?: {\n    /**\n     * @description The placeholder name in the translation string.\n     * This corresponds to the key used within translation resources.\n     */\n    name: string;\n    /**\n     * @description The value to replace the placeholder with in the translated output\n     */\n    value: string;\n  };\n}\n"]}
@@ -21392,9 +21392,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
21392
21392
  class QdTableEmptyStateComponent {
21393
21393
  emptyStateService;
21394
21394
  config;
21395
+ translationParameter = {};
21395
21396
  constructor(emptyStateService) {
21396
21397
  this.emptyStateService = emptyStateService;
21397
21398
  }
21399
+ ngOnInit() {
21400
+ if (this.config?.i18nParameter)
21401
+ this.translationParameter[this.config.i18nParameter.name] = this.config.i18nParameter.value;
21402
+ }
21403
+ ngOnChanges(changes) {
21404
+ if (changes['config'] && this.config && this.config.i18nParameter) {
21405
+ const newValue = changes['config'].currentValue.i18nParameter;
21406
+ this.translationParameter = {};
21407
+ this.translationParameter[newValue.name] = newValue.value;
21408
+ }
21409
+ }
21398
21410
  getI18n() {
21399
21411
  if (!this.emptyStateService.i18ns)
21400
21412
  console.warn('QD-UI | QdTable - No translations available.');
@@ -21405,11 +21417,11 @@ class QdTableEmptyStateComponent {
21405
21417
  this.emptyStateService.emitAction();
21406
21418
  }
21407
21419
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTableEmptyStateComponent, deps: [{ token: QdTableEmptyStateService }], target: i0.ɵɵFactoryTarget.Component });
21408
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdTableEmptyStateComponent, selector: "qd-table-empty-state", inputs: { config: "config" }, ngImport: i0, template: "<p>{{ getI18n() + \".empty.content\" | translate }}</p>\n<button *ngIf=\"config?.action\" qdButton qdButtonLink icon=\"plusCircle\" color=\"primary\" (click)=\"handleClick()\">\n {{ getI18n() + \".empty.action\" | translate }}\n</button>\n", styles: [":host{display:block;padding:1.5rem;background:#fff}:host p{margin:0 0 .5rem}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: QdButtonLinkDirective, selector: "button[qdButtonLink], a[qdButtonLink], button[qd-button-link]" }, { kind: "pipe", type: i1$2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21420
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdTableEmptyStateComponent, selector: "qd-table-empty-state", inputs: { config: "config" }, usesOnChanges: true, ngImport: i0, template: "<p>{{ getI18n() + \".empty.content\" | translate : translationParameter }}</p>\n<button *ngIf=\"config?.action\" qdButton qdButtonLink icon=\"plusCircle\" color=\"primary\" (click)=\"handleClick()\">\n {{ getI18n() + \".empty.action\" | translate }}\n</button>\n", styles: [":host{display:block;padding:1.5rem;background:#fff}:host p{margin:0 0 .5rem}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: QdButtonLinkDirective, selector: "button[qdButtonLink], a[qdButtonLink], button[qd-button-link]" }, { kind: "pipe", type: i1$2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21409
21421
  }
21410
21422
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdTableEmptyStateComponent, decorators: [{
21411
21423
  type: Component,
21412
- args: [{ selector: 'qd-table-empty-state', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p>{{ getI18n() + \".empty.content\" | translate }}</p>\n<button *ngIf=\"config?.action\" qdButton qdButtonLink icon=\"plusCircle\" color=\"primary\" (click)=\"handleClick()\">\n {{ getI18n() + \".empty.action\" | translate }}\n</button>\n", styles: [":host{display:block;padding:1.5rem;background:#fff}:host p{margin:0 0 .5rem}\n"] }]
21424
+ args: [{ selector: 'qd-table-empty-state', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p>{{ getI18n() + \".empty.content\" | translate : translationParameter }}</p>\n<button *ngIf=\"config?.action\" qdButton qdButtonLink icon=\"plusCircle\" color=\"primary\" (click)=\"handleClick()\">\n {{ getI18n() + \".empty.action\" | translate }}\n</button>\n", styles: [":host{display:block;padding:1.5rem;background:#fff}:host p{margin:0 0 .5rem}\n"] }]
21413
21425
  }], ctorParameters: () => [{ type: QdTableEmptyStateService }], propDecorators: { config: [{
21414
21426
  type: Input
21415
21427
  }] } });