@quadrel-enterprise-ui/framework 18.31.2 → 18.31.4-beta.75.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/esm2022/lib/comments/add-comment/add-comment-dialog.component.mjs +3 -4
  2. package/esm2022/lib/comments/comments.component.mjs +3 -3
  3. package/esm2022/lib/dialog/dialog.component.mjs +80 -37
  4. package/esm2022/lib/dialog/dialog.module.mjs +20 -8
  5. package/esm2022/lib/dialog/directives/pending-changes-guard.directive.mjs +7 -7
  6. package/esm2022/lib/dialog/models/dialog-close.model.mjs +2 -0
  7. package/esm2022/lib/dialog/models/page-dialog-host.token.mjs +9 -0
  8. package/esm2022/lib/dialog/services/confirmation-dialog.service.mjs +2 -2
  9. package/esm2022/lib/dialog/services/dialog.service.mjs +36 -8
  10. package/esm2022/lib/file-collector/allowed-files-description/file-collector-allowed-files-description.component.mjs +3 -3
  11. package/esm2022/lib/file-collector/dialog/item/error/file-collector-dialog-item-error.component.mjs +3 -3
  12. package/esm2022/lib/forms/checkbox-chips/checkbox-chips.component.mjs +3 -3
  13. package/esm2022/lib/forms/checkboxes/checkboxes.component.mjs +3 -3
  14. package/esm2022/lib/forms/datepicker/datepicker.component.mjs +3 -3
  15. package/esm2022/lib/forms/dropdown/dropdown.component.mjs +3 -3
  16. package/esm2022/lib/forms/file-upload/file-upload.component.mjs +3 -3
  17. package/esm2022/lib/forms/input/input.component.mjs +6 -4
  18. package/esm2022/lib/forms/multi-input/multi-input.component.mjs +3 -3
  19. package/esm2022/lib/forms/pin-code/pin-code.component.mjs +3 -3
  20. package/esm2022/lib/forms/radio-buttons/radio-buttons.component.mjs +3 -3
  21. package/esm2022/lib/forms/richtext/richtext.component.mjs +3 -3
  22. package/esm2022/lib/forms/switches/switches.component.mjs +3 -3
  23. package/esm2022/lib/forms/textarea/textarea.component.mjs +3 -3
  24. package/esm2022/lib/page/model/page-config.interface.mjs +1 -1
  25. package/esm2022/lib/page/page.component.mjs +37 -13
  26. package/esm2022/lib/page/shared/services/form-group-manager.service.mjs +21 -14
  27. package/esm2022/lib/quick-edit/quick-edit.component.mjs +2 -2
  28. package/esm2022/lib/shell/header/service-navigation/shell-service-navigation.component.mjs +4 -4
  29. package/esm2022/lib/table/services/resolver.service.mjs +30 -7
  30. package/fesm2022/quadrel-enterprise-ui-framework.mjs +750 -609
  31. package/fesm2022/quadrel-enterprise-ui-framework.mjs.map +1 -1
  32. package/lib/comments/add-comment/add-comment-dialog.component.d.ts +0 -4
  33. package/lib/comments/add-comment/add-comment-dialog.component.d.ts.map +1 -1
  34. package/lib/dialog/dialog.component.d.ts +15 -6
  35. package/lib/dialog/dialog.component.d.ts.map +1 -1
  36. package/lib/dialog/dialog.module.d.ts +3 -3
  37. package/lib/dialog/dialog.module.d.ts.map +1 -1
  38. package/lib/dialog/directives/pending-changes-guard.directive.d.ts +5 -5
  39. package/lib/dialog/directives/pending-changes-guard.directive.d.ts.map +1 -1
  40. package/lib/dialog/models/dialog-close.model.d.ts +51 -0
  41. package/lib/dialog/models/dialog-close.model.d.ts.map +1 -0
  42. package/lib/dialog/models/page-dialog-host.token.d.ts +10 -0
  43. package/lib/dialog/models/page-dialog-host.token.d.ts.map +1 -0
  44. package/lib/dialog/services/confirmation-dialog.service.d.ts.map +1 -1
  45. package/lib/dialog/services/dialog.service.d.ts +20 -4
  46. package/lib/dialog/services/dialog.service.d.ts.map +1 -1
  47. package/lib/forms/input/input.component.d.ts.map +1 -1
  48. package/lib/page/model/page-config.interface.d.ts +14 -1
  49. package/lib/page/model/page-config.interface.d.ts.map +1 -1
  50. package/lib/page/page.component.d.ts +5 -2
  51. package/lib/page/page.component.d.ts.map +1 -1
  52. package/lib/page/shared/services/form-group-manager.service.d.ts +1 -0
  53. package/lib/page/shared/services/form-group-manager.service.d.ts.map +1 -1
  54. package/lib/shell/header/service-navigation/shell-service-navigation.component.d.ts +1 -1
  55. package/lib/shell/header/service-navigation/shell-service-navigation.component.d.ts.map +1 -1
  56. package/lib/table/services/resolver.service.d.ts +2 -0
  57. package/lib/table/services/resolver.service.d.ts.map +1 -1
  58. package/package.json +2 -2
  59. package/src/assets/i18n/de.json +2 -0
  60. package/src/assets/i18n/en.json +11 -1
  61. package/src/assets/i18n/fr.json +2 -0
  62. package/src/assets/i18n/it.json +2 -0
  63. package/src/assets/styles/settings/_settings.grid.scss +4 -1
@@ -19,7 +19,6 @@ import * as i11 from "@ngx-translate/core";
19
19
  export class AddCommentDialogComponent {
20
20
  dialogRef;
21
21
  authenticationService;
22
- objectKeys = Object.keys;
23
22
  richtextConfig;
24
23
  addCommentsConfig;
25
24
  authorInputConfig;
@@ -124,15 +123,15 @@ export class AddCommentDialogComponent {
124
123
  };
125
124
  }
126
125
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AddCommentDialogComponent, deps: [{ token: i1.DialogRef }, { token: 'QdAuthenticationService', optional: true }], target: i0.ɵɵFactoryTarget.Component });
127
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: AddCommentDialogComponent, selector: "qd-comment-dialog", ngImport: i0, template: "<qd-dialog>\n <form [formGroup]=\"form\">\n <qd-input [config]=\"authorInputConfig\"></qd-input>\n <qd-dropdown\n *ngIf=\"customInputConfig\"\n [config]=\"customInputConfig\"\n [formControlName]=\"'custom'\"\n [attr.data-test-id]=\"'comment-custom'\"\n ></qd-dropdown>\n\n <qd-richtext [config]=\"richtextConfig\" #commentText [formControlName]=\"'comment'\"> </qd-richtext>\n <div *ngIf=\"form.get('comment')?.touched && form.get('comment')?.errors as errors\">\n <div\n *ngFor=\"let errorKey of objectKeys(errors)\"\n [attr.data-test-id]=\"'comment-validation-' + errorKey\"\n class=\"validation-message\"\n >\n {{ errors[errorKey] | translate }}\n </div>\n </div>\n </form>\n <qd-dialog-action>\n <button qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\" [data-test-id]=\"'button-cancel'\">\n {{ \"i18n.qd.comments.add.dialog.cancel\" | translate }}\n </button>\n <button\n [disabled]=\"!commentText.value || commentText.hasError\"\n qdButton\n (click)=\"close('Yes')\"\n [data-test-id]=\"'button-submit'\"\n >\n {{ \"i18n.qd.comments.add.dialog.submit\" | translate }}\n </button>\n </qd-dialog-action>\n</qd-dialog>\n", styles: [".validation-message{margin-top:4px;color:red;font-size:.875em}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i4.QdButtonGhostDirective, selector: "button[qdButtonGhost], a[qdButtonGhost]" }, { kind: "component", type: i5.QdDropdownComponent, selector: "qd-dropdown", inputs: ["value", "id", "formControlName", "config", "data-test-id", "qdPopoverMaxHeight", "dense"], outputs: ["valueChange", "enterClick", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i6.QdInputComponent, selector: "qd-input", inputs: ["formControlName", "value", "config", "isError", "data-test-id"], outputs: ["valueChange", "enterClick", "clickClear", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i7.QdRichtextComponent, selector: "qd-richtext", inputs: ["formControlName", "value", "config", "data-test-id"], outputs: ["valueChange", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i8.QdDialogActionComponent, selector: "qd-dialog-action" }, { kind: "component", type: i9.QdDialogComponent, selector: "qd-dialog" }, { kind: "directive", type: i10.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i10.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i10.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "pipe", type: i11.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
126
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: AddCommentDialogComponent, selector: "qd-comment-dialog", ngImport: i0, template: "<qd-dialog>\n <form [formGroup]=\"form\">\n <qd-input [config]=\"authorInputConfig\"></qd-input>\n <qd-dropdown\n *ngIf=\"customInputConfig\"\n [config]=\"customInputConfig\"\n [formControlName]=\"'custom'\"\n [attr.data-test-id]=\"'comment-custom'\"\n ></qd-dropdown>\n\n <qd-richtext [config]=\"richtextConfig\" #commentText [formControlName]=\"'comment'\"> </qd-richtext>\n </form>\n <qd-dialog-action>\n <button qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\" [data-test-id]=\"'button-cancel'\">\n {{ \"i18n.qd.comments.add.dialog.cancel\" | translate }}\n </button>\n <button\n [disabled]=\"!commentText.value || commentText.hasError\"\n qdButton\n (click)=\"close('Yes')\"\n [data-test-id]=\"'button-submit'\"\n >\n {{ \"i18n.qd.comments.add.dialog.submit\" | translate }}\n </button>\n </qd-dialog-action>\n</qd-dialog>\n", styles: [".validation-message{margin-top:4px;color:red;font-size:.875em}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i4.QdButtonGhostDirective, selector: "button[qdButtonGhost], a[qdButtonGhost]" }, { kind: "component", type: i5.QdDropdownComponent, selector: "qd-dropdown", inputs: ["value", "id", "formControlName", "config", "data-test-id", "qdPopoverMaxHeight", "dense"], outputs: ["valueChange", "enterClick", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i6.QdInputComponent, selector: "qd-input", inputs: ["formControlName", "value", "config", "isError", "data-test-id"], outputs: ["valueChange", "enterClick", "clickClear", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i7.QdRichtextComponent, selector: "qd-richtext", inputs: ["formControlName", "value", "config", "data-test-id"], outputs: ["valueChange", "clickHint", "clickReadonly", "clickViewonly"] }, { kind: "component", type: i8.QdDialogActionComponent, selector: "qd-dialog-action" }, { kind: "component", type: i9.QdDialogComponent, selector: "qd-dialog" }, { kind: "directive", type: i10.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i10.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i10.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "pipe", type: i11.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
128
127
  }
129
128
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AddCommentDialogComponent, decorators: [{
130
129
  type: Component,
131
- args: [{ selector: 'qd-comment-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<qd-dialog>\n <form [formGroup]=\"form\">\n <qd-input [config]=\"authorInputConfig\"></qd-input>\n <qd-dropdown\n *ngIf=\"customInputConfig\"\n [config]=\"customInputConfig\"\n [formControlName]=\"'custom'\"\n [attr.data-test-id]=\"'comment-custom'\"\n ></qd-dropdown>\n\n <qd-richtext [config]=\"richtextConfig\" #commentText [formControlName]=\"'comment'\"> </qd-richtext>\n <div *ngIf=\"form.get('comment')?.touched && form.get('comment')?.errors as errors\">\n <div\n *ngFor=\"let errorKey of objectKeys(errors)\"\n [attr.data-test-id]=\"'comment-validation-' + errorKey\"\n class=\"validation-message\"\n >\n {{ errors[errorKey] | translate }}\n </div>\n </div>\n </form>\n <qd-dialog-action>\n <button qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\" [data-test-id]=\"'button-cancel'\">\n {{ \"i18n.qd.comments.add.dialog.cancel\" | translate }}\n </button>\n <button\n [disabled]=\"!commentText.value || commentText.hasError\"\n qdButton\n (click)=\"close('Yes')\"\n [data-test-id]=\"'button-submit'\"\n >\n {{ \"i18n.qd.comments.add.dialog.submit\" | translate }}\n </button>\n </qd-dialog-action>\n</qd-dialog>\n", styles: [".validation-message{margin-top:4px;color:red;font-size:.875em}\n"] }]
130
+ args: [{ selector: 'qd-comment-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<qd-dialog>\n <form [formGroup]=\"form\">\n <qd-input [config]=\"authorInputConfig\"></qd-input>\n <qd-dropdown\n *ngIf=\"customInputConfig\"\n [config]=\"customInputConfig\"\n [formControlName]=\"'custom'\"\n [attr.data-test-id]=\"'comment-custom'\"\n ></qd-dropdown>\n\n <qd-richtext [config]=\"richtextConfig\" #commentText [formControlName]=\"'comment'\"> </qd-richtext>\n </form>\n <qd-dialog-action>\n <button qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\" [data-test-id]=\"'button-cancel'\">\n {{ \"i18n.qd.comments.add.dialog.cancel\" | translate }}\n </button>\n <button\n [disabled]=\"!commentText.value || commentText.hasError\"\n qdButton\n (click)=\"close('Yes')\"\n [data-test-id]=\"'button-submit'\"\n >\n {{ \"i18n.qd.comments.add.dialog.submit\" | translate }}\n </button>\n </qd-dialog-action>\n</qd-dialog>\n", styles: [".validation-message{margin-top:4px;color:red;font-size:.875em}\n"] }]
132
131
  }], ctorParameters: () => [{ type: i1.DialogRef }, { type: undefined, decorators: [{
133
132
  type: Optional
134
133
  }, {
135
134
  type: Inject,
136
135
  args: ['QdAuthenticationService']
137
136
  }] }] });
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-comment-dialog.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/comments/add-comment/add-comment-dialog.component.ts","../../../../../../libs/qd-ui/src/lib/comments/add-comment/add-comment-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject, Optional } from '@angular/core';\nimport { DialogRef } from '@angular/cdk/dialog';\nimport {\n  QdFormDropdownConfiguration,\n  QdFormInputConfiguration,\n  QdRichtextConfig\n} from '../../forms/model/forms.interface';\nimport { QdComment, QdCommentsAddConfig } from '../model/comments.interface';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors, ValidatorFn } from '@angular/forms';\nimport { QdFormControl, ValidatorFnWithProps } from '../../forms/reactive-forms/controls/form-control';\nimport { getPlainTextFromHtml } from '../../helpers/html-plaintext.helper';\n\n@Component({\n  selector: 'qd-comment-dialog',\n  templateUrl: './add-comment-dialog.component.html',\n  styleUrls: ['./add-comment-dialog.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AddCommentDialogComponent {\n  objectKeys = Object.keys;\n\n  richtextConfig: QdRichtextConfig;\n\n  addCommentsConfig: QdCommentsAddConfig;\n\n  authorInputConfig?: QdFormInputConfiguration;\n  customInputConfig?: QdFormDropdownConfiguration;\n\n  qdAuthUsername?: string;\n\n  form: FormGroup;\n\n  constructor(\n    private dialogRef: DialogRef<string>,\n    @Optional() @Inject('QdAuthenticationService') private readonly authenticationService: any\n  ) {\n    this.addCommentsConfig = dialogRef.config?.data;\n\n    this.richtextConfig = {\n      label: { i18n: 'i18n.qd.comments.add.richtext.label' }\n    };\n\n    this.form = new FormGroup({\n      comment: new QdFormControl('', [\n        ...(this.addCommentsConfig?.commentField?.minLength != null\n          ? [this.plainTextMinLength(this.addCommentsConfig?.commentField?.minLength)]\n          : []),\n        ...(this.addCommentsConfig?.commentField?.maxLength != null\n          ? [this.plainTextMaxLength(this.addCommentsConfig?.commentField?.maxLength)]\n          : []),\n        this.plainTextRequired()\n      ]),\n      custom: new FormControl(this.findSelectedCustomOption(), [])\n    });\n\n    const isQdAuthUsed = !!this.authenticationService;\n    if (isQdAuthUsed) {\n      authenticationService.name$.pipe(takeUntilDestroyed()).subscribe((name: string) => {\n        if (name) this.qdAuthUsername = name;\n        this.createConfig();\n      });\n    } else {\n      this.createConfig();\n    }\n  }\n\n  private findSelectedCustomOption(): string {\n    if (!this.addCommentsConfig.customField) return '';\n\n    return (\n      this.addCommentsConfig.customField.options.find(\n        customValue =>\n          this.addCommentsConfig.customField?.dropdownDisplayName.i18n === customValue.dropdownDisplayName.i18n\n      )?.dropdownDisplayName.i18n ?? ''\n    );\n  }\n\n  private createConfig(): void {\n    if (!this.addCommentsConfig) return;\n    this.authorInputConfig = {\n      value: this.qdAuthUsername || this.addCommentsConfig?.authorField?.value,\n      disabled: true,\n      label: {\n        i18n: this.addCommentsConfig?.authorField?.label?.i18n || 'i18n.qd.comments.add.author.label'\n      },\n      viewonly: false\n    };\n\n    if (this.addCommentsConfig.customField) {\n      this.customInputConfig = {\n        options: this.addCommentsConfig.customField.options.map(customValue => ({\n          value: customValue.dropdownDisplayName.i18n,\n          i18n: customValue.dropdownDisplayName.i18n,\n          active: this.addCommentsConfig.customField?.dropdownDisplayName.i18n === customValue.dropdownDisplayName.i18n\n        })),\n        label: {\n          i18n: this.addCommentsConfig.customField.label?.i18n || ''\n        },\n        viewonly: false\n      };\n    }\n  }\n\n  close(result?: any): void {\n    if (result === 'Yes' && this.addCommentsConfig.confirmDialogHandler) {\n      const comment: QdComment = {\n        comment: this.form.get('comment')?.value,\n        date: new Date(),\n        author: this.qdAuthUsername || this.addCommentsConfig?.authorField?.value,\n        custom:\n          this.addCommentsConfig?.customField?.options.find(\n            customValue => this.form.get('custom')?.value === customValue.dropdownDisplayName.i18n\n          ) ?? this.addCommentsConfig?.customField\n      };\n      this.addCommentsConfig.confirmDialogHandler(comment);\n    }\n    this.dialogRef.close();\n  }\n\n  plainTextMinLength(min: number): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (control.value == null) return null;\n\n      const sanitizedValue = getPlainTextFromHtml(control.value);\n      return sanitizedValue.length >= min ? null : { minLength: 'i18n.qd.form.error.minLength' };\n    };\n  }\n\n  plainTextMaxLength(max: number): ValidatorFnWithProps {\n    const validator: ValidatorFnWithProps = (control: AbstractControl): ValidationErrors | null => {\n      if (control.value == null) return null;\n\n      const sanitizedValue = getPlainTextFromHtml(control.value);\n      return sanitizedValue.length <= max ? null : { maxLength: 'i18n.qd.form.error.maxLength' };\n    };\n\n    validator.maxLength = max;\n\n    return validator;\n  }\n\n  plainTextRequired(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      const sanitizedValue = getPlainTextFromHtml(control.value);\n      return sanitizedValue == null || sanitizedValue.length === 0 ? { required: 'i18n.qd.form.error.required' } : null;\n    };\n  }\n}\n","<qd-dialog>\n  <form [formGroup]=\"form\">\n    <qd-input [config]=\"authorInputConfig\"></qd-input>\n    <qd-dropdown\n      *ngIf=\"customInputConfig\"\n      [config]=\"customInputConfig\"\n      [formControlName]=\"'custom'\"\n      [attr.data-test-id]=\"'comment-custom'\"\n    ></qd-dropdown>\n\n    <qd-richtext [config]=\"richtextConfig\" #commentText [formControlName]=\"'comment'\"> </qd-richtext>\n    <div *ngIf=\"form.get('comment')?.touched && form.get('comment')?.errors as errors\">\n      <div\n        *ngFor=\"let errorKey of objectKeys(errors)\"\n        [attr.data-test-id]=\"'comment-validation-' + errorKey\"\n        class=\"validation-message\"\n      >\n        {{ errors[errorKey] | translate }}\n      </div>\n    </div>\n  </form>\n  <qd-dialog-action>\n    <button qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\" [data-test-id]=\"'button-cancel'\">\n      {{ \"i18n.qd.comments.add.dialog.cancel\" | translate }}\n    </button>\n    <button\n      [disabled]=\"!commentText.value || commentText.hasError\"\n      qdButton\n      (click)=\"close('Yes')\"\n      [data-test-id]=\"'button-submit'\"\n    >\n      {{ \"i18n.qd.comments.add.dialog.submit\" | translate }}\n    </button>\n  </qd-dialog-action>\n</qd-dialog>\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-comment-dialog.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/comments/add-comment/add-comment-dialog.component.ts","../../../../../../libs/qd-ui/src/lib/comments/add-comment/add-comment-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject, Optional } from '@angular/core';\nimport { DialogRef } from '@angular/cdk/dialog';\nimport {\n  QdFormDropdownConfiguration,\n  QdFormInputConfiguration,\n  QdRichtextConfig\n} from '../../forms/model/forms.interface';\nimport { QdComment, QdCommentsAddConfig } from '../model/comments.interface';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { AbstractControl, FormControl, FormGroup, ValidationErrors, ValidatorFn } from '@angular/forms';\nimport { QdFormControl, ValidatorFnWithProps } from '../../forms/reactive-forms/controls/form-control';\nimport { getPlainTextFromHtml } from '../../helpers/html-plaintext.helper';\n\n@Component({\n  selector: 'qd-comment-dialog',\n  templateUrl: './add-comment-dialog.component.html',\n  styleUrls: ['./add-comment-dialog.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AddCommentDialogComponent {\n  richtextConfig: QdRichtextConfig;\n\n  addCommentsConfig: QdCommentsAddConfig;\n\n  authorInputConfig?: QdFormInputConfiguration;\n  customInputConfig?: QdFormDropdownConfiguration;\n\n  qdAuthUsername?: string;\n\n  form: FormGroup;\n\n  constructor(\n    private dialogRef: DialogRef<string>,\n    @Optional() @Inject('QdAuthenticationService') private readonly authenticationService: any\n  ) {\n    this.addCommentsConfig = dialogRef.config?.data;\n\n    this.richtextConfig = {\n      label: { i18n: 'i18n.qd.comments.add.richtext.label' }\n    };\n\n    this.form = new FormGroup({\n      comment: new QdFormControl('', [\n        ...(this.addCommentsConfig?.commentField?.minLength != null\n          ? [this.plainTextMinLength(this.addCommentsConfig?.commentField?.minLength)]\n          : []),\n        ...(this.addCommentsConfig?.commentField?.maxLength != null\n          ? [this.plainTextMaxLength(this.addCommentsConfig?.commentField?.maxLength)]\n          : []),\n        this.plainTextRequired()\n      ]),\n      custom: new FormControl(this.findSelectedCustomOption(), [])\n    });\n\n    const isQdAuthUsed = !!this.authenticationService;\n    if (isQdAuthUsed) {\n      authenticationService.name$.pipe(takeUntilDestroyed()).subscribe((name: string) => {\n        if (name) this.qdAuthUsername = name;\n        this.createConfig();\n      });\n    } else {\n      this.createConfig();\n    }\n  }\n\n  private findSelectedCustomOption(): string {\n    if (!this.addCommentsConfig.customField) return '';\n\n    return (\n      this.addCommentsConfig.customField.options.find(\n        customValue =>\n          this.addCommentsConfig.customField?.dropdownDisplayName.i18n === customValue.dropdownDisplayName.i18n\n      )?.dropdownDisplayName.i18n ?? ''\n    );\n  }\n\n  private createConfig(): void {\n    if (!this.addCommentsConfig) return;\n    this.authorInputConfig = {\n      value: this.qdAuthUsername || this.addCommentsConfig?.authorField?.value,\n      disabled: true,\n      label: {\n        i18n: this.addCommentsConfig?.authorField?.label?.i18n || 'i18n.qd.comments.add.author.label'\n      },\n      viewonly: false\n    };\n\n    if (this.addCommentsConfig.customField) {\n      this.customInputConfig = {\n        options: this.addCommentsConfig.customField.options.map(customValue => ({\n          value: customValue.dropdownDisplayName.i18n,\n          i18n: customValue.dropdownDisplayName.i18n,\n          active: this.addCommentsConfig.customField?.dropdownDisplayName.i18n === customValue.dropdownDisplayName.i18n\n        })),\n        label: {\n          i18n: this.addCommentsConfig.customField.label?.i18n || ''\n        },\n        viewonly: false\n      };\n    }\n  }\n\n  close(result?: any): void {\n    if (result === 'Yes' && this.addCommentsConfig.confirmDialogHandler) {\n      const comment: QdComment = {\n        comment: this.form.get('comment')?.value,\n        date: new Date(),\n        author: this.qdAuthUsername || this.addCommentsConfig?.authorField?.value,\n        custom:\n          this.addCommentsConfig?.customField?.options.find(\n            customValue => this.form.get('custom')?.value === customValue.dropdownDisplayName.i18n\n          ) ?? this.addCommentsConfig?.customField\n      };\n      this.addCommentsConfig.confirmDialogHandler(comment);\n    }\n    this.dialogRef.close();\n  }\n\n  plainTextMinLength(min: number): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (control.value == null) return null;\n\n      const sanitizedValue = getPlainTextFromHtml(control.value);\n      return sanitizedValue.length >= min ? null : { minLength: 'i18n.qd.form.error.minLength' };\n    };\n  }\n\n  plainTextMaxLength(max: number): ValidatorFnWithProps {\n    const validator: ValidatorFnWithProps = (control: AbstractControl): ValidationErrors | null => {\n      if (control.value == null) return null;\n\n      const sanitizedValue = getPlainTextFromHtml(control.value);\n      return sanitizedValue.length <= max ? null : { maxLength: 'i18n.qd.form.error.maxLength' };\n    };\n\n    validator.maxLength = max;\n\n    return validator;\n  }\n\n  plainTextRequired(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      const sanitizedValue = getPlainTextFromHtml(control.value);\n      return sanitizedValue == null || sanitizedValue.length === 0 ? { required: 'i18n.qd.form.error.required' } : null;\n    };\n  }\n}\n","<qd-dialog>\n  <form [formGroup]=\"form\">\n    <qd-input [config]=\"authorInputConfig\"></qd-input>\n    <qd-dropdown\n      *ngIf=\"customInputConfig\"\n      [config]=\"customInputConfig\"\n      [formControlName]=\"'custom'\"\n      [attr.data-test-id]=\"'comment-custom'\"\n    ></qd-dropdown>\n\n    <qd-richtext [config]=\"richtextConfig\" #commentText [formControlName]=\"'comment'\"> </qd-richtext>\n  </form>\n  <qd-dialog-action>\n    <button qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\" [data-test-id]=\"'button-cancel'\">\n      {{ \"i18n.qd.comments.add.dialog.cancel\" | translate }}\n    </button>\n    <button\n      [disabled]=\"!commentText.value || commentText.hasError\"\n      qdButton\n      (click)=\"close('Yes')\"\n      [data-test-id]=\"'button-submit'\"\n    >\n      {{ \"i18n.qd.comments.add.dialog.submit\" | translate }}\n    </button>\n  </qd-dialog-action>\n</qd-dialog>\n"]}
@@ -59,15 +59,15 @@ export class QdCommentsComponent {
59
59
  });
60
60
  }
61
61
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdCommentsComponent, deps: [{ token: i1.TranslateService }, { token: i2.QdDialogService }], target: i0.ɵɵFactoryTarget.Component });
62
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdCommentsComponent, selector: "qd-comments", inputs: { config: "config", comments: "comments" }, ngImport: i0, template: "<div class=\"comments-list\">\n <div class=\"add-button-area\">\n <button\n qdButton\n qdButtonGhost\n color=\"primary\"\n (click)=\"addNew()\"\n [disabled]=\"config.addConfig?.addButton?.disabled ?? false\"\n >\n <qd-icon icon=\"plusLarge\" class=\"plus-icon\"></qd-icon>\n {{ config.addConfig?.addButton?.i18n | translate }}\n </button>\n </div>\n\n <ng-container *ngFor=\"let comment of commentList\">\n <div\n class=\"comment\"\n (click)=\"clickComment(comment)\"\n [class.hasAction]=\"this.config.primaryActionHandler !== undefined\"\n >\n <div class=\"comment-header\">\n <div>\n <span class=\"comment-author\"><b> {{ comment.author }} </b></span>\n <span class=\"comment-custom\"> {{ comment.custom?.listDisplayName?.i18n ?\n ' - ' + (comment.custom.listDisplayName.i18n | translate) : '' }} </span>\n <span class=\"comment-date\"> {{ \" - \" + formatDate(comment.date) }} </span>\n </div>\n <button\n *ngIf=\"config.secondaryActions?.length > 0\"\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n class=\"menu-button\"\n >\n <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n </button>\n </div>\n <div class=\"deleted-meta\" *ngIf=\"comment?.deletedMeta\">\n <b>{{ comment.deletedMeta.deletedBy }}</b> -\n {{ (comment.deletedMeta.custom?.listDisplayName.i18n) ?\n (comment.deletedMeta.custom.listDisplayName.i18n | translate) + ' -': '' }}\n {{ \"i18n.qd.comments.delete.deleted\" | translate | placeholder : \"deleteDate\" :\n (formatDate(comment.deletedMeta.date)) }}\n\n </div>\n <div\n class=\"comment-content\"\n [style.text-decoration]=\"comment.deletedMeta ? 'line-through' : ''\"\n [style.-webkit-line-clamp]=\"config.numberOfDisplayedRows || 10\"\n >\n <span [innerHTML]=\"comment.comment\"></span>\n </div>\n </div>\n\n <ng-template #menu>\n <qd-comment-menu [menuActions]=\"config.secondaryActions\" [comment]=\"comment\"></qd-comment-menu>\n </ng-template>\n </ng-container>\n</div>\n", styles: [".comments-list{font-size:.875rem}.comments-list .add-button-area{display:flex;justify-content:flex-end;padding:.5rem 1rem;border-bottom:.0625rem solid rgb(213,213,213);margin-bottom:.5rem}.comments-list .add-button-area .qd-button-primary{padding:0 .5625rem;white-space:nowrap}.comments-list .add-button-area .qd-button-primary .plus-icon{padding-right:.5rem}.comments-list .comment{padding:.5rem .4375rem .5rem 1rem}.comments-list .comment.hasAction{cursor:pointer}.comments-list .comment.hasAction:hover{background-color:#f2f7fa}.comments-list .comment .comment-header{display:flex;justify-content:space-between;padding-bottom:.1875rem}.comments-list .comment .comment-header div{align-self:center}.comments-list .comment .comment-header .menu-button{background:unset;color:#454545;font-size:1rem}.comments-list .comment .comment-header .menu-button:hover,.comments-list .comment .comment-header .menu-button:focus{color:#000}.comments-list .comment .deleted-meta{margin-bottom:.5rem;color:#c70023}.comments-list .comment .comment-content{display:-webkit-box;overflow:hidden;padding-right:.5rem;-webkit-box-orient:vertical;color:#757575;-webkit-line-clamp:10}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.QdPopoverOnClickDirective, selector: "[qdPopoverOnClick]", inputs: ["qdPopoverOnClick", "positionStrategy", "qdPopoverCloseStrategy", "qdPopoverDisabled", "qdPopoverStopPropagation", "qdPopoverBackgroundColor", "qdPopoverMaxHeight", "qdPopoverMinWidth", "qdPopoverMaxWidth", "qdPopoverAutoSize", "qdPopoverEnableKeyControl"], outputs: ["opened", "closed"], exportAs: ["qdPopoverOnClick"] }, { kind: "component", type: i5.QdIconComponent, selector: "qd-icon", inputs: ["icon"] }, { kind: "component", type: i6.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i7.QdButtonGhostDirective, selector: "button[qdButtonGhost], a[qdButtonGhost]" }, { kind: "component", type: i8.QdCommentMenuComponent, selector: "qd-comment-menu", inputs: ["menuActions", "comment"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: i9.QdPlaceholderPipe, name: "placeholder" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
62
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdCommentsComponent, selector: "qd-comments", inputs: { config: "config", comments: "comments" }, ngImport: i0, template: "<div class=\"comments-list\">\n <div class=\"add-button-area\">\n <button\n qdButton\n qdButtonGhost\n color=\"primary\"\n (click)=\"addNew()\"\n [disabled]=\"config.addConfig?.addButton?.disabled ?? false\"\n >\n <qd-icon icon=\"plusLarge\" class=\"plus-icon\"></qd-icon>\n {{ config.addConfig?.addButton?.i18n | translate }}\n </button>\n </div>\n\n <ng-container *ngFor=\"let comment of commentList\">\n <div\n class=\"comment\"\n (click)=\"clickComment(comment)\"\n [class.hasAction]=\"this.config.primaryActionHandler !== undefined\"\n >\n <div class=\"comment-header\">\n <div>\n <span class=\"comment-author\"\n ><b> {{ comment.author }} </b></span\n >\n <span class=\"comment-custom\">\n {{ comment.custom?.listDisplayName?.i18n ? \" - \" + (comment.custom.listDisplayName.i18n | translate) : \"\" }}\n </span>\n <span class=\"comment-date\"> {{ \" - \" + formatDate(comment.date) }} </span>\n </div>\n <button\n *ngIf=\"config.secondaryActions?.length > 0\"\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n class=\"menu-button\"\n >\n <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n </button>\n </div>\n <div class=\"deleted-meta\" *ngIf=\"comment?.deletedMeta\">\n <b>{{ comment.deletedMeta.deletedBy }}</b> -\n {{\n comment.deletedMeta.custom?.listDisplayName.i18n\n ? (comment.deletedMeta.custom.listDisplayName.i18n | translate) + \" -\"\n : \"\"\n }}\n {{\n \"i18n.qd.comments.delete.deleted\"\n | translate\n | placeholder : \"deleteDate\" : formatDate(comment.deletedMeta.date)\n }}\n </div>\n <div\n class=\"comment-content\"\n [style.text-decoration]=\"comment.deletedMeta ? 'line-through' : ''\"\n [style.-webkit-line-clamp]=\"config.numberOfDisplayedRows || 10\"\n >\n <span [innerHTML]=\"comment.comment\"></span>\n </div>\n </div>\n\n <ng-template #menu>\n <qd-comment-menu [menuActions]=\"config.secondaryActions\" [comment]=\"comment\"></qd-comment-menu>\n </ng-template>\n </ng-container>\n</div>\n", styles: [".comments-list{font-size:.875rem}.comments-list .add-button-area{display:flex;justify-content:flex-end;padding:.5rem 1rem;border-bottom:.0625rem solid rgb(213,213,213);margin-bottom:.5rem}.comments-list .add-button-area .qd-button-primary{padding:0 .5625rem;white-space:nowrap}.comments-list .add-button-area .qd-button-primary .plus-icon{padding-right:.5rem}.comments-list .comment{padding:.5rem .4375rem .5rem 1rem}.comments-list .comment.hasAction{cursor:pointer}.comments-list .comment.hasAction:hover{background-color:#f2f7fa}.comments-list .comment .comment-header{display:flex;justify-content:space-between;padding-bottom:.1875rem}.comments-list .comment .comment-header div{align-self:center}.comments-list .comment .comment-header .menu-button{background:unset;color:#454545;font-size:1rem}.comments-list .comment .comment-header .menu-button:hover,.comments-list .comment .comment-header .menu-button:focus{color:#000}.comments-list .comment .deleted-meta{margin-bottom:.5rem;color:#c70023}.comments-list .comment .comment-content{display:-webkit-box;overflow:hidden;padding-right:.5rem;-webkit-box-orient:vertical;color:#757575;-webkit-line-clamp:10}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.QdPopoverOnClickDirective, selector: "[qdPopoverOnClick]", inputs: ["qdPopoverOnClick", "positionStrategy", "qdPopoverCloseStrategy", "qdPopoverDisabled", "qdPopoverStopPropagation", "qdPopoverBackgroundColor", "qdPopoverMaxHeight", "qdPopoverMinWidth", "qdPopoverMaxWidth", "qdPopoverAutoSize", "qdPopoverEnableKeyControl"], outputs: ["opened", "closed"], exportAs: ["qdPopoverOnClick"] }, { kind: "component", type: i5.QdIconComponent, selector: "qd-icon", inputs: ["icon"] }, { kind: "component", type: i6.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i7.QdButtonGhostDirective, selector: "button[qdButtonGhost], a[qdButtonGhost]" }, { kind: "component", type: i8.QdCommentMenuComponent, selector: "qd-comment-menu", inputs: ["menuActions", "comment"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: i9.QdPlaceholderPipe, name: "placeholder" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
63
63
  }
64
64
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdCommentsComponent, decorators: [{
65
65
  type: Component,
66
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'qd-comments', template: "<div class=\"comments-list\">\n <div class=\"add-button-area\">\n <button\n qdButton\n qdButtonGhost\n color=\"primary\"\n (click)=\"addNew()\"\n [disabled]=\"config.addConfig?.addButton?.disabled ?? false\"\n >\n <qd-icon icon=\"plusLarge\" class=\"plus-icon\"></qd-icon>\n {{ config.addConfig?.addButton?.i18n | translate }}\n </button>\n </div>\n\n <ng-container *ngFor=\"let comment of commentList\">\n <div\n class=\"comment\"\n (click)=\"clickComment(comment)\"\n [class.hasAction]=\"this.config.primaryActionHandler !== undefined\"\n >\n <div class=\"comment-header\">\n <div>\n <span class=\"comment-author\"><b> {{ comment.author }} </b></span>\n <span class=\"comment-custom\"> {{ comment.custom?.listDisplayName?.i18n ?\n ' - ' + (comment.custom.listDisplayName.i18n | translate) : '' }} </span>\n <span class=\"comment-date\"> {{ \" - \" + formatDate(comment.date) }} </span>\n </div>\n <button\n *ngIf=\"config.secondaryActions?.length > 0\"\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n class=\"menu-button\"\n >\n <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n </button>\n </div>\n <div class=\"deleted-meta\" *ngIf=\"comment?.deletedMeta\">\n <b>{{ comment.deletedMeta.deletedBy }}</b> -\n {{ (comment.deletedMeta.custom?.listDisplayName.i18n) ?\n (comment.deletedMeta.custom.listDisplayName.i18n | translate) + ' -': '' }}\n {{ \"i18n.qd.comments.delete.deleted\" | translate | placeholder : \"deleteDate\" :\n (formatDate(comment.deletedMeta.date)) }}\n\n </div>\n <div\n class=\"comment-content\"\n [style.text-decoration]=\"comment.deletedMeta ? 'line-through' : ''\"\n [style.-webkit-line-clamp]=\"config.numberOfDisplayedRows || 10\"\n >\n <span [innerHTML]=\"comment.comment\"></span>\n </div>\n </div>\n\n <ng-template #menu>\n <qd-comment-menu [menuActions]=\"config.secondaryActions\" [comment]=\"comment\"></qd-comment-menu>\n </ng-template>\n </ng-container>\n</div>\n", styles: [".comments-list{font-size:.875rem}.comments-list .add-button-area{display:flex;justify-content:flex-end;padding:.5rem 1rem;border-bottom:.0625rem solid rgb(213,213,213);margin-bottom:.5rem}.comments-list .add-button-area .qd-button-primary{padding:0 .5625rem;white-space:nowrap}.comments-list .add-button-area .qd-button-primary .plus-icon{padding-right:.5rem}.comments-list .comment{padding:.5rem .4375rem .5rem 1rem}.comments-list .comment.hasAction{cursor:pointer}.comments-list .comment.hasAction:hover{background-color:#f2f7fa}.comments-list .comment .comment-header{display:flex;justify-content:space-between;padding-bottom:.1875rem}.comments-list .comment .comment-header div{align-self:center}.comments-list .comment .comment-header .menu-button{background:unset;color:#454545;font-size:1rem}.comments-list .comment .comment-header .menu-button:hover,.comments-list .comment .comment-header .menu-button:focus{color:#000}.comments-list .comment .deleted-meta{margin-bottom:.5rem;color:#c70023}.comments-list .comment .comment-content{display:-webkit-box;overflow:hidden;padding-right:.5rem;-webkit-box-orient:vertical;color:#757575;-webkit-line-clamp:10}\n"] }]
66
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'qd-comments', template: "<div class=\"comments-list\">\n <div class=\"add-button-area\">\n <button\n qdButton\n qdButtonGhost\n color=\"primary\"\n (click)=\"addNew()\"\n [disabled]=\"config.addConfig?.addButton?.disabled ?? false\"\n >\n <qd-icon icon=\"plusLarge\" class=\"plus-icon\"></qd-icon>\n {{ config.addConfig?.addButton?.i18n | translate }}\n </button>\n </div>\n\n <ng-container *ngFor=\"let comment of commentList\">\n <div\n class=\"comment\"\n (click)=\"clickComment(comment)\"\n [class.hasAction]=\"this.config.primaryActionHandler !== undefined\"\n >\n <div class=\"comment-header\">\n <div>\n <span class=\"comment-author\"\n ><b> {{ comment.author }} </b></span\n >\n <span class=\"comment-custom\">\n {{ comment.custom?.listDisplayName?.i18n ? \" - \" + (comment.custom.listDisplayName.i18n | translate) : \"\" }}\n </span>\n <span class=\"comment-date\"> {{ \" - \" + formatDate(comment.date) }} </span>\n </div>\n <button\n *ngIf=\"config.secondaryActions?.length > 0\"\n type=\"button\"\n [qdPopoverOnClick]=\"menu\"\n [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n [qdPopoverStopPropagation]=\"true\"\n class=\"menu-button\"\n >\n <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n </button>\n </div>\n <div class=\"deleted-meta\" *ngIf=\"comment?.deletedMeta\">\n <b>{{ comment.deletedMeta.deletedBy }}</b> -\n {{\n comment.deletedMeta.custom?.listDisplayName.i18n\n ? (comment.deletedMeta.custom.listDisplayName.i18n | translate) + \" -\"\n : \"\"\n }}\n {{\n \"i18n.qd.comments.delete.deleted\"\n | translate\n | placeholder : \"deleteDate\" : formatDate(comment.deletedMeta.date)\n }}\n </div>\n <div\n class=\"comment-content\"\n [style.text-decoration]=\"comment.deletedMeta ? 'line-through' : ''\"\n [style.-webkit-line-clamp]=\"config.numberOfDisplayedRows || 10\"\n >\n <span [innerHTML]=\"comment.comment\"></span>\n </div>\n </div>\n\n <ng-template #menu>\n <qd-comment-menu [menuActions]=\"config.secondaryActions\" [comment]=\"comment\"></qd-comment-menu>\n </ng-template>\n </ng-container>\n</div>\n", styles: [".comments-list{font-size:.875rem}.comments-list .add-button-area{display:flex;justify-content:flex-end;padding:.5rem 1rem;border-bottom:.0625rem solid rgb(213,213,213);margin-bottom:.5rem}.comments-list .add-button-area .qd-button-primary{padding:0 .5625rem;white-space:nowrap}.comments-list .add-button-area .qd-button-primary .plus-icon{padding-right:.5rem}.comments-list .comment{padding:.5rem .4375rem .5rem 1rem}.comments-list .comment.hasAction{cursor:pointer}.comments-list .comment.hasAction:hover{background-color:#f2f7fa}.comments-list .comment .comment-header{display:flex;justify-content:space-between;padding-bottom:.1875rem}.comments-list .comment .comment-header div{align-self:center}.comments-list .comment .comment-header .menu-button{background:unset;color:#454545;font-size:1rem}.comments-list .comment .comment-header .menu-button:hover,.comments-list .comment .comment-header .menu-button:focus{color:#000}.comments-list .comment .deleted-meta{margin-bottom:.5rem;color:#c70023}.comments-list .comment .comment-content{display:-webkit-box;overflow:hidden;padding-right:.5rem;-webkit-box-orient:vertical;color:#757575;-webkit-line-clamp:10}\n"] }]
67
67
  }], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.QdDialogService }], propDecorators: { config: [{
68
68
  type: Input,
69
69
  args: [{ required: true }]
70
70
  }], comments: [{
71
71
  type: Input
72
72
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comments.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/comments/comments.component.ts","../../../../../libs/qd-ui/src/lib/comments/comments.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAc,MAAM,MAAM,CAAC;AAGnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,yBAAyB,EAAE,MAAM,4CAA4C,CAAC;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;;;;;;;;;;;AAQvD,MAAM,OAAO,mBAAmB;IAiBV;IAA4C;IAhBrC,MAAM,CAAoB;IAErD,IACI,QAAQ,CAAC,KAAkB;QAC7B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;IAC7C,CAAC;IAEO,aAAa,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;IAC3C,OAAO,CAAS;IACjC,WAAW,GAAgB,EAAE,CAAC;IAE9B,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;IAC3C,CAAC;IAED,YAAoB,gBAAkC,EAAU,aAA8B;QAA1E,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAU,kBAAa,GAAb,aAAa,CAAiB;QAC5F,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;IACnD,CAAC;IAED,UAAU,CAAC,IAAU;QACnB,OAAO,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,EAAE;YACnD,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,SAAS;YAChB,GAAG,EAAE,SAAS;YACd,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,SAAS;YACjB,MAAM,EAAE,KAAK;SACd,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IAED,YAAY,CAAC,OAAkB;QAC7B,IAAI,IAAI,CAAC,MAAM,CAAC,oBAAoB,KAAK,SAAS,EAAE,CAAC;YACnD,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;YAC5C,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;QAC5C,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,yBAAyB,EAAE;YACjD,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS;YAC3B,UAAU,EAAE,YAAY,CAAC,KAAK;YAC9B,KAAK,EAAE,EAAE,IAAI,EAAE,mCAAmC,EAAE;SACrD,CAAC,CAAC;IACL,CAAC;uGAhDU,mBAAmB;2FAAnB,mBAAmB,uGCfhC,uwEA4DA;;2FD7Ca,mBAAmB;kBAN/B,SAAS;sCACS,uBAAuB,CAAC,MAAM,YACrC,aAAa;mHAKI,MAAM;sBAAhC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAGrB,QAAQ;sBADX,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\n\nimport { QdComment, QdCommentsConfig } from './model/comments.interface';\nimport { TranslateService } from '@ngx-translate/core';\nimport { AddCommentDialogComponent } from './add-comment/add-comment-dialog.component';\nimport { QdDialogService } from '../dialog/services/dialog.service';\nimport { QdDialogSize } from '../dialog/dialog.module';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'qd-comments',\n  styleUrls: ['./comments.component.scss'],\n  templateUrl: './comments.component.html'\n})\nexport class QdCommentsComponent {\n  @Input({ required: true }) config!: QdCommentsConfig;\n\n  @Input()\n  set comments(value: QdComment[]) {\n    this.commentList = value;\n    this._hasComments$.next(value?.length > 0);\n  }\n\n  private _hasComments$ = new BehaviorSubject<boolean>(false);\n  private readonly _locale: string;\n  commentList: QdComment[] = [];\n\n  get hasComments$(): Observable<boolean> {\n    return this._hasComments$.asObservable();\n  }\n\n  constructor(private translateService: TranslateService, private dialogService: QdDialogService) {\n    this._locale = this.translateService.currentLang;\n  }\n\n  formatDate(date: Date): string {\n    return new Intl.DateTimeFormat(this._locale || 'de', {\n      year: 'numeric',\n      month: '2-digit',\n      day: '2-digit',\n      hour: '2-digit',\n      minute: '2-digit',\n      hour12: false\n    }).format(date);\n  }\n\n  clickComment(comment: QdComment): void {\n    if (this.config.primaryActionHandler !== undefined) {\n      this.config.primaryActionHandler(comment);\n    }\n  }\n\n  addNew(): void {\n    if (this.config.addConfig.addButton.handler) {\n      this.config.addConfig.addButton.handler();\n    }\n\n    this.dialogService.open(AddCommentDialogComponent, {\n      data: this.config.addConfig,\n      dialogSize: QdDialogSize.Small,\n      title: { i18n: 'i18n.qd.comments.add.dialog.title' }\n    });\n  }\n}\n","<div class=\"comments-list\">\n  <div class=\"add-button-area\">\n    <button\n      qdButton\n      qdButtonGhost\n      color=\"primary\"\n      (click)=\"addNew()\"\n      [disabled]=\"config.addConfig?.addButton?.disabled ?? false\"\n    >\n      <qd-icon icon=\"plusLarge\" class=\"plus-icon\"></qd-icon>\n      {{ config.addConfig?.addButton?.i18n | translate }}\n    </button>\n  </div>\n\n  <ng-container *ngFor=\"let comment of commentList\">\n    <div\n      class=\"comment\"\n      (click)=\"clickComment(comment)\"\n      [class.hasAction]=\"this.config.primaryActionHandler !== undefined\"\n    >\n      <div class=\"comment-header\">\n        <div>\n          <span class=\"comment-author\"><b> {{ comment.author }} </b></span>\n          <span class=\"comment-custom\"> {{ comment.custom?.listDisplayName?.i18n ?\n            ' - ' + (comment.custom.listDisplayName.i18n | translate) : '' }} </span>\n          <span class=\"comment-date\"> {{ \" - \" + formatDate(comment.date) }} </span>\n        </div>\n        <button\n          *ngIf=\"config.secondaryActions?.length > 0\"\n          type=\"button\"\n          [qdPopoverOnClick]=\"menu\"\n          [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n          [qdPopoverStopPropagation]=\"true\"\n          class=\"menu-button\"\n        >\n          <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n        </button>\n      </div>\n      <div class=\"deleted-meta\" *ngIf=\"comment?.deletedMeta\">\n        <b>{{ comment.deletedMeta.deletedBy }}</b> -\n        {{ (comment.deletedMeta.custom?.listDisplayName.i18n) ?\n           (comment.deletedMeta.custom.listDisplayName.i18n | translate) + ' -': '' }}\n        {{ \"i18n.qd.comments.delete.deleted\" | translate | placeholder : \"deleteDate\" :\n        (formatDate(comment.deletedMeta.date)) }}\n\n      </div>\n      <div\n        class=\"comment-content\"\n        [style.text-decoration]=\"comment.deletedMeta ? 'line-through' : ''\"\n        [style.-webkit-line-clamp]=\"config.numberOfDisplayedRows || 10\"\n      >\n        <span [innerHTML]=\"comment.comment\"></span>\n      </div>\n    </div>\n\n    <ng-template #menu>\n      <qd-comment-menu [menuActions]=\"config.secondaryActions\" [comment]=\"comment\"></qd-comment-menu>\n    </ng-template>\n  </ng-container>\n</div>\n"]}
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comments.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/comments/comments.component.ts","../../../../../libs/qd-ui/src/lib/comments/comments.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,eAAe,EAAc,MAAM,MAAM,CAAC;AAGnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,yBAAyB,EAAE,MAAM,4CAA4C,CAAC;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;;;;;;;;;;;AAQvD,MAAM,OAAO,mBAAmB;IAiBV;IAA4C;IAhBrC,MAAM,CAAoB;IAErD,IACI,QAAQ,CAAC,KAAkB;QAC7B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;IAC7C,CAAC;IAEO,aAAa,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;IAC3C,OAAO,CAAS;IACjC,WAAW,GAAgB,EAAE,CAAC;IAE9B,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;IAC3C,CAAC;IAED,YAAoB,gBAAkC,EAAU,aAA8B;QAA1E,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAU,kBAAa,GAAb,aAAa,CAAiB;QAC5F,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;IACnD,CAAC;IAED,UAAU,CAAC,IAAU;QACnB,OAAO,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,EAAE;YACnD,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,SAAS;YAChB,GAAG,EAAE,SAAS;YACd,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,SAAS;YACjB,MAAM,EAAE,KAAK;SACd,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IAED,YAAY,CAAC,OAAkB;QAC7B,IAAI,IAAI,CAAC,MAAM,CAAC,oBAAoB,KAAK,SAAS,EAAE,CAAC;YACnD,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;YAC5C,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;QAC5C,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,yBAAyB,EAAE;YACjD,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS;YAC3B,UAAU,EAAE,YAAY,CAAC,KAAK;YAC9B,KAAK,EAAE,EAAE,IAAI,EAAE,mCAAmC,EAAE;SACrD,CAAC,CAAC;IACL,CAAC;uGAhDU,mBAAmB;2FAAnB,mBAAmB,uGCfhC,s3EAoEA;;2FDrDa,mBAAmB;kBAN/B,SAAS;sCACS,uBAAuB,CAAC,MAAM,YACrC,aAAa;mHAKI,MAAM;sBAAhC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAGrB,QAAQ;sBADX,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\n\nimport { QdComment, QdCommentsConfig } from './model/comments.interface';\nimport { TranslateService } from '@ngx-translate/core';\nimport { AddCommentDialogComponent } from './add-comment/add-comment-dialog.component';\nimport { QdDialogService } from '../dialog/services/dialog.service';\nimport { QdDialogSize } from '../dialog/dialog.module';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'qd-comments',\n  styleUrls: ['./comments.component.scss'],\n  templateUrl: './comments.component.html'\n})\nexport class QdCommentsComponent {\n  @Input({ required: true }) config!: QdCommentsConfig;\n\n  @Input()\n  set comments(value: QdComment[]) {\n    this.commentList = value;\n    this._hasComments$.next(value?.length > 0);\n  }\n\n  private _hasComments$ = new BehaviorSubject<boolean>(false);\n  private readonly _locale: string;\n  commentList: QdComment[] = [];\n\n  get hasComments$(): Observable<boolean> {\n    return this._hasComments$.asObservable();\n  }\n\n  constructor(private translateService: TranslateService, private dialogService: QdDialogService) {\n    this._locale = this.translateService.currentLang;\n  }\n\n  formatDate(date: Date): string {\n    return new Intl.DateTimeFormat(this._locale || 'de', {\n      year: 'numeric',\n      month: '2-digit',\n      day: '2-digit',\n      hour: '2-digit',\n      minute: '2-digit',\n      hour12: false\n    }).format(date);\n  }\n\n  clickComment(comment: QdComment): void {\n    if (this.config.primaryActionHandler !== undefined) {\n      this.config.primaryActionHandler(comment);\n    }\n  }\n\n  addNew(): void {\n    if (this.config.addConfig.addButton.handler) {\n      this.config.addConfig.addButton.handler();\n    }\n\n    this.dialogService.open(AddCommentDialogComponent, {\n      data: this.config.addConfig,\n      dialogSize: QdDialogSize.Small,\n      title: { i18n: 'i18n.qd.comments.add.dialog.title' }\n    });\n  }\n}\n","<div class=\"comments-list\">\n  <div class=\"add-button-area\">\n    <button\n      qdButton\n      qdButtonGhost\n      color=\"primary\"\n      (click)=\"addNew()\"\n      [disabled]=\"config.addConfig?.addButton?.disabled ?? false\"\n    >\n      <qd-icon icon=\"plusLarge\" class=\"plus-icon\"></qd-icon>\n      {{ config.addConfig?.addButton?.i18n | translate }}\n    </button>\n  </div>\n\n  <ng-container *ngFor=\"let comment of commentList\">\n    <div\n      class=\"comment\"\n      (click)=\"clickComment(comment)\"\n      [class.hasAction]=\"this.config.primaryActionHandler !== undefined\"\n    >\n      <div class=\"comment-header\">\n        <div>\n          <span class=\"comment-author\"\n            ><b> {{ comment.author }} </b></span\n          >\n          <span class=\"comment-custom\">\n            {{ comment.custom?.listDisplayName?.i18n ? \" - \" + (comment.custom.listDisplayName.i18n | translate) : \"\" }}\n          </span>\n          <span class=\"comment-date\"> {{ \" - \" + formatDate(comment.date) }} </span>\n        </div>\n        <button\n          *ngIf=\"config.secondaryActions?.length > 0\"\n          type=\"button\"\n          [qdPopoverOnClick]=\"menu\"\n          [qdPopoverCloseStrategy]=\"'onEveryClick'\"\n          [qdPopoverStopPropagation]=\"true\"\n          class=\"menu-button\"\n        >\n          <qd-icon icon=\"overflowMenuVertical\"></qd-icon>\n        </button>\n      </div>\n      <div class=\"deleted-meta\" *ngIf=\"comment?.deletedMeta\">\n        <b>{{ comment.deletedMeta.deletedBy }}</b> -\n        {{\n          comment.deletedMeta.custom?.listDisplayName.i18n\n            ? (comment.deletedMeta.custom.listDisplayName.i18n | translate) + \" -\"\n            : \"\"\n        }}\n        {{\n          \"i18n.qd.comments.delete.deleted\"\n            | translate\n            | placeholder : \"deleteDate\" : formatDate(comment.deletedMeta.date)\n        }}\n      </div>\n      <div\n        class=\"comment-content\"\n        [style.text-decoration]=\"comment.deletedMeta ? 'line-through' : ''\"\n        [style.-webkit-line-clamp]=\"config.numberOfDisplayedRows || 10\"\n      >\n        <span [innerHTML]=\"comment.comment\"></span>\n      </div>\n    </div>\n\n    <ng-template #menu>\n      <qd-comment-menu [menuActions]=\"config.secondaryActions\" [comment]=\"comment\"></qd-comment-menu>\n    </ng-template>\n  </ng-container>\n</div>\n"]}
@@ -1,21 +1,22 @@
1
- // @ts-strict-ignore
2
1
  import { ChangeDetectorRef, Component, ElementRef, HostBinding, ViewChild, ViewEncapsulation } from '@angular/core';
3
2
  import { DialogRef } from '@angular/cdk/dialog';
3
+ import { Subject } from 'rxjs';
4
+ import { filter, take, takeUntil } from 'rxjs/operators';
4
5
  import { QdDialogSize } from './models/dialog-config.model';
5
6
  import { QdDialogChangeGuardService } from './services/dialog-change-guard.service';
6
- import { Subject } from 'rxjs';
7
- import { takeUntil } from 'rxjs/operators';
8
7
  import { QdConfirmationDialogOpenerService } from './services/confirmation-dialog.service';
8
+ import { QdDialogService } from './services/dialog.service';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "@angular/cdk/dialog";
11
11
  import * as i2 from "./services/confirmation-dialog.service";
12
12
  import * as i3 from "./services/dialog-change-guard.service";
13
- import * as i4 from "@angular/common";
14
- import * as i5 from "../button/button/button.component";
15
- import * as i6 from "../button/directives/button.directives";
16
- import * as i7 from "../button/icon-button/icon-button.component";
17
- import * as i8 from "../icon/icon/icon.component";
18
- import * as i9 from "@ngx-translate/core";
13
+ import * as i4 from "./services/dialog.service";
14
+ import * as i5 from "@angular/common";
15
+ import * as i6 from "../button/button/button.component";
16
+ import * as i7 from "../button/directives/button.directives";
17
+ import * as i8 from "../button/icon-button/icon-button.component";
18
+ import * as i9 from "../icon/icon/icon.component";
19
+ import * as i10 from "@ngx-translate/core";
19
20
  /**
20
21
  * **QdDialog** creating resonsive dialogs. Three different sizes are available.
21
22
  *
@@ -68,6 +69,7 @@ export class QdDialogComponent {
68
69
  dialog;
69
70
  changeDetectorRef;
70
71
  dialogChangeGuard;
72
+ dialogService;
71
73
  body;
72
74
  infoBanners;
73
75
  get hasSectionsClass() {
@@ -77,62 +79,103 @@ export class QdDialogComponent {
77
79
  hasSections;
78
80
  hasInfoBanner;
79
81
  _destroyed$ = new Subject();
80
- constructor(dialogRef, dialog, changeDetectorRef, dialogChangeGuard) {
82
+ _pageDialogCanCloseFn = null;
83
+ get isFullWidth() {
84
+ return this.config.dialogSize === QdDialogSize.FullWidth;
85
+ }
86
+ constructor(dialogRef, dialog, changeDetectorRef, dialogChangeGuard, dialogService) {
81
87
  this.dialogRef = dialogRef;
82
88
  this.dialog = dialog;
83
89
  this.changeDetectorRef = changeDetectorRef;
84
90
  this.dialogChangeGuard = dialogChangeGuard;
91
+ this.dialogService = dialogService;
85
92
  }
86
93
  ngOnInit() {
87
94
  this.config = this.dialogRef.config;
95
+ this.dialogService.pageDialogCanClose$.pipe(takeUntil(this._destroyed$)).subscribe(entry => {
96
+ this._pageDialogCanCloseFn = entry?.owner === this.dialogRef ? entry.fn : null;
97
+ });
98
+ if (this.isFullWidth)
99
+ this.bindEscToClose();
88
100
  }
89
101
  ngAfterContentChecked() {
90
- const children = Array.from(this.body?.nativeElement?.childNodes || []);
102
+ const children = Array.from(this.body?.nativeElement?.children ?? []);
91
103
  this.hasSections = children.length > 0 && children.every((node) => node.tagName === 'QD-SECTION');
92
104
  this.changeDetectorRef.detectChanges();
93
105
  }
94
106
  ngAfterViewInit() {
95
- const bannerChildren = Array.from(this.infoBanners?.nativeElement?.childNodes || []);
107
+ const bannerChildren = Array.from(this.infoBanners?.nativeElement?.childNodes ?? []);
96
108
  this.hasInfoBanner =
97
109
  bannerChildren.length > 0 && bannerChildren.some((node) => node.tagName === 'QD-PAGE-INFO-BANNER');
98
110
  this.changeDetectorRef.detectChanges();
99
111
  }
112
+ ngOnDestroy() {
113
+ this.dialogService.clearPageDialogCanClose(this.dialogRef);
114
+ this._destroyed$.next();
115
+ this._destroyed$.complete();
116
+ }
100
117
  close() {
101
- const hasPendingChanges = this.dialogChangeGuard.hasPendingChanges;
102
- if (hasPendingChanges) {
103
- this.dialog
104
- .showCancelConfirmation(this.config)
105
- .pipe(takeUntil(this._destroyed$))
106
- .subscribe(confirmed => {
107
- if (confirmed)
108
- this.dialogRef.close();
109
- });
110
- }
111
- else {
112
- if (this.config.cancel?.handler)
113
- this.config.cancel?.handler();
114
- this.dialogRef.close();
115
- }
118
+ if (this.isFullWidth && this._pageDialogCanCloseFn)
119
+ return this.handlePageDialogClose();
120
+ this.handleLegacyDialogClose();
116
121
  }
117
122
  primaryActionClicked() {
118
123
  if (this.config.primary?.handler)
119
124
  this.config.primary?.handler();
120
125
  this.dialogRef.close();
121
126
  }
122
- ngOnDestroy() {
123
- this._destroyed$.next();
124
- this._destroyed$.complete();
127
+ finalizeClose() {
128
+ this.dialogService.clearPageDialogCanClose(this.dialogRef);
129
+ this.dialogRef.close();
125
130
  }
126
- get isFullWidth() {
127
- return this.config.dialogSize === QdDialogSize.FullWidth;
131
+ confirmAndClose() {
132
+ this.dialog
133
+ .showCancelConfirmation(this.config)
134
+ .pipe(take(1))
135
+ .subscribe(confirmed => {
136
+ if (!confirmed)
137
+ return;
138
+ this.config.cancel?.handler?.();
139
+ this.finalizeClose();
140
+ });
141
+ }
142
+ handlePageDialogClose() {
143
+ this._pageDialogCanCloseFn()
144
+ .pipe(take(1))
145
+ .subscribe(result => {
146
+ if (!result)
147
+ return;
148
+ if (result.canClose)
149
+ return this.runCancelHandlerAndClose();
150
+ if (!result.hasChanges)
151
+ return;
152
+ this.confirmAndClose();
153
+ });
154
+ }
155
+ handleLegacyDialogClose() {
156
+ if (!this.dialogChangeGuard.hasPendingChanges)
157
+ return this.runCancelHandlerAndClose();
158
+ this.confirmAndClose();
159
+ }
160
+ runCancelHandlerAndClose() {
161
+ this.config.cancel?.handler?.();
162
+ this.finalizeClose();
163
+ }
164
+ bindEscToClose() {
165
+ this.dialogRef.keydownEvents
166
+ .pipe(takeUntil(this._destroyed$), filter((e) => e.key === 'Escape'))
167
+ .subscribe(e => {
168
+ e.preventDefault();
169
+ this.close();
170
+ });
128
171
  }
129
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogComponent, deps: [{ token: i1.DialogRef }, { token: i2.QdConfirmationDialogOpenerService }, { token: i0.ChangeDetectorRef }, { token: i3.QdDialogChangeGuardService }], target: i0.ɵɵFactoryTarget.Component });
130
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdDialogComponent, selector: "qd-dialog", host: { properties: { "class.full-width": "isFullWidth", "class.has-sections": "this.hasSectionsClass" } }, providers: [QdDialogComponent], viewQueries: [{ propertyName: "body", first: true, predicate: ["body"], descendants: true }, { propertyName: "infoBanners", first: true, predicate: ["banners"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"!isFullWidth\" class=\"dialog-header\">\n <div class=\"title-container\">\n {{ config?.title?.i18n | translate }}\n </div>\n <button\n *ngIf=\"!config?.hideCloseHeaderButton\"\n qdIconButton\n class=\"close\"\n color=\"secondary\"\n tabindex=\"-1\"\n (click)=\"close()\"\n >\n <qd-icon icon=\"timesLargeLight\"></qd-icon>\n </button>\n</div>\n\n<button\n *ngIf=\"!config?.hideCloseHeaderButton && isFullWidth\"\n qdIconButton\n class=\"close\"\n color=\"secondary\"\n tabindex=\"-1\"\n (click)=\"close()\"\n>\n <qd-icon icon=\"timesLargeLight\"></qd-icon>\n</button>\n\n<div class=\"wrapper-body\">\n <div [class.has-dialog-info-banners]=\"hasInfoBanner\" #banners>\n <ng-content select=\"qd-page-info-banner\"></ng-content>\n </div>\n <div class=\"body\" [class.full-width]=\"isFullWidth\" #body>\n <ng-content></ng-content>\n </div>\n</div>\n\n<div class=\"qd-dialog-actions\">\n <button *ngIf=\"config.cancel\" qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\">Cancel</button>\n <button *ngIf=\"config.primary\" qdButton (click)=\"primaryActionClicked()\">Submit as</button>\n <ng-content select=\"qd-dialog-action\"></ng-content>\n</div>\n", styles: ["qd-dialog{display:flex;width:100%;height:100%;flex-direction:column;background:#efefef}qd-dialog.full-width{position:relative;width:calc(100% - 3rem)!important;height:calc(100% - 3rem)!important;margin:1.5rem}qd-dialog.full-width .close{position:absolute;z-index:9999;top:1.25rem;right:1rem;color:#454545;cursor:pointer}.dialog-header{display:flex;height:3.125rem;flex-direction:row;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;border-bottom:2px solid rgb(213,213,213);background:#fff}.dialog-header .title-container{display:block;color:#171717;font-weight:500}.dialog-header .close{cursor:pointer}.wrapper-body{overflow:auto;flex:1;background:#efefef}.wrapper-body .has-dialog-info-banners{padding:1rem 1.25rem .5rem;border-bottom:rgb(213,213,213) solid .0625rem;background-color:#fff}.wrapper-body .has-dialog-info-banners qd-page-info-banner:last-child{margin-bottom:0}.wrapper-body .body.full-width{height:100%}.wrapper-body .body:not(.full-width){max-height:80vh;padding:1rem 1.5rem}.wrapper-body .body:not(.full-width) qd-section{padding-right:1.5rem;padding-left:1.5rem}.wrapper-body .body:not(.full-width) qd-text-section{margin-right:0;margin-left:0}qd-dialog.has-sections .wrapper-body .body:not(.full-width){padding:0}.qd-dialog-actions{display:flex;justify-content:flex-end;padding:.5rem 1.5rem;border-top:2px solid rgb(213,213,213);background:#efefef;column-gap:.625rem}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i6.QdButtonGhostDirective, selector: "button[qdButtonGhost], a[qdButtonGhost]" }, { kind: "component", type: i7.QdIconButtonComponent, selector: "button[qdIconButton], a[qdIconButton], button[qd-icon-button]", inputs: ["color", "data-test-id"] }, { kind: "component", type: i8.QdIconComponent, selector: "qd-icon", inputs: ["icon"] }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
172
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogComponent, deps: [{ token: i1.DialogRef }, { token: i2.QdConfirmationDialogOpenerService }, { token: i0.ChangeDetectorRef }, { token: i3.QdDialogChangeGuardService }, { token: i4.QdDialogService }], target: i0.ɵɵFactoryTarget.Component });
173
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdDialogComponent, selector: "qd-dialog", host: { properties: { "class.full-width": "isFullWidth", "class.has-sections": "this.hasSectionsClass" } }, providers: [QdDialogComponent], viewQueries: [{ propertyName: "body", first: true, predicate: ["body"], descendants: true }, { propertyName: "infoBanners", first: true, predicate: ["banners"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"!isFullWidth\" class=\"dialog-header\">\n <div class=\"title-container\">\n {{ config?.title?.i18n | translate }}\n </div>\n <button\n *ngIf=\"!config?.hideCloseHeaderButton\"\n qdIconButton\n class=\"close\"\n color=\"secondary\"\n tabindex=\"-1\"\n (click)=\"close()\"\n >\n <qd-icon icon=\"timesLargeLight\"></qd-icon>\n </button>\n</div>\n\n<button\n *ngIf=\"!config?.hideCloseHeaderButton && isFullWidth\"\n qdIconButton\n class=\"close\"\n color=\"secondary\"\n tabindex=\"-1\"\n (click)=\"close()\"\n>\n <qd-icon icon=\"timesLargeLight\"></qd-icon>\n</button>\n\n<div class=\"wrapper-body\">\n <div [class.has-dialog-info-banners]=\"hasInfoBanner\" #banners>\n <ng-content select=\"qd-page-info-banner\"></ng-content>\n </div>\n <div class=\"body\" [class.full-width]=\"isFullWidth\" #body>\n <ng-content></ng-content>\n </div>\n</div>\n\n<div class=\"qd-dialog-actions\">\n <button *ngIf=\"config.cancel\" qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\">\n {{ config?.cancel?.label?.i18n ?? \"i18n.qd.dialog.action.cancel\" | translate }}\n </button>\n <button *ngIf=\"config.primary\" qdButton (click)=\"primaryActionClicked()\">\n {{ config?.primary?.label?.i18n ?? \"i18n.qd.dialog.action.primary\" | translate }}\n </button>\n <ng-content select=\"qd-dialog-action\"></ng-content>\n</div>\n", styles: ["qd-dialog{display:flex;width:100%;height:100%;flex-direction:column;background:#efefef}qd-dialog.full-width{position:relative;width:calc(100% - 3rem)!important;height:calc(100% - 3rem)!important;margin:1.5rem}qd-dialog.full-width .close{position:absolute;z-index:9999;top:1.25rem;right:1rem;color:#454545;cursor:pointer}.dialog-header{display:flex;height:3.125rem;flex-direction:row;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;border-bottom:2px solid rgb(213,213,213);background:#fff}.dialog-header .title-container{display:block;color:#171717;font-weight:500}.dialog-header .close{cursor:pointer}.wrapper-body{overflow:auto;flex:1;background:#efefef}.wrapper-body .has-dialog-info-banners{padding:1rem 1.25rem .5rem;border-bottom:rgb(213,213,213) solid .0625rem;background-color:#fff}.wrapper-body .has-dialog-info-banners qd-page-info-banner:last-child{margin-bottom:0}.wrapper-body .body.full-width{height:100%}.wrapper-body .body:not(.full-width){max-height:80vh;padding:1rem 1.5rem}.wrapper-body .body:not(.full-width) qd-section{padding-right:1.5rem;padding-left:1.5rem}.wrapper-body .body:not(.full-width) qd-text-section{margin-right:0;margin-left:0}qd-dialog.has-sections .wrapper-body .body:not(.full-width){padding:0}.qd-dialog-actions{display:flex;justify-content:flex-end;padding:.5rem 1.5rem;border-top:2px solid rgb(213,213,213);background:#efefef;column-gap:.625rem}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i7.QdButtonGhostDirective, selector: "button[qdButtonGhost], a[qdButtonGhost]" }, { kind: "component", type: i8.QdIconButtonComponent, selector: "button[qdIconButton], a[qdIconButton], button[qd-icon-button]", inputs: ["color", "data-test-id"] }, { kind: "component", type: i9.QdIconComponent, selector: "qd-icon", inputs: ["icon"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
131
174
  }
132
175
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogComponent, decorators: [{
133
176
  type: Component,
134
- args: [{ selector: 'qd-dialog', host: { '[class.full-width]': 'isFullWidth' }, encapsulation: ViewEncapsulation.None, providers: [QdDialogComponent], template: "<div *ngIf=\"!isFullWidth\" class=\"dialog-header\">\n <div class=\"title-container\">\n {{ config?.title?.i18n | translate }}\n </div>\n <button\n *ngIf=\"!config?.hideCloseHeaderButton\"\n qdIconButton\n class=\"close\"\n color=\"secondary\"\n tabindex=\"-1\"\n (click)=\"close()\"\n >\n <qd-icon icon=\"timesLargeLight\"></qd-icon>\n </button>\n</div>\n\n<button\n *ngIf=\"!config?.hideCloseHeaderButton && isFullWidth\"\n qdIconButton\n class=\"close\"\n color=\"secondary\"\n tabindex=\"-1\"\n (click)=\"close()\"\n>\n <qd-icon icon=\"timesLargeLight\"></qd-icon>\n</button>\n\n<div class=\"wrapper-body\">\n <div [class.has-dialog-info-banners]=\"hasInfoBanner\" #banners>\n <ng-content select=\"qd-page-info-banner\"></ng-content>\n </div>\n <div class=\"body\" [class.full-width]=\"isFullWidth\" #body>\n <ng-content></ng-content>\n </div>\n</div>\n\n<div class=\"qd-dialog-actions\">\n <button *ngIf=\"config.cancel\" qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\">Cancel</button>\n <button *ngIf=\"config.primary\" qdButton (click)=\"primaryActionClicked()\">Submit as</button>\n <ng-content select=\"qd-dialog-action\"></ng-content>\n</div>\n", styles: ["qd-dialog{display:flex;width:100%;height:100%;flex-direction:column;background:#efefef}qd-dialog.full-width{position:relative;width:calc(100% - 3rem)!important;height:calc(100% - 3rem)!important;margin:1.5rem}qd-dialog.full-width .close{position:absolute;z-index:9999;top:1.25rem;right:1rem;color:#454545;cursor:pointer}.dialog-header{display:flex;height:3.125rem;flex-direction:row;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;border-bottom:2px solid rgb(213,213,213);background:#fff}.dialog-header .title-container{display:block;color:#171717;font-weight:500}.dialog-header .close{cursor:pointer}.wrapper-body{overflow:auto;flex:1;background:#efefef}.wrapper-body .has-dialog-info-banners{padding:1rem 1.25rem .5rem;border-bottom:rgb(213,213,213) solid .0625rem;background-color:#fff}.wrapper-body .has-dialog-info-banners qd-page-info-banner:last-child{margin-bottom:0}.wrapper-body .body.full-width{height:100%}.wrapper-body .body:not(.full-width){max-height:80vh;padding:1rem 1.5rem}.wrapper-body .body:not(.full-width) qd-section{padding-right:1.5rem;padding-left:1.5rem}.wrapper-body .body:not(.full-width) qd-text-section{margin-right:0;margin-left:0}qd-dialog.has-sections .wrapper-body .body:not(.full-width){padding:0}.qd-dialog-actions{display:flex;justify-content:flex-end;padding:.5rem 1.5rem;border-top:2px solid rgb(213,213,213);background:#efefef;column-gap:.625rem}\n"] }]
135
- }], ctorParameters: () => [{ type: i1.DialogRef }, { type: i2.QdConfirmationDialogOpenerService }, { type: i0.ChangeDetectorRef }, { type: i3.QdDialogChangeGuardService }], propDecorators: { body: [{
177
+ args: [{ selector: 'qd-dialog', host: { '[class.full-width]': 'isFullWidth' }, encapsulation: ViewEncapsulation.None, providers: [QdDialogComponent], template: "<div *ngIf=\"!isFullWidth\" class=\"dialog-header\">\n <div class=\"title-container\">\n {{ config?.title?.i18n | translate }}\n </div>\n <button\n *ngIf=\"!config?.hideCloseHeaderButton\"\n qdIconButton\n class=\"close\"\n color=\"secondary\"\n tabindex=\"-1\"\n (click)=\"close()\"\n >\n <qd-icon icon=\"timesLargeLight\"></qd-icon>\n </button>\n</div>\n\n<button\n *ngIf=\"!config?.hideCloseHeaderButton && isFullWidth\"\n qdIconButton\n class=\"close\"\n color=\"secondary\"\n tabindex=\"-1\"\n (click)=\"close()\"\n>\n <qd-icon icon=\"timesLargeLight\"></qd-icon>\n</button>\n\n<div class=\"wrapper-body\">\n <div [class.has-dialog-info-banners]=\"hasInfoBanner\" #banners>\n <ng-content select=\"qd-page-info-banner\"></ng-content>\n </div>\n <div class=\"body\" [class.full-width]=\"isFullWidth\" #body>\n <ng-content></ng-content>\n </div>\n</div>\n\n<div class=\"qd-dialog-actions\">\n <button *ngIf=\"config.cancel\" qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\">\n {{ config?.cancel?.label?.i18n ?? \"i18n.qd.dialog.action.cancel\" | translate }}\n </button>\n <button *ngIf=\"config.primary\" qdButton (click)=\"primaryActionClicked()\">\n {{ config?.primary?.label?.i18n ?? \"i18n.qd.dialog.action.primary\" | translate }}\n </button>\n <ng-content select=\"qd-dialog-action\"></ng-content>\n</div>\n", styles: ["qd-dialog{display:flex;width:100%;height:100%;flex-direction:column;background:#efefef}qd-dialog.full-width{position:relative;width:calc(100% - 3rem)!important;height:calc(100% - 3rem)!important;margin:1.5rem}qd-dialog.full-width .close{position:absolute;z-index:9999;top:1.25rem;right:1rem;color:#454545;cursor:pointer}.dialog-header{display:flex;height:3.125rem;flex-direction:row;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;border-bottom:2px solid rgb(213,213,213);background:#fff}.dialog-header .title-container{display:block;color:#171717;font-weight:500}.dialog-header .close{cursor:pointer}.wrapper-body{overflow:auto;flex:1;background:#efefef}.wrapper-body .has-dialog-info-banners{padding:1rem 1.25rem .5rem;border-bottom:rgb(213,213,213) solid .0625rem;background-color:#fff}.wrapper-body .has-dialog-info-banners qd-page-info-banner:last-child{margin-bottom:0}.wrapper-body .body.full-width{height:100%}.wrapper-body .body:not(.full-width){max-height:80vh;padding:1rem 1.5rem}.wrapper-body .body:not(.full-width) qd-section{padding-right:1.5rem;padding-left:1.5rem}.wrapper-body .body:not(.full-width) qd-text-section{margin-right:0;margin-left:0}qd-dialog.has-sections .wrapper-body .body:not(.full-width){padding:0}.qd-dialog-actions{display:flex;justify-content:flex-end;padding:.5rem 1.5rem;border-top:2px solid rgb(213,213,213);background:#efefef;column-gap:.625rem}\n"] }]
178
+ }], ctorParameters: () => [{ type: i1.DialogRef }, { type: i2.QdConfirmationDialogOpenerService }, { type: i0.ChangeDetectorRef }, { type: i3.QdDialogChangeGuardService }, { type: i4.QdDialogService }], propDecorators: { body: [{
136
179
  type: ViewChild,
137
180
  args: ['body']
138
181
  }], infoBanners: [{
@@ -142,4 +185,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
142
185
  type: HostBinding,
143
186
  args: ['class.has-sections']
144
187
  }] } });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/dialog/dialog.component.ts","../../../../../libs/qd-ui/src/lib/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  AfterContentChecked,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  OnDestroy,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { DialogRef } from '@angular/cdk/dialog';\nimport { QdDialogConfig, QdDialogSize } from './models/dialog-config.model';\nimport { QdDialogChangeGuardService } from './services/dialog-change-guard.service';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { QdConfirmationDialogOpenerService } from './services/confirmation-dialog.service';\n\n/**\n * **QdDialog** creating resonsive dialogs. Three different sizes are available.\n *\n *\n * * @see child component: **QdDialogAction**.\n *\n * **Usage:**\n *\n * @example\n * import { QdDialogService } from '@quadrel-ui/qd-ui';\n *\n * @example\n * const config: QdDialogConfig = {\n *   title: {\n *      i18n: \"i18.my.modal.title\",\n *   },\n *   dialogSize: QdDialogSize.Default,\n *   hideCloseHeaderButton: false\n *   data: myData // API to provide data to the dialog\n * }\n *\n * @example\n * this.dialogService.open(MyModalComponent, config);\n *\n * **Example of MyModalComponent:**\n *\n * @example\n * <qd-dialog>\n *     <!-- Dialog Content START-->\n *     ...\n *     <!-- Dialog Content ENDE-->\n *     <qd-dialog-action>\n *         <button qdButton color=\"secondary\" (click)=\"close()\">Cancel</button>\n *         <button qdButton (click)=\"close('Yes')\">Submit</button>\n *     </qd-dialog-action>\n * </qd-dialog>\n *\n *  **Example of MyModalComponent (Including Form Change Guard):**\n *\n *  @example\n *  <qd-dialog>\n *   <form [formGroup]=\"myForm\" qdPendingChangesGuard>\n *   <input type=\"text\" formControlName=\"name\">\n *   You have unsaved changes!\n *   </form>\n *  </qd-dialog>\n *  */\n@Component({\n  selector: 'qd-dialog',\n  templateUrl: './dialog.component.html',\n  host: { '[class.full-width]': 'isFullWidth' },\n  styleUrls: ['./dialog.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [QdDialogComponent]\n})\nexport class QdDialogComponent implements OnInit, AfterContentChecked, AfterViewInit, OnDestroy {\n  @ViewChild('body') body: ElementRef;\n  @ViewChild('banners') infoBanners: ElementRef;\n\n  @HostBinding('class.has-sections') get hasSectionsClass(): boolean {\n    return this.hasSections;\n  }\n\n  config: QdDialogConfig;\n  hasSections: boolean;\n  hasInfoBanner: boolean;\n\n  private _destroyed$ = new Subject<void>();\n\n  constructor(\n    public dialogRef: DialogRef<string>,\n    private dialog: QdConfirmationDialogOpenerService,\n    private changeDetectorRef: ChangeDetectorRef,\n    private dialogChangeGuard: QdDialogChangeGuardService\n  ) {}\n\n  ngOnInit(): void {\n    this.config = this.dialogRef.config;\n  }\n\n  ngAfterContentChecked(): void {\n    const children = Array.from(this.body?.nativeElement?.childNodes || []);\n    this.hasSections = children.length > 0 && children.every((node: HTMLElement) => node.tagName === 'QD-SECTION');\n    this.changeDetectorRef.detectChanges();\n  }\n\n  ngAfterViewInit(): void {\n    const bannerChildren = Array.from(this.infoBanners?.nativeElement?.childNodes || []);\n    this.hasInfoBanner =\n      bannerChildren.length > 0 && bannerChildren.some((node: HTMLElement) => node.tagName === 'QD-PAGE-INFO-BANNER');\n    this.changeDetectorRef.detectChanges();\n  }\n\n  close(): void {\n    const hasPendingChanges = this.dialogChangeGuard.hasPendingChanges;\n\n    if (hasPendingChanges) {\n      this.dialog\n        .showCancelConfirmation(this.config)\n        .pipe(takeUntil(this._destroyed$))\n        .subscribe(confirmed => {\n          if (confirmed) this.dialogRef.close();\n        });\n    } else {\n      if (this.config.cancel?.handler) this.config.cancel?.handler();\n      this.dialogRef.close();\n    }\n  }\n\n  primaryActionClicked(): void {\n    if (this.config.primary?.handler) this.config.primary?.handler();\n    this.dialogRef.close();\n  }\n\n  ngOnDestroy(): void {\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  get isFullWidth(): boolean {\n    return this.config.dialogSize === QdDialogSize.FullWidth;\n  }\n}\n","<div *ngIf=\"!isFullWidth\" class=\"dialog-header\">\n  <div class=\"title-container\">\n    {{ config?.title?.i18n | translate }}\n  </div>\n  <button\n    *ngIf=\"!config?.hideCloseHeaderButton\"\n    qdIconButton\n    class=\"close\"\n    color=\"secondary\"\n    tabindex=\"-1\"\n    (click)=\"close()\"\n  >\n    <qd-icon icon=\"timesLargeLight\"></qd-icon>\n  </button>\n</div>\n\n<button\n  *ngIf=\"!config?.hideCloseHeaderButton && isFullWidth\"\n  qdIconButton\n  class=\"close\"\n  color=\"secondary\"\n  tabindex=\"-1\"\n  (click)=\"close()\"\n>\n  <qd-icon icon=\"timesLargeLight\"></qd-icon>\n</button>\n\n<div class=\"wrapper-body\">\n  <div [class.has-dialog-info-banners]=\"hasInfoBanner\" #banners>\n    <ng-content select=\"qd-page-info-banner\"></ng-content>\n  </div>\n  <div class=\"body\" [class.full-width]=\"isFullWidth\" #body>\n    <ng-content></ng-content>\n  </div>\n</div>\n\n<div class=\"qd-dialog-actions\">\n  <button *ngIf=\"config.cancel\" qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\">Cancel</button>\n  <button *ngIf=\"config.primary\" qdButton (click)=\"primaryActionClicked()\">Submit as</button>\n  <ng-content select=\"qd-dialog-action\"></ng-content>\n</div>\n"]}
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/dialog/dialog.component.ts","../../../../../libs/qd-ui/src/lib/dialog/dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  OnDestroy,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { DialogRef } from '@angular/cdk/dialog';\nimport { Subject } from 'rxjs';\nimport { filter, take, takeUntil } from 'rxjs/operators';\n\nimport { QdDialogConfig, QdDialogSize } from './models/dialog-config.model';\nimport { QdDialogChangeGuardService } from './services/dialog-change-guard.service';\nimport { QdConfirmationDialogOpenerService } from './services/confirmation-dialog.service';\nimport { QdDialogService } from './services/dialog.service';\nimport { QdPageDialogCanCloseFn } from './models/dialog-close.model';\n\n/**\n * **QdDialog** creating resonsive dialogs. Three different sizes are available.\n *\n *\n * * @see child component: **QdDialogAction**.\n *\n * **Usage:**\n *\n * @example\n * import { QdDialogService } from '@quadrel-ui/qd-ui';\n *\n * @example\n * const config: QdDialogConfig = {\n *   title: {\n *      i18n: \"i18.my.modal.title\",\n *   },\n *   dialogSize: QdDialogSize.Default,\n *   hideCloseHeaderButton: false\n *   data: myData // API to provide data to the dialog\n * }\n *\n * @example\n * this.dialogService.open(MyModalComponent, config);\n *\n * **Example of MyModalComponent:**\n *\n * @example\n * <qd-dialog>\n *     <!-- Dialog Content START-->\n *     ...\n *     <!-- Dialog Content ENDE-->\n *     <qd-dialog-action>\n *         <button qdButton color=\"secondary\" (click)=\"close()\">Cancel</button>\n *         <button qdButton (click)=\"close('Yes')\">Submit</button>\n *     </qd-dialog-action>\n * </qd-dialog>\n *\n *  **Example of MyModalComponent (Including Form Change Guard):**\n *\n *  @example\n *  <qd-dialog>\n *   <form [formGroup]=\"myForm\" qdPendingChangesGuard>\n *   <input type=\"text\" formControlName=\"name\">\n *   You have unsaved changes!\n *   </form>\n *  </qd-dialog>\n *  */\n@Component({\n  selector: 'qd-dialog',\n  templateUrl: './dialog.component.html',\n  host: { '[class.full-width]': 'isFullWidth' },\n  styleUrls: ['./dialog.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [QdDialogComponent]\n})\nexport class QdDialogComponent implements OnInit, AfterContentChecked, AfterViewInit, OnDestroy {\n  @ViewChild('body')\n  body?: ElementRef<HTMLElement>;\n\n  @ViewChild('banners')\n  infoBanners?: ElementRef<HTMLElement>;\n\n  @HostBinding('class.has-sections')\n  get hasSectionsClass(): boolean {\n    return this.hasSections;\n  }\n\n  config!: QdDialogConfig;\n  hasSections!: boolean;\n  hasInfoBanner!: boolean;\n\n  private _destroyed$ = new Subject<void>();\n  private _pageDialogCanCloseFn: QdPageDialogCanCloseFn | null = null;\n\n  get isFullWidth(): boolean {\n    return this.config.dialogSize === QdDialogSize.FullWidth;\n  }\n\n  constructor(\n    public dialogRef: DialogRef<unknown>,\n    private dialog: QdConfirmationDialogOpenerService,\n    private changeDetectorRef: ChangeDetectorRef,\n    private dialogChangeGuard: QdDialogChangeGuardService,\n    private dialogService: QdDialogService\n  ) {}\n\n  ngOnInit(): void {\n    this.config = this.dialogRef.config as unknown as QdDialogConfig;\n\n    this.dialogService.pageDialogCanClose$.pipe(takeUntil(this._destroyed$)).subscribe(entry => {\n      this._pageDialogCanCloseFn = entry?.owner === this.dialogRef ? entry.fn : null;\n    });\n\n    if (this.isFullWidth) this.bindEscToClose();\n  }\n\n  ngAfterContentChecked(): void {\n    const children = Array.from(this.body?.nativeElement?.children ?? []) as HTMLElement[];\n    this.hasSections = children.length > 0 && children.every((node: HTMLElement) => node.tagName === 'QD-SECTION');\n    this.changeDetectorRef.detectChanges();\n  }\n\n  ngAfterViewInit(): void {\n    const bannerChildren = Array.from(this.infoBanners?.nativeElement?.childNodes ?? []) as HTMLElement[];\n    this.hasInfoBanner =\n      bannerChildren.length > 0 && bannerChildren.some((node: HTMLElement) => node.tagName === 'QD-PAGE-INFO-BANNER');\n    this.changeDetectorRef.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.dialogService.clearPageDialogCanClose(this.dialogRef);\n    this._destroyed$.next();\n    this._destroyed$.complete();\n  }\n\n  close(): void {\n    if (this.isFullWidth && this._pageDialogCanCloseFn) return this.handlePageDialogClose();\n\n    this.handleLegacyDialogClose();\n  }\n\n  primaryActionClicked(): void {\n    if (this.config.primary?.handler) this.config.primary?.handler();\n    this.dialogRef.close();\n  }\n\n  private finalizeClose(): void {\n    this.dialogService.clearPageDialogCanClose(this.dialogRef);\n    this.dialogRef.close();\n  }\n\n  private confirmAndClose(): void {\n    this.dialog\n      .showCancelConfirmation(this.config)\n      .pipe(take(1))\n      .subscribe(confirmed => {\n        if (!confirmed) return;\n\n        this.config.cancel?.handler?.();\n        this.finalizeClose();\n      });\n  }\n\n  private handlePageDialogClose(): void {\n    this._pageDialogCanCloseFn!()\n      .pipe(take(1))\n      .subscribe(result => {\n        if (!result) return;\n        if (result.canClose) return this.runCancelHandlerAndClose();\n        if (!result.hasChanges) return;\n\n        this.confirmAndClose();\n      });\n  }\n\n  private handleLegacyDialogClose(): void {\n    if (!this.dialogChangeGuard.hasPendingChanges) return this.runCancelHandlerAndClose();\n\n    this.confirmAndClose();\n  }\n\n  private runCancelHandlerAndClose(): void {\n    this.config.cancel?.handler?.();\n    this.finalizeClose();\n  }\n\n  private bindEscToClose(): void {\n    this.dialogRef.keydownEvents\n      .pipe(\n        takeUntil(this._destroyed$),\n        filter((e: KeyboardEvent) => e.key === 'Escape')\n      )\n      .subscribe(e => {\n        e.preventDefault();\n        this.close();\n      });\n  }\n}\n","<div *ngIf=\"!isFullWidth\" class=\"dialog-header\">\n  <div class=\"title-container\">\n    {{ config?.title?.i18n | translate }}\n  </div>\n  <button\n    *ngIf=\"!config?.hideCloseHeaderButton\"\n    qdIconButton\n    class=\"close\"\n    color=\"secondary\"\n    tabindex=\"-1\"\n    (click)=\"close()\"\n  >\n    <qd-icon icon=\"timesLargeLight\"></qd-icon>\n  </button>\n</div>\n\n<button\n  *ngIf=\"!config?.hideCloseHeaderButton && isFullWidth\"\n  qdIconButton\n  class=\"close\"\n  color=\"secondary\"\n  tabindex=\"-1\"\n  (click)=\"close()\"\n>\n  <qd-icon icon=\"timesLargeLight\"></qd-icon>\n</button>\n\n<div class=\"wrapper-body\">\n  <div [class.has-dialog-info-banners]=\"hasInfoBanner\" #banners>\n    <ng-content select=\"qd-page-info-banner\"></ng-content>\n  </div>\n  <div class=\"body\" [class.full-width]=\"isFullWidth\" #body>\n    <ng-content></ng-content>\n  </div>\n</div>\n\n<div class=\"qd-dialog-actions\">\n  <button *ngIf=\"config.cancel\" qdButton qdButtonGhost color=\"secondary\" (click)=\"close()\">\n    {{ config?.cancel?.label?.i18n ?? \"i18n.qd.dialog.action.cancel\" | translate }}\n  </button>\n  <button *ngIf=\"config.primary\" qdButton (click)=\"primaryActionClicked()\">\n    {{ config?.primary?.label?.i18n ?? \"i18n.qd.dialog.action.primary\" | translate }}\n  </button>\n  <ng-content select=\"qd-dialog-action\"></ng-content>\n</div>\n"]}
@@ -21,10 +21,11 @@ import { QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN } from './models/confirmation.mod
21
21
  import { QdPageDialogWithBreadcrumbsComponent } from './page-dialog-with-breadcrumbs/page-dialog-with-breadcrumbs.component';
22
22
  import { QdCoreModule } from '../core/core.module';
23
23
  import { QdBreadcrumbsModule } from '../core/breadcrumbs/breadcrumbs.module';
24
- import { PendingChangesGuardDirective } from './directives/pending-changes-guard.directive';
24
+ import { QdPendingChangesGuardDirective } from './directives/pending-changes-guard.directive';
25
25
  import { QdCancelDialogComponent } from './cancel-confirmation-dialog/cancel-dialog.component';
26
+ import { QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST } from './models/page-dialog-host.token';
26
27
  import * as i0 from "@angular/core";
27
- export { QdDialogComponent, QdDialogActionComponent, QdDialogRecordStepperComponent, QdDialogAuthSessionEndComponent, QdDialogConfirmationComponent, QdDialogConfirmationErrorDirective, QdDialogConfirmationInfoDirective, QdDialogConfirmationSuccessDirective, QdDialogService, QdDialogAuthSessionEndService, QdDialogSize, PendingChangesGuardDirective, QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN };
28
+ export { QdDialogComponent, QdDialogActionComponent, QdDialogRecordStepperComponent, QdDialogAuthSessionEndComponent, QdDialogConfirmationComponent, QdDialogConfirmationErrorDirective, QdDialogConfirmationInfoDirective, QdDialogConfirmationSuccessDirective, QdDialogService, QdDialogAuthSessionEndService, QdDialogSize, QdPendingChangesGuardDirective, QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN };
28
29
  export class QdDialogModule {
29
30
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
30
31
  static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: QdDialogModule, declarations: [QdDialogActionComponent,
@@ -36,7 +37,7 @@ export class QdDialogModule {
36
37
  QdDialogConfirmationSuccessDirective,
37
38
  QdDialogRecordStepperComponent,
38
39
  QdPageDialogWithBreadcrumbsComponent,
39
- PendingChangesGuardDirective,
40
+ QdPendingChangesGuardDirective,
40
41
  QdCancelDialogComponent], imports: [CommonModule,
41
42
  TranslateModule,
42
43
  RouterModule,
@@ -55,8 +56,13 @@ export class QdDialogModule {
55
56
  QdDialogConfirmationErrorDirective,
56
57
  QdDialogConfirmationSuccessDirective,
57
58
  QdDialogRecordStepperComponent,
58
- PendingChangesGuardDirective] });
59
- static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogModule, imports: [CommonModule,
59
+ QdPendingChangesGuardDirective] });
60
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogModule, providers: [
61
+ {
62
+ provide: QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST,
63
+ useValue: QdPageDialogWithBreadcrumbsComponent
64
+ }
65
+ ], imports: [CommonModule,
60
66
  TranslateModule,
61
67
  RouterModule,
62
68
  CDKDialogModule,
@@ -96,7 +102,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
96
102
  QdDialogConfirmationSuccessDirective,
97
103
  QdDialogRecordStepperComponent,
98
104
  QdPageDialogWithBreadcrumbsComponent,
99
- PendingChangesGuardDirective,
105
+ QdPendingChangesGuardDirective,
100
106
  QdCancelDialogComponent
101
107
  ],
102
108
  exports: [
@@ -107,8 +113,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
107
113
  QdDialogConfirmationErrorDirective,
108
114
  QdDialogConfirmationSuccessDirective,
109
115
  QdDialogRecordStepperComponent,
110
- PendingChangesGuardDirective
116
+ QdPendingChangesGuardDirective
117
+ ],
118
+ providers: [
119
+ {
120
+ provide: QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST,
121
+ useValue: QdPageDialogWithBreadcrumbsComponent
122
+ }
111
123
  ]
112
124
  }]
113
125
  }] });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.module.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/dialog/dialog.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { DialogModule as CDKDialogModule } from '@angular/cdk/dialog';\nimport { TranslateModule } from '@ngx-translate/core';\n\nimport { QdButtonModule } from '../button/button.module';\nimport { QdIconModule } from '../icon/icon.module';\nimport { QdNotificationsModule } from '../notifications/notifications.module';\nimport { QdFormModule } from '../forms/qd-form.module';\nimport { QdTextSectionModule } from '../text-section/text-section.module';\nimport { QdSpinnerModule } from '../spinner/spinner.module';\n\nimport { QdDialogActionComponent } from './action/dialog-action.component';\nimport { QdDialogComponent } from './dialog.component';\nimport { QdDialogConfig, QdDialogSize, QdDialogTitle } from './models/dialog-config.model';\nimport { QdDialogService } from './services/dialog.service';\nimport { QdDialogAuthSessionEndService } from './services/dialog-auth-session-end.service';\nimport { QdDialogRecordStepperComponent } from './record-stepper/dialog-record-stepper.component';\nimport {\n  QdDialogConfirmationComponent,\n  QdDialogConfirmationErrorDirective,\n  QdDialogConfirmationInfoDirective,\n  QdDialogConfirmationSuccessDirective\n} from './confirmation/dialog-confirmation.component';\nimport { QdDialogAuthSessionEndComponent } from './auth-session-end/dialog-auth-session-end.component';\nimport {\n  QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN,\n  QdDialogConfirmationConfig,\n  QdDialogConfirmationResolver\n} from './models/confirmation.model';\nimport { QdDialogData } from './models/record-stepper.model';\nimport { QdDialogAuthSessionEndResult } from './models/session-end-result.model';\nimport { QdPageDialogWithBreadcrumbsComponent } from './page-dialog-with-breadcrumbs/page-dialog-with-breadcrumbs.component';\nimport { QdCoreModule } from '../core/core.module';\nimport { QdBreadcrumbsModule } from '../core/breadcrumbs/breadcrumbs.module';\nimport { PendingChangesGuardDirective } from './directives/pending-changes-guard.directive';\nimport { QdCancelDialogComponent } from './cancel-confirmation-dialog/cancel-dialog.component';\n\nexport {\n  QdDialogComponent,\n  QdDialogActionComponent,\n  QdDialogRecordStepperComponent,\n  QdDialogAuthSessionEndComponent,\n  QdDialogConfirmationComponent,\n  QdDialogConfirmationErrorDirective,\n  QdDialogConfirmationInfoDirective,\n  QdDialogConfirmationSuccessDirective,\n  QdDialogService,\n  QdDialogAuthSessionEndService,\n  QdDialogConfig,\n  QdDialogTitle,\n  QdDialogSize,\n  QdDialogData,\n  QdDialogAuthSessionEndResult,\n  QdDialogConfirmationConfig,\n  QdDialogConfirmationResolver,\n  PendingChangesGuardDirective,\n  QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN\n};\n\n@NgModule({\n  imports: [\n    CommonModule,\n    TranslateModule,\n    RouterModule,\n    CDKDialogModule,\n    QdButtonModule,\n    QdFormModule,\n    QdIconModule,\n    QdNotificationsModule,\n    QdSpinnerModule,\n    QdTextSectionModule,\n    QdCoreModule,\n    QdBreadcrumbsModule\n  ],\n  declarations: [\n    QdDialogActionComponent,\n    QdDialogAuthSessionEndComponent,\n    QdDialogComponent,\n    QdDialogConfirmationComponent,\n    QdDialogConfirmationErrorDirective,\n    QdDialogConfirmationInfoDirective,\n    QdDialogConfirmationSuccessDirective,\n    QdDialogRecordStepperComponent,\n    QdPageDialogWithBreadcrumbsComponent,\n    PendingChangesGuardDirective,\n    QdCancelDialogComponent\n  ],\n  exports: [\n    QdDialogActionComponent,\n    QdDialogAuthSessionEndComponent,\n    QdDialogComponent,\n    QdDialogConfirmationComponent,\n    QdDialogConfirmationErrorDirective,\n    QdDialogConfirmationSuccessDirective,\n    QdDialogRecordStepperComponent,\n    PendingChangesGuardDirective\n  ]\n})\nexport class QdDialogModule {}\n"]}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.module.js","sourceRoot":"","sources":["../../../../../libs/qd-ui/src/lib/dialog/dialog.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { RouterModule } from '@angular/router';\nimport { DialogModule as CDKDialogModule } from '@angular/cdk/dialog';\nimport { TranslateModule } from '@ngx-translate/core';\n\nimport { QdButtonModule } from '../button/button.module';\nimport { QdIconModule } from '../icon/icon.module';\nimport { QdNotificationsModule } from '../notifications/notifications.module';\nimport { QdFormModule } from '../forms/qd-form.module';\nimport { QdTextSectionModule } from '../text-section/text-section.module';\nimport { QdSpinnerModule } from '../spinner/spinner.module';\n\nimport { QdDialogActionComponent } from './action/dialog-action.component';\nimport { QdDialogComponent } from './dialog.component';\nimport { QdDialogConfig, QdDialogSize, QdDialogTitle } from './models/dialog-config.model';\nimport { QdDialogService } from './services/dialog.service';\nimport { QdDialogAuthSessionEndService } from './services/dialog-auth-session-end.service';\nimport { QdDialogRecordStepperComponent } from './record-stepper/dialog-record-stepper.component';\nimport {\n  QdDialogConfirmationComponent,\n  QdDialogConfirmationErrorDirective,\n  QdDialogConfirmationInfoDirective,\n  QdDialogConfirmationSuccessDirective\n} from './confirmation/dialog-confirmation.component';\nimport { QdDialogAuthSessionEndComponent } from './auth-session-end/dialog-auth-session-end.component';\nimport {\n  QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN,\n  QdDialogConfirmationConfig,\n  QdDialogConfirmationResolver\n} from './models/confirmation.model';\nimport { QdDialogData } from './models/record-stepper.model';\nimport { QdDialogAuthSessionEndResult } from './models/session-end-result.model';\nimport { QdPageDialogWithBreadcrumbsComponent } from './page-dialog-with-breadcrumbs/page-dialog-with-breadcrumbs.component';\nimport { QdCoreModule } from '../core/core.module';\nimport { QdBreadcrumbsModule } from '../core/breadcrumbs/breadcrumbs.module';\nimport { QdPendingChangesGuardDirective } from './directives/pending-changes-guard.directive';\nimport { QdCancelDialogComponent } from './cancel-confirmation-dialog/cancel-dialog.component';\nimport { QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST } from './models/page-dialog-host.token';\n\nexport {\n  QdDialogComponent,\n  QdDialogActionComponent,\n  QdDialogRecordStepperComponent,\n  QdDialogAuthSessionEndComponent,\n  QdDialogConfirmationComponent,\n  QdDialogConfirmationErrorDirective,\n  QdDialogConfirmationInfoDirective,\n  QdDialogConfirmationSuccessDirective,\n  QdDialogService,\n  QdDialogAuthSessionEndService,\n  QdDialogConfig,\n  QdDialogTitle,\n  QdDialogSize,\n  QdDialogData,\n  QdDialogAuthSessionEndResult,\n  QdDialogConfirmationConfig,\n  QdDialogConfirmationResolver,\n  QdPendingChangesGuardDirective,\n  QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN\n};\n\n@NgModule({\n  imports: [\n    CommonModule,\n    TranslateModule,\n    RouterModule,\n    CDKDialogModule,\n    QdButtonModule,\n    QdFormModule,\n    QdIconModule,\n    QdNotificationsModule,\n    QdSpinnerModule,\n    QdTextSectionModule,\n    QdCoreModule,\n    QdBreadcrumbsModule\n  ],\n  declarations: [\n    QdDialogActionComponent,\n    QdDialogAuthSessionEndComponent,\n    QdDialogComponent,\n    QdDialogConfirmationComponent,\n    QdDialogConfirmationErrorDirective,\n    QdDialogConfirmationInfoDirective,\n    QdDialogConfirmationSuccessDirective,\n    QdDialogRecordStepperComponent,\n    QdPageDialogWithBreadcrumbsComponent,\n    QdPendingChangesGuardDirective,\n    QdCancelDialogComponent\n  ],\n  exports: [\n    QdDialogActionComponent,\n    QdDialogAuthSessionEndComponent,\n    QdDialogComponent,\n    QdDialogConfirmationComponent,\n    QdDialogConfirmationErrorDirective,\n    QdDialogConfirmationSuccessDirective,\n    QdDialogRecordStepperComponent,\n    QdPendingChangesGuardDirective\n  ],\n  providers: [\n    {\n      provide: QD_PAGE_DIALOG_WITH_BREADCRUMBS_HOST,\n      useValue: QdPageDialogWithBreadcrumbsComponent\n    }\n  ]\n})\nexport class QdDialogModule {}\n"]}