@quadrel-enterprise-ui/framework 18.31.2 → 18.31.4

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.
Files changed (45) hide show
  1. package/esm2022/lib/comments/comments.component.mjs +3 -3
  2. package/esm2022/lib/dialog/dialog.component.mjs +80 -37
  3. package/esm2022/lib/dialog/dialog.module.mjs +20 -8
  4. package/esm2022/lib/dialog/directives/pending-changes-guard.directive.mjs +7 -7
  5. package/esm2022/lib/dialog/models/dialog-close.model.mjs +2 -0
  6. package/esm2022/lib/dialog/models/page-dialog-host.token.mjs +9 -0
  7. package/esm2022/lib/dialog/services/confirmation-dialog.service.mjs +2 -2
  8. package/esm2022/lib/dialog/services/dialog.service.mjs +36 -8
  9. package/esm2022/lib/file-collector/allowed-files-description/file-collector-allowed-files-description.component.mjs +3 -3
  10. package/esm2022/lib/file-collector/dialog/item/error/file-collector-dialog-item-error.component.mjs +3 -3
  11. package/esm2022/lib/forms/input/input.component.mjs +4 -2
  12. package/esm2022/lib/page/model/page-config.interface.mjs +1 -1
  13. package/esm2022/lib/page/page.component.mjs +37 -13
  14. package/esm2022/lib/shell/header/service-navigation/shell-service-navigation.component.mjs +4 -4
  15. package/esm2022/lib/table/services/resolver.service.mjs +30 -7
  16. package/fesm2022/quadrel-enterprise-ui-framework.mjs +712 -577
  17. package/fesm2022/quadrel-enterprise-ui-framework.mjs.map +1 -1
  18. package/lib/dialog/dialog.component.d.ts +15 -6
  19. package/lib/dialog/dialog.component.d.ts.map +1 -1
  20. package/lib/dialog/dialog.module.d.ts +3 -3
  21. package/lib/dialog/dialog.module.d.ts.map +1 -1
  22. package/lib/dialog/directives/pending-changes-guard.directive.d.ts +5 -5
  23. package/lib/dialog/directives/pending-changes-guard.directive.d.ts.map +1 -1
  24. package/lib/dialog/models/dialog-close.model.d.ts +51 -0
  25. package/lib/dialog/models/dialog-close.model.d.ts.map +1 -0
  26. package/lib/dialog/models/page-dialog-host.token.d.ts +10 -0
  27. package/lib/dialog/models/page-dialog-host.token.d.ts.map +1 -0
  28. package/lib/dialog/services/confirmation-dialog.service.d.ts.map +1 -1
  29. package/lib/dialog/services/dialog.service.d.ts +20 -4
  30. package/lib/dialog/services/dialog.service.d.ts.map +1 -1
  31. package/lib/forms/input/input.component.d.ts.map +1 -1
  32. package/lib/page/model/page-config.interface.d.ts +14 -1
  33. package/lib/page/model/page-config.interface.d.ts.map +1 -1
  34. package/lib/page/page.component.d.ts +5 -2
  35. package/lib/page/page.component.d.ts.map +1 -1
  36. package/lib/shell/header/service-navigation/shell-service-navigation.component.d.ts +1 -1
  37. package/lib/shell/header/service-navigation/shell-service-navigation.component.d.ts.map +1 -1
  38. package/lib/table/services/resolver.service.d.ts +2 -0
  39. package/lib/table/services/resolver.service.d.ts.map +1 -1
  40. package/package.json +2 -2
  41. package/src/assets/i18n/de.json +2 -0
  42. package/src/assets/i18n/en.json +11 -1
  43. package/src/assets/i18n/fr.json +2 -0
  44. package/src/assets/i18n/it.json +2 -0
  45. package/src/assets/styles/settings/_settings.grid.scss +4 -1
@@ -1,9 +1,9 @@
1
1
  import { Dialog } from '@angular/cdk/dialog';
2
- import { Injectable } from '@angular/core';
2
+ import { Inject, Injectable, Optional } from '@angular/core';
3
3
  import { Router } from '@angular/router';
4
4
  import { BehaviorSubject, Subject } from 'rxjs';
5
5
  import { QdDialogSize } from '../models/dialog-config.model';
6
- import { QdPageDialogWithBreadcrumbsComponent } from '../page-dialog-with-breadcrumbs/page-dialog-with-breadcrumbs.component';
6
+ import { QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST } from '../models/page-dialog-host.token';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/cdk/dialog";
9
9
  import * as i2 from "@angular/router";
@@ -14,10 +14,13 @@ import * as i2 from "@angular/router";
14
14
  export class QdDialogService {
15
15
  dialog;
16
16
  router;
17
+ pageDialogHost;
17
18
  _currentRowSubject = new BehaviorSubject({});
18
19
  currentRow$ = this._currentRowSubject.asObservable();
19
20
  _currentIndexSubject = new Subject();
20
21
  currentIndex$ = this._currentIndexSubject.asObservable();
22
+ _pageDialogCanClose$ = new BehaviorSubject(null);
23
+ pageDialogCanClose$ = this._pageDialogCanClose$.asObservable();
21
24
  _confirmationStatus = 'info';
22
25
  _isConfirmationLoading = false;
23
26
  _dialogData = { navigation: false, initialPaginationIndex: 0, views: [] };
@@ -42,14 +45,16 @@ export class QdDialogService {
42
45
  get dialogData() {
43
46
  return this._dialogData;
44
47
  }
45
- constructor(dialog, router) {
48
+ constructor(dialog, router, pageDialogHost) {
46
49
  this.dialog = dialog;
47
50
  this.router = router;
51
+ this.pageDialogHost = pageDialogHost;
48
52
  }
49
53
  open(component, config) {
50
54
  config.panelClass = 'qd-custom-panel';
51
55
  config.width = config.dialogSize || QdDialogSize.Default;
52
56
  if (config.dialogSize === QdDialogSize.FullWidth) {
57
+ config.disableClose = true;
53
58
  config.maxWidth = '100vw';
54
59
  config.width = '100vw';
55
60
  config.maxHeight = '100vh';
@@ -62,14 +67,18 @@ export class QdDialogService {
62
67
  return this.dialog.open(component, config);
63
68
  }
64
69
  openPageDialogWithBreadcrumbs(routePath, data) {
70
+ this.clearPageDialogCanCloseForce();
65
71
  this.updateDialogData(data);
66
- this.open(QdPageDialogWithBreadcrumbsComponent, { dialogSize: QdDialogSize.FullWidth });
72
+ if (!this.pageDialogHost)
73
+ throw new Error('QdDialogService | Page dialog host component is not provided.');
74
+ this.open(this.pageDialogHost, { dialogSize: QdDialogSize.FullWidth });
67
75
  this.navigateInsideDialog(routePath || this.getFirstDialogOutletRoutePathOrThrow());
68
76
  }
69
77
  navigateInsideDialog(routePath) {
70
78
  this.router.navigate(['/', { outlets: { dialog: routePath } }]);
71
79
  }
72
80
  closeAll() {
81
+ this.clearPageDialogCanCloseForce();
73
82
  this.dialog.closeAll();
74
83
  }
75
84
  startConfirmation() {
@@ -91,11 +100,25 @@ export class QdDialogService {
91
100
  this._currentRowSubject.next(this._dialogData.views?.[index]);
92
101
  this._currentIndexSubject.next(index);
93
102
  }
103
+ setPageDialogCanClose(fn, owner) {
104
+ this._pageDialogCanClose$.next({ owner, fn });
105
+ }
106
+ clearPageDialogCanClose(owner) {
107
+ const entry = this._pageDialogCanClose$.value;
108
+ if (!entry)
109
+ return;
110
+ if (entry.owner !== owner)
111
+ return;
112
+ this._pageDialogCanClose$.next(null);
113
+ }
114
+ clearPageDialogCanCloseForce() {
115
+ this._pageDialogCanClose$.next(null);
116
+ }
94
117
  updateDialogData(data) {
95
118
  if (!data || typeof data !== 'object')
96
119
  return;
97
120
  Object.entries(data).forEach(([key, value]) => {
98
- if (!value)
121
+ if (value === undefined || value === null)
99
122
  return;
100
123
  if (key === 'initialPaginationIndex') {
101
124
  this._dialogData[key] = data['views'] && value >= 0 ? Math.min(value, data['views'].length - 1) : 0;
@@ -116,7 +139,7 @@ export class QdDialogService {
116
139
  hasRoutePathParameters(routePath) {
117
140
  return routePath.includes(':');
118
141
  }
119
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogService, deps: [{ token: i1.Dialog }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Injectable });
142
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogService, deps: [{ token: i1.Dialog }, { token: i2.Router }, { token: QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
120
143
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogService, providedIn: 'root' });
121
144
  }
122
145
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogService, decorators: [{
@@ -124,5 +147,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
124
147
  args: [{
125
148
  providedIn: 'root'
126
149
  }]
127
- }], ctorParameters: () => [{ type: i1.Dialog }, { type: i2.Router }] });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/dialog/services/dialog.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAA2B,MAAM,qBAAqB,CAAC;AAEtE,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAEhD,OAAO,EAAkB,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAE7E,OAAO,EAAE,oCAAoC,EAAE,MAAM,wEAAwE,CAAC;;;;AAE9H;;;GAGG;AAIH,MAAM,OAAO,eAAe;IAwChB;IACA;IAxCF,kBAAkB,GAAG,IAAI,eAAe,CAAM,EAAE,CAAC,CAAC;IAC1D,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IAE7C,oBAAoB,GAAG,IAAI,OAAO,EAAU,CAAC;IACrD,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,YAAY,EAAE,CAAC;IAEjD,mBAAmB,GAAyB,MAAM,CAAC;IACnD,sBAAsB,GAAG,KAAK,CAAC;IAC/B,WAAW,GAAiB,EAAE,UAAU,EAAE,KAAK,EAAE,sBAAsB,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;IAEhG,IAAI,kBAAkB;QACpB,OAAO,EAAE,kBAAkB,EAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC1D,CAAC;IAED,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,sBAAsB,CAAC;IACrC,CAAC;IAED,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,mBAAmB,KAAK,MAAM,CAAC;IAC7C,CAAC;IAED,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,mBAAmB,KAAK,SAAS,CAAC;IAChD,CAAC;IAED,IAAI,mBAAmB;QACrB,OAAO,IAAI,CAAC,mBAAmB,KAAK,OAAO,CAAC;IAC9C,CAAC;IAED,IAAI,UAAU,CAAC,IAAkB;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,YACU,MAAc,EACd,MAAc;QADd,WAAM,GAAN,MAAM,CAAQ;QACd,WAAM,GAAN,MAAM,CAAQ;IACrB,CAAC;IAEJ,IAAI,CAAI,SAA2B,EAAE,MAAsB;QACzD,MAAM,CAAC,UAAU,GAAG,iBAAiB,CAAC;QACtC,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,UAAU,IAAI,YAAY,CAAC,OAAO,CAAC;QAEzD,IAAI,MAAM,CAAC,UAAU,KAAK,YAAY,CAAC,SAAS,EAAE,CAAC;YACjD,MAAM,CAAC,QAAQ,GAAG,OAAO,CAAC;YAC1B,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC;YACvB,MAAM,CAAC,SAAS,GAAG,OAAO,CAAC;YAC3B,MAAM,CAAC,MAAM,GAAG,OAAO,CAAC;QAC1B,CAAC;QAED,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,MAAgD,CAAC,CAAC;IACvF,CAAC;IAED,cAAc,CAAI,SAA2B,EAAE,MAAsB;QACnE,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAE9B,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,MAAgD,CAAC,CAAC;IACvF,CAAC;IAED,6BAA6B,CAAC,SAAkB,EAAE,IAA6B;QAC7E,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,IAAI,CAAC,oCAAoC,EAAE,EAAE,UAAU,EAAE,YAAY,CAAC,SAAS,EAAE,CAAC,CAAC;QACxF,IAAI,CAAC,oBAAoB,CAAC,SAAS,IAAI,IAAI,CAAC,oCAAoC,EAAE,CAAC,CAAC;IACtF,CAAC;IAED,oBAAoB,CAAC,SAAiB;QACpC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;IAClE,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;IACzB,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;IACrC,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;QACpC,IAAI,CAAC,mBAAmB,GAAG,SAAS,CAAC;IACvC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;QACpC,IAAI,CAAC,mBAAmB,GAAG,OAAO,CAAC;IACrC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;QACpC,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC;IACpC,CAAC;IAED,UAAU,CAAC,KAAa;QACtB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QAC9D,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAEO,gBAAgB,CAAC,IAA4B;QACnD,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ;YAAE,OAAO;QAE9C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YAC5C,IAAI,CAAC,KAAK;gBAAE,OAAO;YAEnB,IAAI,GAAG,KAAK,wBAAwB,EAAE,CAAC;gBACrC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACtG,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YAChC,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,oCAAoC;QAC1C,MAAM,0BAA0B,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,KAAK,QAAQ,CAAC,EAAE,IAAI,CAAC;QAErG,IAAI,CAAC,0BAA0B,IAAI,IAAI,CAAC,sBAAsB,CAAC,0BAA0B,CAAC,EAAE,CAAC;YAC3F,MAAM,IAAI,KAAK,CACb,yFAAyF;gBACvF,8DAA8D,CACjE,CAAC;QACJ,CAAC;QAED,OAAO,0BAA0B,CAAC;IACpC,CAAC;IAEO,sBAAsB,CAAC,SAAiB;QAC9C,OAAO,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;uGAnIU,eAAe;2GAAf,eAAe,cAFd,MAAM;;2FAEP,eAAe;kBAH3B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/portal';\nimport { Injectable } from '@angular/core';\n\nimport { Router } from '@angular/router';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport { QdConfirmationStatus } from '../models/confirmation.model';\nimport { QdDialogConfig, QdDialogSize } from '../models/dialog-config.model';\nimport { QdDialogData } from '../models/record-stepper.model';\nimport { QdPageDialogWithBreadcrumbsComponent } from '../page-dialog-with-breadcrumbs/page-dialog-with-breadcrumbs.component';\n\n/**\n * **QdDialogService**: Service for managing dialogs in the application.\n * This service provides methods to open, close, and manage the handling of dialog data.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class QdDialogService {\n  private _currentRowSubject = new BehaviorSubject<any>({});\n  currentRow$ = this._currentRowSubject.asObservable();\n\n  private _currentIndexSubject = new Subject<number>();\n  currentIndex$ = this._currentIndexSubject.asObservable();\n\n  private _confirmationStatus: QdConfirmationStatus = 'info';\n  private _isConfirmationLoading = false;\n  private _dialogData: QdDialogData = { navigation: false, initialPaginationIndex: 0, views: [] };\n\n  get confirmationStatus(): { confirmationStatus: QdConfirmationStatus } {\n    return { confirmationStatus: this._confirmationStatus };\n  }\n\n  get isConfirmationLoading(): boolean {\n    return this._isConfirmationLoading;\n  }\n\n  get isConfirmationInfo(): boolean {\n    return this._confirmationStatus === 'info';\n  }\n\n  get isConfirmationSuccess(): boolean {\n    return this._confirmationStatus === 'success';\n  }\n\n  get isConfirmationError(): boolean {\n    return this._confirmationStatus === 'error';\n  }\n\n  set dialogData(data: QdDialogData) {\n    this._dialogData = data;\n  }\n\n  get dialogData(): QdDialogData {\n    return this._dialogData;\n  }\n\n  constructor(\n    private dialog: Dialog,\n    private router: Router\n  ) {}\n\n  open<C>(component: ComponentType<C>, config: QdDialogConfig): DialogRef<unknown, C> {\n    config.panelClass = 'qd-custom-panel';\n    config.width = config.dialogSize || QdDialogSize.Default;\n\n    if (config.dialogSize === QdDialogSize.FullWidth) {\n      config.maxWidth = '100vw';\n      config.width = '100vw';\n      config.maxHeight = '100vh';\n      config.height = '100vh';\n    }\n\n    return this.dialog.open(component, config as DialogConfig<C, DialogRef<unknown, C>>);\n  }\n\n  openFullscreen<C>(component: ComponentType<C>, config: QdDialogConfig): DialogRef<unknown, C> {\n    this.updateDialogData(config);\n\n    return this.dialog.open(component, config as DialogConfig<C, DialogRef<unknown, C>>);\n  }\n\n  openPageDialogWithBreadcrumbs(routePath?: string, data?: { [key: string]: any }): void {\n    this.updateDialogData(data);\n    this.open(QdPageDialogWithBreadcrumbsComponent, { dialogSize: QdDialogSize.FullWidth });\n    this.navigateInsideDialog(routePath || this.getFirstDialogOutletRoutePathOrThrow());\n  }\n\n  navigateInsideDialog(routePath: string): void {\n    this.router.navigate(['/', { outlets: { dialog: routePath } }]);\n  }\n\n  closeAll(): void {\n    this.dialog.closeAll();\n  }\n\n  startConfirmation(): void {\n    this._isConfirmationLoading = true;\n  }\n\n  confirmationSuccess(): void {\n    this._isConfirmationLoading = false;\n    this._confirmationStatus = 'success';\n  }\n\n  confirmationError(): void {\n    this._isConfirmationLoading = false;\n    this._confirmationStatus = 'error';\n  }\n\n  resetConfirmation(): void {\n    this._isConfirmationLoading = false;\n    this._confirmationStatus = 'info';\n  }\n\n  updateStep(index: number): void {\n    this._currentRowSubject.next(this._dialogData.views?.[index]);\n    this._currentIndexSubject.next(index);\n  }\n\n  private updateDialogData(data: { [key: string]: any }): void {\n    if (!data || typeof data !== 'object') return;\n\n    Object.entries(data).forEach(([key, value]) => {\n      if (!value) return;\n\n      if (key === 'initialPaginationIndex') {\n        this._dialogData[key] = data['views'] && value >= 0 ? Math.min(value, data['views'].length - 1) : 0;\n      } else {\n        this._dialogData[key] = value;\n      }\n    });\n  }\n\n  private getFirstDialogOutletRoutePathOrThrow(): string {\n    const firstDialogOutletRoutePath = this.router.config.find(route => route.outlet === 'dialog')?.path;\n\n    if (!firstDialogOutletRoutePath || this.hasRoutePathParameters(firstDialogOutletRoutePath)) {\n      throw new Error(\n        'QdDialogService | Please provide a route for the openPageDialogWithBreadcrumbs method. ' +\n          'The main dialog route could not be determined automatically.'\n      );\n    }\n\n    return firstDialogOutletRoutePath;\n  }\n\n  private hasRoutePathParameters(routePath: string): boolean {\n    return routePath.includes(':');\n  }\n}\n"]}
150
+ }], ctorParameters: () => [{ type: i1.Dialog }, { type: i2.Router }, { type: undefined, decorators: [{
151
+ type: Optional
152
+ }, {
153
+ type: Inject,
154
+ args: [QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST]
155
+ }] }] });
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/dialog/services/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/portal';\nimport { Inject, Injectable, Optional } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\n\nimport { QdConfirmationStatus } from '../models/confirmation.model';\nimport { QdDialogConfig, QdDialogSize } from '../models/dialog-config.model';\nimport { QdPageDialogCanCloseFn } from '../models/dialog-close.model';\nimport { QdDialogData } from '../models/record-stepper.model';\nimport { QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST } from '../models/page-dialog-host.token';\n\n/**\n * Entry for the Page Dialog close contract.\n * Owner-bound so multiple dialogs cannot accidentally consume each other’s contracts.\n */\nexport type QdPageDialogCanCloseEntry = { owner: DialogRef<unknown>; fn: QdPageDialogCanCloseFn } | null;\n\n/**\n * **QdDialogService**: Service for managing dialogs in the application.\n * This service provides methods to open, close, and manage the handling of dialog data.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class QdDialogService {\n  private _currentRowSubject = new BehaviorSubject<unknown>({});\n  currentRow$: Observable<unknown> = this._currentRowSubject.asObservable();\n\n  private _currentIndexSubject = new Subject<number>();\n  currentIndex$: Observable<number> = this._currentIndexSubject.asObservable();\n\n  private _pageDialogCanClose$ = new BehaviorSubject<QdPageDialogCanCloseEntry>(null);\n  pageDialogCanClose$: Observable<QdPageDialogCanCloseEntry> = this._pageDialogCanClose$.asObservable();\n\n  private _confirmationStatus: QdConfirmationStatus = 'info';\n  private _isConfirmationLoading = false;\n  private _dialogData: QdDialogData = { navigation: false, initialPaginationIndex: 0, views: [] };\n\n  get confirmationStatus(): { confirmationStatus: QdConfirmationStatus } {\n    return { confirmationStatus: this._confirmationStatus };\n  }\n\n  get isConfirmationLoading(): boolean {\n    return this._isConfirmationLoading;\n  }\n\n  get isConfirmationInfo(): boolean {\n    return this._confirmationStatus === 'info';\n  }\n\n  get isConfirmationSuccess(): boolean {\n    return this._confirmationStatus === 'success';\n  }\n\n  get isConfirmationError(): boolean {\n    return this._confirmationStatus === 'error';\n  }\n\n  set dialogData(data: QdDialogData) {\n    this._dialogData = data;\n  }\n\n  get dialogData(): QdDialogData {\n    return this._dialogData;\n  }\n\n  constructor(\n    private dialog: Dialog,\n    private router: Router,\n    @Optional() @Inject(QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST) private pageDialogHost?: ComponentType<unknown>\n  ) {}\n\n  open<C>(component: ComponentType<C>, config: QdDialogConfig): DialogRef<unknown, C> {\n    config.panelClass = 'qd-custom-panel';\n    config.width = config.dialogSize || QdDialogSize.Default;\n\n    if (config.dialogSize === QdDialogSize.FullWidth) {\n      config.disableClose = true;\n      config.maxWidth = '100vw';\n      config.width = '100vw';\n      config.maxHeight = '100vh';\n      config.height = '100vh';\n    }\n\n    return this.dialog.open(component, config as DialogConfig<C, DialogRef<unknown, C>>);\n  }\n\n  openFullscreen<C>(component: ComponentType<C>, config: QdDialogConfig): DialogRef<unknown, C> {\n    this.updateDialogData(config);\n\n    return this.dialog.open(component, config as DialogConfig<C, DialogRef<unknown, C>>);\n  }\n\n  openPageDialogWithBreadcrumbs(routePath?: string, data?: { [key: string]: any }): void {\n    this.clearPageDialogCanCloseForce();\n    this.updateDialogData(data);\n\n    if (!this.pageDialogHost) throw new Error('QdDialogService | Page dialog host component is not provided.');\n\n    this.open(this.pageDialogHost, { dialogSize: QdDialogSize.FullWidth });\n    this.navigateInsideDialog(routePath || this.getFirstDialogOutletRoutePathOrThrow());\n  }\n\n  navigateInsideDialog(routePath: string): void {\n    this.router.navigate(['/', { outlets: { dialog: routePath } }]);\n  }\n\n  closeAll(): void {\n    this.clearPageDialogCanCloseForce();\n    this.dialog.closeAll();\n  }\n\n  startConfirmation(): void {\n    this._isConfirmationLoading = true;\n  }\n\n  confirmationSuccess(): void {\n    this._isConfirmationLoading = false;\n    this._confirmationStatus = 'success';\n  }\n\n  confirmationError(): void {\n    this._isConfirmationLoading = false;\n    this._confirmationStatus = 'error';\n  }\n\n  resetConfirmation(): void {\n    this._isConfirmationLoading = false;\n    this._confirmationStatus = 'info';\n  }\n\n  updateStep(index: number): void {\n    this._currentRowSubject.next(this._dialogData.views?.[index]);\n    this._currentIndexSubject.next(index);\n  }\n\n  setPageDialogCanClose(fn: QdPageDialogCanCloseFn, owner: DialogRef<unknown>): void {\n    this._pageDialogCanClose$.next({ owner, fn });\n  }\n\n  clearPageDialogCanClose(owner: DialogRef<unknown>): void {\n    const entry = this._pageDialogCanClose$.value;\n    if (!entry) return;\n    if (entry.owner !== owner) return;\n\n    this._pageDialogCanClose$.next(null);\n  }\n\n  clearPageDialogCanCloseForce(): void {\n    this._pageDialogCanClose$.next(null);\n  }\n\n  private updateDialogData(data: { [key: string]: any } | void): void {\n    if (!data || typeof data !== 'object') return;\n\n    Object.entries(data).forEach(([key, value]) => {\n      if (value === undefined || value === null) return;\n\n      if (key === 'initialPaginationIndex') {\n        this._dialogData[key] = data['views'] && value >= 0 ? Math.min(value, data['views'].length - 1) : 0;\n      } else {\n        this._dialogData[key] = value;\n      }\n    });\n  }\n\n  private getFirstDialogOutletRoutePathOrThrow(): string {\n    const firstDialogOutletRoutePath = this.router.config.find(route => route.outlet === 'dialog')?.path;\n\n    if (!firstDialogOutletRoutePath || this.hasRoutePathParameters(firstDialogOutletRoutePath)) {\n      throw new Error(\n        'QdDialogService | Please provide a route for the openPageDialogWithBreadcrumbs method. ' +\n          'The main dialog route could not be determined automatically.'\n      );\n    }\n\n    return firstDialogOutletRoutePath;\n  }\n\n  private hasRoutePathParameters(routePath: string): boolean {\n    return routePath.includes(':');\n  }\n}\n"]}
@@ -25,10 +25,10 @@ export class QdFileCollectorAllowedFilesDescriptionComponent {
25
25
  this.fileCollectorService = fileCollectorService;
26
26
  }
27
27
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdFileCollectorAllowedFilesDescriptionComponent, deps: [{ token: i1.QdFileCollectorService }], target: i0.ɵɵFactoryTarget.Component });
28
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdFileCollectorAllowedFilesDescriptionComponent, selector: "qd-file-collector-allowed-files-description", ngImport: i0, template: "<span *ngIf=\"allowedFilesDescriptionI18n\"\n >{{ allowedFilesDescriptionI18n | translate | placeholder : \"allowedFileTypes\" : allowedFileTypes.join(', ') |\n placeholder : \"maxFileSize\" : (maxFileSizeInBytes | filesize | async) }}</span\n>\n<ng-container *ngIf=\"allowedFilesDescriptionI18n === undefined\">\n <span *ngIf=\"allowedFileTypes.length > 0\"\n >{{ \"i18n.qd.fileCollector.allowedFilesDescription.allowedFileTypes\" | translate | placeholder : \"allowedFileTypes\"\n : allowedFileTypes.join(', ') }}</span\n >\n <span *ngIf=\"maxFileSizeInBytes\"\n >{{ \"i18n.qd.fileCollector.allowedFilesDescription.maxFileSize\" | translate | placeholder : \"maxFileSize\" :\n (maxFileSizeInBytes | filesize | async) }}</span\n >\n</ng-container>\n", styles: [":host span{color:#333;font-size:.875rem;font-weight:400;line-height:1.3125rem;display:block;white-space:pre-wrap}:host span:last-child{margin-bottom:1rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.QdPlaceholderPipe, name: "placeholder" }, { kind: "pipe", type: i5.QdFileSizePipe, name: "filesize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
28
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdFileCollectorAllowedFilesDescriptionComponent, selector: "qd-file-collector-allowed-files-description", ngImport: i0, template: "<span *ngIf=\"allowedFilesDescriptionI18n\">{{\n allowedFilesDescriptionI18n\n | translate\n | placeholder : \"allowedFileTypes\" : allowedFileTypes.join(\", \")\n | placeholder : \"maxFileSize\" : (maxFileSizeInBytes | filesize | async)\n}}</span>\n<ng-container *ngIf=\"allowedFilesDescriptionI18n === undefined\">\n <span *ngIf=\"allowedFileTypes.length > 0\">{{\n \"i18n.qd.fileCollector.allowedFilesDescription.allowedFileTypes\"\n | translate\n | placeholder : \"allowedFileTypes\" : allowedFileTypes.join(\", \")\n }}</span>\n <span *ngIf=\"maxFileSizeInBytes\">{{\n \"i18n.qd.fileCollector.allowedFilesDescription.maxFileSize\"\n | translate\n | placeholder : \"maxFileSize\" : (maxFileSizeInBytes | filesize | async)\n }}</span>\n</ng-container>\n", styles: [":host span{color:#333;font-size:.875rem;font-weight:400;line-height:1.3125rem;display:block;white-space:pre-wrap}:host span:last-child{margin-bottom:1rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.QdPlaceholderPipe, name: "placeholder" }, { kind: "pipe", type: i5.QdFileSizePipe, name: "filesize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
29
29
  }
30
30
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdFileCollectorAllowedFilesDescriptionComponent, decorators: [{
31
31
  type: Component,
32
- args: [{ selector: 'qd-file-collector-allowed-files-description', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span *ngIf=\"allowedFilesDescriptionI18n\"\n >{{ allowedFilesDescriptionI18n | translate | placeholder : \"allowedFileTypes\" : allowedFileTypes.join(', ') |\n placeholder : \"maxFileSize\" : (maxFileSizeInBytes | filesize | async) }}</span\n>\n<ng-container *ngIf=\"allowedFilesDescriptionI18n === undefined\">\n <span *ngIf=\"allowedFileTypes.length > 0\"\n >{{ \"i18n.qd.fileCollector.allowedFilesDescription.allowedFileTypes\" | translate | placeholder : \"allowedFileTypes\"\n : allowedFileTypes.join(', ') }}</span\n >\n <span *ngIf=\"maxFileSizeInBytes\"\n >{{ \"i18n.qd.fileCollector.allowedFilesDescription.maxFileSize\" | translate | placeholder : \"maxFileSize\" :\n (maxFileSizeInBytes | filesize | async) }}</span\n >\n</ng-container>\n", styles: [":host span{color:#333;font-size:.875rem;font-weight:400;line-height:1.3125rem;display:block;white-space:pre-wrap}:host span:last-child{margin-bottom:1rem}\n"] }]
32
+ args: [{ selector: 'qd-file-collector-allowed-files-description', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span *ngIf=\"allowedFilesDescriptionI18n\">{{\n allowedFilesDescriptionI18n\n | translate\n | placeholder : \"allowedFileTypes\" : allowedFileTypes.join(\", \")\n | placeholder : \"maxFileSize\" : (maxFileSizeInBytes | filesize | async)\n}}</span>\n<ng-container *ngIf=\"allowedFilesDescriptionI18n === undefined\">\n <span *ngIf=\"allowedFileTypes.length > 0\">{{\n \"i18n.qd.fileCollector.allowedFilesDescription.allowedFileTypes\"\n | translate\n | placeholder : \"allowedFileTypes\" : allowedFileTypes.join(\", \")\n }}</span>\n <span *ngIf=\"maxFileSizeInBytes\">{{\n \"i18n.qd.fileCollector.allowedFilesDescription.maxFileSize\"\n | translate\n | placeholder : \"maxFileSize\" : (maxFileSizeInBytes | filesize | async)\n }}</span>\n</ng-container>\n", styles: [":host span{color:#333;font-size:.875rem;font-weight:400;line-height:1.3125rem;display:block;white-space:pre-wrap}:host span:last-child{margin-bottom:1rem}\n"] }]
33
33
  }], ctorParameters: () => [{ type: i1.QdFileCollectorService }] });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1jb2xsZWN0b3ItYWxsb3dlZC1maWxlcy1kZXNjcmlwdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3FkLXVpL3NyYy9saWIvZmlsZS1jb2xsZWN0b3IvYWxsb3dlZC1maWxlcy1kZXNjcmlwdGlvbi9maWxlLWNvbGxlY3Rvci1hbGxvd2VkLWZpbGVzLWRlc2NyaXB0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9maWxlLWNvbGxlY3Rvci9hbGxvd2VkLWZpbGVzLWRlc2NyaXB0aW9uL2ZpbGUtY29sbGVjdG9yLWFsbG93ZWQtZmlsZXMtZGVzY3JpcHRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsb0JBQW9CO0FBQ3BCLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHbkUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7Ozs7Ozs7QUFRNUUsTUFBTSxPQUFPLCtDQUErQztJQWlCN0I7SUFoQjdCLElBQUksZ0JBQWdCO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxnQkFBZ0IsSUFBSSxFQUFFLENBQUM7SUFDN0MsQ0FBQztJQUVELElBQUksa0JBQWtCO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxrQkFBa0IsQ0FBQztJQUN6QyxDQUFDO0lBRUQsSUFBSSwyQkFBMkI7UUFDN0IsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLDJCQUEyQixDQUFDO0lBQ2xELENBQUM7SUFFRCxJQUFZLE1BQU07UUFDaEIsT0FBTyxJQUFJLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDO0lBQzFDLENBQUM7SUFFRCxZQUE2QixvQkFBNEM7UUFBNUMseUJBQW9CLEdBQXBCLG9CQUFvQixDQUF3QjtJQUFHLENBQUM7dUdBakJsRSwrQ0FBK0M7MkZBQS9DLCtDQUErQyxtRkNaNUQsa3dCQWNBOzsyRkRGYSwrQ0FBK0M7a0JBTjNELFNBQVM7K0JBQ0UsNkNBQTZDLG1CQUd0Qyx1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLXN0cmljdC1pZ25vcmVcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFFkRmlsZUNvbGxlY3RvckNvbmZpZyB9IGZyb20gJy4uL21vZGVscy9maWxlLWNvbGxlY3Rvci1jb25maWcnO1xuaW1wb3J0IHsgUWRGaWxlVHlwZSB9IGZyb20gJy4uL21vZGVscy9maWxlLXR5cGUnO1xuaW1wb3J0IHsgUWRGaWxlQ29sbGVjdG9yU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2ZpbGUtY29sbGVjdG9yLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdxZC1maWxlLWNvbGxlY3Rvci1hbGxvd2VkLWZpbGVzLWRlc2NyaXB0aW9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpbGUtY29sbGVjdG9yLWFsbG93ZWQtZmlsZXMtZGVzY3JpcHRpb24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9maWxlLWNvbGxlY3Rvci1hbGxvd2VkLWZpbGVzLWRlc2NyaXB0aW9uLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFFkRmlsZUNvbGxlY3RvckFsbG93ZWRGaWxlc0Rlc2NyaXB0aW9uQ29tcG9uZW50IHtcbiAgZ2V0IGFsbG93ZWRGaWxlVHlwZXMoKTogUWRGaWxlVHlwZVtdIHtcbiAgICByZXR1cm4gdGhpcy5jb25maWc/LmFsbG93ZWRGaWxlVHlwZXMgfHwgW107XG4gIH1cblxuICBnZXQgbWF4RmlsZVNpemVJbkJ5dGVzKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnPy5tYXhGaWxlU2l6ZUluQnl0ZXM7XG4gIH1cblxuICBnZXQgYWxsb3dlZEZpbGVzRGVzY3JpcHRpb25JMThuKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnPy5hbGxvd2VkRmlsZXNEZXNjcmlwdGlvbkkxOG47XG4gIH1cblxuICBwcml2YXRlIGdldCBjb25maWcoKTogUWRGaWxlQ29sbGVjdG9yQ29uZmlnIHtcbiAgICByZXR1cm4gdGhpcy5maWxlQ29sbGVjdG9yU2VydmljZS5jb25maWc7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGZpbGVDb2xsZWN0b3JTZXJ2aWNlOiBRZEZpbGVDb2xsZWN0b3JTZXJ2aWNlKSB7fVxufVxuIiwiPHNwYW4gKm5nSWY9XCJhbGxvd2VkRmlsZXNEZXNjcmlwdGlvbkkxOG5cIlxuICA+e3sgYWxsb3dlZEZpbGVzRGVzY3JpcHRpb25JMThuIHwgdHJhbnNsYXRlIHwgcGxhY2Vob2xkZXIgOiBcImFsbG93ZWRGaWxlVHlwZXNcIiA6IGFsbG93ZWRGaWxlVHlwZXMuam9pbignLCAnKSB8XG4gIHBsYWNlaG9sZGVyIDogXCJtYXhGaWxlU2l6ZVwiIDogKG1heEZpbGVTaXplSW5CeXRlcyB8IGZpbGVzaXplIHwgYXN5bmMpIH19PC9zcGFuXG4+XG48bmctY29udGFpbmVyICpuZ0lmPVwiYWxsb3dlZEZpbGVzRGVzY3JpcHRpb25JMThuID09PSB1bmRlZmluZWRcIj5cbiAgPHNwYW4gKm5nSWY9XCJhbGxvd2VkRmlsZVR5cGVzLmxlbmd0aCA+IDBcIlxuICAgID57eyBcImkxOG4ucWQuZmlsZUNvbGxlY3Rvci5hbGxvd2VkRmlsZXNEZXNjcmlwdGlvbi5hbGxvd2VkRmlsZVR5cGVzXCIgfCB0cmFuc2xhdGUgfCBwbGFjZWhvbGRlciA6IFwiYWxsb3dlZEZpbGVUeXBlc1wiXG4gICAgOiBhbGxvd2VkRmlsZVR5cGVzLmpvaW4oJywgJykgfX08L3NwYW5cbiAgPlxuICA8c3BhbiAqbmdJZj1cIm1heEZpbGVTaXplSW5CeXRlc1wiXG4gICAgPnt7IFwiaTE4bi5xZC5maWxlQ29sbGVjdG9yLmFsbG93ZWRGaWxlc0Rlc2NyaXB0aW9uLm1heEZpbGVTaXplXCIgfCB0cmFuc2xhdGUgfCBwbGFjZWhvbGRlciA6IFwibWF4RmlsZVNpemVcIiA6XG4gICAgKG1heEZpbGVTaXplSW5CeXRlcyB8IGZpbGVzaXplIHwgYXN5bmMpIH19PC9zcGFuXG4gID5cbjwvbmctY29udGFpbmVyPlxuIl19
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1jb2xsZWN0b3ItYWxsb3dlZC1maWxlcy1kZXNjcmlwdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3FkLXVpL3NyYy9saWIvZmlsZS1jb2xsZWN0b3IvYWxsb3dlZC1maWxlcy1kZXNjcmlwdGlvbi9maWxlLWNvbGxlY3Rvci1hbGxvd2VkLWZpbGVzLWRlc2NyaXB0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9maWxlLWNvbGxlY3Rvci9hbGxvd2VkLWZpbGVzLWRlc2NyaXB0aW9uL2ZpbGUtY29sbGVjdG9yLWFsbG93ZWQtZmlsZXMtZGVzY3JpcHRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsb0JBQW9CO0FBQ3BCLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHbkUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7Ozs7Ozs7QUFRNUUsTUFBTSxPQUFPLCtDQUErQztJQWlCN0I7SUFoQjdCLElBQUksZ0JBQWdCO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxnQkFBZ0IsSUFBSSxFQUFFLENBQUM7SUFDN0MsQ0FBQztJQUVELElBQUksa0JBQWtCO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxrQkFBa0IsQ0FBQztJQUN6QyxDQUFDO0lBRUQsSUFBSSwyQkFBMkI7UUFDN0IsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLDJCQUEyQixDQUFDO0lBQ2xELENBQUM7SUFFRCxJQUFZLE1BQU07UUFDaEIsT0FBTyxJQUFJLENBQUMsb0JBQW9CLENBQUMsTUFBTSxDQUFDO0lBQzFDLENBQUM7SUFFRCxZQUE2QixvQkFBNEM7UUFBNUMseUJBQW9CLEdBQXBCLG9CQUFvQixDQUF3QjtJQUFHLENBQUM7dUdBakJsRSwrQ0FBK0M7MkZBQS9DLCtDQUErQyxtRkNaNUQsOHhCQWtCQTs7MkZETmEsK0NBQStDO2tCQU4zRCxTQUFTOytCQUNFLDZDQUE2QyxtQkFHdEMsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbIi8vIEB0cy1zdHJpY3QtaWdub3JlXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBRZEZpbGVDb2xsZWN0b3JDb25maWcgfSBmcm9tICcuLi9tb2RlbHMvZmlsZS1jb2xsZWN0b3ItY29uZmlnJztcbmltcG9ydCB7IFFkRmlsZVR5cGUgfSBmcm9tICcuLi9tb2RlbHMvZmlsZS10eXBlJztcbmltcG9ydCB7IFFkRmlsZUNvbGxlY3RvclNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9maWxlLWNvbGxlY3Rvci5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncWQtZmlsZS1jb2xsZWN0b3ItYWxsb3dlZC1maWxlcy1kZXNjcmlwdGlvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWxlLWNvbGxlY3Rvci1hbGxvd2VkLWZpbGVzLWRlc2NyaXB0aW9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsZS1jb2xsZWN0b3ItYWxsb3dlZC1maWxlcy1kZXNjcmlwdGlvbi5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBRZEZpbGVDb2xsZWN0b3JBbGxvd2VkRmlsZXNEZXNjcmlwdGlvbkNvbXBvbmVudCB7XG4gIGdldCBhbGxvd2VkRmlsZVR5cGVzKCk6IFFkRmlsZVR5cGVbXSB7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnPy5hbGxvd2VkRmlsZVR5cGVzIHx8IFtdO1xuICB9XG5cbiAgZ2V0IG1heEZpbGVTaXplSW5CeXRlcygpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLmNvbmZpZz8ubWF4RmlsZVNpemVJbkJ5dGVzO1xuICB9XG5cbiAgZ2V0IGFsbG93ZWRGaWxlc0Rlc2NyaXB0aW9uSTE4bigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmNvbmZpZz8uYWxsb3dlZEZpbGVzRGVzY3JpcHRpb25JMThuO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXQgY29uZmlnKCk6IFFkRmlsZUNvbGxlY3RvckNvbmZpZyB7XG4gICAgcmV0dXJuIHRoaXMuZmlsZUNvbGxlY3RvclNlcnZpY2UuY29uZmlnO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBmaWxlQ29sbGVjdG9yU2VydmljZTogUWRGaWxlQ29sbGVjdG9yU2VydmljZSkge31cbn1cbiIsIjxzcGFuICpuZ0lmPVwiYWxsb3dlZEZpbGVzRGVzY3JpcHRpb25JMThuXCI+e3tcbiAgYWxsb3dlZEZpbGVzRGVzY3JpcHRpb25JMThuXG4gICAgfCB0cmFuc2xhdGVcbiAgICB8IHBsYWNlaG9sZGVyIDogXCJhbGxvd2VkRmlsZVR5cGVzXCIgOiBhbGxvd2VkRmlsZVR5cGVzLmpvaW4oXCIsIFwiKVxuICAgIHwgcGxhY2Vob2xkZXIgOiBcIm1heEZpbGVTaXplXCIgOiAobWF4RmlsZVNpemVJbkJ5dGVzIHwgZmlsZXNpemUgfCBhc3luYylcbn19PC9zcGFuPlxuPG5nLWNvbnRhaW5lciAqbmdJZj1cImFsbG93ZWRGaWxlc0Rlc2NyaXB0aW9uSTE4biA9PT0gdW5kZWZpbmVkXCI+XG4gIDxzcGFuICpuZ0lmPVwiYWxsb3dlZEZpbGVUeXBlcy5sZW5ndGggPiAwXCI+e3tcbiAgICBcImkxOG4ucWQuZmlsZUNvbGxlY3Rvci5hbGxvd2VkRmlsZXNEZXNjcmlwdGlvbi5hbGxvd2VkRmlsZVR5cGVzXCJcbiAgICAgIHwgdHJhbnNsYXRlXG4gICAgICB8IHBsYWNlaG9sZGVyIDogXCJhbGxvd2VkRmlsZVR5cGVzXCIgOiBhbGxvd2VkRmlsZVR5cGVzLmpvaW4oXCIsIFwiKVxuICB9fTwvc3Bhbj5cbiAgPHNwYW4gKm5nSWY9XCJtYXhGaWxlU2l6ZUluQnl0ZXNcIj57e1xuICAgIFwiaTE4bi5xZC5maWxlQ29sbGVjdG9yLmFsbG93ZWRGaWxlc0Rlc2NyaXB0aW9uLm1heEZpbGVTaXplXCJcbiAgICAgIHwgdHJhbnNsYXRlXG4gICAgICB8IHBsYWNlaG9sZGVyIDogXCJtYXhGaWxlU2l6ZVwiIDogKG1heEZpbGVTaXplSW5CeXRlcyB8IGZpbGVzaXplIHwgYXN5bmMpXG4gIH19PC9zcGFuPlxuPC9uZy1jb250YWluZXI+XG4iXX0=
@@ -28,12 +28,12 @@ export class QdFileCollectorDialogItemErrorComponent {
28
28
  this.fileCollectorService = fileCollectorService;
29
29
  }
30
30
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdFileCollectorDialogItemErrorComponent, deps: [{ token: i1.QdFileCollectorService }], target: i0.ɵɵFactoryTarget.Component });
31
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdFileCollectorDialogItemErrorComponent, selector: "qd-file-collector-dialog-item-error", inputs: { error: "error" }, ngImport: i0, template: "<span *ngIf=\"error.message; else errorMessageNotGiven\">{{ error.message }}</span>\n<ng-template #errorMessageNotGiven [ngSwitch]=\"error.type\">\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_MIME_TYPE\">{{\n invalidMimeTypeErrorMessageI18n || \"i18n.qd.fileCollector.invalid.fileType\" | translate\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_FILE_SIZE\">{{\n \"i18n.qd.fileCollector.invalid.fileSize\"\n | translate\n | placeholder: \"maxFileSize\" : (maxFileSizeInBytes | filesize | async)\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_FILE_NAME\">{{\n invalidFileNameErrorMessageI18n || \"i18n.qd.fileCollector.invalid.fileName\" | translate\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.UNKNOWN_ERROR\">{{ \"i18n.qd.fileCollector.invalid.unknown\" | translate }}</span>\n</ng-template>\n", styles: [":host{display:flex;width:100%;align-items:center}:host span{color:#c70023}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.QdPlaceholderPipe, name: "placeholder" }, { kind: "pipe", type: i5.QdFileSizePipe, name: "filesize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
31
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdFileCollectorDialogItemErrorComponent, selector: "qd-file-collector-dialog-item-error", inputs: { error: "error" }, ngImport: i0, template: "<span *ngIf=\"error.message; else errorMessageNotGiven\">{{ error.message }}</span>\n<ng-template #errorMessageNotGiven [ngSwitch]=\"error.type\">\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_MIME_TYPE\">{{\n invalidMimeTypeErrorMessageI18n || \"i18n.qd.fileCollector.invalid.fileType\" | translate\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_FILE_SIZE\">{{\n \"i18n.qd.fileCollector.invalid.fileSize\"\n | translate\n | placeholder : \"maxFileSize\" : (maxFileSizeInBytes | filesize | async)\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_FILE_NAME\">{{\n invalidFileNameErrorMessageI18n || \"i18n.qd.fileCollector.invalid.fileName\" | translate\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.UNKNOWN_ERROR\">{{ \"i18n.qd.fileCollector.invalid.unknown\" | translate }}</span>\n</ng-template>\n", styles: [":host{display:flex;width:100%;align-items:center}:host span{color:#c70023}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.QdPlaceholderPipe, name: "placeholder" }, { kind: "pipe", type: i5.QdFileSizePipe, name: "filesize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
32
32
  }
33
33
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdFileCollectorDialogItemErrorComponent, decorators: [{
34
34
  type: Component,
35
- args: [{ selector: 'qd-file-collector-dialog-item-error', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span *ngIf=\"error.message; else errorMessageNotGiven\">{{ error.message }}</span>\n<ng-template #errorMessageNotGiven [ngSwitch]=\"error.type\">\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_MIME_TYPE\">{{\n invalidMimeTypeErrorMessageI18n || \"i18n.qd.fileCollector.invalid.fileType\" | translate\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_FILE_SIZE\">{{\n \"i18n.qd.fileCollector.invalid.fileSize\"\n | translate\n | placeholder: \"maxFileSize\" : (maxFileSizeInBytes | filesize | async)\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_FILE_NAME\">{{\n invalidFileNameErrorMessageI18n || \"i18n.qd.fileCollector.invalid.fileName\" | translate\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.UNKNOWN_ERROR\">{{ \"i18n.qd.fileCollector.invalid.unknown\" | translate }}</span>\n</ng-template>\n", styles: [":host{display:flex;width:100%;align-items:center}:host span{color:#c70023}\n"] }]
35
+ args: [{ selector: 'qd-file-collector-dialog-item-error', changeDetection: ChangeDetectionStrategy.OnPush, template: "<span *ngIf=\"error.message; else errorMessageNotGiven\">{{ error.message }}</span>\n<ng-template #errorMessageNotGiven [ngSwitch]=\"error.type\">\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_MIME_TYPE\">{{\n invalidMimeTypeErrorMessageI18n || \"i18n.qd.fileCollector.invalid.fileType\" | translate\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_FILE_SIZE\">{{\n \"i18n.qd.fileCollector.invalid.fileSize\"\n | translate\n | placeholder : \"maxFileSize\" : (maxFileSizeInBytes | filesize | async)\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.INVALID_FILE_NAME\">{{\n invalidFileNameErrorMessageI18n || \"i18n.qd.fileCollector.invalid.fileName\" | translate\n }}</span>\n <span *ngSwitchCase=\"QdUploadErrorType.UNKNOWN_ERROR\">{{ \"i18n.qd.fileCollector.invalid.unknown\" | translate }}</span>\n</ng-template>\n", styles: [":host{display:flex;width:100%;align-items:center}:host span{color:#c70023}\n"] }]
36
36
  }], ctorParameters: () => [{ type: i1.QdFileCollectorService }], propDecorators: { error: [{
37
37
  type: Input
38
38
  }] } });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1jb2xsZWN0b3ItZGlhbG9nLWl0ZW0tZXJyb3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9xZC11aS9zcmMvbGliL2ZpbGUtY29sbGVjdG9yL2RpYWxvZy9pdGVtL2Vycm9yL2ZpbGUtY29sbGVjdG9yLWRpYWxvZy1pdGVtLWVycm9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9maWxlLWNvbGxlY3Rvci9kaWFsb2cvaXRlbS9lcnJvci9maWxlLWNvbGxlY3Rvci1kaWFsb2ctaXRlbS1lcnJvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxvQkFBb0I7QUFDcEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUUsT0FBTyxFQUFpQixpQkFBaUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQy9FLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDOzs7Ozs7O0FBU2xGLE1BQU0sT0FBTyx1Q0FBdUM7SUFxQnJCO0lBcEJwQixLQUFLLENBQWdCO0lBRVgsaUJBQWlCLEdBQUcsaUJBQWlCLENBQUM7SUFFekQsSUFBSSxrQkFBa0I7UUFDcEIsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLGtCQUFrQixDQUFDO0lBQ3pDLENBQUM7SUFFRCxJQUFJLCtCQUErQjtRQUNqQyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsK0JBQStCLENBQUM7SUFDdEQsQ0FBQztJQUVELElBQUksK0JBQStCO1FBQ2pDLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSwrQkFBK0IsQ0FBQztJQUN0RCxDQUFDO0lBRUQsSUFBWSxNQUFNO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sQ0FBQztJQUMxQyxDQUFDO0lBRUQsWUFBNkIsb0JBQTRDO1FBQTVDLHlCQUFvQixHQUFwQixvQkFBb0IsQ0FBd0I7SUFBRyxDQUFDO3VHQXJCbEUsdUNBQXVDOzJGQUF2Qyx1Q0FBdUMsdUdDWnBELGsyQkFlQTs7MkZESGEsdUNBQXVDO2tCQU5uRCxTQUFTOytCQUNFLHFDQUFxQyxtQkFHOUIsdUJBQXVCLENBQUMsTUFBTTsyRkFHdEMsS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLXN0cmljdC1pZ25vcmVcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBRZFVwbG9hZEVycm9yLCBRZFVwbG9hZEVycm9yVHlwZSB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9maWxlLXVwbG9hZCc7XG5pbXBvcnQgeyBRZEZpbGVDb2xsZWN0b3JTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvZmlsZS1jb2xsZWN0b3Iuc2VydmljZSc7XG5pbXBvcnQgeyBRZEZpbGVDb2xsZWN0b3JDb25maWcgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvZmlsZS1jb2xsZWN0b3ItY29uZmlnJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncWQtZmlsZS1jb2xsZWN0b3ItZGlhbG9nLWl0ZW0tZXJyb3InLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsZS1jb2xsZWN0b3ItZGlhbG9nLWl0ZW0tZXJyb3IuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9maWxlLWNvbGxlY3Rvci1kaWFsb2ctaXRlbS1lcnJvci5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBRZEZpbGVDb2xsZWN0b3JEaWFsb2dJdGVtRXJyb3JDb21wb25lbnQge1xuICBASW5wdXQoKSBlcnJvcjogUWRVcGxvYWRFcnJvcjtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgUWRVcGxvYWRFcnJvclR5cGUgPSBRZFVwbG9hZEVycm9yVHlwZTtcblxuICBnZXQgbWF4RmlsZVNpemVJbkJ5dGVzKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnPy5tYXhGaWxlU2l6ZUluQnl0ZXM7XG4gIH1cblxuICBnZXQgaW52YWxpZE1pbWVUeXBlRXJyb3JNZXNzYWdlSTE4bigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmNvbmZpZz8uaW52YWxpZE1pbWVUeXBlRXJyb3JNZXNzYWdlSTE4bjtcbiAgfVxuXG4gIGdldCBpbnZhbGlkRmlsZU5hbWVFcnJvck1lc3NhZ2VJMThuKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnPy5pbnZhbGlkRmlsZU5hbWVFcnJvck1lc3NhZ2VJMThuO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXQgY29uZmlnKCk6IFFkRmlsZUNvbGxlY3RvckNvbmZpZyB7XG4gICAgcmV0dXJuIHRoaXMuZmlsZUNvbGxlY3RvclNlcnZpY2UuY29uZmlnO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBmaWxlQ29sbGVjdG9yU2VydmljZTogUWRGaWxlQ29sbGVjdG9yU2VydmljZSkge31cbn1cbiIsIjxzcGFuICpuZ0lmPVwiZXJyb3IubWVzc2FnZTsgZWxzZSBlcnJvck1lc3NhZ2VOb3RHaXZlblwiPnt7IGVycm9yLm1lc3NhZ2UgfX08L3NwYW4+XG48bmctdGVtcGxhdGUgI2Vycm9yTWVzc2FnZU5vdEdpdmVuIFtuZ1N3aXRjaF09XCJlcnJvci50eXBlXCI+XG4gIDxzcGFuICpuZ1N3aXRjaENhc2U9XCJRZFVwbG9hZEVycm9yVHlwZS5JTlZBTElEX01JTUVfVFlQRVwiPnt7XG4gICAgaW52YWxpZE1pbWVUeXBlRXJyb3JNZXNzYWdlSTE4biB8fCBcImkxOG4ucWQuZmlsZUNvbGxlY3Rvci5pbnZhbGlkLmZpbGVUeXBlXCIgfCB0cmFuc2xhdGVcbiAgfX08L3NwYW4+XG4gIDxzcGFuICpuZ1N3aXRjaENhc2U9XCJRZFVwbG9hZEVycm9yVHlwZS5JTlZBTElEX0ZJTEVfU0laRVwiPnt7XG4gICAgXCJpMThuLnFkLmZpbGVDb2xsZWN0b3IuaW52YWxpZC5maWxlU2l6ZVwiXG4gICAgICB8IHRyYW5zbGF0ZVxuICAgICAgfCBwbGFjZWhvbGRlcjogXCJtYXhGaWxlU2l6ZVwiIDogKG1heEZpbGVTaXplSW5CeXRlcyB8IGZpbGVzaXplIHwgYXN5bmMpXG4gIH19PC9zcGFuPlxuICA8c3BhbiAqbmdTd2l0Y2hDYXNlPVwiUWRVcGxvYWRFcnJvclR5cGUuSU5WQUxJRF9GSUxFX05BTUVcIj57e1xuICAgIGludmFsaWRGaWxlTmFtZUVycm9yTWVzc2FnZUkxOG4gfHwgXCJpMThuLnFkLmZpbGVDb2xsZWN0b3IuaW52YWxpZC5maWxlTmFtZVwiIHwgdHJhbnNsYXRlXG4gIH19PC9zcGFuPlxuICA8c3BhbiAqbmdTd2l0Y2hDYXNlPVwiUWRVcGxvYWRFcnJvclR5cGUuVU5LTk9XTl9FUlJPUlwiPnt7IFwiaTE4bi5xZC5maWxlQ29sbGVjdG9yLmludmFsaWQudW5rbm93blwiIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1jb2xsZWN0b3ItZGlhbG9nLWl0ZW0tZXJyb3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9xZC11aS9zcmMvbGliL2ZpbGUtY29sbGVjdG9yL2RpYWxvZy9pdGVtL2Vycm9yL2ZpbGUtY29sbGVjdG9yLWRpYWxvZy1pdGVtLWVycm9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9maWxlLWNvbGxlY3Rvci9kaWFsb2cvaXRlbS9lcnJvci9maWxlLWNvbGxlY3Rvci1kaWFsb2ctaXRlbS1lcnJvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxvQkFBb0I7QUFDcEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUUsT0FBTyxFQUFpQixpQkFBaUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQy9FLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDOzs7Ozs7O0FBU2xGLE1BQU0sT0FBTyx1Q0FBdUM7SUFxQnJCO0lBcEJwQixLQUFLLENBQWdCO0lBRVgsaUJBQWlCLEdBQUcsaUJBQWlCLENBQUM7SUFFekQsSUFBSSxrQkFBa0I7UUFDcEIsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLGtCQUFrQixDQUFDO0lBQ3pDLENBQUM7SUFFRCxJQUFJLCtCQUErQjtRQUNqQyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsK0JBQStCLENBQUM7SUFDdEQsQ0FBQztJQUVELElBQUksK0JBQStCO1FBQ2pDLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSwrQkFBK0IsQ0FBQztJQUN0RCxDQUFDO0lBRUQsSUFBWSxNQUFNO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sQ0FBQztJQUMxQyxDQUFDO0lBRUQsWUFBNkIsb0JBQTRDO1FBQTVDLHlCQUFvQixHQUFwQixvQkFBb0IsQ0FBd0I7SUFBRyxDQUFDO3VHQXJCbEUsdUNBQXVDOzJGQUF2Qyx1Q0FBdUMsdUdDWnBELG0yQkFlQTs7MkZESGEsdUNBQXVDO2tCQU5uRCxTQUFTOytCQUNFLHFDQUFxQyxtQkFHOUIsdUJBQXVCLENBQUMsTUFBTTsyRkFHdEMsS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLXN0cmljdC1pZ25vcmVcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBRZFVwbG9hZEVycm9yLCBRZFVwbG9hZEVycm9yVHlwZSB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9maWxlLXVwbG9hZCc7XG5pbXBvcnQgeyBRZEZpbGVDb2xsZWN0b3JTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvZmlsZS1jb2xsZWN0b3Iuc2VydmljZSc7XG5pbXBvcnQgeyBRZEZpbGVDb2xsZWN0b3JDb25maWcgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvZmlsZS1jb2xsZWN0b3ItY29uZmlnJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncWQtZmlsZS1jb2xsZWN0b3ItZGlhbG9nLWl0ZW0tZXJyb3InLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsZS1jb2xsZWN0b3ItZGlhbG9nLWl0ZW0tZXJyb3IuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9maWxlLWNvbGxlY3Rvci1kaWFsb2ctaXRlbS1lcnJvci5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBRZEZpbGVDb2xsZWN0b3JEaWFsb2dJdGVtRXJyb3JDb21wb25lbnQge1xuICBASW5wdXQoKSBlcnJvcjogUWRVcGxvYWRFcnJvcjtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgUWRVcGxvYWRFcnJvclR5cGUgPSBRZFVwbG9hZEVycm9yVHlwZTtcblxuICBnZXQgbWF4RmlsZVNpemVJbkJ5dGVzKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnPy5tYXhGaWxlU2l6ZUluQnl0ZXM7XG4gIH1cblxuICBnZXQgaW52YWxpZE1pbWVUeXBlRXJyb3JNZXNzYWdlSTE4bigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmNvbmZpZz8uaW52YWxpZE1pbWVUeXBlRXJyb3JNZXNzYWdlSTE4bjtcbiAgfVxuXG4gIGdldCBpbnZhbGlkRmlsZU5hbWVFcnJvck1lc3NhZ2VJMThuKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnPy5pbnZhbGlkRmlsZU5hbWVFcnJvck1lc3NhZ2VJMThuO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXQgY29uZmlnKCk6IFFkRmlsZUNvbGxlY3RvckNvbmZpZyB7XG4gICAgcmV0dXJuIHRoaXMuZmlsZUNvbGxlY3RvclNlcnZpY2UuY29uZmlnO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBmaWxlQ29sbGVjdG9yU2VydmljZTogUWRGaWxlQ29sbGVjdG9yU2VydmljZSkge31cbn1cbiIsIjxzcGFuICpuZ0lmPVwiZXJyb3IubWVzc2FnZTsgZWxzZSBlcnJvck1lc3NhZ2VOb3RHaXZlblwiPnt7IGVycm9yLm1lc3NhZ2UgfX08L3NwYW4+XG48bmctdGVtcGxhdGUgI2Vycm9yTWVzc2FnZU5vdEdpdmVuIFtuZ1N3aXRjaF09XCJlcnJvci50eXBlXCI+XG4gIDxzcGFuICpuZ1N3aXRjaENhc2U9XCJRZFVwbG9hZEVycm9yVHlwZS5JTlZBTElEX01JTUVfVFlQRVwiPnt7XG4gICAgaW52YWxpZE1pbWVUeXBlRXJyb3JNZXNzYWdlSTE4biB8fCBcImkxOG4ucWQuZmlsZUNvbGxlY3Rvci5pbnZhbGlkLmZpbGVUeXBlXCIgfCB0cmFuc2xhdGVcbiAgfX08L3NwYW4+XG4gIDxzcGFuICpuZ1N3aXRjaENhc2U9XCJRZFVwbG9hZEVycm9yVHlwZS5JTlZBTElEX0ZJTEVfU0laRVwiPnt7XG4gICAgXCJpMThuLnFkLmZpbGVDb2xsZWN0b3IuaW52YWxpZC5maWxlU2l6ZVwiXG4gICAgICB8IHRyYW5zbGF0ZVxuICAgICAgfCBwbGFjZWhvbGRlciA6IFwibWF4RmlsZVNpemVcIiA6IChtYXhGaWxlU2l6ZUluQnl0ZXMgfCBmaWxlc2l6ZSB8IGFzeW5jKVxuICB9fTwvc3Bhbj5cbiAgPHNwYW4gKm5nU3dpdGNoQ2FzZT1cIlFkVXBsb2FkRXJyb3JUeXBlLklOVkFMSURfRklMRV9OQU1FXCI+e3tcbiAgICBpbnZhbGlkRmlsZU5hbWVFcnJvck1lc3NhZ2VJMThuIHx8IFwiaTE4bi5xZC5maWxlQ29sbGVjdG9yLmludmFsaWQuZmlsZU5hbWVcIiB8IHRyYW5zbGF0ZVxuICB9fTwvc3Bhbj5cbiAgPHNwYW4gKm5nU3dpdGNoQ2FzZT1cIlFkVXBsb2FkRXJyb3JUeXBlLlVOS05PV05fRVJST1JcIj57eyBcImkxOG4ucWQuZmlsZUNvbGxlY3Rvci5pbnZhbGlkLnVua25vd25cIiB8IHRyYW5zbGF0ZSB9fTwvc3Bhbj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
@@ -364,7 +364,7 @@ export class QdInputComponent {
364
364
  console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');
365
365
  }
366
366
  }
367
- this.writeValue(this.value || getValue(this.config));
367
+ this.writeValue(this.value ?? getValue(this.config));
368
368
  this.normalizeInitialControlValueIfNeeded();
369
369
  this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));
370
370
  this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));
@@ -496,6 +496,8 @@ export class QdInputComponent {
496
496
  if (!this.control)
497
497
  return;
498
498
  const modelValue = this.control.value;
499
+ if (modelValue == null)
500
+ return void (this._value = getValueWithUnit(modelValue, this.config));
499
501
  const normalized = getValueWithUnit(modelValue, this.config);
500
502
  const target = this.hasUnits ? normalized : normalized.value;
501
503
  if (!isEqual(modelValue, target))
@@ -607,4 +609,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
607
609
  type: ViewChild,
608
610
  args: ['input']
609
611
  }] } });
610
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/input/input.component.ts","../../../../../../libs/qd-ui/src/lib/forms/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  SkipSelf,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isEqual } from 'lodash';\nimport { Subscription } from 'rxjs';\n\nimport { QdFocusable } from '../../core/focusable/focusable';\nimport { QD_FOCUSABLE_TOKEN } from '../../core/focusable/focusable.token';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\nimport { getValueWithUnit } from './helpers/get-value-with-unit';\n\nimport { QdPopoverSizingService } from '../../core/popover/popover-sizing.service';\nimport { QdFormOptionsResolver } from '../model/form-options-resolver';\nimport {\n  QdFormInputConfiguration,\n  QdInputMode,\n  QdInputType,\n  QdInputValue,\n  QdInputValueWithUnit\n} from '../model/forms.interface';\nimport { QdFormInputOption } from '../model/options.interface';\nimport { QdFormControl } from '../reactive-forms/controls/form-control';\nimport {\n  getClearable,\n  getDisabled,\n  getHasAutofocus,\n  getHint,\n  getHintAction,\n  getInputMode,\n  getInputType,\n  getLabel,\n  getPlaceholder,\n  getReadonly,\n  getReadonlyAction,\n  getValue,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdFormOptionsResolverRegistry } from '../shared/services/options-resolver.registry';\n\n/**\n * The **QdInput** component provides a FormElement for entering text into a UI.<br />\n * It can be used with Quadrel Reactive Forms or with model binding.\n *\n * ### **Usage with Reactive Forms**\n *\n * ```ts\n * form = new QdFormGroup({\n *   input: new QdFormControl()\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-input [formControlName]=\"input\" [config]=\"config\"></qd-input>\n * </form>\n * ```\n *\n * ### **Usage with Model Binding**\n * ```ts\n * value;\n * ```\n * ```html\n * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n * ```\n *\n * ## **Suggested Options**\n *\n * ### **Static options by config**\n *\n * Static options can be defined in the config `options` field:\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   options: [\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.import', value: 'import' },\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.export', value: 'export' },\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.transit', value: 'transit', disabled: true }\n *   ]\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * ```\n *\n * <Story id=\"components-grid-system-container--columns-6\" />\n *\n * ### **Dynamic options by resolver**\n *\n * If you want to define the options dynamically, you can inject a `QdFormOptionsResolver`\n * with the `QD_FORM_OPTIONS_RESOLVER` injection token. The resolver just has to implement the `resolver`\n * method.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   constructor(private readonly httpClient: HttpClient) {}\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError(error => {\n *           console.error('your error message');\n *\n *           return throwError(error);\n *         })\n *       );\n *   }\n * }\n * ```\n * The options resolver can be injected into a component that contains the `QdInput` or also into a parent\n * component. If you need dynamic options for the search in the section toolbar, you can inject\n * the resolver on a higher level, e.g. in the component that contains the section.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: YourFormOptionsResolver\n *     }\n *   ]\n * })\n * ```\n *\n * By default, the resolver is applied to every input that is inside the component that injects the resolver.\n * To disable the resolver for an input, you have to set the `optionsResolverName` property in the\n * input config to `null`. It's also possible to define a `name` for the resolver by setting the `name` property\n * in the resolver class. Thus, you can connect the input to a specific resolver. Below there is also a\n * description of how to use multiple inputs with different resolvers in one component.\n * <br><br>\n *\n * #### **Multiple inputs with suggested options**\n *\n * For multiple inputs with various resolvers in one component you can distinguish the resolvers by setting the\n * `name` as a property in the resolver class.\n *\n * ```ts\n * @Injectable()\n * export class FruitsFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'fruits';\n *   // ...\n * }\n * ```\n *\n * ```ts\n * @Injectable()\n * export class CountriesFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'countries';\n *   // ...\n * }\n * ```\n *\n * Then the input can be assigned to a resolver by setting the `optionsResolverName` property\n * in the input config.\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'fruits'\n * }\n *\n * config2: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'countries'\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * <qd-input [config]=\"config2\"></qd-input>\n * ```\n * To inject multiple resolvers in a component you can use the provider setting `multi: true`.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: FruitsFormOptionsResolver,\n *       multi: true\n *     },\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: CountriesFormOptionsResolver,\n *       multi: true\n *     }\n *   ]\n * })\n * ```\n *\n * #### **Custom loading and error hints**\n *\n * In the resolver you also can define custom loading and error hints with the properties `requestLoadingHint`\n * and `requestErrorHint`.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   requestLoadingHint = { i18n: 'i18n.custom.options.loading' };\n *   requestErrorHint = { i18n: 'i18n.custom.options.error' };\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     // ...\n *   }\n * }\n * ```\n * You also can update the error hint directly in the resolve method to display a more specific error\n * message when an error occurs.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   // ...\n *\n *   constructor(\n *     @Optional() @Inject(BACKEND_ERROR_CODES) private readonly backendErrorCodes\n *   ) {\n *     this.backendErrorCodes = this.backendErrorCodes || {};\n *   }\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError((error: HttpErrorResponse) => {\n *           if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)\n *             this.requestErrorHint = { i18n: 'ERROR.' + error.error.errorCode };\n *           return throwError(() => error);\n *         })\n *       );\n *   }\n * }\n * ```\n */\n@Component({\n  selector: 'qd-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdInputComponent,\n      multi: true\n    },\n    QdFormsActionEmitterService,\n    QdFormOptionsResolverRegistry,\n    // TODO: Remove when removing derived directive\n    QdPopoverSizingService,\n    {\n      provide: QD_FOCUSABLE_TOKEN,\n      useExisting: QdInputComponent\n    }\n  ]\n})\nexport class QdInputComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, QdFocusable {\n  /**\n   * The form control name can be assigned here if you want to use Reactive Forms.\n   */\n  @Input()\n  formControlName: string;\n\n  /**\n   * The current form item value, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n   */\n  @Input()\n  value;\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'label' },\n   *   placeholder: { i18n: 'placeholder' },\n   *   hint: { i18n: 'hint' }\n   * };\n   */\n  @Input()\n  config: QdFormInputConfiguration;\n\n  /**\n   * Set component to \"error\" externally. No reactive forms required. Used for components within the Quadrel UI framework. This is done by a CSS class.\n   *\n   * @default false\n   */\n  @Input()\n  isError = false;\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id')\n  testId = 'text-input';\n\n  /**\n   * Emits event when the value has changed.\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly valueChange = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the value has changed. Note: Emits on keyup (no longer on click, as before)!\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly enterClick = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the input field was lapped on click/tap on the x icon. <br />\n   * `QdFormInputConfiguration['clearable']` must be set to true for this.\n   */\n  @Output()\n  readonly clickClear = new EventEmitter();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when the readonly value is clicked/tapped. `clickReadonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when the viewonly value is clicked/tapped. `clickViewonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickViewonly = new EventEmitter();\n\n  @HostBinding('class.qd-input-readonly')\n  readonly: boolean;\n\n  @HostBinding('class.qd-input--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-input-viewonly')\n  viewonly: boolean;\n\n  @HostBinding('class.qd-input--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-input-hint-action')\n  hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  @HostBinding('class.qd-input-disabled')\n  disabled: boolean;\n\n  @HostBinding('class.qd-input-focus')\n  isInputFocused = false;\n  areUnitsOpened = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-input-error')\n  get hasError(): boolean {\n    return this.control ? this.control.touched && this.control.invalid : false;\n  }\n\n  @HostBinding('class.qd-input-error-from-outside')\n  get isErrorFromOutside(): boolean {\n    return this.isError;\n  }\n\n  @ViewChild('input')\n  inputElement: ElementRef;\n\n  inputType: QdInputType;\n  inputMode: QdInputMode;\n  placeholder: string;\n  label: string;\n  hint: string;\n  clearable: boolean;\n  hasAutofocus: boolean;\n  hasOptions = false;\n  _value: QdInputValueWithUnit = { value: '' };\n  control: AbstractControl | QdFormControl<any>;\n\n  private _optionsResolver!: QdFormOptionsResolver | null;\n  private _subs = new Subscription();\n\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  get hasOnlyUnitsError(): boolean {\n    return isEqual(Object.keys(this.control.errors), ['required']) && this._value.value !== '';\n  }\n\n  get hasUnits(): boolean {\n    return this.config?.units?.length > 0;\n  }\n\n  get numberOfCharacters(): number {\n    if (!this._value.value) return 0;\n\n    return String(this._value.value).length;\n  }\n\n  get hasMaxLength(): boolean {\n    if (!(this.control instanceof QdFormControl)) return false;\n\n    return this.control.hasMaxLength();\n  }\n\n  get maxLength(): number {\n    if (!(this.control instanceof QdFormControl)) return;\n\n    return this.control.getMaxLengthOrUndefined();\n  }\n\n  get valueAsList(): string[] {\n    return [`${this._value.value}${this._value.unit ? ' ' + this._value.unit : ''}`];\n  }\n\n  constructor(\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    private readonly resolverRegistry: QdFormOptionsResolverRegistry,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {}\n\n  ngOnInit(): void {\n    this.initializeOptionsResolver();\n    this.updateConfig();\n\n    if (this.controlContainer) {\n      if (this.formControlName) {\n        this.control = this.controlContainer.control.get(this.formControlName);\n\n        // TODO remove logic for support of angular FormControl with angular 20 update\n        if (!(this.control instanceof QdFormControl))\n          console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');\n      }\n    }\n\n    this.writeValue(this.value || getValue(this.config));\n\n    this.normalizeInitialControlValueIfNeeded();\n\n    this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));\n    this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));\n    this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));\n    this._subs.add(this.initOpModeSubscription());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) {\n      this.updateConfig();\n      this.normalizeInitialControlValueIfNeeded();\n    }\n\n    if (changes['value']) this.writeValue(this.value);\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    const fnString = fn.toString();\n\n    if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange')) return;\n\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  writeValue(value: QdInputValueWithUnit | QdInputValue): void {\n    this._value = getValueWithUnit(value, this.config);\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n    this.clearable = getClearable(this.config) && !this.disabled;\n  }\n\n  handleInput(event): void {\n    const value = event.target.value;\n    this._value = { ...this._value, value };\n    this.emitValue();\n    this._onTouch();\n  }\n\n  handleOptionSelected(option: QdFormInputOption): void {\n    this._value = { ...this._value, value: option.i18n };\n    this.valueChange.emit(option.value);\n    this._onChange(option.value);\n    this._onTouch();\n  }\n\n  handleUnitChange(unit): void {\n    this._value = { ...this._value, unit };\n    this.emitValue();\n  }\n\n  handleInputFocus(): void {\n    this.isInputFocused = true;\n  }\n\n  handleInputBlur(): void {\n    this.isInputFocused = false;\n\n    setTimeout(() => {\n      if (!this.areUnitsOpened) this._onTouch();\n    }, 100);\n  }\n\n  handleUnitsOpened(): void {\n    this.areUnitsOpened = true;\n  }\n\n  handleUnitsClosed(): void {\n    this.areUnitsOpened = false;\n\n    if (this._value.unit && this._value.value === '') {\n      this.inputElement.nativeElement.focus();\n    } else {\n      this._onTouch();\n    }\n  }\n\n  clearInput(): void {\n    this._value = { ...this._value, value: '' };\n    this.inputElement.nativeElement.focus();\n\n    this.emitValue();\n    this.clickClear.emit();\n  }\n\n  focus(): void {\n    this.inputElement.nativeElement.focus();\n  }\n\n  emitEnterClick(): void {\n    if (this.hasUnits) {\n      this.enterClick.emit(this._value);\n    } else {\n      this.enterClick.emit(this._value.value);\n    }\n  }\n\n  private updateConfig(): void {\n    this.inputType = getInputType(this.config);\n    this.inputMode = getInputMode(this.config);\n    this.placeholder = getPlaceholder(this.config);\n    this.label = getLabel(this.config);\n    this.hint = getHint(this.config);\n    this.readonly = getReadonly(this.config, this.readonly);\n    this.viewonly = getViewonly(this.config, this.viewonly);\n    this.hintAction = getHintAction(this.config);\n    this.readonlyAction = getReadonlyAction(this.config);\n    this.viewonlyAction = getViewonlyAction(this.config);\n    this.disabled = getDisabled(this.config) || !!this.control?.disabled;\n    this.clearable = !this.disabled && getClearable(this.config);\n    this.hasAutofocus = getHasAutofocus(this.config);\n    this.hasOptions = (this.config.options && this.config.options.length > 0) || !!this._optionsResolver;\n  }\n\n  private initializeOptionsResolver(): void {\n    this.resolverRegistry.initialize(this.config?.optionsResolverName);\n    this._optionsResolver = this.resolverRegistry.findResolver();\n  }\n\n  private emitValue(): void {\n    if (this.hasUnits) {\n      this.valueChange.emit(this._value);\n      this._onChange(this._value);\n    } else {\n      this.valueChange.emit(this._value.value);\n      this._onChange(this._value.value);\n    }\n  }\n\n  private initOpModeSubscription(): Subscription | void {\n    if (!this.eventBrokerService) return;\n\n    return this.eventBrokerService.consume<{ isViewonly: boolean }>('operation_mode_changed').subscribe(topic => {\n      if (typeof this.config.viewonly === 'boolean') return;\n\n      this.viewonly = getViewonly(this.config, topic.payload.isViewonly);\n    });\n  }\n\n  private normalizeInitialControlValueIfNeeded(): void {\n    if (!this.control) return;\n\n    const modelValue = (this.control as any).value;\n    const normalized = getValueWithUnit(modelValue, this.config);\n    const target = this.hasUnits ? normalized : normalized.value;\n\n    if (!isEqual(modelValue, target)) (this.control as any).setValue(target, { emitEvent: false });\n\n    this._value = normalized;\n  }\n}\n","<qd-form-label\n  [label]=\"label\"\n  [readonly]=\"readonly\"\n  [viewonly]=\"viewonly\"\n  [control]=\"control\"\n  [tooltip]=\"config?.tooltip\"\n  [data-test-id]=\"testId\"\n></qd-form-label>\n\n<ng-container *ngIf=\"!readonly && !viewonly && !hasOptions\">\n  <div class=\"qd-input-input\" (keydown.enter)=\"emitEnterClick()\">\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</ng-container>\n\n<div *ngIf=\"!readonly && !viewonly && hasOptions\">\n  <div\n    class=\"qd-input-input\"\n    qdInputOptions\n    [qdPopoverMinWidth]=\"200\"\n    [config]=\"config\"\n    [value]=\"_value.value\"\n    (optionSelected)=\"handleOptionSelected($event)\"\n    (enterClick)=\"emitEnterClick()\"\n  >\n    <!-- handle (enterClick) by options directive here because event has to be fired after selection -->\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</div>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"valueAsList\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"valueAsList\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n\n<ng-template #inputBox>\n  <input\n    #input\n    [placeholder]=\"placeholder | translate\"\n    [value]=\"hasOptions ? (_value.value.toString() | translate) : _value.value\"\n    (input)=\"handleInput($event)\"\n    (focus)=\"handleInputFocus()\"\n    (blur)=\"handleInputBlur()\"\n    [disabled]=\"disabled || readonly\"\n    [type]=\"inputType\"\n    [attr.inputmode]=\"inputMode\"\n    [qdAutofocus]=\"hasAutofocus\"\n    [attr.data-test-id]=\"testId + '-input'\"\n    [step]=\"config?.step\"\n    required\n  />\n  <div class=\"qd-input-suffix\">\n    <qd-icon *ngIf=\"hasError && !hasOnlyUnitsError\" class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n    <qd-icon *ngIf=\"clearable\" class=\"qd-input-clearable-icon\" icon=\"timesLarge\" (click)=\"clearInput()\"></qd-icon>\n    <ng-content select=\"[qdIconButton]\"></ng-content>\n  </div>\n  <qd-input-units\n    *ngIf=\"hasUnits\"\n    [unit]=\"_value.unit\"\n    [config]=\"config\"\n    (unitChange)=\"handleUnitChange($event)\"\n    (opened)=\"handleUnitsOpened()\"\n    (closed)=\"handleUnitsClosed()\"\n  ></qd-input-units>\n  <div class=\"qd-input-suffix\" *ngIf=\"hasError && hasOnlyUnitsError\">\n    <qd-icon class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n  </div>\n</ng-template>\n"]}
612
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/input/input.component.ts","../../../../../../libs/qd-ui/src/lib/forms/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  SkipSelf,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isEqual } from 'lodash';\nimport { Subscription } from 'rxjs';\n\nimport { QdFocusable } from '../../core/focusable/focusable';\nimport { QD_FOCUSABLE_TOKEN } from '../../core/focusable/focusable.token';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\nimport { getValueWithUnit } from './helpers/get-value-with-unit';\n\nimport { QdPopoverSizingService } from '../../core/popover/popover-sizing.service';\nimport { QdFormOptionsResolver } from '../model/form-options-resolver';\nimport {\n  QdFormInputConfiguration,\n  QdInputMode,\n  QdInputType,\n  QdInputValue,\n  QdInputValueWithUnit\n} from '../model/forms.interface';\nimport { QdFormInputOption } from '../model/options.interface';\nimport { QdFormControl } from '../reactive-forms/controls/form-control';\nimport {\n  getClearable,\n  getDisabled,\n  getHasAutofocus,\n  getHint,\n  getHintAction,\n  getInputMode,\n  getInputType,\n  getLabel,\n  getPlaceholder,\n  getReadonly,\n  getReadonlyAction,\n  getValue,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdFormOptionsResolverRegistry } from '../shared/services/options-resolver.registry';\n\n/**\n * The **QdInput** component provides a FormElement for entering text into a UI.<br />\n * It can be used with Quadrel Reactive Forms or with model binding.\n *\n * ### **Usage with Reactive Forms**\n *\n * ```ts\n * form = new QdFormGroup({\n *   input: new QdFormControl()\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-input [formControlName]=\"input\" [config]=\"config\"></qd-input>\n * </form>\n * ```\n *\n * ### **Usage with Model Binding**\n * ```ts\n * value;\n * ```\n * ```html\n * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n * ```\n *\n * ## **Suggested Options**\n *\n * ### **Static options by config**\n *\n * Static options can be defined in the config `options` field:\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   options: [\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.import', value: 'import' },\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.export', value: 'export' },\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.transit', value: 'transit', disabled: true }\n *   ]\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * ```\n *\n * <Story id=\"components-grid-system-container--columns-6\" />\n *\n * ### **Dynamic options by resolver**\n *\n * If you want to define the options dynamically, you can inject a `QdFormOptionsResolver`\n * with the `QD_FORM_OPTIONS_RESOLVER` injection token. The resolver just has to implement the `resolver`\n * method.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   constructor(private readonly httpClient: HttpClient) {}\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError(error => {\n *           console.error('your error message');\n *\n *           return throwError(error);\n *         })\n *       );\n *   }\n * }\n * ```\n * The options resolver can be injected into a component that contains the `QdInput` or also into a parent\n * component. If you need dynamic options for the search in the section toolbar, you can inject\n * the resolver on a higher level, e.g. in the component that contains the section.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: YourFormOptionsResolver\n *     }\n *   ]\n * })\n * ```\n *\n * By default, the resolver is applied to every input that is inside the component that injects the resolver.\n * To disable the resolver for an input, you have to set the `optionsResolverName` property in the\n * input config to `null`. It's also possible to define a `name` for the resolver by setting the `name` property\n * in the resolver class. Thus, you can connect the input to a specific resolver. Below there is also a\n * description of how to use multiple inputs with different resolvers in one component.\n * <br><br>\n *\n * #### **Multiple inputs with suggested options**\n *\n * For multiple inputs with various resolvers in one component you can distinguish the resolvers by setting the\n * `name` as a property in the resolver class.\n *\n * ```ts\n * @Injectable()\n * export class FruitsFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'fruits';\n *   // ...\n * }\n * ```\n *\n * ```ts\n * @Injectable()\n * export class CountriesFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'countries';\n *   // ...\n * }\n * ```\n *\n * Then the input can be assigned to a resolver by setting the `optionsResolverName` property\n * in the input config.\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'fruits'\n * }\n *\n * config2: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'countries'\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * <qd-input [config]=\"config2\"></qd-input>\n * ```\n * To inject multiple resolvers in a component you can use the provider setting `multi: true`.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: FruitsFormOptionsResolver,\n *       multi: true\n *     },\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: CountriesFormOptionsResolver,\n *       multi: true\n *     }\n *   ]\n * })\n * ```\n *\n * #### **Custom loading and error hints**\n *\n * In the resolver you also can define custom loading and error hints with the properties `requestLoadingHint`\n * and `requestErrorHint`.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   requestLoadingHint = { i18n: 'i18n.custom.options.loading' };\n *   requestErrorHint = { i18n: 'i18n.custom.options.error' };\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     // ...\n *   }\n * }\n * ```\n * You also can update the error hint directly in the resolve method to display a more specific error\n * message when an error occurs.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   // ...\n *\n *   constructor(\n *     @Optional() @Inject(BACKEND_ERROR_CODES) private readonly backendErrorCodes\n *   ) {\n *     this.backendErrorCodes = this.backendErrorCodes || {};\n *   }\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError((error: HttpErrorResponse) => {\n *           if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)\n *             this.requestErrorHint = { i18n: 'ERROR.' + error.error.errorCode };\n *           return throwError(() => error);\n *         })\n *       );\n *   }\n * }\n * ```\n */\n@Component({\n  selector: 'qd-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdInputComponent,\n      multi: true\n    },\n    QdFormsActionEmitterService,\n    QdFormOptionsResolverRegistry,\n    // TODO: Remove when removing derived directive\n    QdPopoverSizingService,\n    {\n      provide: QD_FOCUSABLE_TOKEN,\n      useExisting: QdInputComponent\n    }\n  ]\n})\nexport class QdInputComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, QdFocusable {\n  /**\n   * The form control name can be assigned here if you want to use Reactive Forms.\n   */\n  @Input()\n  formControlName: string;\n\n  /**\n   * The current form item value, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n   */\n  @Input()\n  value;\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'label' },\n   *   placeholder: { i18n: 'placeholder' },\n   *   hint: { i18n: 'hint' }\n   * };\n   */\n  @Input()\n  config: QdFormInputConfiguration;\n\n  /**\n   * Set component to \"error\" externally. No reactive forms required. Used for components within the Quadrel UI framework. This is done by a CSS class.\n   *\n   * @default false\n   */\n  @Input()\n  isError = false;\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id')\n  testId = 'text-input';\n\n  /**\n   * Emits event when the value has changed.\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly valueChange = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the value has changed. Note: Emits on keyup (no longer on click, as before)!\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly enterClick = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the input field was lapped on click/tap on the x icon. <br />\n   * `QdFormInputConfiguration['clearable']` must be set to true for this.\n   */\n  @Output()\n  readonly clickClear = new EventEmitter();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when the readonly value is clicked/tapped. `clickReadonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when the viewonly value is clicked/tapped. `clickViewonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickViewonly = new EventEmitter();\n\n  @HostBinding('class.qd-input-readonly')\n  readonly: boolean;\n\n  @HostBinding('class.qd-input--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-input-viewonly')\n  viewonly: boolean;\n\n  @HostBinding('class.qd-input--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-input-hint-action')\n  hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  @HostBinding('class.qd-input-disabled')\n  disabled: boolean;\n\n  @HostBinding('class.qd-input-focus')\n  isInputFocused = false;\n  areUnitsOpened = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-input-error')\n  get hasError(): boolean {\n    return this.control ? this.control.touched && this.control.invalid : false;\n  }\n\n  @HostBinding('class.qd-input-error-from-outside')\n  get isErrorFromOutside(): boolean {\n    return this.isError;\n  }\n\n  @ViewChild('input')\n  inputElement: ElementRef;\n\n  inputType: QdInputType;\n  inputMode: QdInputMode;\n  placeholder: string;\n  label: string;\n  hint: string;\n  clearable: boolean;\n  hasAutofocus: boolean;\n  hasOptions = false;\n  _value: QdInputValueWithUnit = { value: '' };\n  control: AbstractControl | QdFormControl<any>;\n\n  private _optionsResolver!: QdFormOptionsResolver | null;\n  private _subs = new Subscription();\n\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  get hasOnlyUnitsError(): boolean {\n    return isEqual(Object.keys(this.control.errors), ['required']) && this._value.value !== '';\n  }\n\n  get hasUnits(): boolean {\n    return this.config?.units?.length > 0;\n  }\n\n  get numberOfCharacters(): number {\n    if (!this._value.value) return 0;\n\n    return String(this._value.value).length;\n  }\n\n  get hasMaxLength(): boolean {\n    if (!(this.control instanceof QdFormControl)) return false;\n\n    return this.control.hasMaxLength();\n  }\n\n  get maxLength(): number {\n    if (!(this.control instanceof QdFormControl)) return;\n\n    return this.control.getMaxLengthOrUndefined();\n  }\n\n  get valueAsList(): string[] {\n    return [`${this._value.value}${this._value.unit ? ' ' + this._value.unit : ''}`];\n  }\n\n  constructor(\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    private readonly resolverRegistry: QdFormOptionsResolverRegistry,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {}\n\n  ngOnInit(): void {\n    this.initializeOptionsResolver();\n    this.updateConfig();\n\n    if (this.controlContainer) {\n      if (this.formControlName) {\n        this.control = this.controlContainer.control.get(this.formControlName);\n\n        // TODO remove logic for support of angular FormControl with angular 20 update\n        if (!(this.control instanceof QdFormControl))\n          console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');\n      }\n    }\n\n    this.writeValue(this.value ?? getValue(this.config));\n\n    this.normalizeInitialControlValueIfNeeded();\n\n    this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));\n    this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));\n    this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));\n    this._subs.add(this.initOpModeSubscription());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) {\n      this.updateConfig();\n      this.normalizeInitialControlValueIfNeeded();\n    }\n\n    if (changes['value']) this.writeValue(this.value);\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    const fnString = fn.toString();\n\n    if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange')) return;\n\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  writeValue(value: QdInputValueWithUnit | QdInputValue): void {\n    this._value = getValueWithUnit(value, this.config);\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n    this.clearable = getClearable(this.config) && !this.disabled;\n  }\n\n  handleInput(event): void {\n    const value = event.target.value;\n    this._value = { ...this._value, value };\n    this.emitValue();\n    this._onTouch();\n  }\n\n  handleOptionSelected(option: QdFormInputOption): void {\n    this._value = { ...this._value, value: option.i18n };\n    this.valueChange.emit(option.value);\n    this._onChange(option.value);\n    this._onTouch();\n  }\n\n  handleUnitChange(unit): void {\n    this._value = { ...this._value, unit };\n    this.emitValue();\n  }\n\n  handleInputFocus(): void {\n    this.isInputFocused = true;\n  }\n\n  handleInputBlur(): void {\n    this.isInputFocused = false;\n\n    setTimeout(() => {\n      if (!this.areUnitsOpened) this._onTouch();\n    }, 100);\n  }\n\n  handleUnitsOpened(): void {\n    this.areUnitsOpened = true;\n  }\n\n  handleUnitsClosed(): void {\n    this.areUnitsOpened = false;\n\n    if (this._value.unit && this._value.value === '') {\n      this.inputElement.nativeElement.focus();\n    } else {\n      this._onTouch();\n    }\n  }\n\n  clearInput(): void {\n    this._value = { ...this._value, value: '' };\n    this.inputElement.nativeElement.focus();\n\n    this.emitValue();\n    this.clickClear.emit();\n  }\n\n  focus(): void {\n    this.inputElement.nativeElement.focus();\n  }\n\n  emitEnterClick(): void {\n    if (this.hasUnits) {\n      this.enterClick.emit(this._value);\n    } else {\n      this.enterClick.emit(this._value.value);\n    }\n  }\n\n  private updateConfig(): void {\n    this.inputType = getInputType(this.config);\n    this.inputMode = getInputMode(this.config);\n    this.placeholder = getPlaceholder(this.config);\n    this.label = getLabel(this.config);\n    this.hint = getHint(this.config);\n    this.readonly = getReadonly(this.config, this.readonly);\n    this.viewonly = getViewonly(this.config, this.viewonly);\n    this.hintAction = getHintAction(this.config);\n    this.readonlyAction = getReadonlyAction(this.config);\n    this.viewonlyAction = getViewonlyAction(this.config);\n    this.disabled = getDisabled(this.config) || !!this.control?.disabled;\n    this.clearable = !this.disabled && getClearable(this.config);\n    this.hasAutofocus = getHasAutofocus(this.config);\n    this.hasOptions = (this.config.options && this.config.options.length > 0) || !!this._optionsResolver;\n  }\n\n  private initializeOptionsResolver(): void {\n    this.resolverRegistry.initialize(this.config?.optionsResolverName);\n    this._optionsResolver = this.resolverRegistry.findResolver();\n  }\n\n  private emitValue(): void {\n    if (this.hasUnits) {\n      this.valueChange.emit(this._value);\n      this._onChange(this._value);\n    } else {\n      this.valueChange.emit(this._value.value);\n      this._onChange(this._value.value);\n    }\n  }\n\n  private initOpModeSubscription(): Subscription | void {\n    if (!this.eventBrokerService) return;\n\n    return this.eventBrokerService.consume<{ isViewonly: boolean }>('operation_mode_changed').subscribe(topic => {\n      if (typeof this.config.viewonly === 'boolean') return;\n\n      this.viewonly = getViewonly(this.config, topic.payload.isViewonly);\n    });\n  }\n\n  private normalizeInitialControlValueIfNeeded(): void {\n    if (!this.control) return;\n\n    const modelValue = (this.control as any).value;\n\n    if (modelValue == null) return void (this._value = getValueWithUnit(modelValue, this.config));\n\n    const normalized = getValueWithUnit(modelValue, this.config);\n    const target = this.hasUnits ? normalized : normalized.value;\n\n    if (!isEqual(modelValue, target)) (this.control as any).setValue(target, { emitEvent: false });\n\n    this._value = normalized;\n  }\n}\n","<qd-form-label\n  [label]=\"label\"\n  [readonly]=\"readonly\"\n  [viewonly]=\"viewonly\"\n  [control]=\"control\"\n  [tooltip]=\"config?.tooltip\"\n  [data-test-id]=\"testId\"\n></qd-form-label>\n\n<ng-container *ngIf=\"!readonly && !viewonly && !hasOptions\">\n  <div class=\"qd-input-input\" (keydown.enter)=\"emitEnterClick()\">\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</ng-container>\n\n<div *ngIf=\"!readonly && !viewonly && hasOptions\">\n  <div\n    class=\"qd-input-input\"\n    qdInputOptions\n    [qdPopoverMinWidth]=\"200\"\n    [config]=\"config\"\n    [value]=\"_value.value\"\n    (optionSelected)=\"handleOptionSelected($event)\"\n    (enterClick)=\"emitEnterClick()\"\n  >\n    <!-- handle (enterClick) by options directive here because event has to be fired after selection -->\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</div>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"valueAsList\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"valueAsList\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n\n<ng-template #inputBox>\n  <input\n    #input\n    [placeholder]=\"placeholder | translate\"\n    [value]=\"hasOptions ? (_value.value.toString() | translate) : _value.value\"\n    (input)=\"handleInput($event)\"\n    (focus)=\"handleInputFocus()\"\n    (blur)=\"handleInputBlur()\"\n    [disabled]=\"disabled || readonly\"\n    [type]=\"inputType\"\n    [attr.inputmode]=\"inputMode\"\n    [qdAutofocus]=\"hasAutofocus\"\n    [attr.data-test-id]=\"testId + '-input'\"\n    [step]=\"config?.step\"\n    required\n  />\n  <div class=\"qd-input-suffix\">\n    <qd-icon *ngIf=\"hasError && !hasOnlyUnitsError\" class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n    <qd-icon *ngIf=\"clearable\" class=\"qd-input-clearable-icon\" icon=\"timesLarge\" (click)=\"clearInput()\"></qd-icon>\n    <ng-content select=\"[qdIconButton]\"></ng-content>\n  </div>\n  <qd-input-units\n    *ngIf=\"hasUnits\"\n    [unit]=\"_value.unit\"\n    [config]=\"config\"\n    (unitChange)=\"handleUnitChange($event)\"\n    (opened)=\"handleUnitsOpened()\"\n    (closed)=\"handleUnitsClosed()\"\n  ></qd-input-units>\n  <div class=\"qd-input-suffix\" *ngIf=\"hasError && hasOnlyUnitsError\">\n    <qd-icon class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n  </div>\n</ng-template>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-config.interface.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/page/model/page-config.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { Observable } from 'rxjs';\n\nimport { QdMenuButtonActionConfig } from '../../button/model/button-config';\nimport { QdPageHeaderFacetConfig } from './page-header-facet.interface';\n\n/**\n * @description Configuration of QdPage.\n *\n * @template T - The type of the page object data\n */\nexport type QdPageConfig<T extends object = object> =\n  | QdPageConfigOverview\n  | QdPageConfigCreate<T>\n  | QdPageConfigInspect<T>\n  | QdPageConfigCustom<T>;\n\nexport interface QdPageSelectedContext {\n  value: string;\n  label: {\n    i18n: string;\n  };\n}\n\ninterface QdPageContextConfigBase {\n  /**\n   * @description Description for the specific header facet\n   */\n  label: {\n    /**\n     * @description i18n string for the description, used for translation.\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Allows to identify the context\n   */\n  id: string;\n\n  /**\n   * @description Register some handler that is executed when the selection changes.\n   */\n  changed?: (selection: QdPageSelectedContext | QdPageSelectedContext[] | null) => void;\n}\n\n/**\n * @description Configuration for a context with single selection\n */\nexport interface QdPageContextConfigSingle extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'single';\n\n  /**\n   * @description Available options for selection.\n   */\n  options: QdPageSelectedContext[];\n\n  /**\n   * @description Configures whether the context options are searchable for the user.\n   * @default false\n   */\n  hasSearch?: boolean;\n\n  /**\n   * @description Placeholder for search\n   */\n  searchPlaceholder?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Title for the dialog that will be opened\n   */\n  title?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n}\n\n/**\n * @description Configuration for a context with multi selection\n */\nexport interface QdPageContextConfigMulti extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'multi';\n\n  /**\n   * @description Available options for selection.\n   */\n  options: QdPageSelectedContext[];\n\n  /**\n   * @description Configures whether the context options are searchable for the user.\n   * @default false\n   */\n  hasSearch?: boolean;\n\n  /**\n   * @description Placeholder for search\n\n   */\n  searchPlaceholder?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Title for the dialog that will be opened\n   */\n  title?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n}\n\n/**\n * @description Configuration for a context with custom selection (e. g. your own dialog)\n */\nexport interface QdPageContextConfigCustom extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'custom';\n\n  /**\n   * @description Handler to open a custom dialog for selection\n   */\n  open: () => void;\n}\n\n/**\n * @description Configures the context with one of the available types\n */\nexport type QdPageContextConfig = QdPageContextConfigSingle | QdPageContextConfigMulti | QdPageContextConfigCustom;\n\n/**\n * @description Base configuration for QdPage.\n */\ninterface QdPageConfigBase {\n  /**\n   * @description Title of the page.\n   */\n  title: QdPageTitle;\n\n  /**\n   * @description Hides contexts from being shown. The ContextService will still work in the background.\n   *\n   * @default false\n   */\n  hideContexts?: boolean;\n\n  /**\n   * @description Label for the menu button of custom actions.\n   */\n  customActionsLabel?: QdPageCustomActionsLabel;\n}\n\n/**\n * @description Configuration for the overview page type.\n *\n * @template T - The type of the page object data\n */\nexport interface QdPageConfigOverview extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'overview'\n   */\n  pageType?: 'overview'; // Optional to make it default\n\n  /**\n   * @description Configuration specific to the overview page type.\n   */\n  pageTypeConfig?: QdPageTypeOverviewConfig;\n}\n\n/**\n * @description Configuration for the create page type.\n *\n * @template T - The type of the page object data\n */\nexport interface QdPageConfigCreate<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'create'\n   */\n  pageType: 'create';\n\n  /**\n   * @description Configuration specific to the create page type.\n   */\n  pageTypeConfig?: QdPageTypeCreateConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n}\n\nexport interface QdPageConfigInspect<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'inspect'\n   */\n  pageType: 'inspect';\n\n  /**\n   * @description Configuration specific to the inspect page type.\n   */\n  pageTypeConfig?: QdPageTypeInspectConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n\n  /**\n   * @description Determines whether the facets in header should be collapsed and custom actions are in a menu. This mode is designed for touch devices and mobile phones only.\n   *\n   * @default false\n   */\n  adaptiveMode?: boolean;\n}\n\nexport interface QdPageConfigCustom<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'custom'\n   */\n  pageType: 'custom';\n\n  /**\n   * @description Configuration specific to the custom page type.\n   */\n  pageTypeConfig?: QdPageTypeCustomConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n\n  /**\n   * @description Determines whether the facets in header should be collapsed and custom actions are in a menu. This mode is designed for touch devices and mobile phones only.\n   *\n   * @default false\n   */\n  adaptiveMode?: boolean;\n}\n\n/**\n * Configures the overview page\n */\nexport interface QdPageTypeOverviewConfig {\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\n/**\n * @description Configures the create page.\n */\nexport interface QdPageTypeCreateConfig {\n  /**\n   * @description Configuration for the save draft action.\n   */\n  saveDraft?: QdPageSaveDraftAction;\n\n  /**\n   * @description Configuration for the cancel button.\n   */\n  cancel: QdPageCancelAction;\n\n  /**\n   * @description Configuration for the submit button.\n   */\n  submit: QdPageCreateSubmitAction;\n\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\n/**\n * @description Configures the inspect page.\n */\nexport interface QdPageTypeInspectConfig {\n  /**\n   * @description Operation mode for the page.\n   *\n   * * This property determines the mode in which the page operates. It can be either 'view' or 'edit'.\n   *\n   * * **view**: The page is in read-only mode.\n   * * **edit**: The page allows modifications.\n   */\n  operationMode?: QdInspectOperationMode;\n\n  /**\n   * @description Specifies whether the user can edit the object or not.\n   */\n  hideEdit?: boolean;\n\n  /**\n   * @description Configuration for the edit action.\n   */\n  edit?: QdPageEditAction;\n\n  /**\n   * @description Configuration for the save action.\n   */\n  save?: QdPageSaveAction;\n\n  /**\n   * @description Configuration for the cancel action.\n   */\n  cancel: QdPageCancelAction;\n\n  /**\n   * @description Configuration for the delete action.\n   */\n  delete?: QdPageDeleteAction;\n\n  /**\n   * @description Configuration for the archive action.\n   */\n  archive?: QdPageArchiveAction;\n\n  /**\n   * @description Configuration for the submit action.\n   */\n  submit?: QdPageSubmitAction;\n\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * In the \"Inspect\" page type, you can assign custom actions to the operation modes \"view\" or \"edit.\" By default, the action is active in both modes.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: (QdMenuButtonActionConfig & { operationMode?: QdInspectOperationMode })[];\n}\n\nexport interface QdPageTypeCustomConfig {\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\nexport interface QdPageTitle {\n  /**\n   * @description Defines the translation key\n   *\n   * * @example { i18n: \"i18n.overview.title\"}\n   */\n  i18n: string;\n}\n\n/**\n * @description Configuration for the custom actions label, used when multiple custom actions exist.\n */\nexport interface QdPageCustomActionsLabel {\n  /**\n   * @description Label for the menu button of custom actions, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   *\n   * * This label becomes visible if more than one custom action is defined, as the actions will be grouped under a QdMenuButton that displays this label.\n   */\n  i18n: string;\n}\n\n/**\n * @description Operation modes for the inspect page.\n *\n * @default 'view'\n */\nexport type QdInspectOperationMode = 'view' | 'edit';\n\n/**\n * @description Interface for the save action, including optional validation configuration.\n */\nexport interface QdPageSaveAction {\n  /**\n   * @description Label for the save action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Triggered when the save action is executed.\n   *\n   * Success criteria:\n   * - If the handler returns an Observable<boolean>, only the first emission after the save click counts:\n   *   - **true:** success - toggle to view and apply the saved values\n   *   - **false:** failure/cancel - stay in edit mode\n   * - If the handler returns no Observable (void), the save is treated as instant success (toggle + apply values).\n   *\n   * On a successful save, the framework applies the values and resets its internal validation and change-tracking state.\n   */\n  handler: (formValues?: any) => void | Observable<boolean>;\n\n  /**\n   * @description Optional validation flag, defaults to true.\n   * Determines whether form validation is required before saving and ensures that changes must be present in the form before saving.\n   *\n   * * By default, this flag is set to true, meaning that validation is enforced, and the form will only save if there are changes.\n   *\n   * * If set to `false`, the form will be saved without validation checks, but changes must still be present to proceed with the save operation.\n   *\n   * * This flag is useful in scenarios where form validation is not needed or should be bypassed, but it ensures that only modified forms can be saved.\n   */\n  hasValidation?: boolean;\n}\n\n/**\n * @description Interface for the safe draft action.\n */\nexport interface QdPageSaveDraftAction {\n  /**\n   * @description Label for the save draft action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the save draft action is executed.\n   */\n  handler: () => void;\n}\n\n/**\n * @description Interface for the cancel action, including an optional confirmation message.\n */\nexport interface QdPageCancelAction {\n  /**\n   * @description Label for the cancel action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the cancel action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description An optional confirmation message displayed in a dialog when the user attempts to cancel the operation, warning that all changes will be discarded.\n   * If no custom message is provided, a standard message will be shown by default.\n   *\n   * * The cancellation process checks whether there are unsaved changes in the form. If there are changes, the dialog will appear.\n   *\n   * * If no changes are detected, the cancellation proceeds without showing the confirmation dialog.\n   */\n  confirmationMessage?: { i18n: string };\n}\n\n/**\n * @description Interface for the submit action on create pages.\n */\nexport interface QdPageCreateSubmitAction {\n  /**\n   * @description Label for the submit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the submit action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the submit action.\n */\nexport interface QdPageSubmitAction {\n  /**\n   * @description Label for the submit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the submit action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description By default, the visibility of the submit button depends on the page type and the operation mode.\n   * To completely hide the submit button, you can set this isHidden flag.\n   *\n   * @default false\n   */\n  isHidden?: boolean;\n}\n\n/**\n * @description Interface for the edit action.\n */\nexport interface QdPageEditAction {\n  /**\n   * @description Label for the edit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the edit action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the delete action.\n *\n * * This action is represented as an icon, so it does not require a label.\n */\nexport interface QdPageDeleteAction {\n  /**\n   * @description Handler function that is triggered when the delete action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the archive action.\n *\n * * This action is represented as an icon, so it does not require a label.\n */\nexport interface QdPageArchiveAction {\n  /**\n   * @description Handler function that is triggered when the archive action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-config.interface.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/page/model/page-config.interface.ts"],"names":[],"mappings":"","sourcesContent":["import { Observable } from 'rxjs';\n\nimport { QdMenuButtonActionConfig } from '../../button/model/button-config';\nimport { QdPageHeaderFacetConfig } from './page-header-facet.interface';\n\n/**\n * @description Configuration of QdPage.\n *\n * @template T - The type of the page object data\n */\nexport type QdPageConfig<T extends object = object> =\n  | QdPageConfigOverview\n  | QdPageConfigCreate<T>\n  | QdPageConfigInspect<T>\n  | QdPageConfigCustom<T>;\n\nexport interface QdPageSelectedContext {\n  value: string;\n  label: {\n    i18n: string;\n  };\n}\n\ninterface QdPageContextConfigBase {\n  /**\n   * @description Description for the specific header facet\n   */\n  label: {\n    /**\n     * @description i18n string for the description, used for translation.\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Allows to identify the context\n   */\n  id: string;\n\n  /**\n   * @description Register some handler that is executed when the selection changes.\n   */\n  changed?: (selection: QdPageSelectedContext | QdPageSelectedContext[] | null) => void;\n}\n\n/**\n * @description Configuration for a context with single selection\n */\nexport interface QdPageContextConfigSingle extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'single';\n\n  /**\n   * @description Available options for selection.\n   */\n  options: QdPageSelectedContext[];\n\n  /**\n   * @description Configures whether the context options are searchable for the user.\n   * @default false\n   */\n  hasSearch?: boolean;\n\n  /**\n   * @description Placeholder for search\n   */\n  searchPlaceholder?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Title for the dialog that will be opened\n   */\n  title?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n}\n\n/**\n * @description Configuration for a context with multi selection\n */\nexport interface QdPageContextConfigMulti extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'multi';\n\n  /**\n   * @description Available options for selection.\n   */\n  options: QdPageSelectedContext[];\n\n  /**\n   * @description Configures whether the context options are searchable for the user.\n   * @default false\n   */\n  hasSearch?: boolean;\n\n  /**\n   * @description Placeholder for search\n\n   */\n  searchPlaceholder?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n\n  /**\n   * @description Title for the dialog that will be opened\n   */\n  title?: {\n    /**\n     * @description i18n string\n     */\n    i18n: string;\n  };\n}\n\n/**\n * @description Configuration for a context with custom selection (e. g. your own dialog)\n */\nexport interface QdPageContextConfigCustom extends QdPageContextConfigBase {\n  /**\n   * @description Configures the type on how the context selection happens.\n   */\n  type: 'custom';\n\n  /**\n   * @description Handler to open a custom dialog for selection\n   */\n  open: () => void;\n}\n\n/**\n * @description Configures the context with one of the available types\n */\nexport type QdPageContextConfig = QdPageContextConfigSingle | QdPageContextConfigMulti | QdPageContextConfigCustom;\n\n/**\n * @description Base configuration for QdPage.\n */\ninterface QdPageConfigBase {\n  /**\n   * @description Title of the page.\n   */\n  title: QdPageTitle;\n\n  /**\n   * @description Hides contexts from being shown. The ContextService will still work in the background.\n   *\n   * @default false\n   */\n  hideContexts?: boolean;\n\n  /**\n   * @description Label for the menu button of custom actions.\n   */\n  customActionsLabel?: QdPageCustomActionsLabel;\n}\n\n/**\n * @description Configuration for the overview page type.\n *\n * @template T - The type of the page object data\n */\nexport interface QdPageConfigOverview extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'overview'\n   */\n  pageType?: 'overview'; // Optional to make it default\n\n  /**\n   * @description Configuration specific to the overview page type.\n   */\n  pageTypeConfig?: QdPageTypeOverviewConfig;\n}\n\n/**\n * @description Configuration for the create page type.\n *\n * @template T - The type of the page object data\n */\nexport interface QdPageConfigCreate<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'create'\n   */\n  pageType: 'create';\n\n  /**\n   * @description Configuration specific to the create page type.\n   */\n  pageTypeConfig?: QdPageTypeCreateConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n}\n\nexport interface QdPageConfigInspect<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'inspect'\n   */\n  pageType: 'inspect';\n\n  /**\n   * @description Configuration specific to the inspect page type.\n   */\n  pageTypeConfig?: QdPageTypeInspectConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n\n  /**\n   * @description Determines whether the facets in header should be collapsed and custom actions are in a menu. This mode is designed for touch devices and mobile phones only.\n   *\n   * @default false\n   */\n  adaptiveMode?: boolean;\n}\n\nexport interface QdPageConfigCustom<T extends object = object> extends QdPageConfigBase {\n  /**\n   * @description Page Type\n   *\n   * @default 'custom'\n   */\n  pageType: 'custom';\n\n  /**\n   * @description Configuration specific to the custom page type.\n   */\n  pageTypeConfig?: QdPageTypeCustomConfig;\n\n  /**\n   * @description Information placed in the header of the page. Concerns current shown object.\n   */\n  headerFacets?: QdPageHeaderFacetConfig<T>[];\n\n  /**\n   * @description Determines whether the facets in header should be collapsed and custom actions are in a menu. This mode is designed for touch devices and mobile phones only.\n   *\n   * @default false\n   */\n  adaptiveMode?: boolean;\n}\n\n/**\n * Configures the overview page\n */\nexport interface QdPageTypeOverviewConfig {\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\n/**\n * @description Configures the create page.\n */\nexport interface QdPageTypeCreateConfig {\n  /**\n   * @description Configuration for the save draft action.\n   */\n  saveDraft?: QdPageSaveDraftAction;\n\n  /**\n   * @description Configuration for the cancel button.\n   */\n  cancel: QdPageCancelAction;\n\n  /**\n   * @description Configuration for the submit button.\n   */\n  submit: QdPageCreateSubmitAction;\n\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\n/**\n * @description Configures the inspect page.\n */\nexport interface QdPageTypeInspectConfig {\n  /**\n   * @description Operation mode for the page.\n   *\n   * * This property determines the mode in which the page operates. It can be either 'view' or 'edit'.\n   *\n   * * **view**: The page is in read-only mode.\n   * * **edit**: The page allows modifications.\n   */\n  operationMode?: QdInspectOperationMode;\n\n  /**\n   * @description Specifies whether the user can edit the object or not.\n   */\n  hideEdit?: boolean;\n\n  /**\n   * @description Configuration for the edit action.\n   */\n  edit?: QdPageEditAction;\n\n  /**\n   * @description Configuration for the save action.\n   */\n  save?: QdPageSaveAction;\n\n  /**\n   * @description Configuration for the cancel action.\n   */\n  cancel: QdPageCancelAction;\n\n  /**\n   * @description Configuration for the delete action.\n   */\n  delete?: QdPageDeleteAction;\n\n  /**\n   * @description Configuration for the archive action.\n   */\n  archive?: QdPageArchiveAction;\n\n  /**\n   * @description Configuration for the submit action.\n   */\n  submit?: QdPageInspectSubmitAction;\n\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * In the \"Inspect\" page type, you can assign custom actions to the operation modes \"view\" or \"edit.\" By default, the action is active in both modes.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: (QdMenuButtonActionConfig & { operationMode?: QdInspectOperationMode })[];\n}\n\nexport interface QdPageTypeCustomConfig {\n  /**\n   * @description Custom actions for the header.\n   * You can define a label, a handler, and you can disable or hide the action.\n   *\n   * * If there exists more than 1 Custom Action, a QdMenuButton will be displayed.\n   *\n   * * These actions are not intended to influence the core process flow or manipulate the object directly. Instead, they should be used for side effects, such as triggering notifications, updating external services, or executing supplementary tasks that do not alter the main state of the object.\n   */\n  customActions?: QdMenuButtonActionConfig[];\n}\n\nexport interface QdPageTitle {\n  /**\n   * @description Defines the translation key\n   *\n   * * @example { i18n: \"i18n.overview.title\"}\n   */\n  i18n: string;\n}\n\n/**\n * @description Configuration for the custom actions label, used when multiple custom actions exist.\n */\nexport interface QdPageCustomActionsLabel {\n  /**\n   * @description Label for the menu button of custom actions, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   *\n   * * This label becomes visible if more than one custom action is defined, as the actions will be grouped under a QdMenuButton that displays this label.\n   */\n  i18n: string;\n}\n\n/**\n * @description Operation modes for the inspect page.\n *\n * @default 'view'\n */\nexport type QdInspectOperationMode = 'view' | 'edit';\n\n/**\n * @description Interface for the save action, including optional validation configuration.\n */\nexport interface QdPageSaveAction {\n  /**\n   * @description Label for the save action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Triggered when the save action is executed.\n   *\n   * Success criteria:\n   * - If the handler returns an Observable<boolean>, only the first emission after the save click counts:\n   *   - **true:** success - toggle to view and apply the saved values\n   *   - **false:** failure/cancel - stay in edit mode\n   * - If the handler returns no Observable (void), the save is treated as instant success (toggle + apply values).\n   *\n   * On a successful save, the framework applies the values and resets its internal validation and change-tracking state.\n   */\n  handler: (formValues?: any) => void | Observable<boolean>;\n\n  /**\n   * @description Optional validation flag, defaults to true.\n   * Determines whether form validation is required before saving and ensures that changes must be present in the form before saving.\n   *\n   * * By default, this flag is set to true, meaning that validation is enforced, and the form will only save if there are changes.\n   *\n   * * If set to `false`, the form will be saved without validation checks, but changes must still be present to proceed with the save operation.\n   *\n   * * This flag is useful in scenarios where form validation is not needed or should be bypassed, but it ensures that only modified forms can be saved.\n   */\n  hasValidation?: boolean;\n}\n\n/**\n * @description Interface for the safe draft action.\n */\nexport interface QdPageSaveDraftAction {\n  /**\n   * @description Label for the save draft action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the save draft action is executed.\n   */\n  handler: () => void;\n}\n\n/**\n * @description Interface for the cancel action, including an optional confirmation message.\n */\nexport interface QdPageCancelAction {\n  /**\n   * @description Label for the cancel action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the cancel action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description An optional confirmation message displayed in a dialog when the user attempts to cancel the operation, warning that all changes will be discarded.\n   * If no custom message is provided, a standard message will be shown by default.\n   *\n   * * The cancellation process checks whether there are unsaved changes in the form. If there are changes, the dialog will appear.\n   *\n   * * If no changes are detected, the cancellation proceeds without showing the confirmation dialog.\n   */\n  confirmationMessage?: { i18n: string };\n}\n\n/**\n * @description Interface for the submit action on create pages.\n */\nexport interface QdPageCreateSubmitAction {\n  /**\n   * @description Label for the submit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the submit action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the submit action.\n */\nexport interface QdPageSubmitAction {\n  /**\n   * @description Label for the submit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the submit action is executed.\n   */\n  handler: (formValues?: any) => void;\n\n  /**\n   * @description By default, the visibility of the submit button depends on the page type and the operation mode.\n   * To completely hide the submit button, you can set this isHidden flag.\n   *\n   * @default false\n   */\n  isHidden?: boolean;\n}\n\n/**\n * @description Interface for the edit action.\n */\nexport interface QdPageEditAction {\n  /**\n   * @description Label for the edit action, used for translation.\n   *\n   * * If no custom translation key is provided, a standard label will be used by default.\n   */\n  label?: { i18n: string };\n\n  /**\n   * @description Handler function that is triggered when the edit action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the delete action.\n *\n * * This action is represented as an icon, so it does not require a label.\n */\nexport interface QdPageDeleteAction {\n  /**\n   * @description Handler function that is triggered when the delete action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Interface for the archive action.\n *\n * * This action is represented as an icon, so it does not require a label.\n */\nexport interface QdPageArchiveAction {\n  /**\n   * @description Handler function that is triggered when the archive action is executed.\n   */\n  handler: (formValues?: any) => void;\n}\n\n/**\n * @description Inspect-specific submit action configuration.\n */\nexport interface QdPageInspectSubmitAction extends QdPageSubmitAction {\n  /**\n   * @description Optional info message shown when submit is disabled on inspect pages for non-validation reasons.\n   *\n   * * If not provided, the standard disabled explanation is used.\n   */\n  disabledInfo?: { i18n: string };\n}\n"]}