@quadrel-enterprise-ui/framework 18.19.1 → 18.20.0

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.
@@ -1,14 +1,11 @@
1
1
  // @ts-strict-ignore
2
2
  import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
3
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
3
  import { v4 as uuid } from 'uuid';
5
4
  import * as i0 from "@angular/core";
6
5
  import * as i1 from "@angular/common";
7
6
  import * as i2 from "@ngx-translate/core";
8
7
  export class QdSwitchComponent {
9
- // TODO: Refactor FormInput for better internal interface
10
8
  inputData;
11
- value;
12
9
  id;
13
10
  disabled = false;
14
11
  testId = 'switch';
@@ -29,60 +26,19 @@ export class QdSwitchComponent {
29
26
  get labelPosition() {
30
27
  return this.inputData.labelPosition || 'right';
31
28
  }
32
- _onChange = () => { };
33
- _onTouch = () => { };
34
29
  ngOnInit() {
35
30
  if (!this.id) {
36
31
  this.id = uuid();
37
32
  }
38
33
  }
39
- registerOnChange(fn) {
40
- this._onChange = fn;
41
- this._onChange(this.value);
42
- }
43
- registerOnTouched(fn) {
44
- this._onTouch = fn;
45
- }
46
- setDisabledState(state) {
47
- this.disabled = state;
48
- }
49
- writeValue(value) {
50
- this.value = value;
51
- this.valueChange.emit(this.value);
52
- }
53
- handleClick(value, event) {
54
- event.stopPropagation();
55
- if (this.disabled) {
56
- return;
57
- }
58
- const _value = value !== this.value ? value : null;
59
- this._onChange(_value);
60
- this._onTouch(_value);
61
- this.value = _value;
62
- this.valueChange.emit(this.value);
63
- }
64
34
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdSwitchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
65
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdSwitchComponent, selector: "qd-switch", inputs: { inputData: "inputData", value: "value", id: "id", disabled: "disabled", testId: ["data-test-id", "testId"] }, outputs: { valueChange: "valueChange" }, host: { properties: { "class.qd-switch-active": "this.active", "class.qd-switch-disabled": "this.isDisabled" }, classAttribute: "qd-switch" }, providers: [
66
- {
67
- provide: NG_VALUE_ACCESSOR,
68
- useExisting: QdSwitchComponent,
69
- multi: true
70
- }
71
- ], ngImport: i0, template: "<label [for]=\"toggleId\">\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'left'\" [attr.data-test-id]=\"testId + '-label'\">\n {{ label | translate }}\n </div>\n <div class=\"switch-toggle-bar\">\n <input\n class=\"switch-toggle-input\"\n name=\"switch-toggle\"\n type=\"checkbox\"\n [id]=\"toggleId\"\n (click)=\"handleClick(value, $event)\"\n [value]=\"value\"\n [disabled]=\"isDisabled\"\n [attr.data-test-id]=\"testId + '-input'\"\n />\n <div class=\"switch-toggle-button\"></div>\n </div>\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'right'\" [attr.data-test-id]=\"testId + '-content'\">\n {{ label | translate }}\n </div>\n</label>\n", styles: [".qd-switch label{display:flex;width:max-content;align-items:center}.qd-switch label:hover{cursor:pointer}.qd-switch .switch-toggle-bar{position:relative;width:2.5rem;height:1.25rem;border-radius:1.25rem;background-color:#e5e5e5}.qd-switch .switch-toggle-bar input{appearance:none}.qd-switch .switch-toggle-bar .switch-toggle-button{position:absolute;top:0;width:1.25rem;height:1.25rem;border-radius:1.25rem;background-color:#b4b4b4;transition:all 80ms linear;transition-property:transform}.qd-switch .switch-content{margin-right:.75rem;margin-left:.75rem;color:#171717;font-size:.875rem;font-weight:400;line-height:.875rem}.qd-switch:hover .switch-toggle-bar{background-color:#d5d5d5}.qd-switch:hover .switch-toggle-bar .switch-toggle-button{background-color:#979797}.qd-switch.qd-switch-active .switch-toggle-bar{background-color:#c3e8cd}.qd-switch.qd-switch-active .switch-toggle-bar .switch-toggle-button{background-color:#00813a;transform:translate(1.25rem)}.qd-switch.qd-switch-active:hover .switch-toggle-bar .switch-toggle-button{background-color:#006226}.qd-switch.qd-switch-disabled label:hover{cursor:initial}.qd-switch.qd-switch-disabled .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}.qd-switch.qd-switch-disabled .switch-content{color:#757575}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
35
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdSwitchComponent, selector: "qd-switch", inputs: { inputData: "inputData", id: "id", disabled: "disabled", testId: ["data-test-id", "testId"] }, outputs: { valueChange: "valueChange" }, host: { properties: { "class.qd-switch-active": "this.active", "class.qd-switch-disabled": "this.isDisabled" }, classAttribute: "qd-switch" }, ngImport: i0, template: "<label [for]=\"toggleId\">\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'left'\" [attr.data-test-id]=\"testId + '-label'\">\n {{ label | translate }}\n </div>\n <div class=\"switch-toggle-bar\">\n <div class=\"switch-toggle-button\"></div>\n </div>\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'right'\" [attr.data-test-id]=\"testId + '-content'\">\n {{ label | translate }}\n </div>\n</label>\n", styles: [".qd-switch label{display:flex;width:max-content;align-items:center}.qd-switch label:hover{cursor:pointer}.qd-switch .switch-toggle-bar{position:relative;width:2.5rem;height:1.25rem;border-radius:1.25rem;background-color:#e5e5e5}.qd-switch .switch-toggle-bar .switch-toggle-button{position:absolute;top:0;width:1.25rem;height:1.25rem;border-radius:1.25rem;background-color:#b4b4b4;transition:all 80ms linear;transition-property:transform}.qd-switch .switch-content{margin-right:.75rem;margin-left:.75rem;color:#171717;font-size:.875rem;font-weight:400;line-height:.875rem}.qd-switch:hover .switch-toggle-bar{background-color:#d5d5d5}.qd-switch:hover .switch-toggle-bar .switch-toggle-button{background-color:#979797}.qd-switch.qd-switch-active .switch-toggle-bar{background-color:#c3e8cd}.qd-switch.qd-switch-active .switch-toggle-bar .switch-toggle-button{background-color:#00813a;transform:translate(1.25rem)}.qd-switch.qd-switch-active:hover .switch-toggle-bar .switch-toggle-button{background-color:#006226}.qd-switch.qd-switch-disabled label:hover{cursor:initial}.qd-switch.qd-switch-disabled .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}.qd-switch.qd-switch-disabled .switch-content{color:#757575}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
72
36
  }
73
37
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdSwitchComponent, decorators: [{
74
38
  type: Component,
75
- args: [{ selector: 'qd-switch', encapsulation: ViewEncapsulation.None, providers: [
76
- {
77
- provide: NG_VALUE_ACCESSOR,
78
- useExisting: QdSwitchComponent,
79
- multi: true
80
- }
81
- ], host: { class: 'qd-switch' }, template: "<label [for]=\"toggleId\">\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'left'\" [attr.data-test-id]=\"testId + '-label'\">\n {{ label | translate }}\n </div>\n <div class=\"switch-toggle-bar\">\n <input\n class=\"switch-toggle-input\"\n name=\"switch-toggle\"\n type=\"checkbox\"\n [id]=\"toggleId\"\n (click)=\"handleClick(value, $event)\"\n [value]=\"value\"\n [disabled]=\"isDisabled\"\n [attr.data-test-id]=\"testId + '-input'\"\n />\n <div class=\"switch-toggle-button\"></div>\n </div>\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'right'\" [attr.data-test-id]=\"testId + '-content'\">\n {{ label | translate }}\n </div>\n</label>\n", styles: [".qd-switch label{display:flex;width:max-content;align-items:center}.qd-switch label:hover{cursor:pointer}.qd-switch .switch-toggle-bar{position:relative;width:2.5rem;height:1.25rem;border-radius:1.25rem;background-color:#e5e5e5}.qd-switch .switch-toggle-bar input{appearance:none}.qd-switch .switch-toggle-bar .switch-toggle-button{position:absolute;top:0;width:1.25rem;height:1.25rem;border-radius:1.25rem;background-color:#b4b4b4;transition:all 80ms linear;transition-property:transform}.qd-switch .switch-content{margin-right:.75rem;margin-left:.75rem;color:#171717;font-size:.875rem;font-weight:400;line-height:.875rem}.qd-switch:hover .switch-toggle-bar{background-color:#d5d5d5}.qd-switch:hover .switch-toggle-bar .switch-toggle-button{background-color:#979797}.qd-switch.qd-switch-active .switch-toggle-bar{background-color:#c3e8cd}.qd-switch.qd-switch-active .switch-toggle-bar .switch-toggle-button{background-color:#00813a;transform:translate(1.25rem)}.qd-switch.qd-switch-active:hover .switch-toggle-bar .switch-toggle-button{background-color:#006226}.qd-switch.qd-switch-disabled label:hover{cursor:initial}.qd-switch.qd-switch-disabled .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}.qd-switch.qd-switch-disabled .switch-content{color:#757575}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}\n"] }]
39
+ args: [{ selector: 'qd-switch', encapsulation: ViewEncapsulation.None, host: { class: 'qd-switch' }, template: "<label [for]=\"toggleId\">\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'left'\" [attr.data-test-id]=\"testId + '-label'\">\n {{ label | translate }}\n </div>\n <div class=\"switch-toggle-bar\">\n <div class=\"switch-toggle-button\"></div>\n </div>\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'right'\" [attr.data-test-id]=\"testId + '-content'\">\n {{ label | translate }}\n </div>\n</label>\n", styles: [".qd-switch label{display:flex;width:max-content;align-items:center}.qd-switch label:hover{cursor:pointer}.qd-switch .switch-toggle-bar{position:relative;width:2.5rem;height:1.25rem;border-radius:1.25rem;background-color:#e5e5e5}.qd-switch .switch-toggle-bar .switch-toggle-button{position:absolute;top:0;width:1.25rem;height:1.25rem;border-radius:1.25rem;background-color:#b4b4b4;transition:all 80ms linear;transition-property:transform}.qd-switch .switch-content{margin-right:.75rem;margin-left:.75rem;color:#171717;font-size:.875rem;font-weight:400;line-height:.875rem}.qd-switch:hover .switch-toggle-bar{background-color:#d5d5d5}.qd-switch:hover .switch-toggle-bar .switch-toggle-button{background-color:#979797}.qd-switch.qd-switch-active .switch-toggle-bar{background-color:#c3e8cd}.qd-switch.qd-switch-active .switch-toggle-bar .switch-toggle-button{background-color:#00813a;transform:translate(1.25rem)}.qd-switch.qd-switch-active:hover .switch-toggle-bar .switch-toggle-button{background-color:#006226}.qd-switch.qd-switch-disabled label:hover{cursor:initial}.qd-switch.qd-switch-disabled .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}.qd-switch.qd-switch-disabled .switch-content{color:#757575}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}\n"] }]
82
40
  }], propDecorators: { inputData: [{
83
41
  type: Input
84
- }], value: [{
85
- type: Input
86
42
  }], id: [{
87
43
  type: Input
88
44
  }], disabled: [{
@@ -99,4 +55,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
99
55
  type: HostBinding,
100
56
  args: ['class.qd-switch-disabled']
101
57
  }] } });
102
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9mb3Jtcy9zd2l0Y2hlcy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9mb3Jtcy9zd2l0Y2hlcy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG9CQUFvQjtBQUNwQixPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRyxPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDekUsT0FBTyxFQUFFLEVBQUUsSUFBSSxJQUFJLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7QUFrQmxDLE1BQU0sT0FBTyxpQkFBaUI7SUFDNUIseURBQXlEO0lBQ2hELFNBQVMsQ0FBZ0I7SUFDekIsS0FBSyxDQUFDO0lBQ04sRUFBRSxDQUFDO0lBQ0gsUUFBUSxHQUFHLEtBQUssQ0FBQztJQUNILE1BQU0sR0FBRyxRQUFRLENBQUM7SUFFL0IsV0FBVyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7SUFFbkQsSUFDSSxNQUFNO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztJQUMvQixDQUFDO0lBRUQsSUFDSSxVQUFVO1FBQ1osT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ2xELENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsRUFB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RW1pdHRlciwgSG9zdEJpbmRpbmcsIElucHV0LCBPbkluaXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IHY0IGFzIHV1aWQgfSBmcm9tICd1dWlkJztcblxuaW1wb3J0IHsgUWRTd2l0Y2hJbnB1dCB9IGZyb20gJy4uLy4uL21vZGVsL29wdGlvbnMuaW50ZXJmYWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncWQtc3dpdGNoJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3N3aXRjaC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3N3aXRjaC5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcbiAgICAgIHVzZUV4aXN0aW5nOiBRZFN3aXRjaENvbXBvbmVudCxcbiAgICAgIG11bHRpOiB0cnVlXG4gICAgfVxuICBdLFxuICBob3N0OiB7IGNsYXNzOiAncWQtc3dpdGNoJyB9XG59KVxuZXhwb3J0IGNsYXNzIFFkU3dpdGNoQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBDb250cm9sVmFsdWVBY2Nlc3NvciB7XG4gIC8vIFRPRE86IFJlZmFjdG9yIEZvcm1JbnB1dCBmb3IgYmV0dGVyIGludGVybmFsIGludGVyZmFjZVxuICBASW5wdXQoKSBpbnB1dERhdGE6IFFkU3dpdGNoSW5wdXQ7XG4gIEBJbnB1dCgpIHZhbHVlO1xuICBASW5wdXQoKSBpZDtcbiAgQElucHV0KCkgZGlzYWJsZWQgPSBmYWxzZTtcbiAgQElucHV0KCdkYXRhLXRlc3QtaWQnKSB0ZXN0SWQgPSAnc3dpdGNoJztcblxuICBAT3V0cHV0KCkgdmFsdWVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLnFkLXN3aXRjaC1hY3RpdmUnKVxuICBnZXQgYWN0aXZlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmlucHV0RGF0YS5hY3RpdmU7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLnFkLXN3aXRjaC1kaXNhYmxlZCcpXG4gIGdldCBpc0Rpc2FibGVkKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmlucHV0RGF0YS5kaXNhYmxlZCB8fCB0aGlzLmRpc2FibGVkO1xuICB9XG5cbiAgZ2V0IHRvZ2dsZUlkKCk6IHN0cmluZyB7XG4gICAgY29uc3QgdWlkID0gdGhpcy5pbnB1dERhdGEgPyB0aGlzLmlucHV0RGF0YS52YWx1ZSArIHRoaXMuaWQgOiB0aGlzLmlkO1xuICAgIHJldHVybiBgc3dpdGNoLXRvZ2dsZS0ke3VpZH1gO1xuICB9XG5cbiAgZ2V0IGxhYmVsKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuaW5wdXREYXRhLmkxOG47XG4gIH1cblxuICBnZXQgbGFiZWxQb3NpdGlvbigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmlucHV0RGF0YS5sYWJlbFBvc2l0aW9uIHx8ICdyaWdodCc7XG4gIH1cblxuICBwcml2YXRlIF9vbkNoYW5nZTogYW55ID0gKCkgPT4ge307XG4gIHByaXZhdGUgX29uVG91Y2g6IGFueSA9ICgpID0+IHt9O1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5pZCkge1xuICAgICAgdGhpcy5pZCA9IHV1aWQoKTtcbiAgICB9XG4gIH1cblxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiAoXzogYW55KSA9PiB2b2lkKTogdm9pZCB7XG4gICAgdGhpcy5fb25DaGFuZ2UgPSBmbjtcbiAgICB0aGlzLl9vbkNoYW5nZSh0aGlzLnZhbHVlKTtcbiAgfVxuXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLl9vblRvdWNoID0gZm47XG4gIH1cblxuICBzZXREaXNhYmxlZFN0YXRlKHN0YXRlOiBib29sZWFuKTogdm9pZCB7XG4gICAgdGhpcy5kaXNhYmxlZCA9IHN0YXRlO1xuICB9XG5cbiAgd3JpdGVWYWx1ZSh2YWx1ZSk6IHZvaWQge1xuICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcbiAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQodGhpcy52YWx1ZSk7XG4gIH1cblxuICBoYW5kbGVDbGljayh2YWx1ZTogc3RyaW5nLCBldmVudDogTW91c2VFdmVudCk6IHZvaWQge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuXG4gICAgaWYgKHRoaXMuZGlzYWJsZWQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBfdmFsdWUgPSB2YWx1ZSAhPT0gdGhpcy52YWx1ZSA/IHZhbHVlIDogbnVsbDtcblxuICAgIHRoaXMuX29uQ2hhbmdlKF92YWx1ZSk7XG4gICAgdGhpcy5fb25Ub3VjaChfdmFsdWUpO1xuICAgIHRoaXMudmFsdWUgPSBfdmFsdWU7XG4gICAgdGhpcy52YWx1ZUNoYW5nZS5lbWl0KHRoaXMudmFsdWUpO1xuICB9XG59XG4iLCI8bGFiZWwgW2Zvcl09XCJ0b2dnbGVJZFwiPlxuICA8ZGl2IGNsYXNzPVwic3dpdGNoLWNvbnRlbnRcIiAqbmdJZj1cImxhYmVsUG9zaXRpb24gPT09ICdsZWZ0J1wiIFthdHRyLmRhdGEtdGVzdC1pZF09XCJ0ZXN0SWQgKyAnLWxhYmVsJ1wiPlxuICAgIHt7IGxhYmVsIHwgdHJhbnNsYXRlIH19XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwic3dpdGNoLXRvZ2dsZS1iYXJcIj5cbiAgICA8aW5wdXRcbiAgICAgIGNsYXNzPVwic3dpdGNoLXRvZ2dsZS1pbnB1dFwiXG4gICAgICBuYW1lPVwic3dpdGNoLXRvZ2dsZVwiXG4gICAgICB0eXBlPVwiY2hlY2tib3hcIlxuICAgICAgW2lkXT1cInRvZ2dsZUlkXCJcbiAgICAgIChjbGljayk9XCJoYW5kbGVDbGljayh2YWx1ZSwgJGV2ZW50KVwiXG4gICAgICBbdmFsdWVdPVwidmFsdWVcIlxuICAgICAgW2Rpc2FibGVkXT1cImlzRGlzYWJsZWRcIlxuICAgICAgW2F0dHIuZGF0YS10ZXN0LWlkXT1cInRlc3RJZCArICctaW5wdXQnXCJcbiAgICAvPlxuICAgIDxkaXYgY2xhc3M9XCJzd2l0Y2gtdG9nZ2xlLWJ1dHRvblwiPjwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cInN3aXRjaC1jb250ZW50XCIgKm5nSWY9XCJsYWJlbFBvc2l0aW9uID09PSAncmlnaHQnXCIgW2F0dHIuZGF0YS10ZXN0LWlkXT1cInRlc3RJZCArICctY29udGVudCdcIj5cbiAgICB7eyBsYWJlbCB8IHRyYW5zbGF0ZSB9fVxuICA8L2Rpdj5cbjwvbGFiZWw+XG4iXX0=
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9mb3Jtcy9zd2l0Y2hlcy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9mb3Jtcy9zd2l0Y2hlcy9zd2l0Y2gvc3dpdGNoLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG9CQUFvQjtBQUNwQixPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRyxPQUFPLEVBQUUsRUFBRSxJQUFJLElBQUksRUFBRSxNQUFNLE1BQU0sQ0FBQzs7OztBQVdsQyxNQUFNLE9BQU8saUJBQWlCO0lBQ25CLFNBQVMsQ0FBZ0I7SUFDekIsRUFBRSxDQUFTO0lBQ1gsUUFBUSxHQUFHLEtBQUssQ0FBQztJQUNILE1BQU0sR0FBRyxRQUFRLENBQUM7SUFFL0IsV0FBVyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7SUFFbkQsSUFDSSxNQUFNO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztJQUMvQixDQUFDO0lBRUQsSUFDSSxVQUFVO1FBQ1osT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ2xELENBQUM7SUFFRCxJQUFJLFFBQVE7UUFDVixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ3RFLE9BQU8saUJBQWlCLEdBQUcsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO0lBQzdCLENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDZixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxJQUFJLE9BQU8sQ0FBQztJQUNqRCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDYixJQUFJLENBQUMsRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDO1FBQ25CLENBQUM7SUFDSCxDQUFDO3VHQW5DVSxpQkFBaUI7MkZBQWpCLGlCQUFpQixpVkNiOUIsc2JBV0E7OzJGREVhLGlCQUFpQjtrQkFQN0IsU0FBUzsrQkFDRSxXQUFXLGlCQUdOLGlCQUFpQixDQUFDLElBQUksUUFDL0IsRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFFOzhCQUduQixTQUFTO3NCQUFqQixLQUFLO2dCQUNHLEVBQUU7c0JBQVYsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNpQixNQUFNO3NCQUE1QixLQUFLO3VCQUFDLGNBQWM7Z0JBRVgsV0FBVztzQkFBcEIsTUFBTTtnQkFHSCxNQUFNO3NCQURULFdBQVc7dUJBQUMsd0JBQXdCO2dCQU1qQyxVQUFVO3NCQURiLFdBQVc7dUJBQUMsMEJBQTBCIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLXN0cmljdC1pZ25vcmVcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE9uSW5pdCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgdjQgYXMgdXVpZCB9IGZyb20gJ3V1aWQnO1xuXG5pbXBvcnQgeyBRZFN3aXRjaElucHV0IH0gZnJvbSAnLi4vLi4vbW9kZWwvb3B0aW9ucy5pbnRlcmZhY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdxZC1zd2l0Y2gnLFxuICB0ZW1wbGF0ZVVybDogJy4vc3dpdGNoLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3dpdGNoLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGhvc3Q6IHsgY2xhc3M6ICdxZC1zd2l0Y2gnIH1cbn0pXG5leHBvcnQgY2xhc3MgUWRTd2l0Y2hDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBpbnB1dERhdGE6IFFkU3dpdGNoSW5wdXQ7XG4gIEBJbnB1dCgpIGlkOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XG4gIEBJbnB1dCgnZGF0YS10ZXN0LWlkJykgdGVzdElkID0gJ3N3aXRjaCc7XG5cbiAgQE91dHB1dCgpIHZhbHVlQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5xZC1zd2l0Y2gtYWN0aXZlJylcbiAgZ2V0IGFjdGl2ZSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5pbnB1dERhdGEuYWN0aXZlO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5xZC1zd2l0Y2gtZGlzYWJsZWQnKVxuICBnZXQgaXNEaXNhYmxlZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5pbnB1dERhdGEuZGlzYWJsZWQgfHwgdGhpcy5kaXNhYmxlZDtcbiAgfVxuXG4gIGdldCB0b2dnbGVJZCgpOiBzdHJpbmcge1xuICAgIGNvbnN0IHVpZCA9IHRoaXMuaW5wdXREYXRhID8gdGhpcy5pbnB1dERhdGEudmFsdWUgKyB0aGlzLmlkIDogdGhpcy5pZDtcbiAgICByZXR1cm4gYHN3aXRjaC10b2dnbGUtJHt1aWR9YDtcbiAgfVxuXG4gIGdldCBsYWJlbCgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmlucHV0RGF0YS5pMThuO1xuICB9XG5cbiAgZ2V0IGxhYmVsUG9zaXRpb24oKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5pbnB1dERhdGEubGFiZWxQb3NpdGlvbiB8fCAncmlnaHQnO1xuICB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLmlkKSB7XG4gICAgICB0aGlzLmlkID0gdXVpZCgpO1xuICAgIH1cbiAgfVxufVxuIiwiPGxhYmVsIFtmb3JdPVwidG9nZ2xlSWRcIj5cbiAgPGRpdiBjbGFzcz1cInN3aXRjaC1jb250ZW50XCIgKm5nSWY9XCJsYWJlbFBvc2l0aW9uID09PSAnbGVmdCdcIiBbYXR0ci5kYXRhLXRlc3QtaWRdPVwidGVzdElkICsgJy1sYWJlbCdcIj5cbiAgICB7eyBsYWJlbCB8IHRyYW5zbGF0ZSB9fVxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cInN3aXRjaC10b2dnbGUtYmFyXCI+XG4gICAgPGRpdiBjbGFzcz1cInN3aXRjaC10b2dnbGUtYnV0dG9uXCI+PC9kaXY+XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwic3dpdGNoLWNvbnRlbnRcIiAqbmdJZj1cImxhYmVsUG9zaXRpb24gPT09ICdyaWdodCdcIiBbYXR0ci5kYXRhLXRlc3QtaWRdPVwidGVzdElkICsgJy1jb250ZW50J1wiPlxuICAgIHt7IGxhYmVsIHwgdHJhbnNsYXRlIH19XG4gIDwvZGl2PlxuPC9sYWJlbD5cbiJdfQ==
@@ -225,7 +225,7 @@ export class QdSwitchesComponent {
225
225
  },
226
226
  QdSwitchesService,
227
227
  QdFormsActionEmitterService
228
- ], usesOnChanges: true, ngImport: i0, template: "<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<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n <div class=\"qd-switches__switch-section\">\n <qd-switch\n *ngFor=\"let input of switchesInputs\"\n [inputData]=\"input\"\n [(value)]=\"switchesValues[input.index]\"\n (click)=\"handleClick(input)\"\n [data-test-id]=\"testId + '-switch-' + input.index\"\n [disabled]=\"disabled\"\n ></qd-switch>\n </div>\n</div>\n\n<qd-form-hint\n *ngIf=\"!readonly && !viewonly\"\n [hint]=\"hasHint ? config.hint.i18n : ''\"\n [control]=\"control\"\n [hasError]=\"hasError\"\n [hintAction]=\"hintAction\"\n [data-test-id]=\"testId\"\n></qd-form-hint>\n\n<qd-form-readonly\n *ngIf=\"readonly\"\n [values]=\"selectedValuesTranslated\"\n [readonlyAction]=\"readonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n *ngIf=\"viewonly\"\n [values]=\"selectedValuesTranslated\"\n [viewonlyAction]=\"viewonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-viewonly>\n", styles: [".qd-switches{display:block;flex-direction:column;margin-bottom:.75rem}.qd-switches .qd-switches__input-section{display:flex;flex-direction:column;margin-bottom:.375rem}.qd-switches .qd-switches__switch-section{display:flex;flex-direction:row}.qd-switches .qd-switches__switch-section .switch-toggle-bar{margin-right:.375rem}.qd-switches .qd-switches__switch-section .switch-content{margin:0 1rem 0 0}.qd-switches qd-switch:last-child .switch-content{margin-right:0}.qd-switches.qd-switches-vertical .qd-switches__switch-section{display:flex;flex-direction:column}.qd-switches.qd-switches-vertical .qd-switches__switch-section .qd-switch:not(:last-child){margin-bottom:.5rem}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section{align-items:center}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section .qd-switch{display:flex;height:2.25rem}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.QdFormHintComponent, selector: "qd-form-hint", inputs: ["hint", "control", "hasError", "hintAction", "data-test-id"] }, { kind: "component", type: i7.QdFormLabelComponent, selector: "qd-form-label", inputs: ["label", "isDisabled", "readonly", "viewonly", "control", "tooltip", "data-test-id"] }, { kind: "component", type: i8.QdFormReadonlyComponent, selector: "qd-form-readonly", inputs: ["values", "readonlyAction", "data-test-id"] }, { kind: "component", type: i9.QdFormViewonlyComponent, selector: "qd-form-viewonly", inputs: ["values", "viewonlyAction", "data-test-id"] }, { kind: "component", type: i10.QdSwitchComponent, selector: "qd-switch", inputs: ["inputData", "value", "id", "disabled", "data-test-id"], outputs: ["valueChange"] }], encapsulation: i0.ViewEncapsulation.None });
228
+ ], usesOnChanges: true, ngImport: i0, template: "<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<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n <div class=\"qd-switches__switch-section\">\n <qd-switch\n *ngFor=\"let input of switchesInputs\"\n [inputData]=\"input\"\n (click)=\"handleClick(input)\"\n [data-test-id]=\"testId + '-switch-' + input.index\"\n [disabled]=\"disabled\"\n ></qd-switch>\n </div>\n</div>\n\n<qd-form-hint\n *ngIf=\"!readonly && !viewonly\"\n [hint]=\"hasHint ? config.hint.i18n : ''\"\n [control]=\"control\"\n [hasError]=\"hasError\"\n [hintAction]=\"hintAction\"\n [data-test-id]=\"testId\"\n></qd-form-hint>\n\n<qd-form-readonly\n *ngIf=\"readonly\"\n [values]=\"selectedValuesTranslated\"\n [readonlyAction]=\"readonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n *ngIf=\"viewonly\"\n [values]=\"selectedValuesTranslated\"\n [viewonlyAction]=\"viewonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-viewonly>\n", styles: [".qd-switches{display:block;flex-direction:column;margin-bottom:.75rem}.qd-switches .qd-switches__input-section{display:flex;flex-direction:column;margin-bottom:.375rem}.qd-switches .qd-switches__switch-section{display:flex;flex-direction:row}.qd-switches .qd-switches__switch-section .switch-toggle-bar{margin-right:.375rem}.qd-switches .qd-switches__switch-section .switch-content{margin:0 1rem 0 0}.qd-switches qd-switch:last-child .switch-content{margin-right:0}.qd-switches.qd-switches-vertical .qd-switches__switch-section{display:flex;flex-direction:column}.qd-switches.qd-switches-vertical .qd-switches__switch-section .qd-switch:not(:last-child){margin-bottom:.5rem}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section{align-items:center}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section .qd-switch{display:flex;height:2.25rem}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.QdFormHintComponent, selector: "qd-form-hint", inputs: ["hint", "control", "hasError", "hintAction", "data-test-id"] }, { kind: "component", type: i7.QdFormLabelComponent, selector: "qd-form-label", inputs: ["label", "isDisabled", "readonly", "viewonly", "control", "tooltip", "data-test-id"] }, { kind: "component", type: i8.QdFormReadonlyComponent, selector: "qd-form-readonly", inputs: ["values", "readonlyAction", "data-test-id"] }, { kind: "component", type: i9.QdFormViewonlyComponent, selector: "qd-form-viewonly", inputs: ["values", "viewonlyAction", "data-test-id"] }, { kind: "component", type: i10.QdSwitchComponent, selector: "qd-switch", inputs: ["inputData", "id", "disabled", "data-test-id"], outputs: ["valueChange"] }], encapsulation: i0.ViewEncapsulation.None });
229
229
  }
230
230
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdSwitchesComponent, decorators: [{
231
231
  type: Component,
@@ -237,7 +237,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
237
237
  },
238
238
  QdSwitchesService,
239
239
  QdFormsActionEmitterService
240
- ], encapsulation: ViewEncapsulation.None, host: { class: 'qd-switches' }, template: "<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<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n <div class=\"qd-switches__switch-section\">\n <qd-switch\n *ngFor=\"let input of switchesInputs\"\n [inputData]=\"input\"\n [(value)]=\"switchesValues[input.index]\"\n (click)=\"handleClick(input)\"\n [data-test-id]=\"testId + '-switch-' + input.index\"\n [disabled]=\"disabled\"\n ></qd-switch>\n </div>\n</div>\n\n<qd-form-hint\n *ngIf=\"!readonly && !viewonly\"\n [hint]=\"hasHint ? config.hint.i18n : ''\"\n [control]=\"control\"\n [hasError]=\"hasError\"\n [hintAction]=\"hintAction\"\n [data-test-id]=\"testId\"\n></qd-form-hint>\n\n<qd-form-readonly\n *ngIf=\"readonly\"\n [values]=\"selectedValuesTranslated\"\n [readonlyAction]=\"readonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n *ngIf=\"viewonly\"\n [values]=\"selectedValuesTranslated\"\n [viewonlyAction]=\"viewonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-viewonly>\n", styles: [".qd-switches{display:block;flex-direction:column;margin-bottom:.75rem}.qd-switches .qd-switches__input-section{display:flex;flex-direction:column;margin-bottom:.375rem}.qd-switches .qd-switches__switch-section{display:flex;flex-direction:row}.qd-switches .qd-switches__switch-section .switch-toggle-bar{margin-right:.375rem}.qd-switches .qd-switches__switch-section .switch-content{margin:0 1rem 0 0}.qd-switches qd-switch:last-child .switch-content{margin-right:0}.qd-switches.qd-switches-vertical .qd-switches__switch-section{display:flex;flex-direction:column}.qd-switches.qd-switches-vertical .qd-switches__switch-section .qd-switch:not(:last-child){margin-bottom:.5rem}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section{align-items:center}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section .qd-switch{display:flex;height:2.25rem}\n"] }]
240
+ ], encapsulation: ViewEncapsulation.None, host: { class: 'qd-switches' }, template: "<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<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n <div class=\"qd-switches__switch-section\">\n <qd-switch\n *ngFor=\"let input of switchesInputs\"\n [inputData]=\"input\"\n (click)=\"handleClick(input)\"\n [data-test-id]=\"testId + '-switch-' + input.index\"\n [disabled]=\"disabled\"\n ></qd-switch>\n </div>\n</div>\n\n<qd-form-hint\n *ngIf=\"!readonly && !viewonly\"\n [hint]=\"hasHint ? config.hint.i18n : ''\"\n [control]=\"control\"\n [hasError]=\"hasError\"\n [hintAction]=\"hintAction\"\n [data-test-id]=\"testId\"\n></qd-form-hint>\n\n<qd-form-readonly\n *ngIf=\"readonly\"\n [values]=\"selectedValuesTranslated\"\n [readonlyAction]=\"readonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n *ngIf=\"viewonly\"\n [values]=\"selectedValuesTranslated\"\n [viewonlyAction]=\"viewonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-viewonly>\n", styles: [".qd-switches{display:block;flex-direction:column;margin-bottom:.75rem}.qd-switches .qd-switches__input-section{display:flex;flex-direction:column;margin-bottom:.375rem}.qd-switches .qd-switches__switch-section{display:flex;flex-direction:row}.qd-switches .qd-switches__switch-section .switch-toggle-bar{margin-right:.375rem}.qd-switches .qd-switches__switch-section .switch-content{margin:0 1rem 0 0}.qd-switches qd-switch:last-child .switch-content{margin-right:0}.qd-switches.qd-switches-vertical .qd-switches__switch-section{display:flex;flex-direction:column}.qd-switches.qd-switches-vertical .qd-switches__switch-section .qd-switch:not(:last-child){margin-bottom:.5rem}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section{align-items:center}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section .qd-switch{display:flex;height:2.25rem}\n"] }]
241
241
  }], ctorParameters: () => [{ type: i1.QdSwitchesService }, { type: i0.ChangeDetectorRef }, { type: i2.QdFormsActionEmitterService }, { type: i3.ControlContainer, decorators: [{
242
242
  type: Optional
243
243
  }, {
@@ -297,4 +297,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
297
297
  type: HostBinding,
298
298
  args: ['class.qd-switches-hint']
299
299
  }] } });
300
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switches.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/switches/switches.component.ts","../../../../../../libs/qd-ui/src/lib/forms/switches/switches.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  SkipSelf,\n  ViewEncapsulation\n} from '@angular/core';\nimport { AbstractControl, ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { v4 as uuid } from 'uuid';\n\nimport { QdFormOption, QdFormSwitchesConfiguration } from '../model/forms.interface';\nimport {\n  getAlign,\n  getDisabled,\n  getHintAction,\n  getLabel,\n  getOptions,\n  getReadonly,\n  getReadonlyAction,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { hasValidationKey } from '../shared/helpers/has-validators.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdSwitchesService } from './switches-service/switches.service';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\nimport { QdSwitchInput } from '../model/options.interface';\n\n/**\n * **QdSwitches** component provides a FormElement.\n * The **QdSwitches** is a component that provides a form element for switches.<br />\n * It allows users to select multiple options from a list of options. 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 *   switches: new QdFormControl([]) // at least an empty array to prevent runtime errors.\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-switches formControlName=\"switches\" [config]=\"config\"></qd-switches>\n * </form>\n * ```\n *\n * ####**Usage with Model Binding**\n * ```ts\n * values;\n * ```\n * ```html\n * <qd-switches [(values)]=\"values\" [config]=\"config\"></qd-switches>\n * ```\n */\n@Component({\n  selector: 'qd-switches',\n  templateUrl: './switches.component.html',\n  styleUrls: ['./switches.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdSwitchesComponent,\n      multi: true\n    },\n    QdSwitchesService,\n    QdFormsActionEmitterService\n  ],\n  encapsulation: ViewEncapsulation.None,\n  host: { class: 'qd-switches' }\n})\nexport class QdSwitchesComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor {\n  /**\n   * The current form control name can be assigned here if you want to use Reactive Forms.\n   */\n  @Input() formControlName: string;\n\n  /**\n   * The form item values, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-switches [(values)]=\"values\" [config]=\"config\"></qd-switches>\n   */\n  @Input() values: string[] = [];\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'Qd-Forms Switches' },\n   *   hint: { i18n: 'Helpertext' },\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' }\n   *   ]\n   * };\n   */\n  @Input() config: QdFormSwitchesConfiguration;\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') testId = 'switches';\n\n  /**\n   * Emits event when the values change. Return values match the current values.\n   */\n  @Output() readonly valuesChange = new EventEmitter<string[]>();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output() readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when the readonly value is clicked/tapped. `readonlyAction ` must be set to `true` for this.\n   */\n  @Output() readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when the viewonly value is clicked/tapped. `viewonlyAction ` must be set to `true` for this.\n   */\n  @Output() readonly clickViewonly = new EventEmitter();\n\n  @HostBinding('class.qd-dropdown-readonly')\n  readonly = false;\n\n  @HostBinding('class.qd-dropdown--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-dropdown-viewonly')\n  viewonly = false;\n\n  @HostBinding('class.qd-dropdown--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-switches--hint-action')\n  public hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  disabled = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-switches-error')\n  get hasError(): boolean {\n    return this.control ? this.control.touched && this.control.invalid : false;\n  }\n\n  @HostBinding('class.qd-switches-vertical')\n  get isVertical(): boolean {\n    return this.align === 'vertical';\n  }\n\n  @HostBinding('class.qd-switches-hint')\n  get hasHint(): boolean {\n    return this.config.hint && this.config.hint.i18n && !this.config.hint.disabled;\n  }\n\n  get required(): boolean {\n    if (!this.control) return false;\n\n    return hasValidationKey(this.control, 'required');\n  }\n\n  control: AbstractControl;\n  id: string;\n  label: string;\n  align;\n  labelPosition;\n  options: QdFormOption[];\n  switchesValues: string[];\n  switchesInputs: QdSwitchInput[];\n\n  private _subs = new Subscription();\n\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  constructor(\n    private readonly switchesService: QdSwitchesService,\n    private readonly changeDetectorRef: ChangeDetectorRef,\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {\n    this.id = uuid();\n  }\n\n  ngOnInit(): void {\n    this.updateConfiguration();\n\n    if (this.controlContainer) {\n      if (this.formControlName) {\n        this.control = this.controlContainer.control.get(this.formControlName);\n      } else {\n        console.warn(\n          'QD-UI | QdSwitchesComponent - Missing FormControlName directive from host element of the component'\n        );\n      }\n    }\n\n    this.switchesService.setList(this.options);\n    this.switchesService.fillListWithDefaults(this.values);\n    this.setData();\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']) this.updateConfiguration();\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n  }\n\n  writeValue(values): void {\n    this.switchesService.fillListWithDefaults(values);\n    this.setData();\n    this.switchesValues = values;\n  }\n\n  public handleClick(item): void {\n    if (item.disabled) return;\n\n    this.updateData(item.value);\n\n    this._onChange(this.switchesValues);\n    this._onTouch(this.switchesValues);\n\n    this.valuesChange.emit(this.switchesValues);\n  }\n\n  get selectedValuesTranslated(): string[] {\n    return this.switchesInputs.filter(input => input.active).map(input => input.i18n);\n  }\n\n  private updateConfiguration(): void {\n    this.disabled = getDisabled(this.config) || !!this.control?.disabled;\n    this.label = getLabel(this.config);\n    this.align = getAlign(this.config);\n    this.options = getOptions(this.config);\n    this.hintAction = getHintAction(this.config);\n    this.readonly = getReadonly(this.config);\n    this.readonlyAction = getReadonlyAction(this.config);\n    this.viewonly = getViewonly(this.config);\n    this.viewonlyAction = getViewonlyAction(this.config);\n  }\n\n  private setData(): void {\n    this.switchesValues = this.switchesService.getValues();\n    this.switchesInputs = this.switchesService.getList();\n  }\n\n  private updateData(value): void {\n    this.switchesService.updateList(value);\n    this.switchesValues = this.switchesService.getValues();\n    this.switchesInputs = this.switchesService.getList();\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","<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<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n  <div class=\"qd-switches__switch-section\">\n    <qd-switch\n      *ngFor=\"let input of switchesInputs\"\n      [inputData]=\"input\"\n      [(value)]=\"switchesValues[input.index]\"\n      (click)=\"handleClick(input)\"\n      [data-test-id]=\"testId + '-switch-' + input.index\"\n      [disabled]=\"disabled\"\n    ></qd-switch>\n  </div>\n</div>\n\n<qd-form-hint\n  *ngIf=\"!readonly && !viewonly\"\n  [hint]=\"hasHint ? config.hint.i18n : ''\"\n  [control]=\"control\"\n  [hasError]=\"hasError\"\n  [hintAction]=\"hintAction\"\n  [data-test-id]=\"testId\"\n></qd-form-hint>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"selectedValuesTranslated\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"selectedValuesTranslated\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n"]}
300
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"switches.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/switches/switches.component.ts","../../../../../../libs/qd-ui/src/lib/forms/switches/switches.component.html"],"names":[],"mappings":"AAAA,oBAAoB;AACpB,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,IAAI,EACJ,WAAW,EACX,KAAK,EAIL,QAAQ,EACR,MAAM,EAEN,QAAQ,EACR,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,gBAAgB,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAC5G,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,EAAE,EAAE,IAAI,IAAI,EAAE,MAAM,MAAM,CAAC;AAGlC,OAAO,EACL,QAAQ,EACR,WAAW,EACX,aAAa,EACb,QAAQ,EACR,UAAU,EACV,WAAW,EACX,iBAAiB,EACjB,WAAW,EACX,iBAAiB,EAClB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,0CAA0C,CAAC;AAC5E,OAAO,EAAE,2BAA2B,EAAE,MAAM,2CAA2C,CAAC;AACxF,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;;;;;;;;;;;;AAGhF;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AAiBH,MAAM,OAAO,mBAAmB;IAgHX;IACA;IACA;IACgC;IACpB;IAnH/B;;OAEG;IACM,eAAe,CAAS;IAEjC;;;;;OAKG;IACM,MAAM,GAAa,EAAE,CAAC;IAE/B;;;;;;;;;;;;;OAaG;IACM,MAAM,CAA8B;IAE7C;;;OAGG;IACoB,MAAM,GAAG,UAAU,CAAC;IAE3C;;OAEG;IACgB,YAAY,GAAG,IAAI,YAAY,EAAY,CAAC;IAE/D;;OAEG;IACgB,SAAS,GAAG,IAAI,YAAY,EAAE,CAAC;IAElD;;OAEG;IACgB,aAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IAEtD;;OAEG;IACgB,aAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IAGtD,QAAQ,GAAG,KAAK,CAAC;IAGjB,cAAc,GAAG,KAAK,CAAC;IAGvB,QAAQ,GAAG,KAAK,CAAC;IAGjB,cAAc,GAAG,KAAK,CAAC;IAIhB,UAAU,GAAG,KAAK,CAAC;IAG1B,QAAQ,GAAG,KAAK,CAAC;IAEjB,IAEI,QAAQ;QACV,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;IAC7E,CAAC;IAED,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC;IACnC,CAAC;IAED,IACI,OAAO;QACT,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;IACjF,CAAC;IAED,IAAI,QAAQ;QACV,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO,KAAK,CAAC;QAEhC,OAAO,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IACpD,CAAC;IAED,OAAO,CAAkB;IACzB,EAAE,CAAS;IACX,KAAK,CAAS;IACd,KAAK,CAAC;IACN,aAAa,CAAC;IACd,OAAO,CAAiB;IACxB,cAAc,CAAW;IACzB,cAAc,CAAkB;IAExB,KAAK,GAAG,IAAI,YAAY,EAAE,CAAC;IAE3B,SAAS,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAC1B,QAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAEjC,YACmB,eAAkC,EAClC,iBAAoC,EACpC,oBAAiD,EACjB,gBAAkC,EACtD,kBAAwC;QAJpD,oBAAe,GAAf,eAAe,CAAmB;QAClC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,yBAAoB,GAApB,oBAAoB,CAA6B;QACjB,qBAAgB,GAAhB,gBAAgB,CAAkB;QACtD,uBAAkB,GAAlB,kBAAkB,CAAsB;QAErE,IAAI,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC;IACnB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YACzE,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CACV,oGAAoG,CACrG,CAAC;YACJ,CAAC;QACH,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3C,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvD,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QACnG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAC3G,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;QAC3G,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;IAChD,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,QAAQ,CAAC;YAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC;IACpD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;IAC3B,CAAC;IAED,gBAAgB,CAAC,EAAoB;QACnC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAC,QAAiB;QAChC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,UAAU,CAAC,MAAM;QACf,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;QAClD,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;IAC/B,CAAC;IAEM,WAAW,CAAC,IAAI;QACrB,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAE1B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAEnC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC9C,CAAC;IAED,IAAI,wBAAwB;QAC1B,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACpF,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC;QACrE,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACnC,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACnC,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvC,IAAI,CAAC,UAAU,GAAG,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzC,IAAI,CAAC,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACrD,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzC,IAAI,CAAC,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACvD,CAAC;IAEO,OAAO;QACb,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,CAAC;QACvD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;IAEO,UAAU,CAAC,KAAK;QACtB,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,CAAC;QACvD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC;IAEO,sBAAsB;QAC5B,IAAI,CAAC,IAAI,CAAC,kBAAkB;YAAE,OAAO;QAErC,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAA0B,wBAAwB,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC1G,IAAI,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,KAAK,SAAS;gBAAE,OAAO;YAEtD,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;IACL,CAAC;uGAxNU,mBAAmB;2FAAnB,mBAAmB,i3BAZnB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,mBAAmB;gBAChC,KAAK,EAAE,IAAI;aACZ;YACD,iBAAiB;YACjB,2BAA2B;SAC5B,+CC7EH,uoCA2CA;;2FDsCa,mBAAmB;kBAhB/B,SAAS;+BACE,aAAa,aAGZ;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,qBAAqB;4BAChC,KAAK,EAAE,IAAI;yBACZ;wBACD,iBAAiB;wBACjB,2BAA2B;qBAC5B,iBACc,iBAAiB,CAAC,IAAI,QAC/B,EAAE,KAAK,EAAE,aAAa,EAAE;;0BAqH3B,QAAQ;;0BAAI,IAAI;;0BAAI,QAAQ;;0BAC5B,QAAQ;yCAhHF,eAAe;sBAAvB,KAAK;gBAQG,MAAM;sBAAd,KAAK;gBAgBG,MAAM;sBAAd,KAAK;gBAMiB,MAAM;sBAA5B,KAAK;uBAAC,cAAc;gBAKF,YAAY;sBAA9B,MAAM;gBAKY,SAAS;sBAA3B,MAAM;gBAKY,aAAa;sBAA/B,MAAM;gBAKY,aAAa;sBAA/B,MAAM;gBAGP,QAAQ;sBADP,WAAW;uBAAC,4BAA4B;gBAIzC,cAAc;sBADb,WAAW;uBAAC,oCAAoC;gBAIjD,QAAQ;sBADP,WAAW;uBAAC,4BAA4B;gBAIzC,cAAc;sBADb,WAAW;uBAAC,oCAAoC;gBAK1C,UAAU;sBAFhB,WAAW;uBAAC,2BAA2B;;sBACvC,WAAW;uBAAC,gCAAgC;gBAI7C,QAAQ;sBADP,WAAW;uBAAC,wBAAwB;gBAKjC,QAAQ;sBAFX,WAAW;uBAAC,qBAAqB;;sBACjC,WAAW;uBAAC,yBAAyB;gBAMlC,UAAU;sBADb,WAAW;uBAAC,4BAA4B;gBAMrC,OAAO;sBADV,WAAW;uBAAC,wBAAwB","sourcesContent":["// @ts-strict-ignore\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  SkipSelf,\n  ViewEncapsulation\n} from '@angular/core';\nimport { AbstractControl, ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { v4 as uuid } from 'uuid';\n\nimport { QdFormOption, QdFormSwitchesConfiguration } from '../model/forms.interface';\nimport {\n  getAlign,\n  getDisabled,\n  getHintAction,\n  getLabel,\n  getOptions,\n  getReadonly,\n  getReadonlyAction,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { hasValidationKey } from '../shared/helpers/has-validators.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdSwitchesService } from './switches-service/switches.service';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\nimport { QdSwitchInput } from '../model/options.interface';\n\n/**\n * **QdSwitches** component provides a FormElement.\n * The **QdSwitches** is a component that provides a form element for switches.<br />\n * It allows users to select multiple options from a list of options. 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 *   switches: new QdFormControl([]) // at least an empty array to prevent runtime errors.\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-switches formControlName=\"switches\" [config]=\"config\"></qd-switches>\n * </form>\n * ```\n *\n * ####**Usage with Model Binding**\n * ```ts\n * values;\n * ```\n * ```html\n * <qd-switches [(values)]=\"values\" [config]=\"config\"></qd-switches>\n * ```\n */\n@Component({\n  selector: 'qd-switches',\n  templateUrl: './switches.component.html',\n  styleUrls: ['./switches.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdSwitchesComponent,\n      multi: true\n    },\n    QdSwitchesService,\n    QdFormsActionEmitterService\n  ],\n  encapsulation: ViewEncapsulation.None,\n  host: { class: 'qd-switches' }\n})\nexport class QdSwitchesComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor {\n  /**\n   * The current form control name can be assigned here if you want to use Reactive Forms.\n   */\n  @Input() formControlName: string;\n\n  /**\n   * The form item values, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-switches [(values)]=\"values\" [config]=\"config\"></qd-switches>\n   */\n  @Input() values: string[] = [];\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'Qd-Forms Switches' },\n   *   hint: { i18n: 'Helpertext' },\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' }\n   *   ]\n   * };\n   */\n  @Input() config: QdFormSwitchesConfiguration;\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') testId = 'switches';\n\n  /**\n   * Emits event when the values change. Return values match the current values.\n   */\n  @Output() readonly valuesChange = new EventEmitter<string[]>();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output() readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when the readonly value is clicked/tapped. `readonlyAction ` must be set to `true` for this.\n   */\n  @Output() readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when the viewonly value is clicked/tapped. `viewonlyAction ` must be set to `true` for this.\n   */\n  @Output() readonly clickViewonly = new EventEmitter();\n\n  @HostBinding('class.qd-dropdown-readonly')\n  readonly = false;\n\n  @HostBinding('class.qd-dropdown--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-dropdown-viewonly')\n  viewonly = false;\n\n  @HostBinding('class.qd-dropdown--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-switches--hint-action')\n  public hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  disabled = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-switches-error')\n  get hasError(): boolean {\n    return this.control ? this.control.touched && this.control.invalid : false;\n  }\n\n  @HostBinding('class.qd-switches-vertical')\n  get isVertical(): boolean {\n    return this.align === 'vertical';\n  }\n\n  @HostBinding('class.qd-switches-hint')\n  get hasHint(): boolean {\n    return this.config.hint && this.config.hint.i18n && !this.config.hint.disabled;\n  }\n\n  get required(): boolean {\n    if (!this.control) return false;\n\n    return hasValidationKey(this.control, 'required');\n  }\n\n  control: AbstractControl;\n  id: string;\n  label: string;\n  align;\n  labelPosition;\n  options: QdFormOption[];\n  switchesValues: string[];\n  switchesInputs: QdSwitchInput[];\n\n  private _subs = new Subscription();\n\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  constructor(\n    private readonly switchesService: QdSwitchesService,\n    private readonly changeDetectorRef: ChangeDetectorRef,\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {\n    this.id = uuid();\n  }\n\n  ngOnInit(): void {\n    this.updateConfiguration();\n\n    if (this.controlContainer) {\n      if (this.formControlName) {\n        this.control = this.controlContainer.control.get(this.formControlName);\n      } else {\n        console.warn(\n          'QD-UI | QdSwitchesComponent - Missing FormControlName directive from host element of the component'\n        );\n      }\n    }\n\n    this.switchesService.setList(this.options);\n    this.switchesService.fillListWithDefaults(this.values);\n    this.setData();\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']) this.updateConfiguration();\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n  }\n\n  writeValue(values): void {\n    this.switchesService.fillListWithDefaults(values);\n    this.setData();\n    this.switchesValues = values;\n  }\n\n  public handleClick(item): void {\n    if (item.disabled) return;\n\n    this.updateData(item.value);\n\n    this._onChange(this.switchesValues);\n    this._onTouch(this.switchesValues);\n\n    this.valuesChange.emit(this.switchesValues);\n  }\n\n  get selectedValuesTranslated(): string[] {\n    return this.switchesInputs.filter(input => input.active).map(input => input.i18n);\n  }\n\n  private updateConfiguration(): void {\n    this.disabled = getDisabled(this.config) || !!this.control?.disabled;\n    this.label = getLabel(this.config);\n    this.align = getAlign(this.config);\n    this.options = getOptions(this.config);\n    this.hintAction = getHintAction(this.config);\n    this.readonly = getReadonly(this.config);\n    this.readonlyAction = getReadonlyAction(this.config);\n    this.viewonly = getViewonly(this.config);\n    this.viewonlyAction = getViewonlyAction(this.config);\n  }\n\n  private setData(): void {\n    this.switchesValues = this.switchesService.getValues();\n    this.switchesInputs = this.switchesService.getList();\n  }\n\n  private updateData(value): void {\n    this.switchesService.updateList(value);\n    this.switchesValues = this.switchesService.getValues();\n    this.switchesInputs = this.switchesService.getList();\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","<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<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n  <div class=\"qd-switches__switch-section\">\n    <qd-switch\n      *ngFor=\"let input of switchesInputs\"\n      [inputData]=\"input\"\n      (click)=\"handleClick(input)\"\n      [data-test-id]=\"testId + '-switch-' + input.index\"\n      [disabled]=\"disabled\"\n    ></qd-switch>\n  </div>\n</div>\n\n<qd-form-hint\n  *ngIf=\"!readonly && !viewonly\"\n  [hint]=\"hasHint ? config.hint.i18n : ''\"\n  [control]=\"control\"\n  [hasError]=\"hasError\"\n  [hintAction]=\"hintAction\"\n  [data-test-id]=\"testId\"\n></qd-form-hint>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"selectedValuesTranslated\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"selectedValuesTranslated\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n"]}
@@ -99,6 +99,42 @@ import * as i5 from "@ngx-translate/core";
99
99
  * }
100
100
  * ```
101
101
  *
102
+ * ### Whitelisting HTTP status codes
103
+ *
104
+ * In some cases, you might want to prevent certain HTTP status codes from triggering error notifications. For example, a 304 Not Modified response is not actually an error and should not display an error notification. The **QdUiModule** allows you to whitelist specific HTTP status codes.
105
+ *
106
+ * To whitelist HTTP status codes, pass an array of status codes as the third parameter to the **QdUiModule.forRoot** method:
107
+ *
108
+ * ```typescript
109
+ * import { HttpStatusCode } from '@angular/common/http';
110
+ *
111
+ * imports: [
112
+ * ...
113
+ * QdUiModule.forRoot(
114
+ * appEnvironment,
115
+ * ErrorCodes,
116
+ * [HttpStatusCode.NotModified, HttpStatusCode.NoContent] // Whitelist 304 Not Modified and 204 No Content
117
+ * ),
118
+ * ...
119
+ * ]
120
+ * ```
121
+ *
122
+ * When a response with a whitelisted status code is received, no error notification will be displayed, even if it would normally be treated as an error by the HTTP client.
123
+ *
124
+ * ### Blacklisting HTTP status codes
125
+ *
126
+ * For critical errors, notifications are always shown, even if the status code is whitelisted. The **QdUiModule** implements a fixed blacklist that takes precedence over the whitelist.
127
+ *
128
+ * The following status codes are permanently blacklisted:
129
+ * - 401 Unauthorized
130
+ * - 402 Payment Required
131
+ * - 403 Forbidden
132
+ * - All 5xx server error codes (500-511)
133
+ *
134
+ * These critical errors will always show notifications, even if they are included in the whitelist.
135
+ *
136
+ * **Important**: The blacklist has higher precedence than the whitelist. If a status code appears in both the whitelist and the blacklist, it will be treated as blacklisted, and an error notification will be shown.
137
+ *
102
138
  * ### Component:
103
139
  *
104
140
  * ```typescript
@@ -508,4 +544,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
508
544
  type: HostBinding,
509
545
  args: ['attr.class']
510
546
  }] } });
511
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/notifications/notification/notification.component.ts","../../../../../../libs/qd-ui/src/lib/notifications/notification/notification.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport { Component, ElementRef, HostBinding, Input } from '@angular/core';\nimport { QdNotification, QdNotificationType } from '../interfaces/notifications';\nimport { QdNotificationsService } from '../services/notifications-service.service';\nimport { QdSnackbarService } from '../services/snackbar.service';\n\n/**\n *  **QdNotification** displays a single notification item within a **QdNotifications** container.\n *\n * # Notifications Service\n *\n * The **Notifications Service** can be used to catch errors from the backend. In addition, this service provides several methods to display messages.\n *\n * ## Notification from Backend\n *\n * The **QdUiModule** provides an HTTP interceptor that displays request errors as snackbar notifications. To get the proper notification messages for the corresponding backend errors, please comply with these conventions.\n *\n * ### Example of a response object\n *\n * The backend service response has to contain an errorCode field. This error code will be mapped to get the translation for the notification message.\n *\n * ```json\n * {\n *   \"errorCode\": \"TRANSPORT_COCKPIT_PERSISTENCE_ERROR\",\n *   \"errorMessage\": \"TRANSPORT_COCKPIT_PERSISTENCE_ERROR: Could not find Declaration wih id: b78e0734-ae1b-434e-b44d-b48797f5696d\"\n * }\n * ```\n *\n * ### Define Error Codes in the QdUiModule\n *\n * The **QdUiModule** expects an enum with error codes as the second parameter. For these given error codes you can define specific notification messages.\n *\n * This is an example configuration of the **QdUiModule** in the **app.module.ts**.\n *\n * ```typescript\n * enum ErrorCodes {\n *   TRANSPORT_COCKPIT_PERSISTENCE_ERROR,\n *   TRANSPORT_COCKPIT_VALIDATION_ERROR\n * }\n * ```\n *\n * ```typescript\n * imports: [\n *   ...\n *   QdUiModule.forRoot(appEnvironment, ErrorCodes),\n *   ...\n * ]\n * ```\n *\n * ### Translations:\n *\n * You can define the specific backend error notification messages for the respective error codes under `\"ERROR\"` in the translation files.\n *\n * ```json\n * {\n *   ...\n *\n *   \"ERROR\": {\n *     \"TRANSPORT_COCKPIT_PERSISTENCE_ERROR\": \"In der Datenbank ist ein Fehler aufgetreten\",\n *     \"TRANSPORT_COCKPIT_VALIDATION_ERROR\": \"Ungültige Eingabe\"\n *   }\n * }\n * ```\n *\n * ### Default error messages\n *\n * A default error message is shown if no error code is given in the backend response or the error code is not defined in the `ErrorCodes` enum that you pass to the **QdUiModule**.\n *\n * To override the default error messages you have to add the corresponding HTTP error code in the `ErrorCodes` enum. Then you can define a custom default error message in the translation files.\n *\n * ```typescript\n * enum ErrorCodes {\n *   ...,\n *   HTTP_BAD_REQUEST,\n *   HTTP_UNAUTHORIZED,\n *   HTTP_FORBIDDEN,\n *   HTTP_NOT_FOUND,\n *   HTTP_SERVER_ERROR,\n *   HTTP_UNKNOWN_ERROR\n * }\n * ```\n *\n * ```json\n * {\n *   ...\n *\n *   \"ERROR\": {\n *     \"HTTP_BAD_REQUEST\": \"This is a custom error message for a response with the HTTP status code 400.\",\n *     \"HTTP_UNAUTHORIZED\": \"This is a custom error message for a response with the HTTP status code 401.\",\n *     \"HTTP_FORBIDDEN\": \"This is a custom error message for a response with the HTTP status code 403.\",\n *     \"HTTP_NOT_FOUND\": \"This is a custom error message for a response with the HTTP status code 404.\",\n *     \"HTTP_SERVER_ERROR\": \"This is a custom error message for a response with some server error (HTTP status code 5xx).\",\n *     \"HTTP_UNKNOWN_ERROR\": \"This is a custom error message for all other errors.\"\n *   }\n * }\n * ```\n *\n * ### Component:\n *\n * ```typescript\n * class MyNotificationComponent {\n *   data;\n *\n *   constructor(private http: HttpClient) {}\n *\n *   private setData(data) {\n *     this.data = data;\n *   }\n *\n *   public callApiEndPoint() {\n *     // This way you can display the content in the frontend.\n *     return this.http.get('route/to/endpoint').subscribe({\n *       next: res => this.setData(res),\n *       error: err => this.setData(err)\n *     });\n *   }\n * }\n * ```\n *\n * The errors are rendered into a container, which by default has the attribute `context=\"qdPanel\"`.\n *\n * ```html\n * <!-- Landing pad for notifications -->\n * <qd-notifications></qd-notifications>\n * ```\n *\n * ## Notifications via service\n *\n * ### Interfaces:\n *\n * ```typescript\n * interface QdNotification {\n *   uuid?: string;\n *   context?: string;\n *   type: QdNotificationType;\n *   i18n: QdNotificationTranslation;\n *   title?: QdNotificationTitle;\n *   date?: Date;\n *   lifeTime?: number;\n *   disableClose?: boolean;\n *   onClose?: () => void;\n *   showAsSnackbar?: boolean;\n *   snackbarOptions?: QdSnackbarNotificationOptions;\n *   showAsOsNotification?: boolean;\n *   osNotificationOptions?: QdOsNotificationOptions;\n * }\n *\n * type QdNotificationType = 'info' | 'warning' | 'critical' | 'success';\n *\n * type QdNotificationTranslation = string;\n * type QdNotificationTitle = { i18n: string };\n *\n * type QdNotifications = QdNotification[];\n *\n * interface QdSnackbarNotificationOptions {\n *   lifeTime?: number;\n *   disableClose?: boolean;\n *   onClose?: () => void;\n * }\n *\n * interface QdOsNotificationOptions {\n *   silent?: boolean;\n *   lifeTime?: number;\n *   onClose?: (event) => void;\n *   onClick?: (event) => void;\n * }\n * ```\n *\n * The Notifications Service provides some methods to display them in the frontend.\n *\n * ### Component\n *\n * ```typescript\n * class MyNotificationComponent {\n *   constructor(private notificationsService: QdNotificationsService) {}\n *\n *   public add(context: string, notification: QdNotification): void {\n *     this.notificationsService.add(context, notification);\n *   }\n * }\n * ```\n *\n * ### Type QdNotification (Second param of the add method)\n *\n * ```typescript\n * interface QdNotification {\n *   ...\n *\n *   type: QdNotificationType;\n *   i18n: string;\n *   lifeTime?: number;\n * }\n *\n * type QdNotifications = QdNotification[];\n * ```\n *\n * ### Type QdNotificationType\n *\n * ```typescript\n * type QdNotificationType = 'info' | 'warning' | 'critical' | 'success';\n * ```\n *\n * ### Template\n *\n * ```html\n * <button (click)=\"add('qdPanel', { type: 'critical', i18n: 'i18n.error.critical' })\">Add Notification</button>\n * ```\n *\n * ### Template for displaying notifications - for instance in the Info Panel\n *\n * ```html\n * <qd-notifications></qd-notifications>\n * ```\n *\n * ## Notifications as a snackbar\n *\n * You can also display the notifications as a snack bar. They are then on top of the layout system. What you need to do is to place the directive `qdSnackbarListener` there. Also, just add the `showAsSnackbar` parameter to the method call.\n *\n * ### Example\n *\n * ```html\n * <qd-container qdSnackbarListener> My Container Content </qd-container>\n *\n * <button (click)=\"addNotification('qdPanel', { type: 'critical', i18n: 'i18n.error.critical', showAsSnackbar: true })\">\n *   Add Notification\n * </button>\n * ```\n *\n * All notifications are now displayed by the directive contained in the `qd-container`. Also, all notifications from the backend are displayed there.\n *\n * **Recommendation of the Quadrel Team**: Place the `qdSnackbarListener` directly on top of the layout system - so for example in the **AppComponent**.\n *\n * ### Options\n *\n * You can also pass a configuration object in the `snackbarOptions` parameter to customize the snackbar notification or to set an `onClose` handler.\n * When you close the main notification, the snackbar notification will be closed automatically. The snackbar notification can be closed for itself alone.\n *\n * In the `snackbarOptions` configuration object you can override the properties `disableClose` and `lifeTime`. When the main notification is closed,\n * the snackbar notification will also be closed. So the life time of the snackbar notification only can be shorter.\n *\n * ## OS Notifications\n *\n * To bring a notification to the foreground, even if the application window is not in focus, you can also push the notification as an OS Notification.\n * Then the notification will also be pushed through the Notification browser API and will be displayed on your operating system (e.g. Windows/Linux).\n * In the future, the OS Notifications will also be pushed as smartphone system notifications. Currently, only desktop notifications are supported.\n *\n * ### Example\n *\n * ```html\n * <button (click)=\"addNotification('qdPanel', { type: 'critical', i18n: 'i18n.error.critical', showAsOsNotification: true })\">\n *   Add Notification\n * </button>\n * ```\n *\n * ### Options\n *\n * You can also pass a configuration object in the `osNotificationOptions` parameter to customize the OS notification or to set `onClick` and `onClose` handlers.\n * When you close the main notification, the OS notification will be closed automatically. The OS notification can be closed for itself alone.\n *\n * In the `osNotificationOptions` configuration object you can override the properties `disableClose` and `lifeTime`. When the main notification is closed,\n * the OS notification will also be closed. So the life time of the OS notification only can be shorter.\n *\n * ### Deep links\n *\n * To open a deep link when the OS notification is clicked, use the following code for the click handler:\n *\n * ```typescript\n * event.preventDefault();\n * window.open('https://your/deep/link');\n * ```\n *\n * ## Notifications via service (multiple instances)\n *\n * ### Object of multiple notifications\n *\n * ```typescript\n * const BULK: QdNotifications = [\n *   {\n *     type: 'critical',\n *     i18n: 'i18n.error.1'\n *   },\n *   {\n *     type: 'critical',\n *     i18n: 'i18n.error.2'\n *   }\n * ];\n * ```\n *\n * ### Component\n *\n * ```typescript\n * class MyNotificationComponent {\n *   bulk: QdNotifications = BULK;\n *\n *   constructor(private notificationsService: QdNotificationsService, public modalService: QdModalService) {}\n *\n *   openNotificationModal(mrn) {\n *     // MRN represents a unique context\n *     this.modalService.open(MyNotificationModalComponent, { data: { mrn } });\n *\n *     // Adds the notifications when opening\n *     this.notificationsService.addBulk(mrn, this.bulk);\n *   }\n * }\n * ```\n *\n * ### Template\n *\n * ```html\n * <mat-table [dataSource]=\"dataSource\">\n *   <ng-container matColumnDef=\"mrn\">\n *     <mat-header-cell *matHeaderCellDef class=\"center\">Mrn.</mat-header-cell>\n *     <mat-cell *matCellDef=\"let element\" class=\"center\">\n *       <button mat-button color=\"primary\" (click)=\"openNotificationModal(element.mrn)\">\n *         <!-- MRN represents a unique context -->\n *         {{ element.mrn }}\n *       </button>\n *     </mat-cell>\n *   </ng-container>\n * </mat-table>\n * ```\n *\n * ## Notification Events\n *\n * You can define an `onClose` callback for each notification type. When the main notification is closed, then\n * the corresponding snackbar notification and OS notification will also be closed and all events will be fired.\n *\n * ```typescript\n * class MyNotificationComponent {\n *   constructor(private notificationsService: QdNotificationsService) {}\n *\n *   showNotification(): void {\n *     this.notificationsService.add(\n *       'qdPanel',\n *       {\n *         type: 'critical',\n *         i18n: 'i18n.error.critical',\n *         onClose: () => console.log('Notification closed.'),\n *         showAsSnackbar: true,\n *         snackbarOptions: {\n *           onClose: () => console.log('Snackbar Notification closed.')\n *         }\n *         showAsOsNotification: true,\n *         osNotificationOptions: {\n *           onClose: () => console.log('OS Notification closed.')\n *         }\n *       }\n *     );\n *   }\n * }\n * ```\n *\n * Especially for the OS notification an `onClick` handler can be defined. With the onClick handler it's also possible\n * to define a deep link that will be opened on click with the following code:\n *\n * ```typescript\n * this.notificationsService.add(\n *   'qdPanel',\n *   {\n *     type: 'critical',\n *     i18n: 'i18n.error.critical',\n *     showAsOsNotification: true,\n *     osNotificationOptions: {\n *       onClick: (event) => {\n *         event.preventDefault();\n *         window.open('https://your/deep/link');\n *       }\n *     }\n *   }\n * );\n * ```\n *\n * ## Inline Notifications\n *\n * Notifications can also be inserted directly into the template.\n *\n * ```html\n * <qd-notification [type]=\"type\" [notification]=\"notification\">\n *   <qd-notification-content> test notification content </qd-notification-content>\n * </qd-notification>\n * ```\n *\n * ```typescript\n * // The type can be defined with the type input\n * type = 'critical';\n *\n * // ... or in the notification config\n * notification: QdNotification = {\n *   type: 'critical'\n * }\n * ```\n *\n * The content can also be defined in the config. Then you don't have to put a `qd-notification-content`\n * element into the `qd-notification`.\n *\n * ```html\n * <qd-notification [notification]=\"notification\"></qd-notification>\n * ```\n *\n * ```typescript\n * notification: QdNotification = {\n *   type: 'critical',\n *   i18n: 'i18n.error.critical'\n * }\n * ```\n *\n * ## Multiline Notifications\n *\n * To create a multiline notification you simply can insert `\\n` in the i18n translation text. Line breaks (`\\n`) are\n * not considered if you use the `<qd-notification-content>` variant. Line breaks only work if you define the\n * i18n key in the notification config.\n *\n * ### Example\n *\n * ```typescript\n * notification: QdNotification = {\n *   type: 'warning',\n *   i18n: 'i18n.ncts.declaration.detailInventoryResult.notification.transitDeadlineExpired'\n * }\n * ```\n *\n * ```json\n * {\n *   ...\n *\n *   \"i18n.ncts.declaration.detailInventoryResult.notification.transitDeadlineExpired\": \"The inventory result must be checked and the control result recorded. \\nAttention: The transit period has expired upon arrival at the Authorized Place\",\n * }\n * ```\n *\n * ### Notifications Service\n *\n * | Method                       | Params                                                 | description                                      | default |\n * | ---------------------------- | ------------------------------------------------------ | ------------------------------------------------ | ------- |\n * | getNotificationsForContext() | context: string                                        | Returns notification stream for context.         | -       |\n * | add()                        | context: string, notification: QdNotification          | Adds a single notification.                      | -       |\n * | addBulk()                    | context: string, notifications: QdNotifications        | Adds multiple notifications.                     | -       |\n * | remove()                     | context: string, id: string                            | Removes specific notification.                   | -       |\n * | removeAll()                  | context: string                                        | Removes all notifications in context.            | -       |\n * | reset()                      | -                                                      | Clear all notifications.                         | -       |\n */\n@Component({\n  selector: 'qd-notification',\n  templateUrl: './notification.component.html',\n  styleUrls: ['./notification.component.scss'],\n  host: { class: 'qd-notification' }\n})\nexport class QdNotificationComponent {\n  /**\n   * Defines the type of this notification.\n   */\n  @Input() type: QdNotificationType = 'critical';\n\n  /**\n   * Configuration of a notification.\n   */\n  @Input() notification: QdNotification;\n\n  @HostBinding('attr.class') get typeClassName(): string {\n    return `qd-notification qd-notification-${this.getType()}`;\n  }\n\n  get closeable(): boolean {\n    return this.notification ? !this.notification.disableClose : true;\n  }\n\n  constructor(\n    private readonly notificationService: QdNotificationsService,\n    private readonly snackbarService: QdSnackbarService,\n    private element: ElementRef\n  ) {}\n\n  getType(): QdNotificationType {\n    return this.notification?.type || this.type;\n  }\n\n  getIcon(): string {\n    switch (this.getType()) {\n      case 'success':\n        return 'checkCircleSolid';\n      case 'info':\n        return 'checkCircleSolid';\n      case 'warning':\n        return 'warningHexFilled';\n      case 'critical':\n        return 'exclamationCircleSolid';\n    }\n  }\n\n  remove(): void {\n    if (this.isNotificationInSnackbar()) {\n      this.snackbarService.close(this.notification.uuid);\n    } else {\n      this.notificationService.remove(this.notification.context, this.notification.uuid);\n    }\n  }\n\n  handleLinkClick(): void {\n    this.notification.link.handler();\n  }\n\n  private isNotificationInSnackbar(): boolean {\n    return !!this.element.nativeElement.closest('qd-snackbar');\n  }\n}\n","<qd-icon *ngIf=\"closeable\" [icon]=\"'timesLarge'\" class=\"closer\" (click)=\"remove()\"></qd-icon>\n<qd-icon [icon]=\"this.getIcon()\" class=\"icon\"></qd-icon>\n\n<ng-content select=\"qd-notification-content\"></ng-content>\n\n<div class=\"title\" *ngIf=\"notification?.title\">{{ notification.title.i18n | translate }}</div>\n<div class=\"message\">\n  <span>{{ notification?.i18n | translate }}</span>\n  <a class=\"link\" *ngIf=\"notification?.link\" (click)=\"handleLinkClick()\">{{ notification.link.i18n | translate }}</a>\n</div>\n"]}
547
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/notifications/notification/notification.component.ts","../../../../../../libs/qd-ui/src/lib/notifications/notification/notification.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport { Component, ElementRef, HostBinding, Input } from '@angular/core';\nimport { QdNotification, QdNotificationType } from '../interfaces/notifications';\nimport { QdNotificationsService } from '../services/notifications-service.service';\nimport { QdSnackbarService } from '../services/snackbar.service';\n\n/**\n *  **QdNotification** displays a single notification item within a **QdNotifications** container.\n *\n * # Notifications Service\n *\n * The **Notifications Service** can be used to catch errors from the backend. In addition, this service provides several methods to display messages.\n *\n * ## Notification from Backend\n *\n * The **QdUiModule** provides an HTTP interceptor that displays request errors as snackbar notifications. To get the proper notification messages for the corresponding backend errors, please comply with these conventions.\n *\n * ### Example of a response object\n *\n * The backend service response has to contain an errorCode field. This error code will be mapped to get the translation for the notification message.\n *\n * ```json\n * {\n *   \"errorCode\": \"TRANSPORT_COCKPIT_PERSISTENCE_ERROR\",\n *   \"errorMessage\": \"TRANSPORT_COCKPIT_PERSISTENCE_ERROR: Could not find Declaration wih id: b78e0734-ae1b-434e-b44d-b48797f5696d\"\n * }\n * ```\n *\n * ### Define Error Codes in the QdUiModule\n *\n * The **QdUiModule** expects an enum with error codes as the second parameter. For these given error codes you can define specific notification messages.\n *\n * This is an example configuration of the **QdUiModule** in the **app.module.ts**.\n *\n * ```typescript\n * enum ErrorCodes {\n *   TRANSPORT_COCKPIT_PERSISTENCE_ERROR,\n *   TRANSPORT_COCKPIT_VALIDATION_ERROR\n * }\n * ```\n *\n * ```typescript\n * imports: [\n *   ...\n *   QdUiModule.forRoot(appEnvironment, ErrorCodes),\n *   ...\n * ]\n * ```\n *\n * ### Translations:\n *\n * You can define the specific backend error notification messages for the respective error codes under `\"ERROR\"` in the translation files.\n *\n * ```json\n * {\n *   ...\n *\n *   \"ERROR\": {\n *     \"TRANSPORT_COCKPIT_PERSISTENCE_ERROR\": \"In der Datenbank ist ein Fehler aufgetreten\",\n *     \"TRANSPORT_COCKPIT_VALIDATION_ERROR\": \"Ungültige Eingabe\"\n *   }\n * }\n * ```\n *\n * ### Default error messages\n *\n * A default error message is shown if no error code is given in the backend response or the error code is not defined in the `ErrorCodes` enum that you pass to the **QdUiModule**.\n *\n * To override the default error messages you have to add the corresponding HTTP error code in the `ErrorCodes` enum. Then you can define a custom default error message in the translation files.\n *\n * ```typescript\n * enum ErrorCodes {\n *   ...,\n *   HTTP_BAD_REQUEST,\n *   HTTP_UNAUTHORIZED,\n *   HTTP_FORBIDDEN,\n *   HTTP_NOT_FOUND,\n *   HTTP_SERVER_ERROR,\n *   HTTP_UNKNOWN_ERROR\n * }\n * ```\n *\n * ```json\n * {\n *   ...\n *\n *   \"ERROR\": {\n *     \"HTTP_BAD_REQUEST\": \"This is a custom error message for a response with the HTTP status code 400.\",\n *     \"HTTP_UNAUTHORIZED\": \"This is a custom error message for a response with the HTTP status code 401.\",\n *     \"HTTP_FORBIDDEN\": \"This is a custom error message for a response with the HTTP status code 403.\",\n *     \"HTTP_NOT_FOUND\": \"This is a custom error message for a response with the HTTP status code 404.\",\n *     \"HTTP_SERVER_ERROR\": \"This is a custom error message for a response with some server error (HTTP status code 5xx).\",\n *     \"HTTP_UNKNOWN_ERROR\": \"This is a custom error message for all other errors.\"\n *   }\n * }\n * ```\n *\n * ### Whitelisting HTTP status codes\n *\n * In some cases, you might want to prevent certain HTTP status codes from triggering error notifications. For example, a 304 Not Modified response is not actually an error and should not display an error notification. The **QdUiModule** allows you to whitelist specific HTTP status codes.\n *\n * To whitelist HTTP status codes, pass an array of status codes as the third parameter to the **QdUiModule.forRoot** method:\n *\n * ```typescript\n * import { HttpStatusCode } from '@angular/common/http';\n *\n * imports: [\n *   ...\n *   QdUiModule.forRoot(\n *     appEnvironment,\n *     ErrorCodes,\n *     [HttpStatusCode.NotModified, HttpStatusCode.NoContent] // Whitelist 304 Not Modified and 204 No Content\n *   ),\n *   ...\n * ]\n * ```\n *\n * When a response with a whitelisted status code is received, no error notification will be displayed, even if it would normally be treated as an error by the HTTP client.\n *\n * ### Blacklisting HTTP status codes\n *\n * For critical errors, notifications are always shown, even if the status code is whitelisted. The **QdUiModule** implements a fixed blacklist that takes precedence over the whitelist.\n *\n * The following status codes are permanently blacklisted:\n * - 401 Unauthorized\n * - 402 Payment Required\n * - 403 Forbidden\n * - All 5xx server error codes (500-511)\n *\n * These critical errors will always show notifications, even if they are included in the whitelist.\n *\n * **Important**: The blacklist has higher precedence than the whitelist. If a status code appears in both the whitelist and the blacklist, it will be treated as blacklisted, and an error notification will be shown.\n *\n * ### Component:\n *\n * ```typescript\n * class MyNotificationComponent {\n *   data;\n *\n *   constructor(private http: HttpClient) {}\n *\n *   private setData(data) {\n *     this.data = data;\n *   }\n *\n *   public callApiEndPoint() {\n *     // This way you can display the content in the frontend.\n *     return this.http.get('route/to/endpoint').subscribe({\n *       next: res => this.setData(res),\n *       error: err => this.setData(err)\n *     });\n *   }\n * }\n * ```\n *\n * The errors are rendered into a container, which by default has the attribute `context=\"qdPanel\"`.\n *\n * ```html\n * <!-- Landing pad for notifications -->\n * <qd-notifications></qd-notifications>\n * ```\n *\n * ## Notifications via service\n *\n * ### Interfaces:\n *\n * ```typescript\n * interface QdNotification {\n *   uuid?: string;\n *   context?: string;\n *   type: QdNotificationType;\n *   i18n: QdNotificationTranslation;\n *   title?: QdNotificationTitle;\n *   date?: Date;\n *   lifeTime?: number;\n *   disableClose?: boolean;\n *   onClose?: () => void;\n *   showAsSnackbar?: boolean;\n *   snackbarOptions?: QdSnackbarNotificationOptions;\n *   showAsOsNotification?: boolean;\n *   osNotificationOptions?: QdOsNotificationOptions;\n * }\n *\n * type QdNotificationType = 'info' | 'warning' | 'critical' | 'success';\n *\n * type QdNotificationTranslation = string;\n * type QdNotificationTitle = { i18n: string };\n *\n * type QdNotifications = QdNotification[];\n *\n * interface QdSnackbarNotificationOptions {\n *   lifeTime?: number;\n *   disableClose?: boolean;\n *   onClose?: () => void;\n * }\n *\n * interface QdOsNotificationOptions {\n *   silent?: boolean;\n *   lifeTime?: number;\n *   onClose?: (event) => void;\n *   onClick?: (event) => void;\n * }\n * ```\n *\n * The Notifications Service provides some methods to display them in the frontend.\n *\n * ### Component\n *\n * ```typescript\n * class MyNotificationComponent {\n *   constructor(private notificationsService: QdNotificationsService) {}\n *\n *   public add(context: string, notification: QdNotification): void {\n *     this.notificationsService.add(context, notification);\n *   }\n * }\n * ```\n *\n * ### Type QdNotification (Second param of the add method)\n *\n * ```typescript\n * interface QdNotification {\n *   ...\n *\n *   type: QdNotificationType;\n *   i18n: string;\n *   lifeTime?: number;\n * }\n *\n * type QdNotifications = QdNotification[];\n * ```\n *\n * ### Type QdNotificationType\n *\n * ```typescript\n * type QdNotificationType = 'info' | 'warning' | 'critical' | 'success';\n * ```\n *\n * ### Template\n *\n * ```html\n * <button (click)=\"add('qdPanel', { type: 'critical', i18n: 'i18n.error.critical' })\">Add Notification</button>\n * ```\n *\n * ### Template for displaying notifications - for instance in the Info Panel\n *\n * ```html\n * <qd-notifications></qd-notifications>\n * ```\n *\n * ## Notifications as a snackbar\n *\n * You can also display the notifications as a snack bar. They are then on top of the layout system. What you need to do is to place the directive `qdSnackbarListener` there. Also, just add the `showAsSnackbar` parameter to the method call.\n *\n * ### Example\n *\n * ```html\n * <qd-container qdSnackbarListener> My Container Content </qd-container>\n *\n * <button (click)=\"addNotification('qdPanel', { type: 'critical', i18n: 'i18n.error.critical', showAsSnackbar: true })\">\n *   Add Notification\n * </button>\n * ```\n *\n * All notifications are now displayed by the directive contained in the `qd-container`. Also, all notifications from the backend are displayed there.\n *\n * **Recommendation of the Quadrel Team**: Place the `qdSnackbarListener` directly on top of the layout system - so for example in the **AppComponent**.\n *\n * ### Options\n *\n * You can also pass a configuration object in the `snackbarOptions` parameter to customize the snackbar notification or to set an `onClose` handler.\n * When you close the main notification, the snackbar notification will be closed automatically. The snackbar notification can be closed for itself alone.\n *\n * In the `snackbarOptions` configuration object you can override the properties `disableClose` and `lifeTime`. When the main notification is closed,\n * the snackbar notification will also be closed. So the life time of the snackbar notification only can be shorter.\n *\n * ## OS Notifications\n *\n * To bring a notification to the foreground, even if the application window is not in focus, you can also push the notification as an OS Notification.\n * Then the notification will also be pushed through the Notification browser API and will be displayed on your operating system (e.g. Windows/Linux).\n * In the future, the OS Notifications will also be pushed as smartphone system notifications. Currently, only desktop notifications are supported.\n *\n * ### Example\n *\n * ```html\n * <button (click)=\"addNotification('qdPanel', { type: 'critical', i18n: 'i18n.error.critical', showAsOsNotification: true })\">\n *   Add Notification\n * </button>\n * ```\n *\n * ### Options\n *\n * You can also pass a configuration object in the `osNotificationOptions` parameter to customize the OS notification or to set `onClick` and `onClose` handlers.\n * When you close the main notification, the OS notification will be closed automatically. The OS notification can be closed for itself alone.\n *\n * In the `osNotificationOptions` configuration object you can override the properties `disableClose` and `lifeTime`. When the main notification is closed,\n * the OS notification will also be closed. So the life time of the OS notification only can be shorter.\n *\n * ### Deep links\n *\n * To open a deep link when the OS notification is clicked, use the following code for the click handler:\n *\n * ```typescript\n * event.preventDefault();\n * window.open('https://your/deep/link');\n * ```\n *\n * ## Notifications via service (multiple instances)\n *\n * ### Object of multiple notifications\n *\n * ```typescript\n * const BULK: QdNotifications = [\n *   {\n *     type: 'critical',\n *     i18n: 'i18n.error.1'\n *   },\n *   {\n *     type: 'critical',\n *     i18n: 'i18n.error.2'\n *   }\n * ];\n * ```\n *\n * ### Component\n *\n * ```typescript\n * class MyNotificationComponent {\n *   bulk: QdNotifications = BULK;\n *\n *   constructor(private notificationsService: QdNotificationsService, public modalService: QdModalService) {}\n *\n *   openNotificationModal(mrn) {\n *     // MRN represents a unique context\n *     this.modalService.open(MyNotificationModalComponent, { data: { mrn } });\n *\n *     // Adds the notifications when opening\n *     this.notificationsService.addBulk(mrn, this.bulk);\n *   }\n * }\n * ```\n *\n * ### Template\n *\n * ```html\n * <mat-table [dataSource]=\"dataSource\">\n *   <ng-container matColumnDef=\"mrn\">\n *     <mat-header-cell *matHeaderCellDef class=\"center\">Mrn.</mat-header-cell>\n *     <mat-cell *matCellDef=\"let element\" class=\"center\">\n *       <button mat-button color=\"primary\" (click)=\"openNotificationModal(element.mrn)\">\n *         <!-- MRN represents a unique context -->\n *         {{ element.mrn }}\n *       </button>\n *     </mat-cell>\n *   </ng-container>\n * </mat-table>\n * ```\n *\n * ## Notification Events\n *\n * You can define an `onClose` callback for each notification type. When the main notification is closed, then\n * the corresponding snackbar notification and OS notification will also be closed and all events will be fired.\n *\n * ```typescript\n * class MyNotificationComponent {\n *   constructor(private notificationsService: QdNotificationsService) {}\n *\n *   showNotification(): void {\n *     this.notificationsService.add(\n *       'qdPanel',\n *       {\n *         type: 'critical',\n *         i18n: 'i18n.error.critical',\n *         onClose: () => console.log('Notification closed.'),\n *         showAsSnackbar: true,\n *         snackbarOptions: {\n *           onClose: () => console.log('Snackbar Notification closed.')\n *         }\n *         showAsOsNotification: true,\n *         osNotificationOptions: {\n *           onClose: () => console.log('OS Notification closed.')\n *         }\n *       }\n *     );\n *   }\n * }\n * ```\n *\n * Especially for the OS notification an `onClick` handler can be defined. With the onClick handler it's also possible\n * to define a deep link that will be opened on click with the following code:\n *\n * ```typescript\n * this.notificationsService.add(\n *   'qdPanel',\n *   {\n *     type: 'critical',\n *     i18n: 'i18n.error.critical',\n *     showAsOsNotification: true,\n *     osNotificationOptions: {\n *       onClick: (event) => {\n *         event.preventDefault();\n *         window.open('https://your/deep/link');\n *       }\n *     }\n *   }\n * );\n * ```\n *\n * ## Inline Notifications\n *\n * Notifications can also be inserted directly into the template.\n *\n * ```html\n * <qd-notification [type]=\"type\" [notification]=\"notification\">\n *   <qd-notification-content> test notification content </qd-notification-content>\n * </qd-notification>\n * ```\n *\n * ```typescript\n * // The type can be defined with the type input\n * type = 'critical';\n *\n * // ... or in the notification config\n * notification: QdNotification = {\n *   type: 'critical'\n * }\n * ```\n *\n * The content can also be defined in the config. Then you don't have to put a `qd-notification-content`\n * element into the `qd-notification`.\n *\n * ```html\n * <qd-notification [notification]=\"notification\"></qd-notification>\n * ```\n *\n * ```typescript\n * notification: QdNotification = {\n *   type: 'critical',\n *   i18n: 'i18n.error.critical'\n * }\n * ```\n *\n * ## Multiline Notifications\n *\n * To create a multiline notification you simply can insert `\\n` in the i18n translation text. Line breaks (`\\n`) are\n * not considered if you use the `<qd-notification-content>` variant. Line breaks only work if you define the\n * i18n key in the notification config.\n *\n * ### Example\n *\n * ```typescript\n * notification: QdNotification = {\n *   type: 'warning',\n *   i18n: 'i18n.ncts.declaration.detailInventoryResult.notification.transitDeadlineExpired'\n * }\n * ```\n *\n * ```json\n * {\n *   ...\n *\n *   \"i18n.ncts.declaration.detailInventoryResult.notification.transitDeadlineExpired\": \"The inventory result must be checked and the control result recorded. \\nAttention: The transit period has expired upon arrival at the Authorized Place\",\n * }\n * ```\n *\n * ### Notifications Service\n *\n * | Method                       | Params                                                 | description                                      | default |\n * | ---------------------------- | ------------------------------------------------------ | ------------------------------------------------ | ------- |\n * | getNotificationsForContext() | context: string                                        | Returns notification stream for context.         | -       |\n * | add()                        | context: string, notification: QdNotification          | Adds a single notification.                      | -       |\n * | addBulk()                    | context: string, notifications: QdNotifications        | Adds multiple notifications.                     | -       |\n * | remove()                     | context: string, id: string                            | Removes specific notification.                   | -       |\n * | removeAll()                  | context: string                                        | Removes all notifications in context.            | -       |\n * | reset()                      | -                                                      | Clear all notifications.                         | -       |\n */\n@Component({\n  selector: 'qd-notification',\n  templateUrl: './notification.component.html',\n  styleUrls: ['./notification.component.scss'],\n  host: { class: 'qd-notification' }\n})\nexport class QdNotificationComponent {\n  /**\n   * Defines the type of this notification.\n   */\n  @Input() type: QdNotificationType = 'critical';\n\n  /**\n   * Configuration of a notification.\n   */\n  @Input() notification: QdNotification;\n\n  @HostBinding('attr.class') get typeClassName(): string {\n    return `qd-notification qd-notification-${this.getType()}`;\n  }\n\n  get closeable(): boolean {\n    return this.notification ? !this.notification.disableClose : true;\n  }\n\n  constructor(\n    private readonly notificationService: QdNotificationsService,\n    private readonly snackbarService: QdSnackbarService,\n    private element: ElementRef\n  ) {}\n\n  getType(): QdNotificationType {\n    return this.notification?.type || this.type;\n  }\n\n  getIcon(): string {\n    switch (this.getType()) {\n      case 'success':\n        return 'checkCircleSolid';\n      case 'info':\n        return 'checkCircleSolid';\n      case 'warning':\n        return 'warningHexFilled';\n      case 'critical':\n        return 'exclamationCircleSolid';\n    }\n  }\n\n  remove(): void {\n    if (this.isNotificationInSnackbar()) {\n      this.snackbarService.close(this.notification.uuid);\n    } else {\n      this.notificationService.remove(this.notification.context, this.notification.uuid);\n    }\n  }\n\n  handleLinkClick(): void {\n    this.notification.link.handler();\n  }\n\n  private isNotificationInSnackbar(): boolean {\n    return !!this.element.nativeElement.closest('qd-snackbar');\n  }\n}\n","<qd-icon *ngIf=\"closeable\" [icon]=\"'timesLarge'\" class=\"closer\" (click)=\"remove()\"></qd-icon>\n<qd-icon [icon]=\"this.getIcon()\" class=\"icon\"></qd-icon>\n\n<ng-content select=\"qd-notification-content\"></ng-content>\n\n<div class=\"title\" *ngIf=\"notification?.title\">{{ notification.title.i18n | translate }}</div>\n<div class=\"message\">\n  <span>{{ notification?.i18n | translate }}</span>\n  <a class=\"link\" *ngIf=\"notification?.link\" (click)=\"handleLinkClick()\">{{ notification.link.i18n | translate }}</a>\n</div>\n"]}
@@ -10,27 +10,54 @@ import { QdNotificationsService } from './notifications-service.service';
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "./notifications-service.service";
12
12
  export const BACKEND_ERROR_CODES = new InjectionToken('BACKEND_ERROR_CODES');
13
+ export const WHITELIST_ERROR_CODES = new InjectionToken('WHITELIST_ERROR_CODES');
13
14
  /**
14
15
  * The QdNotificationsHttpInterceptorService is an Angular HTTP interceptor that captures error responses from HTTP requests and generates notifications for backend errors. This Service not only intercepts error responses, but it also handles specific error codes and translates them into appropriate error messages for display.
15
16
  */
16
17
  export class QdNotificationsHttpInterceptorService {
17
18
  appEnvironment;
18
19
  backendErrorCodes;
20
+ whitelistErrorCodes;
19
21
  notificationService;
20
- constructor(appEnvironment, backendErrorCodes, notificationService) {
22
+ blacklistErrorCodes;
23
+ constructor(appEnvironment, backendErrorCodes, whitelistErrorCodes, notificationService) {
21
24
  this.appEnvironment = appEnvironment;
22
25
  this.backendErrorCodes = backendErrorCodes;
26
+ this.whitelistErrorCodes = whitelistErrorCodes;
23
27
  this.notificationService = notificationService;
24
28
  this.backendErrorCodes = this.backendErrorCodes || {};
29
+ this.whitelistErrorCodes = this.whitelistErrorCodes || [];
30
+ this.blacklistErrorCodes = [
31
+ // 401, 402, 403
32
+ HttpStatusCode.Unauthorized,
33
+ HttpStatusCode.PaymentRequired,
34
+ HttpStatusCode.Forbidden,
35
+ // All 5xx codes
36
+ HttpStatusCode.InternalServerError,
37
+ HttpStatusCode.NotImplemented,
38
+ HttpStatusCode.BadGateway,
39
+ HttpStatusCode.ServiceUnavailable,
40
+ HttpStatusCode.GatewayTimeout,
41
+ HttpStatusCode.HttpVersionNotSupported,
42
+ HttpStatusCode.VariantAlsoNegotiates,
43
+ HttpStatusCode.InsufficientStorage,
44
+ HttpStatusCode.LoopDetected,
45
+ HttpStatusCode.NotExtended,
46
+ HttpStatusCode.NetworkAuthenticationRequired
47
+ ];
25
48
  }
26
49
  intercept(request, next) {
27
50
  if (this.appEnvironment.disableBackendNotifications)
28
51
  return next.handle(request);
29
52
  return next.handle(request).pipe(catchError((error) => {
30
- let i18n = this.getErrorTranslationKeyForHttpStatus(error.status);
31
- if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)
32
- i18n = 'ERROR.' + error.error.errorCode;
33
- this.notificationService.add('qdPanel', { type: 'critical', i18n, showAsSnackbar: true });
53
+ const isBlacklisted = this.blacklistErrorCodes.includes(error.status);
54
+ const shouldShowNotification = isBlacklisted || !this.whitelistErrorCodes.includes(error.status);
55
+ if (shouldShowNotification) {
56
+ let i18n = this.getErrorTranslationKeyForHttpStatus(error.status);
57
+ if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)
58
+ i18n = 'ERROR.' + error.error.errorCode;
59
+ this.notificationService.add('qdPanel', { type: 'critical', i18n, showAsSnackbar: true });
60
+ }
34
61
  return throwError(() => error);
35
62
  }));
36
63
  }
@@ -57,7 +84,7 @@ export class QdNotificationsHttpInterceptorService {
57
84
  return 'UnknownError';
58
85
  }
59
86
  }
60
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdNotificationsHttpInterceptorService, deps: [{ token: APP_ENVIRONMENT, optional: true }, { token: BACKEND_ERROR_CODES, optional: true }, { token: i1.QdNotificationsService }], target: i0.ɵɵFactoryTarget.Injectable });
87
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdNotificationsHttpInterceptorService, deps: [{ token: APP_ENVIRONMENT, optional: true }, { token: BACKEND_ERROR_CODES, optional: true }, { token: WHITELIST_ERROR_CODES, optional: true }, { token: i1.QdNotificationsService }], target: i0.ɵɵFactoryTarget.Injectable });
61
88
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdNotificationsHttpInterceptorService, providedIn: 'root' });
62
89
  }
63
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdNotificationsHttpInterceptorService, decorators: [{
@@ -75,5 +102,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
75
102
  }, {
76
103
  type: Inject,
77
104
  args: [BACKEND_ERROR_CODES]
105
+ }] }, { type: undefined, decorators: [{
106
+ type: Optional
107
+ }, {
108
+ type: Inject,
109
+ args: [WHITELIST_ERROR_CODES]
78
110
  }] }, { type: i1.QdNotificationsService }] });
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9ucy1odHRwLWludGVyY2VwdG9yLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3FkLXVpL3NyYy9saWIvbm90aWZpY2F0aW9ucy9zZXJ2aWNlcy9ub3RpZmljYXRpb25zLWh0dHAtaW50ZXJjZXB0b3Iuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxvQkFBb0I7QUFDcEIsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsY0FBYyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RSxPQUFPLEVBTUwsY0FBYyxFQUNmLE1BQU0sc0JBQXNCLENBQUM7QUFDOUIsT0FBTyxFQUFjLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM5QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDNUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFFcEMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRXhFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOzs7QUFFekUsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsSUFBSSxjQUFjLENBQUMscUJBQXFCLENBQUMsQ0FBQztBQUU3RTs7R0FFRztBQUlILE1BQU0sT0FBTyxxQ0FBcUM7SUFFUTtJQUNJO0lBQzFDO0lBSGxCLFlBQ3dELGNBQWdDLEVBQzVCLGlCQUFpQixFQUMzRCxtQkFBMkM7UUFGTCxtQkFBYyxHQUFkLGNBQWMsQ0FBa0I7UUFDNUIsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFBO1FBQzNELHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBd0I7UUFFM0QsSUFBSSxDQUFDLGlCQUFpQixHQUFHLElBQUksQ0FBQyxpQkFBaUIsSUFBSSxFQUFFLENBQUM7SUFDeEQsQ0FBQztJQUVELFNBQVMsQ0FBQyxPQUF5QixFQUFFLElBQWlCO1FBQ3BELElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQywyQkFBMkI7WUFBRSxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFakYsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FDOUIsVUFBVSxDQUFDLENBQUMsS0FBd0IsRUFBRSxFQUFFO1lBQ3RDLElBQUksSUFBSSxHQUFHLElBQUksQ0FBQyxtQ0FBbUMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7WUFFbEUsSUFBSSxLQUFLLENBQUMsS0FBSyxFQUFFLFNBQVMsSUFBSSxLQUFLLENBQUMsS0FBSyxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsaUJBQWlCO2dCQUMzRSxJQUFJLEdBQUcsUUFBUSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDO1lBRTFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7WUFFMUYsT0FBTyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDakMsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7SUFFTyxtQ0FBbUMsQ0FBQyxjQUE4QjtRQUN4RSxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxDQUFDLENBQUM7UUFFNUQsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsUUFBUSxZQUFZLENBQUMsYUFBYSxDQUFDLEVBQUUsQ0FBQztZQUNsRSxDQUFDLENBQUMsY0FBYyxZQUFZLENBQUMsYUFBYSxDQUFDLEVBQUU7WUFDN0MsQ0FBQyxDQUFDLDhCQUE4QixVQUFVLENBQUMsYUFBYSxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDO0lBQ3JGLENBQUM7SUFFTyxnQkFBZ0IsQ0FBQyxjQUE4QjtRQUNyRCxRQUFRLGNBQWMsRUFBRSxDQUFDO1lBQ3ZCLEtBQUssY0FBYyxDQUFDLFVBQVU7Z0JBQzVCLE9BQU8sWUFBWSxDQUFDO1lBQ3RCLEtBQUssY0FBYyxDQUFDLFlBQVk7Z0JBQzlCLE9BQU8sY0FBYyxDQUFDO1lBQ3hCLEtBQUssY0FBYyxDQUFDLFNBQVM7Z0JBQzNCLE9BQU8sV0FBVyxDQUFDO1lBQ3JCLEtBQUssY0FBYyxDQUFDLFFBQVE7Z0JBQzFCLE9BQU8sVUFBVSxDQUFDO1lBQ3BCO2dCQUNFLElBQUksY0FBYyxJQUFJLEdBQUcsRUFBRSxDQUFDO29CQUMxQixPQUFPLGFBQWEsQ0FBQztnQkFDdkIsQ0FBQztnQkFDRCxPQUFPLGNBQWMsQ0FBQztRQUMxQixDQUFDO0lBQ0gsQ0FBQzt1R0FsRFUscUNBQXFDLGtCQUUxQixlQUFlLDZCQUNmLG1CQUFtQjsyR0FIOUIscUNBQXFDLGNBRnBDLE1BQU07OzJGQUVQLHFDQUFxQztrQkFIakQsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQUdJLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsZUFBZTs7MEJBQ2xDLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLXN0cmljdC1pZ25vcmVcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgSW5qZWN0aW9uVG9rZW4sIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBIdHRwRXJyb3JSZXNwb25zZSxcbiAgSHR0cEV2ZW50LFxuICBIdHRwSGFuZGxlcixcbiAgSHR0cEludGVyY2VwdG9yLFxuICBIdHRwUmVxdWVzdCxcbiAgSHR0cFN0YXR1c0NvZGVcbn0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgdGhyb3dFcnJvciB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgY2F0Y2hFcnJvciB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7IGNvbnN0YW50Q2FzZSB9IGZyb20gJy4uLy4uL2NvcmUvdG9vbHMvY29uc3RhbnRDYXNlLnRvb2xzJztcbmltcG9ydCB7IGxvd2VyRmlyc3QgfSBmcm9tICdsb2Rhc2gnO1xuXG5pbXBvcnQgeyBBUFBfRU5WSVJPTk1FTlQgfSBmcm9tICcuLi8uLi9jb3JlL21vZGVsL2FwcC1lbnZpcm9tZW50LnRva2VuJztcbmltcG9ydCB7IFFkQXBwRW52aXJvbm1lbnQgfSBmcm9tICcuLi8uLi9jb3JlL21vZGVsL2FwcC1lbnZpcm9tZW50LmludGVyZmFjZSc7XG5pbXBvcnQgeyBRZE5vdGlmaWNhdGlvbnNTZXJ2aWNlIH0gZnJvbSAnLi9ub3RpZmljYXRpb25zLXNlcnZpY2Uuc2VydmljZSc7XG5cbmV4cG9ydCBjb25zdCBCQUNLRU5EX0VSUk9SX0NPREVTID0gbmV3IEluamVjdGlvblRva2VuKCdCQUNLRU5EX0VSUk9SX0NPREVTJyk7XG5cbi8qKlxuICogVGhlIFFkTm90aWZpY2F0aW9uc0h0dHBJbnRlcmNlcHRvclNlcnZpY2UgaXMgYW4gQW5ndWxhciBIVFRQIGludGVyY2VwdG9yIHRoYXQgY2FwdHVyZXMgZXJyb3IgcmVzcG9uc2VzIGZyb20gSFRUUCByZXF1ZXN0cyBhbmQgZ2VuZXJhdGVzIG5vdGlmaWNhdGlvbnMgZm9yIGJhY2tlbmQgZXJyb3JzLiBUaGlzIFNlcnZpY2Ugbm90IG9ubHkgaW50ZXJjZXB0cyBlcnJvciByZXNwb25zZXMsIGJ1dCBpdCBhbHNvIGhhbmRsZXMgc3BlY2lmaWMgZXJyb3IgY29kZXMgYW5kIHRyYW5zbGF0ZXMgdGhlbSBpbnRvIGFwcHJvcHJpYXRlIGVycm9yIG1lc3NhZ2VzIGZvciBkaXNwbGF5LlxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBRZE5vdGlmaWNhdGlvbnNIdHRwSW50ZXJjZXB0b3JTZXJ2aWNlIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcbiAgY29uc3RydWN0b3IoXG4gICAgQE9wdGlvbmFsKCkgQEluamVjdChBUFBfRU5WSVJPTk1FTlQpIHByaXZhdGUgcmVhZG9ubHkgYXBwRW52aXJvbm1lbnQ6IFFkQXBwRW52aXJvbm1lbnQsXG4gICAgQE9wdGlvbmFsKCkgQEluamVjdChCQUNLRU5EX0VSUk9SX0NPREVTKSBwcml2YXRlIHJlYWRvbmx5IGJhY2tlbmRFcnJvckNvZGVzLFxuICAgIHB1YmxpYyByZWFkb25seSBub3RpZmljYXRpb25TZXJ2aWNlOiBRZE5vdGlmaWNhdGlvbnNTZXJ2aWNlXG4gICkge1xuICAgIHRoaXMuYmFja2VuZEVycm9yQ29kZXMgPSB0aGlzLmJhY2tlbmRFcnJvckNvZGVzIHx8IHt9O1xuICB9XG5cbiAgaW50ZXJjZXB0KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xuICAgIGlmICh0aGlzLmFwcEVudmlyb25tZW50LmRpc2FibGVCYWNrZW5kTm90aWZpY2F0aW9ucykgcmV0dXJuIG5leHQuaGFuZGxlKHJlcXVlc3QpO1xuXG4gICAgcmV0dXJuIG5leHQuaGFuZGxlKHJlcXVlc3QpLnBpcGUoXG4gICAgICBjYXRjaEVycm9yKChlcnJvcjogSHR0cEVycm9yUmVzcG9uc2UpID0+IHtcbiAgICAgICAgbGV0IGkxOG4gPSB0aGlzLmdldEVycm9yVHJhbnNsYXRpb25LZXlGb3JIdHRwU3RhdHVzKGVycm9yLnN0YXR1cyk7XG5cbiAgICAgICAgaWYgKGVycm9yLmVycm9yPy5lcnJvckNvZGUgJiYgZXJyb3IuZXJyb3IuZXJyb3JDb2RlIGluIHRoaXMuYmFja2VuZEVycm9yQ29kZXMpXG4gICAgICAgICAgaTE4biA9ICdFUlJPUi4nICsgZXJyb3IuZXJyb3IuZXJyb3JDb2RlO1xuXG4gICAgICAgIHRoaXMubm90aWZpY2F0aW9uU2VydmljZS5hZGQoJ3FkUGFuZWwnLCB7IHR5cGU6ICdjcml0aWNhbCcsIGkxOG4sIHNob3dBc1NuYWNrYmFyOiB0cnVlIH0pO1xuXG4gICAgICAgIHJldHVybiB0aHJvd0Vycm9yKCgpID0+IGVycm9yKTtcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIHByaXZhdGUgZ2V0RXJyb3JUcmFuc2xhdGlvbktleUZvckh0dHBTdGF0dXMoaHR0cFN0YXR1c0NvZGU6IEh0dHBTdGF0dXNDb2RlKTogc3RyaW5nIHtcbiAgICBjb25zdCBodHRwRXJyb3JOYW1lID0gdGhpcy5nZXRIdHRwRXJyb3JOYW1lKGh0dHBTdGF0dXNDb2RlKTtcblxuICAgIHJldHVybiB0aGlzLmJhY2tlbmRFcnJvckNvZGVzW2BIVFRQXyR7Y29uc3RhbnRDYXNlKGh0dHBFcnJvck5hbWUpfWBdXG4gICAgICA/IGBFcnJvci5IVFRQXyR7Y29uc3RhbnRDYXNlKGh0dHBFcnJvck5hbWUpfWBcbiAgICAgIDogYGkxOG4ucWQubm90aWZpY2F0aW9uLmVycm9yLiR7bG93ZXJGaXJzdChodHRwRXJyb3JOYW1lKS5yZXBsYWNlKCdFcnJvcicsICcnKX1gO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXRIdHRwRXJyb3JOYW1lKGh0dHBTdGF0dXNDb2RlOiBIdHRwU3RhdHVzQ29kZSk6IHN0cmluZyB7XG4gICAgc3dpdGNoIChodHRwU3RhdHVzQ29kZSkge1xuICAgICAgY2FzZSBIdHRwU3RhdHVzQ29kZS5CYWRSZXF1ZXN0OlxuICAgICAgICByZXR1cm4gJ0JhZFJlcXVlc3QnO1xuICAgICAgY2FzZSBIdHRwU3RhdHVzQ29kZS5VbmF1dGhvcml6ZWQ6XG4gICAgICAgIHJldHVybiAnVW5hdXRob3JpemVkJztcbiAgICAgIGNhc2UgSHR0cFN0YXR1c0NvZGUuRm9yYmlkZGVuOlxuICAgICAgICByZXR1cm4gJ0ZvcmJpZGRlbic7XG4gICAgICBjYXNlIEh0dHBTdGF0dXNDb2RlLk5vdEZvdW5kOlxuICAgICAgICByZXR1cm4gJ05vdEZvdW5kJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIGlmIChodHRwU3RhdHVzQ29kZSA+PSA1MDApIHtcbiAgICAgICAgICByZXR1cm4gJ1NlcnZlckVycm9yJztcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gJ1Vua25vd25FcnJvcic7XG4gICAgfVxuICB9XG59XG4iXX0=
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications-http-interceptor.service.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/notifications/services/notifications-http-interceptor.service.ts"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport { Inject, Injectable, InjectionToken, Optional } from '@angular/core';\nimport {\n  HttpErrorResponse,\n  HttpEvent,\n  HttpHandler,\n  HttpInterceptor,\n  HttpRequest,\n  HttpStatusCode\n} from '@angular/common/http';\nimport { Observable, throwError } from 'rxjs';\nimport { catchError } from 'rxjs/operators';\nimport { constantCase } from '../../core/tools/constantCase.tools';\nimport { lowerFirst } from 'lodash';\n\nimport { APP_ENVIRONMENT } from '../../core/model/app-enviroment.token';\nimport { QdAppEnvironment } from '../../core/model/app-enviroment.interface';\nimport { QdNotificationsService } from './notifications-service.service';\n\nexport const BACKEND_ERROR_CODES = new InjectionToken('BACKEND_ERROR_CODES');\nexport const WHITELIST_ERROR_CODES = new InjectionToken<number[]>('WHITELIST_ERROR_CODES');\n\n/**\n * The QdNotificationsHttpInterceptorService is an Angular HTTP interceptor that captures error responses from HTTP requests and generates notifications for backend errors. This Service not only intercepts error responses, but it also handles specific error codes and translates them into appropriate error messages for display.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class QdNotificationsHttpInterceptorService implements HttpInterceptor {\n  private readonly blacklistErrorCodes: number[];\n\n  constructor(\n    @Optional() @Inject(APP_ENVIRONMENT) private readonly appEnvironment: QdAppEnvironment,\n    @Optional() @Inject(BACKEND_ERROR_CODES) private readonly backendErrorCodes,\n    @Optional() @Inject(WHITELIST_ERROR_CODES) private readonly whitelistErrorCodes: number[],\n    public readonly notificationService: QdNotificationsService\n  ) {\n    this.backendErrorCodes = this.backendErrorCodes || {};\n    this.whitelistErrorCodes = this.whitelistErrorCodes || [];\n\n    this.blacklistErrorCodes = [\n      // 401, 402, 403\n      HttpStatusCode.Unauthorized,\n      HttpStatusCode.PaymentRequired,\n      HttpStatusCode.Forbidden,\n      // All 5xx codes\n      HttpStatusCode.InternalServerError,\n      HttpStatusCode.NotImplemented,\n      HttpStatusCode.BadGateway,\n      HttpStatusCode.ServiceUnavailable,\n      HttpStatusCode.GatewayTimeout,\n      HttpStatusCode.HttpVersionNotSupported,\n      HttpStatusCode.VariantAlsoNegotiates,\n      HttpStatusCode.InsufficientStorage,\n      HttpStatusCode.LoopDetected,\n      HttpStatusCode.NotExtended,\n      HttpStatusCode.NetworkAuthenticationRequired\n    ];\n  }\n\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n    if (this.appEnvironment.disableBackendNotifications) return next.handle(request);\n\n    return next.handle(request).pipe(\n      catchError((error: HttpErrorResponse) => {\n        const isBlacklisted = this.blacklistErrorCodes.includes(error.status);\n        const shouldShowNotification = isBlacklisted || !this.whitelistErrorCodes.includes(error.status);\n\n        if (shouldShowNotification) {\n          let i18n = this.getErrorTranslationKeyForHttpStatus(error.status);\n\n          if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)\n            i18n = 'ERROR.' + error.error.errorCode;\n\n          this.notificationService.add('qdPanel', { type: 'critical', i18n, showAsSnackbar: true });\n        }\n\n        return throwError(() => error);\n      })\n    );\n  }\n\n  private getErrorTranslationKeyForHttpStatus(httpStatusCode: HttpStatusCode): string {\n    const httpErrorName = this.getHttpErrorName(httpStatusCode);\n\n    return this.backendErrorCodes[`HTTP_${constantCase(httpErrorName)}`]\n      ? `Error.HTTP_${constantCase(httpErrorName)}`\n      : `i18n.qd.notification.error.${lowerFirst(httpErrorName).replace('Error', '')}`;\n  }\n\n  private getHttpErrorName(httpStatusCode: HttpStatusCode): string {\n    switch (httpStatusCode) {\n      case HttpStatusCode.BadRequest:\n        return 'BadRequest';\n      case HttpStatusCode.Unauthorized:\n        return 'Unauthorized';\n      case HttpStatusCode.Forbidden:\n        return 'Forbidden';\n      case HttpStatusCode.NotFound:\n        return 'NotFound';\n      default:\n        if (httpStatusCode >= 500) {\n          return 'ServerError';\n        }\n        return 'UnknownError';\n    }\n  }\n}\n"]}