@quadrel-enterprise-ui/framework 18.28.0 → 18.29.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/comments/add-comment/add-comment-dialog.component.mjs +3 -3
- package/esm2022/lib/dialog/action/dialog-action.component.mjs +2 -2
- package/esm2022/lib/dialog/cancel-confirmation-dialog/cancel-dialog.component.mjs +40 -0
- package/esm2022/lib/dialog/dialog.component.mjs +57 -12
- package/esm2022/lib/dialog/dialog.module.mjs +14 -6
- package/esm2022/lib/dialog/directives/pending-changes-guard.directive.mjs +78 -0
- package/esm2022/lib/dialog/models/dialog-config.model.mjs +1 -1
- package/esm2022/lib/dialog/services/confirmation-dialog.service.mjs +36 -0
- package/esm2022/lib/dialog/services/dialog-change-guard.service.mjs +20 -0
- package/fesm2022/quadrel-enterprise-ui-framework.mjs +214 -18
- package/fesm2022/quadrel-enterprise-ui-framework.mjs.map +1 -1
- package/lib/dialog/cancel-confirmation-dialog/cancel-dialog.component.d.ts +14 -0
- package/lib/dialog/dialog.component.d.ts +21 -5
- package/lib/dialog/dialog.module.d.ts +17 -14
- package/lib/dialog/directives/pending-changes-guard.directive.d.ts +35 -0
- package/lib/dialog/models/dialog-config.model.d.ts +53 -0
- package/lib/dialog/services/confirmation-dialog.service.d.ts +13 -0
- package/lib/dialog/services/dialog-change-guard.service.d.ts +8 -0
- package/package.json +1 -1
|
@@ -124,15 +124,15 @@ export class AddCommentDialogComponent {
|
|
|
124
124
|
};
|
|
125
125
|
}
|
|
126
126
|
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
|
|
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 });
|
|
128
128
|
}
|
|
129
129
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AddCommentDialogComponent, decorators: [{
|
|
130
130
|
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
|
|
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"] }]
|
|
132
132
|
}], ctorParameters: () => [{ type: i1.DialogRef }, { type: undefined, decorators: [{
|
|
133
133
|
type: Optional
|
|
134
134
|
}, {
|
|
135
135
|
type: Inject,
|
|
136
136
|
args: ['QdAuthenticationService']
|
|
137
137
|
}] }] });
|
|
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 *ngIf=\"customInputConfig\" [config]=\"customInputConfig\" [formControlName]=\"'custom'\"\n                 [attr.data-test-id]=\"'comment-custom'\"></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 *ngFor=\"let errorKey of objectKeys(errors)\" [attr.data-test-id]=\"'comment-validation-' + errorKey\"\n           class=\"validation-message\">\n        {{ errors[errorKey] | translate }}\n      </div>\n    </div>\n\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 [disabled]=\"!commentText.value || commentText.hasError\"\n        qdButton (click)=\"close('Yes')\" [data-test-id]=\"'button-submit'\">\n        {{ \"i18n.qd.comments.add.dialog.submit\" | translate }}\n      </button>\n    </qd-dialog-action>\n  </form>\n</qd-dialog>\n"]}
|
|
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"]}
|
|
@@ -2,10 +2,10 @@ import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class QdDialogActionComponent {
|
|
4
4
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogActionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
5
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdDialogActionComponent, selector: "qd-dialog-action", ngImport: i0, template: "<ng-content></ng-content>\n", styles: [":host{display:flex;
|
|
5
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdDialogActionComponent, selector: "qd-dialog-action", ngImport: i0, template: "<ng-content></ng-content>\n", styles: [":host{display:flex;column-gap:.625rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
6
6
|
}
|
|
7
7
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogActionComponent, decorators: [{
|
|
8
8
|
type: Component,
|
|
9
|
-
args: [{ selector: 'qd-dialog-action', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n", styles: [":host{display:flex;
|
|
9
|
+
args: [{ selector: 'qd-dialog-action', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n", styles: [":host{display:flex;column-gap:.625rem}\n"] }]
|
|
10
10
|
}] });
|
|
11
11
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWFjdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3FkLXVpL3NyYy9saWIvZGlhbG9nL2FjdGlvbi9kaWFsb2ctYWN0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9kaWFsb2cvYWN0aW9uL2RpYWxvZy1hY3Rpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFRbkUsTUFBTSxPQUFPLHVCQUF1Qjt1R0FBdkIsdUJBQXVCOzJGQUF2Qix1QkFBdUIsd0RDUnBDLDZCQUNBOzsyRkRPYSx1QkFBdUI7a0JBTm5DLFNBQVM7K0JBQ0Usa0JBQWtCLG1CQUdYLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3FkLWRpYWxvZy1hY3Rpb24nLFxuICB0ZW1wbGF0ZVVybDogJy4vZGlhbG9nLWFjdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2RpYWxvZy1hY3Rpb24uY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgUWREaWFsb2dBY3Rpb25Db21wb25lbnQge31cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { DialogRef } from '@angular/cdk/dialog';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/cdk/dialog";
|
|
5
|
+
import * as i2 from "../../button/button/button.component";
|
|
6
|
+
import * as i3 from "../../button/directives/button.directives";
|
|
7
|
+
import * as i4 from "../../text-section/text-section.component";
|
|
8
|
+
import * as i5 from "../../text-section/text-section-paragraph/text-section-paragraph.component";
|
|
9
|
+
import * as i6 from "../action/dialog-action.component";
|
|
10
|
+
import * as i7 from "../dialog.component";
|
|
11
|
+
import * as i8 from "@ngx-translate/core";
|
|
12
|
+
export class QdCancelDialogComponent {
|
|
13
|
+
dialogRef;
|
|
14
|
+
i18n;
|
|
15
|
+
handler;
|
|
16
|
+
constructor(dialogRef) {
|
|
17
|
+
this.dialogRef = dialogRef;
|
|
18
|
+
}
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
this.i18n =
|
|
21
|
+
this.dialogRef.config.data?.cancel?.confirmationMessage?.i18n ??
|
|
22
|
+
'i18n.qd.page.cancel.confirmation.dialog.message';
|
|
23
|
+
this.handler = this.dialogRef.config.data?.cancel?.handler;
|
|
24
|
+
}
|
|
25
|
+
close() {
|
|
26
|
+
this.dialogRef.close(false);
|
|
27
|
+
}
|
|
28
|
+
confirm() {
|
|
29
|
+
if (this.handler)
|
|
30
|
+
this.handler();
|
|
31
|
+
this.dialogRef.close(true);
|
|
32
|
+
}
|
|
33
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdCancelDialogComponent, deps: [{ token: i1.DialogRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
34
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdCancelDialogComponent, selector: "qd-cancel-dialog", ngImport: i0, template: "<qd-dialog>\n <qd-text-section>\n <qd-text-section-paragraph>\n {{ i18n | translate }}\n </qd-text-section-paragraph>\n </qd-text-section>\n\n <qd-dialog-action>\n <button\n qdButton\n qdButtonGhost\n color=\"secondary\"\n (click)=\"close()\"\n data-test-id=\"dialog-cancel-confirmation-dialog-close\"\n >\n {{ \"i18n.qd.page.cancel.confirmation.dialog.close\" | translate }}\n </button>\n\n <button qdButton color=\"error\" (click)=\"confirm()\" data-test-id=\"dialog-cancel-confirmation-dialog-proceed\">\n {{ \"i18n.qd.page.cancel.confirmation.dialog.proceed\" | translate }}\n </button>\n </qd-dialog-action>\n</qd-dialog>\n", dependencies: [{ kind: "component", type: i2.QdButtonComponent, selector: "button[qdButton], a[qdButton], button[qd-button]", inputs: ["disabled", "color", "icon", "data-test-id", "additionalInfo"] }, { kind: "directive", type: i3.QdButtonGhostDirective, selector: "button[qdButtonGhost], a[qdButtonGhost]" }, { kind: "component", type: i4.QdTextSectionComponent, selector: "qd-text-section" }, { kind: "component", type: i5.QdTextSectionParagraphComponent, selector: "qd-text-section-paragraph" }, { kind: "component", type: i6.QdDialogActionComponent, selector: "qd-dialog-action" }, { kind: "component", type: i7.QdDialogComponent, selector: "qd-dialog" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] });
|
|
35
|
+
}
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdCancelDialogComponent, decorators: [{
|
|
37
|
+
type: Component,
|
|
38
|
+
args: [{ selector: 'qd-cancel-dialog', standalone: false, template: "<qd-dialog>\n <qd-text-section>\n <qd-text-section-paragraph>\n {{ i18n | translate }}\n </qd-text-section-paragraph>\n </qd-text-section>\n\n <qd-dialog-action>\n <button\n qdButton\n qdButtonGhost\n color=\"secondary\"\n (click)=\"close()\"\n data-test-id=\"dialog-cancel-confirmation-dialog-close\"\n >\n {{ \"i18n.qd.page.cancel.confirmation.dialog.close\" | translate }}\n </button>\n\n <button qdButton color=\"error\" (click)=\"confirm()\" data-test-id=\"dialog-cancel-confirmation-dialog-proceed\">\n {{ \"i18n.qd.page.cancel.confirmation.dialog.proceed\" | translate }}\n </button>\n </qd-dialog-action>\n</qd-dialog>\n" }]
|
|
39
|
+
}], ctorParameters: () => [{ type: i1.DialogRef }] });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FuY2VsLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3FkLXVpL3NyYy9saWIvZGlhbG9nL2NhbmNlbC1jb25maXJtYXRpb24tZGlhbG9nL2NhbmNlbC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9xZC11aS9zcmMvbGliL2RpYWxvZy9jYW5jZWwtY29uZmlybWF0aW9uLWRpYWxvZy9jYW5jZWwtZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHFCQUFxQixDQUFDOzs7Ozs7Ozs7O0FBT2hELE1BQU0sT0FBTyx1QkFBdUI7SUFJZDtJQUhwQixJQUFJLENBQVU7SUFDZCxPQUFPLENBQWM7SUFFckIsWUFBb0IsU0FBeUI7UUFBekIsY0FBUyxHQUFULFNBQVMsQ0FBZ0I7SUFBRyxDQUFDO0lBRWpELFFBQVE7UUFDTixJQUFJLENBQUMsSUFBSTtZQUNQLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUUsbUJBQW1CLEVBQUUsSUFBSTtnQkFDN0QsaURBQWlELENBQUM7UUFDcEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFLE9BQU8sQ0FBQztJQUM3RCxDQUFDO0lBRUQsS0FBSztRQUNILElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxJQUFJLENBQUMsT0FBTztZQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNqQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM3QixDQUFDO3VHQXBCVSx1QkFBdUI7MkZBQXZCLHVCQUF1Qix3RENScEMsdXJCQXVCQTs7MkZEZmEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLGtCQUFrQixjQUVoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kaWFsb2cnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdxZC1jYW5jZWwtZGlhbG9nJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NhbmNlbC1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdGFuZGFsb25lOiBmYWxzZVxufSlcbmV4cG9ydCBjbGFzcyBRZENhbmNlbERpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIGkxOG4hOiBzdHJpbmc7XG4gIGhhbmRsZXIhOiAoKSA9PiB2b2lkO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZGlhbG9nUmVmOiBEaWFsb2dSZWY8YW55Pikge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmkxOG4gPVxuICAgICAgdGhpcy5kaWFsb2dSZWYuY29uZmlnLmRhdGE/LmNhbmNlbD8uY29uZmlybWF0aW9uTWVzc2FnZT8uaTE4biA/P1xuICAgICAgJ2kxOG4ucWQucGFnZS5jYW5jZWwuY29uZmlybWF0aW9uLmRpYWxvZy5tZXNzYWdlJztcbiAgICB0aGlzLmhhbmRsZXIgPSB0aGlzLmRpYWxvZ1JlZi5jb25maWcuZGF0YT8uY2FuY2VsPy5oYW5kbGVyO1xuICB9XG5cbiAgY2xvc2UoKTogdm9pZCB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoZmFsc2UpO1xuICB9XG5cbiAgY29uZmlybSgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5oYW5kbGVyKSB0aGlzLmhhbmRsZXIoKTtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSh0cnVlKTtcbiAgfVxufVxuIiwiPHFkLWRpYWxvZz5cbiAgPHFkLXRleHQtc2VjdGlvbj5cbiAgICA8cWQtdGV4dC1zZWN0aW9uLXBhcmFncmFwaD5cbiAgICAgIHt7IGkxOG4gfCB0cmFuc2xhdGUgfX1cbiAgICA8L3FkLXRleHQtc2VjdGlvbi1wYXJhZ3JhcGg+XG4gIDwvcWQtdGV4dC1zZWN0aW9uPlxuXG4gIDxxZC1kaWFsb2ctYWN0aW9uPlxuICAgIDxidXR0b25cbiAgICAgIHFkQnV0dG9uXG4gICAgICBxZEJ1dHRvbkdob3N0XG4gICAgICBjb2xvcj1cInNlY29uZGFyeVwiXG4gICAgICAoY2xpY2spPVwiY2xvc2UoKVwiXG4gICAgICBkYXRhLXRlc3QtaWQ9XCJkaWFsb2ctY2FuY2VsLWNvbmZpcm1hdGlvbi1kaWFsb2ctY2xvc2VcIlxuICAgID5cbiAgICAgIHt7IFwiaTE4bi5xZC5wYWdlLmNhbmNlbC5jb25maXJtYXRpb24uZGlhbG9nLmNsb3NlXCIgfCB0cmFuc2xhdGUgfX1cbiAgICA8L2J1dHRvbj5cblxuICAgIDxidXR0b24gcWRCdXR0b24gY29sb3I9XCJlcnJvclwiIChjbGljayk9XCJjb25maXJtKClcIiBkYXRhLXRlc3QtaWQ9XCJkaWFsb2ctY2FuY2VsLWNvbmZpcm1hdGlvbi1kaWFsb2ctcHJvY2VlZFwiPlxuICAgICAge3sgXCJpMThuLnFkLnBhZ2UuY2FuY2VsLmNvbmZpcm1hdGlvbi5kaWFsb2cucHJvY2VlZFwiIHwgdHJhbnNsYXRlIH19XG4gICAgPC9idXR0b24+XG4gIDwvcWQtZGlhbG9nLWFjdGlvbj5cbjwvcWQtZGlhbG9nPlxuIl19
|
|
@@ -2,16 +2,23 @@
|
|
|
2
2
|
import { ChangeDetectorRef, Component, ElementRef, HostBinding, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import { DialogRef } from '@angular/cdk/dialog';
|
|
4
4
|
import { QdDialogSize } from './models/dialog-config.model';
|
|
5
|
+
import { QdDialogChangeGuardService } from './services/dialog-change-guard.service';
|
|
6
|
+
import { Subject } from 'rxjs';
|
|
7
|
+
import { takeUntil } from 'rxjs/operators';
|
|
8
|
+
import { QdConfirmationDialogOpenerService } from './services/confirmation-dialog.service';
|
|
5
9
|
import * as i0 from "@angular/core";
|
|
6
10
|
import * as i1 from "@angular/cdk/dialog";
|
|
7
|
-
import * as i2 from "
|
|
8
|
-
import * as i3 from "
|
|
9
|
-
import * as i4 from "
|
|
10
|
-
import * as i5 from "
|
|
11
|
+
import * as i2 from "./services/confirmation-dialog.service";
|
|
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";
|
|
11
19
|
/**
|
|
12
20
|
* **QdDialog** creating resonsive dialogs. Three different sizes are available.
|
|
13
21
|
*
|
|
14
|
-
* Detailed migration guideline from QdModal to QdDialog: https://confluence.bit.admin.ch/display/DAZUIC/Migration+Dialoge
|
|
15
22
|
*
|
|
16
23
|
* * @see child component: **QdDialogAction**.
|
|
17
24
|
*
|
|
@@ -45,10 +52,22 @@ import * as i5 from "@ngx-translate/core";
|
|
|
45
52
|
* <button qdButton (click)="close('Yes')">Submit</button>
|
|
46
53
|
* </qd-dialog-action>
|
|
47
54
|
* </qd-dialog>
|
|
48
|
-
|
|
55
|
+
*
|
|
56
|
+
* **Example of MyModalComponent (Including Form Change Guard):**
|
|
57
|
+
*
|
|
58
|
+
* @example
|
|
59
|
+
* <qd-dialog>
|
|
60
|
+
* <form [formGroup]="myForm" qdPendingChangesGuard>
|
|
61
|
+
* <input type="text" formControlName="name">
|
|
62
|
+
* You have unsaved changes!
|
|
63
|
+
* </form>
|
|
64
|
+
* </qd-dialog>
|
|
65
|
+
* */
|
|
49
66
|
export class QdDialogComponent {
|
|
50
67
|
dialogRef;
|
|
68
|
+
dialog;
|
|
51
69
|
changeDetectorRef;
|
|
70
|
+
dialogChangeGuard;
|
|
52
71
|
body;
|
|
53
72
|
infoBanners;
|
|
54
73
|
get hasSectionsClass() {
|
|
@@ -57,9 +76,12 @@ export class QdDialogComponent {
|
|
|
57
76
|
config;
|
|
58
77
|
hasSections;
|
|
59
78
|
hasInfoBanner;
|
|
60
|
-
|
|
79
|
+
_destroyed$ = new Subject();
|
|
80
|
+
constructor(dialogRef, dialog, changeDetectorRef, dialogChangeGuard) {
|
|
61
81
|
this.dialogRef = dialogRef;
|
|
82
|
+
this.dialog = dialog;
|
|
62
83
|
this.changeDetectorRef = changeDetectorRef;
|
|
84
|
+
this.dialogChangeGuard = dialogChangeGuard;
|
|
63
85
|
}
|
|
64
86
|
ngOnInit() {
|
|
65
87
|
this.config = this.dialogRef.config;
|
|
@@ -76,18 +98,41 @@ export class QdDialogComponent {
|
|
|
76
98
|
this.changeDetectorRef.detectChanges();
|
|
77
99
|
}
|
|
78
100
|
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
|
+
}
|
|
116
|
+
}
|
|
117
|
+
primaryActionClicked() {
|
|
118
|
+
if (this.config.primary?.handler)
|
|
119
|
+
this.config.primary?.handler();
|
|
79
120
|
this.dialogRef.close();
|
|
80
121
|
}
|
|
122
|
+
ngOnDestroy() {
|
|
123
|
+
this._destroyed$.next();
|
|
124
|
+
this._destroyed$.complete();
|
|
125
|
+
}
|
|
81
126
|
get isFullWidth() {
|
|
82
127
|
return this.config.dialogSize === QdDialogSize.FullWidth;
|
|
83
128
|
}
|
|
84
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogComponent, deps: [{ token: i1.DialogRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
85
|
-
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<ng-content select=\"qd-dialog-action\"></ng-content>\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}\n"], dependencies: [{ kind: "directive", type:
|
|
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 });
|
|
86
131
|
}
|
|
87
132
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogComponent, decorators: [{
|
|
88
133
|
type: Component,
|
|
89
|
-
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<ng-content select=\"qd-dialog-action\"></ng-content>\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}\n"] }]
|
|
90
|
-
}], ctorParameters: () => [{ type: i1.DialogRef }, { type: i0.ChangeDetectorRef }], propDecorators: { body: [{
|
|
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: [{
|
|
91
136
|
type: ViewChild,
|
|
92
137
|
args: ['body']
|
|
93
138
|
}], infoBanners: [{
|
|
@@ -97,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
97
142
|
type: HostBinding,
|
|
98
143
|
args: ['class.has-sections']
|
|
99
144
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9kaWFsb2cvZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9kaWFsb2cvZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG9CQUFvQjtBQUNwQixPQUFPLEVBR0wsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsV0FBVyxFQUVYLFNBQVMsRUFDVCxpQkFBaUIsRUFDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2hELE9BQU8sRUFBa0IsWUFBWSxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7Ozs7QUFFNUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FxQ0c7QUFTSCxNQUFNLE9BQU8saUJBQWlCO0lBWVQ7SUFBc0M7SUFYdEMsSUFBSSxDQUFhO0lBQ2QsV0FBVyxDQUFhO0lBRTlDLElBQXVDLGdCQUFnQjtRQUNyRCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDMUIsQ0FBQztJQUVELE1BQU0sQ0FBaUI7SUFDdkIsV0FBVyxDQUFVO0lBQ3JCLGFBQWEsQ0FBVTtJQUV2QixZQUFtQixTQUE0QixFQUFVLGlCQUFvQztRQUExRSxjQUFTLEdBQVQsU0FBUyxDQUFtQjtRQUFVLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7SUFBRyxDQUFDO0lBRWpHLFFBQVE7UUFDTixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDO0lBQ3RDLENBQUM7SUFFRCxxQkFBcUI7UUFDbkIsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLGFBQWEsRUFBRSxVQUFVLElBQUksRUFBRSxDQUFDLENBQUM7UUFDeEUsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBaUIsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sS0FBSyxZQUFZLENBQUMsQ0FBQztRQUMvRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDekMsQ0FBQztJQUVELGVBQWU7UUFDYixNQUFNLGNBQWMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsYUFBYSxFQUFFLFVBQVUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNyRixJQUFJLENBQUMsYUFBYTtZQUNoQixjQUFjLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBaUIsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sS0FBSyxxQkFBcUIsQ0FBQyxDQUFDO1FBQ2xILElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUN6QyxDQUFDO0lBRUQsS0FBSztRQUNILElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEtBQUssWUFBWSxDQUFDLFNBQVMsQ0FBQztJQUMzRCxDQUFDO3VHQXJDVSxpQkFBaUI7MkZBQWpCLGlCQUFpQixnSkFGakIsQ0FBQyxpQkFBaUIsQ0FBQyxpTkMzRGhDLGc4QkFvQ0E7OzJGRHlCYSxpQkFBaUI7a0JBUjdCLFNBQVM7K0JBQ0UsV0FBVyxRQUVmLEVBQUUsb0JBQW9CLEVBQUUsYUFBYSxFQUFFLGlCQUU5QixpQkFBaUIsQ0FBQyxJQUFJLGFBQzFCLG1CQUFtQjs4R0FHWCxJQUFJO3NCQUF0QixTQUFTO3VCQUFDLE1BQU07Z0JBQ0ssV0FBVztzQkFBaEMsU0FBUzt1QkFBQyxTQUFTO2dCQUVtQixnQkFBZ0I7c0JBQXRELFdBQVc7dUJBQUMsb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLXN0cmljdC1pZ25vcmVcbmltcG9ydCB7XG4gIEFmdGVyQ29udGVudENoZWNrZWQsXG4gIEFmdGVyVmlld0luaXQsXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEhvc3RCaW5kaW5nLFxuICBPbkluaXQsXG4gIFZpZXdDaGlsZCxcbiAgVmlld0VuY2Fwc3VsYXRpb25cbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEaWFsb2dSZWYgfSBmcm9tICdAYW5ndWxhci9jZGsvZGlhbG9nJztcbmltcG9ydCB7IFFkRGlhbG9nQ29uZmlnLCBRZERpYWxvZ1NpemUgfSBmcm9tICcuL21vZGVscy9kaWFsb2ctY29uZmlnLm1vZGVsJztcblxuLyoqXG4gKiAqKlFkRGlhbG9nKiogY3JlYXRpbmcgcmVzb25zaXZlIGRpYWxvZ3MuIFRocmVlIGRpZmZlcmVudCBzaXplcyBhcmUgYXZhaWxhYmxlLlxuICpcbiAqIERldGFpbGVkIG1pZ3JhdGlvbiBndWlkZWxpbmUgZnJvbSBRZE1vZGFsIHRvIFFkRGlhbG9nOiBodHRwczovL2NvbmZsdWVuY2UuYml0LmFkbWluLmNoL2Rpc3BsYXkvREFaVUlDL01pZ3JhdGlvbitEaWFsb2dlXG4gKlxuICogKiBAc2VlIGNoaWxkIGNvbXBvbmVudDogKipRZERpYWxvZ0FjdGlvbioqLlxuICpcbiAqICoqVXNhZ2U6KipcbiAqXG4gKiBAZXhhbXBsZVxuICogaW1wb3J0IHsgUWREaWFsb2dTZXJ2aWNlIH0gZnJvbSAnQHF1YWRyZWwtdWkvcWQtdWknO1xuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCBjb25maWc6IFFkRGlhbG9nQ29uZmlnID0ge1xuICogICB0aXRsZToge1xuICogICAgICBpMThuOiBcImkxOC5teS5tb2RhbC50aXRsZVwiLFxuICogICB9LFxuICogICBkaWFsb2dTaXplOiBRZERpYWxvZ1NpemUuRGVmYXVsdCxcbiAqICAgaGlkZUNsb3NlSGVhZGVyQnV0dG9uOiBmYWxzZVxuICogICBkYXRhOiBteURhdGEgLy8gQVBJIHRvIHByb3ZpZGUgZGF0YSB0byB0aGUgZGlhbG9nXG4gKiB9XG4gKlxuICogQGV4YW1wbGVcbiAqIHRoaXMuZGlhbG9nU2VydmljZS5vcGVuKE15TW9kYWxDb21wb25lbnQsIGNvbmZpZyk7XG4gKlxuICogKipFeGFtcGxlIG9mIE15TW9kYWxDb21wb25lbnQ6KipcbiAqXG4gKiBAZXhhbXBsZVxuICogPHFkLWRpYWxvZz5cbiAqICAgICA8IS0tIERpYWxvZyBDb250ZW50IFNUQVJULS0+XG4gKiAgICAgLi4uXG4gKiAgICAgPCEtLSBEaWFsb2cgQ29udGVudCBFTkRFLS0+XG4gKiAgICAgPHFkLWRpYWxvZy1hY3Rpb24+XG4gKiAgICAgICAgIDxidXR0b24gcWRCdXR0b24gY29sb3I9XCJzZWNvbmRhcnlcIiAoY2xpY2spPVwiY2xvc2UoKVwiPkNhbmNlbDwvYnV0dG9uPlxuICogICAgICAgICA8YnV0dG9uIHFkQnV0dG9uIChjbGljayk9XCJjbG9zZSgnWWVzJylcIj5TdWJtaXQ8L2J1dHRvbj5cbiAqICAgICA8L3FkLWRpYWxvZy1hY3Rpb24+XG4gKiA8L3FkLWRpYWxvZz5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncWQtZGlhbG9nJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gIGhvc3Q6IHsgJ1tjbGFzcy5mdWxsLXdpZHRoXSc6ICdpc0Z1bGxXaWR0aCcgfSxcbiAgc3R5bGVVcmxzOiBbJy4vZGlhbG9nLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIHByb3ZpZGVyczogW1FkRGlhbG9nQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBRZERpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJDb250ZW50Q2hlY2tlZCwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBWaWV3Q2hpbGQoJ2JvZHknKSBib2R5OiBFbGVtZW50UmVmO1xuICBAVmlld0NoaWxkKCdiYW5uZXJzJykgaW5mb0Jhbm5lcnM6IEVsZW1lbnRSZWY7XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5oYXMtc2VjdGlvbnMnKSBnZXQgaGFzU2VjdGlvbnNDbGFzcygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5oYXNTZWN0aW9ucztcbiAgfVxuXG4gIGNvbmZpZzogUWREaWFsb2dDb25maWc7XG4gIGhhc1NlY3Rpb25zOiBib29sZWFuO1xuICBoYXNJbmZvQmFubmVyOiBib29sZWFuO1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBkaWFsb2dSZWY6IERpYWxvZ1JlZjxzdHJpbmc+LCBwcml2YXRlIGNoYW5nZURldGVjdG9yUmVmOiBDaGFuZ2VEZXRlY3RvclJlZikge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmNvbmZpZyA9IHRoaXMuZGlhbG9nUmVmLmNvbmZpZztcbiAgfVxuXG4gIG5nQWZ0ZXJDb250ZW50Q2hlY2tlZCgpOiB2b2lkIHtcbiAgICBjb25zdCBjaGlsZHJlbiA9IEFycmF5LmZyb20odGhpcy5ib2R5Py5uYXRpdmVFbGVtZW50Py5jaGlsZE5vZGVzIHx8IFtdKTtcbiAgICB0aGlzLmhhc1NlY3Rpb25zID0gY2hpbGRyZW4ubGVuZ3RoID4gMCAmJiBjaGlsZHJlbi5ldmVyeSgobm9kZTogSFRNTEVsZW1lbnQpID0+IG5vZGUudGFnTmFtZSA9PT0gJ1FELVNFQ1RJT04nKTtcbiAgICB0aGlzLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICBjb25zdCBiYW5uZXJDaGlsZHJlbiA9IEFycmF5LmZyb20odGhpcy5pbmZvQmFubmVycz8ubmF0aXZlRWxlbWVudD8uY2hpbGROb2RlcyB8fCBbXSk7XG4gICAgdGhpcy5oYXNJbmZvQmFubmVyID1cbiAgICAgIGJhbm5lckNoaWxkcmVuLmxlbmd0aCA+IDAgJiYgYmFubmVyQ2hpbGRyZW4uc29tZSgobm9kZTogSFRNTEVsZW1lbnQpID0+IG5vZGUudGFnTmFtZSA9PT0gJ1FELVBBR0UtSU5GTy1CQU5ORVInKTtcbiAgICB0aGlzLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIGNsb3NlKCk6IHZvaWQge1xuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKCk7XG4gIH1cblxuICBnZXQgaXNGdWxsV2lkdGgoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnLmRpYWxvZ1NpemUgPT09IFFkRGlhbG9nU2l6ZS5GdWxsV2lkdGg7XG4gIH1cbn1cbiIsIjxkaXYgKm5nSWY9XCIhaXNGdWxsV2lkdGhcIiBjbGFzcz1cImRpYWxvZy1oZWFkZXJcIj5cbiAgPGRpdiBjbGFzcz1cInRpdGxlLWNvbnRhaW5lclwiPlxuICAgIHt7IGNvbmZpZz8udGl0bGU/LmkxOG4gfCB0cmFuc2xhdGUgfX1cbiAgPC9kaXY+XG4gIDxidXR0b25cbiAgICAqbmdJZj1cIiFjb25maWc/LmhpZGVDbG9zZUhlYWRlckJ1dHRvblwiXG4gICAgcWRJY29uQnV0dG9uXG4gICAgY2xhc3M9XCJjbG9zZVwiXG4gICAgY29sb3I9XCJzZWNvbmRhcnlcIlxuICAgIHRhYmluZGV4PVwiLTFcIlxuICAgIChjbGljayk9XCJjbG9zZSgpXCJcbiAgPlxuICAgIDxxZC1pY29uIGljb249XCJ0aW1lc0xhcmdlTGlnaHRcIj48L3FkLWljb24+XG4gIDwvYnV0dG9uPlxuPC9kaXY+XG5cbjxidXR0b25cbiAgKm5nSWY9XCIhY29uZmlnPy5oaWRlQ2xvc2VIZWFkZXJCdXR0b24gJiYgaXNGdWxsV2lkdGhcIlxuICBxZEljb25CdXR0b25cbiAgY2xhc3M9XCJjbG9zZVwiXG4gIGNvbG9yPVwic2Vjb25kYXJ5XCJcbiAgdGFiaW5kZXg9XCItMVwiXG4gIChjbGljayk9XCJjbG9zZSgpXCJcbj5cbiAgPHFkLWljb24gaWNvbj1cInRpbWVzTGFyZ2VMaWdodFwiPjwvcWQtaWNvbj5cbjwvYnV0dG9uPlxuXG48ZGl2IGNsYXNzPVwid3JhcHBlci1ib2R5XCI+XG4gIDxkaXYgW2NsYXNzLmhhcy1kaWFsb2ctaW5mby1iYW5uZXJzXT1cImhhc0luZm9CYW5uZXJcIiAjYmFubmVycz5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJxZC1wYWdlLWluZm8tYmFubmVyXCI+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImJvZHlcIiBbY2xhc3MuZnVsbC13aWR0aF09XCJpc0Z1bGxXaWR0aFwiICNib2R5PlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L2Rpdj5cbjxuZy1jb250ZW50IHNlbGVjdD1cInFkLWRpYWxvZy1hY3Rpb25cIj48L25nLWNvbnRlbnQ+XG4iXX0=
|
|
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"]}
|
|
@@ -21,8 +21,10 @@ 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';
|
|
25
|
+
import { QdCancelDialogComponent } from './cancel-confirmation-dialog/cancel-dialog.component';
|
|
24
26
|
import * as i0 from "@angular/core";
|
|
25
|
-
export { QdDialogComponent, QdDialogActionComponent, QdDialogRecordStepperComponent, QdDialogAuthSessionEndComponent, QdDialogConfirmationComponent, QdDialogConfirmationErrorDirective, QdDialogConfirmationInfoDirective, QdDialogConfirmationSuccessDirective, QdDialogService, QdDialogAuthSessionEndService, QdDialogSize, QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN };
|
|
27
|
+
export { QdDialogComponent, QdDialogActionComponent, QdDialogRecordStepperComponent, QdDialogAuthSessionEndComponent, QdDialogConfirmationComponent, QdDialogConfirmationErrorDirective, QdDialogConfirmationInfoDirective, QdDialogConfirmationSuccessDirective, QdDialogService, QdDialogAuthSessionEndService, QdDialogSize, PendingChangesGuardDirective, QD_DIALOG_CONFIRMATION_RESOLVER_TOKEN };
|
|
26
28
|
export class QdDialogModule {
|
|
27
29
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
28
30
|
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: QdDialogModule, declarations: [QdDialogActionComponent,
|
|
@@ -33,7 +35,9 @@ export class QdDialogModule {
|
|
|
33
35
|
QdDialogConfirmationInfoDirective,
|
|
34
36
|
QdDialogConfirmationSuccessDirective,
|
|
35
37
|
QdDialogRecordStepperComponent,
|
|
36
|
-
QdPageDialogWithBreadcrumbsComponent
|
|
38
|
+
QdPageDialogWithBreadcrumbsComponent,
|
|
39
|
+
PendingChangesGuardDirective,
|
|
40
|
+
QdCancelDialogComponent], imports: [CommonModule,
|
|
37
41
|
TranslateModule,
|
|
38
42
|
RouterModule,
|
|
39
43
|
CDKDialogModule,
|
|
@@ -50,7 +54,8 @@ export class QdDialogModule {
|
|
|
50
54
|
QdDialogConfirmationComponent,
|
|
51
55
|
QdDialogConfirmationErrorDirective,
|
|
52
56
|
QdDialogConfirmationSuccessDirective,
|
|
53
|
-
QdDialogRecordStepperComponent
|
|
57
|
+
QdDialogRecordStepperComponent,
|
|
58
|
+
PendingChangesGuardDirective] });
|
|
54
59
|
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdDialogModule, imports: [CommonModule,
|
|
55
60
|
TranslateModule,
|
|
56
61
|
RouterModule,
|
|
@@ -90,7 +95,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
90
95
|
QdDialogConfirmationInfoDirective,
|
|
91
96
|
QdDialogConfirmationSuccessDirective,
|
|
92
97
|
QdDialogRecordStepperComponent,
|
|
93
|
-
QdPageDialogWithBreadcrumbsComponent
|
|
98
|
+
QdPageDialogWithBreadcrumbsComponent,
|
|
99
|
+
PendingChangesGuardDirective,
|
|
100
|
+
QdCancelDialogComponent
|
|
94
101
|
],
|
|
95
102
|
exports: [
|
|
96
103
|
QdDialogActionComponent,
|
|
@@ -99,8 +106,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
99
106
|
QdDialogConfirmationComponent,
|
|
100
107
|
QdDialogConfirmationErrorDirective,
|
|
101
108
|
QdDialogConfirmationSuccessDirective,
|
|
102
|
-
QdDialogRecordStepperComponent
|
|
109
|
+
QdDialogRecordStepperComponent,
|
|
110
|
+
PendingChangesGuardDirective
|
|
103
111
|
]
|
|
104
112
|
}]
|
|
105
113
|
}] });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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"]}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { NgForm, FormGroupDirective } from '@angular/forms';
|
|
2
|
+
import { Directive, Optional } from '@angular/core';
|
|
3
|
+
import { QdDialogChangeGuardService } from '../services/dialog-change-guard.service';
|
|
4
|
+
import { isEqual } from 'lodash';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/forms";
|
|
7
|
+
import * as i2 from "../services/dialog-change-guard.service";
|
|
8
|
+
/**
|
|
9
|
+
* @name PendingChangesGuardDirective
|
|
10
|
+
* @description
|
|
11
|
+
* Automatically monitors the status of form changes in QdDialogComponent (Reactive or Template-Driven Forms)
|
|
12
|
+
* by comparing the current form value with its initial value.
|
|
13
|
+
* * The directive automatically marks the form as `pristine` when all values
|
|
14
|
+
* match the initial state, even if the form has been modified in between.
|
|
15
|
+
* * @example
|
|
16
|
+
* // Usage in the Dialog Content Component (Reactive Form):
|
|
17
|
+
* // import { QdPendingChangesGuardDirective } from '...';
|
|
18
|
+
* // template:
|
|
19
|
+
* // <qd-dialog>
|
|
20
|
+
* // <form [formGroup]="myForm" qdPendingChangesGuard>
|
|
21
|
+
* // <input type="text" formControlName="name">
|
|
22
|
+
* // </form>
|
|
23
|
+
* // </qd-dialog>
|
|
24
|
+
*/
|
|
25
|
+
export class PendingChangesGuardDirective {
|
|
26
|
+
ngForm;
|
|
27
|
+
formGroupDirective;
|
|
28
|
+
changeGuard;
|
|
29
|
+
statusSubscription;
|
|
30
|
+
initialValue;
|
|
31
|
+
formGroup;
|
|
32
|
+
constructor(ngForm, formGroupDirective, changeGuard) {
|
|
33
|
+
this.ngForm = ngForm;
|
|
34
|
+
this.formGroupDirective = formGroupDirective;
|
|
35
|
+
this.changeGuard = changeGuard;
|
|
36
|
+
if (!this.ngForm && !this.formGroupDirective) {
|
|
37
|
+
console.error('QD-UI | QdPendingChangesGuardDirective - requires NgForm or FormGroupDirective to be present on the host element.');
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
ngOnInit() {
|
|
41
|
+
this.formGroup = this.ngForm?.form || this.formGroupDirective?.form;
|
|
42
|
+
if (this.formGroup) {
|
|
43
|
+
this.initialValue = { ...this.formGroup.value };
|
|
44
|
+
this.updateStatus();
|
|
45
|
+
this.statusSubscription = this.formGroup.valueChanges.subscribe(() => {
|
|
46
|
+
this.updateStatus();
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
updateStatus() {
|
|
51
|
+
if (!this.formGroup)
|
|
52
|
+
return;
|
|
53
|
+
const isPristine = isEqual(this.formGroup.value, this.initialValue);
|
|
54
|
+
const hasChanges = !isPristine;
|
|
55
|
+
this.changeGuard.setPendingChangesStatus(hasChanges);
|
|
56
|
+
if (isPristine && this.formGroup.dirty) {
|
|
57
|
+
this.formGroup.markAsPristine();
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
ngOnDestroy() {
|
|
61
|
+
this.statusSubscription?.unsubscribe();
|
|
62
|
+
this.changeGuard.setPendingChangesStatus(false);
|
|
63
|
+
}
|
|
64
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PendingChangesGuardDirective, deps: [{ token: i1.NgForm, optional: true }, { token: i1.FormGroupDirective, optional: true }, { token: i2.QdDialogChangeGuardService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
65
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.9", type: PendingChangesGuardDirective, selector: "[qdPendingChangesGuard]", ngImport: i0 });
|
|
66
|
+
}
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PendingChangesGuardDirective, decorators: [{
|
|
68
|
+
type: Directive,
|
|
69
|
+
args: [{
|
|
70
|
+
selector: '[qdPendingChangesGuard]',
|
|
71
|
+
standalone: false
|
|
72
|
+
}]
|
|
73
|
+
}], ctorParameters: () => [{ type: i1.NgForm, decorators: [{
|
|
74
|
+
type: Optional
|
|
75
|
+
}] }, { type: i1.FormGroupDirective, decorators: [{
|
|
76
|
+
type: Optional
|
|
77
|
+
}] }, { type: i2.QdDialogChangeGuardService }] });
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVuZGluZy1jaGFuZ2VzLWd1YXJkLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9kaWFsb2cvZGlyZWN0aXZlcy9wZW5kaW5nLWNoYW5nZXMtZ3VhcmQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsa0JBQWtCLEVBQWEsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsU0FBUyxFQUFxQixRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdkUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDckYsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFFBQVEsQ0FBQzs7OztBQUVqQzs7Ozs7Ozs7Ozs7Ozs7OztHQWdCRztBQUtILE1BQU0sT0FBTyw0QkFBNEI7SUFNakI7SUFDQTtJQUNaO0lBUEYsa0JBQWtCLENBQTJCO0lBQzdDLFlBQVksQ0FBTTtJQUNsQixTQUFTLENBQXdCO0lBRXpDLFlBQ3NCLE1BQWMsRUFDZCxrQkFBc0MsRUFDbEQsV0FBdUM7UUFGM0IsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFDbEQsZ0JBQVcsR0FBWCxXQUFXLENBQTRCO1FBRS9DLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7WUFDN0MsT0FBTyxDQUFDLEtBQUssQ0FDWCxtSEFBbUgsQ0FDcEgsQ0FBQztRQUNKLENBQUM7SUFDSCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLElBQUksSUFBSSxDQUFDLGtCQUFrQixFQUFFLElBQUksQ0FBQztRQUVwRSxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNuQixJQUFJLENBQUMsWUFBWSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2hELElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUVwQixJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDbkUsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3RCLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztJQUNILENBQUM7SUFFTyxZQUFZO1FBQ2xCLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUztZQUFFLE9BQU87UUFFNUIsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNwRSxNQUFNLFVBQVUsR0FBRyxDQUFDLFVBQVUsQ0FBQztRQUUvQixJQUFJLENBQUMsV0FBVyxDQUFDLHVCQUF1QixDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRXJELElBQUksVUFBVSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDdkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUNsQyxDQUFDO0lBQ0gsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsa0JBQWtCLEVBQUUsV0FBVyxFQUFFLENBQUM7UUFDdkMsSUFBSSxDQUFDLFdBQVcsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNsRCxDQUFDO3VHQTlDVSw0QkFBNEI7MkZBQTVCLDRCQUE0Qjs7MkZBQTVCLDRCQUE0QjtrQkFKeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUseUJBQXlCO29CQUNuQyxVQUFVLEVBQUUsS0FBSztpQkFDbEI7OzBCQU9JLFFBQVE7OzBCQUNSLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ0Zvcm0sIEZvcm1Hcm91cERpcmVjdGl2ZSwgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRGlyZWN0aXZlLCBPbkRlc3Ryb3ksIE9uSW5pdCwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgUWREaWFsb2dDaGFuZ2VHdWFyZFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9kaWFsb2ctY2hhbmdlLWd1YXJkLnNlcnZpY2UnO1xuaW1wb3J0IHsgaXNFcXVhbCB9IGZyb20gJ2xvZGFzaCc7XG5cbi8qKlxuICogQG5hbWUgUGVuZGluZ0NoYW5nZXNHdWFyZERpcmVjdGl2ZVxuICogQGRlc2NyaXB0aW9uXG4gKiBBdXRvbWF0aWNhbGx5IG1vbml0b3JzIHRoZSBzdGF0dXMgb2YgZm9ybSBjaGFuZ2VzIGluIFFkRGlhbG9nQ29tcG9uZW50IChSZWFjdGl2ZSBvciBUZW1wbGF0ZS1Ecml2ZW4gRm9ybXMpXG4gKiBieSBjb21wYXJpbmcgdGhlIGN1cnJlbnQgZm9ybSB2YWx1ZSB3aXRoIGl0cyBpbml0aWFsIHZhbHVlLlxuICogKiBUaGUgZGlyZWN0aXZlIGF1dG9tYXRpY2FsbHkgbWFya3MgdGhlIGZvcm0gYXMgYHByaXN0aW5lYCB3aGVuIGFsbCB2YWx1ZXNcbiAqIG1hdGNoIHRoZSBpbml0aWFsIHN0YXRlLCBldmVuIGlmIHRoZSBmb3JtIGhhcyBiZWVuIG1vZGlmaWVkIGluIGJldHdlZW4uXG4gKiAqIEBleGFtcGxlXG4gKiAvLyBVc2FnZSBpbiB0aGUgRGlhbG9nIENvbnRlbnQgQ29tcG9uZW50IChSZWFjdGl2ZSBGb3JtKTpcbiAqIC8vIGltcG9ydCB7IFFkUGVuZGluZ0NoYW5nZXNHdWFyZERpcmVjdGl2ZSB9IGZyb20gJy4uLic7XG4gKiAvLyB0ZW1wbGF0ZTpcbiAqIC8vIDxxZC1kaWFsb2c+XG4gKiAvLyAgIDxmb3JtIFtmb3JtR3JvdXBdPVwibXlGb3JtXCIgcWRQZW5kaW5nQ2hhbmdlc0d1YXJkPlxuICogLy8gICAgIDxpbnB1dCB0eXBlPVwidGV4dFwiIGZvcm1Db250cm9sTmFtZT1cIm5hbWVcIj5cbiAqIC8vICAgPC9mb3JtPlxuICogLy8gPC9xZC1kaWFsb2c+XG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1txZFBlbmRpbmdDaGFuZ2VzR3VhcmRdJyxcbiAgc3RhbmRhbG9uZTogZmFsc2Vcbn0pXG5leHBvcnQgY2xhc3MgUGVuZGluZ0NoYW5nZXNHdWFyZERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSBzdGF0dXNTdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbiB8IHVuZGVmaW5lZDtcbiAgcHJpdmF0ZSBpbml0aWFsVmFsdWU6IGFueTtcbiAgcHJpdmF0ZSBmb3JtR3JvdXA6IEZvcm1Hcm91cCB8IHVuZGVmaW5lZDtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBAT3B0aW9uYWwoKSBwcml2YXRlIG5nRm9ybTogTmdGb3JtLFxuICAgIEBPcHRpb25hbCgpIHByaXZhdGUgZm9ybUdyb3VwRGlyZWN0aXZlOiBGb3JtR3JvdXBEaXJlY3RpdmUsXG4gICAgcHJpdmF0ZSBjaGFuZ2VHdWFyZDogUWREaWFsb2dDaGFuZ2VHdWFyZFNlcnZpY2VcbiAgKSB7XG4gICAgaWYgKCF0aGlzLm5nRm9ybSAmJiAhdGhpcy5mb3JtR3JvdXBEaXJlY3RpdmUpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICdRRC1VSSB8IFFkUGVuZGluZ0NoYW5nZXNHdWFyZERpcmVjdGl2ZSAtIHJlcXVpcmVzIE5nRm9ybSBvciBGb3JtR3JvdXBEaXJlY3RpdmUgdG8gYmUgcHJlc2VudCBvbiB0aGUgaG9zdCBlbGVtZW50LidcbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5mb3JtR3JvdXAgPSB0aGlzLm5nRm9ybT8uZm9ybSB8fCB0aGlzLmZvcm1Hcm91cERpcmVjdGl2ZT8uZm9ybTtcblxuICAgIGlmICh0aGlzLmZvcm1Hcm91cCkge1xuICAgICAgdGhpcy5pbml0aWFsVmFsdWUgPSB7IC4uLnRoaXMuZm9ybUdyb3VwLnZhbHVlIH07XG4gICAgICB0aGlzLnVwZGF0ZVN0YXR1cygpO1xuXG4gICAgICB0aGlzLnN0YXR1c1N1YnNjcmlwdGlvbiA9IHRoaXMuZm9ybUdyb3VwLnZhbHVlQ2hhbmdlcy5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLnVwZGF0ZVN0YXR1cygpO1xuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSB1cGRhdGVTdGF0dXMoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLmZvcm1Hcm91cCkgcmV0dXJuO1xuXG4gICAgY29uc3QgaXNQcmlzdGluZSA9IGlzRXF1YWwodGhpcy5mb3JtR3JvdXAudmFsdWUsIHRoaXMuaW5pdGlhbFZhbHVlKTtcbiAgICBjb25zdCBoYXNDaGFuZ2VzID0gIWlzUHJpc3RpbmU7XG5cbiAgICB0aGlzLmNoYW5nZUd1YXJkLnNldFBlbmRpbmdDaGFuZ2VzU3RhdHVzKGhhc0NoYW5nZXMpO1xuXG4gICAgaWYgKGlzUHJpc3RpbmUgJiYgdGhpcy5mb3JtR3JvdXAuZGlydHkpIHtcbiAgICAgIHRoaXMuZm9ybUdyb3VwLm1hcmtBc1ByaXN0aW5lKCk7XG4gICAgfVxuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5zdGF0dXNTdWJzY3JpcHRpb24/LnVuc3Vic2NyaWJlKCk7XG4gICAgdGhpcy5jaGFuZ2VHdWFyZC5zZXRQZW5kaW5nQ2hhbmdlc1N0YXR1cyhmYWxzZSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -7,4 +7,4 @@ export var QdDialogSize;
|
|
|
7
7
|
QdDialogSize["Default"] = "900px";
|
|
8
8
|
QdDialogSize["FullWidth"] = "100%";
|
|
9
9
|
})(QdDialogSize || (QdDialogSize = {}));
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWNvbmZpZy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvcWQtdWkvc3JjL2xpYi9kaWFsb2cvbW9kZWxzL2RpYWxvZy1jb25maWcubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeURBOztHQUVHO0FBQ0gsTUFBTSxDQUFOLElBQVksWUFJWDtBQUpELFdBQVksWUFBWTtJQUN0QiwrQkFBZSxDQUFBO0lBQ2YsaUNBQWlCLENBQUE7SUFDakIsa0NBQWtCLENBQUE7QUFDcEIsQ0FBQyxFQUpXLFlBQVksS0FBWixZQUFZLFFBSXZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlhbG9nQ29uZmlnIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2RpYWxvZyc7XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBvYmplY3QgZm9yIGRpYWxvZy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBRZERpYWxvZ0NvbmZpZyBleHRlbmRzIERpYWxvZ0NvbmZpZyB7XG4gIC8qKlxuICAgKiBUaXRsZSBvZiBkaWFsb2cuXG4gICAqL1xuICB0aXRsZT86IFFkRGlhbG9nVGl0bGU7XG5cbiAgLyoqXG4gICAqIEhpZGVzIHRoZSBjbG9zZSBidXR0b24gaW4gdGhlIGRpYWxvZyBoZWFkZXIuXG4gICAqL1xuICBoaWRlQ2xvc2VIZWFkZXJCdXR0b24/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBEZXRlcm1pbmVzIHRoZSBzaXplIG9mIHRoZSBkaWFsb2cuIFRoZXJlIGFyZSAzIGRpZmZlcmVudCB3aWR0aCBzaXplcy5cbiAgICogU21hbGwgLSA1MDBweFxuICAgKiBEZWZhdWx0IC0gOTAwcHhcbiAgICogRnVsbFdpZHRoIC0gMTAwJVxuICAgKi9cbiAgZGlhbG9nU2l6ZT86IFFkRGlhbG9nU2l6ZTtcblxuICAvKipcbiAgICogQWRkaXRpb25hbCBkYXRhIGZvciB0aGUgZGlhbG9nLlxuICAgKi9cbiAgZGF0YT86IHsgW2tleTogc3RyaW5nXTogYW55IH07XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBDb25maWd1cmF0aW9uIGZvciB0aGUgcHJpbWFyeSBhY3Rpb24uXG4gICAqL1xuICBwcmltYXJ5PzogUWREaWFsb2dQcmltYXJ5QWN0aW9uO1xuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gQ29uZmlndXJhdGlvbiBmb3IgdGhlIGNhbmNlbCBidXR0b24uXG4gICAqL1xuICBjYW5jZWw/OiBRZERpYWxvZ0NhbmNlbEFjdGlvbjtcbn1cblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIG9iamVjdCBmb3IgcGFnZSBkaWFsb2cuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUWRQYWdlRGlhbG9nQ29uZmlnIHtcbiAgZGF0YT86IGFueTtcbn1cblxuLyoqXG4gKiBUaXRsZSBvZiBkaWFsb2cuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUWREaWFsb2dUaXRsZSB7XG4gIC8qKlxuICAgKiBUcmFuc2xhdGlvbiBrZXkuXG4gICAqL1xuICBpMThuOiBzdHJpbmc7XG59XG5cbi8qKlxuICogRW51bSBmb3IgZGlmZmVyZW50IERpYWxvZyBzaXplcy5cbiAqL1xuZXhwb3J0IGVudW0gUWREaWFsb2dTaXplIHtcbiAgU21hbGwgPSAnNTAwcHgnLFxuICBEZWZhdWx0ID0gJzkwMHB4JyxcbiAgRnVsbFdpZHRoID0gJzEwMCUnXG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEludGVyZmFjZSBmb3IgdGhlIHByaW1hcnkgYWN0aW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFFkRGlhbG9nUHJpbWFyeUFjdGlvbiB7XG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gTGFiZWwgZm9yIGEgcHJpbWFyeSBhY3Rpb24gYnV0dG9uLCB1c2VkIGZvciB0cmFuc2xhdGlvbi5cbiAgICpcbiAgICogKiBJZiBubyBjdXN0b20gdHJhbnNsYXRpb24ga2V5IGlzIHByb3ZpZGVkLCBhIHN0YW5kYXJkIGxhYmVsIHdpbGwgYmUgdXNlZCBieSBkZWZhdWx0LlxuICAgKi9cbiAgbGFiZWw/OiB7IGkxOG46IHN0cmluZyB9O1xuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gSGFuZGxlciBmdW5jdGlvbiB0aGF0IGlzIHRyaWdnZXJlZCB3aGVuIHRoZSBwcmltYXJ5IGFjdGlvbiBpcyBleGVjdXRlZC5cbiAgICovXG4gIGhhbmRsZXI/OiAoKSA9PiB2b2lkO1xufVxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBJbnRlcmZhY2UgZm9yIHRoZSBjYW5jZWwgYWN0aW9uLCBpbmNsdWRpbmcgYW4gb3B0aW9uYWwgY29uZmlybWF0aW9uIG1lc3NhZ2UuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUWREaWFsb2dDYW5jZWxBY3Rpb24ge1xuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIExhYmVsIGZvciB0aGUgY2FuY2VsIGFjdGlvbiwgdXNlZCBmb3IgdHJhbnNsYXRpb24uXG4gICAqXG4gICAqICogSWYgbm8gY3VzdG9tIHRyYW5zbGF0aW9uIGtleSBpcyBwcm92aWRlZCwgYSBzdGFuZGFyZCBsYWJlbCB3aWxsIGJlIHVzZWQgYnkgZGVmYXVsdC5cbiAgICovXG4gIGxhYmVsPzogeyBpMThuOiBzdHJpbmcgfTtcblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIEhhbmRsZXIgZnVuY3Rpb24gdGhhdCBpcyB0cmlnZ2VyZWQgd2hlbiB0aGUgY2FuY2VsIGFjdGlvbiBpcyBleGVjdXRlZC5cbiAgICovXG4gIGhhbmRsZXI/OiAoZm9ybVZhbHVlcz86IGFueSkgPT4gdm9pZDtcblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIEFuIG9wdGlvbmFsIGNvbmZpcm1hdGlvbiBtZXNzYWdlIGRpc3BsYXllZCBpbiBhIGRpYWxvZyB3aGVuIHRoZSB1c2VyIGF0dGVtcHRzIHRvIGNhbmNlbCB0aGUgb3BlcmF0aW9uLCB3YXJuaW5nIHRoYXQgYWxsIGNoYW5nZXMgd2lsbCBiZSBkaXNjYXJkZWQuXG4gICAqIElmIG5vIGN1c3RvbSBtZXNzYWdlIGlzIHByb3ZpZGVkLCBhIHN0YW5kYXJkIG1lc3NhZ2Ugd2lsbCBiZSBzaG93biBieSBkZWZhdWx0LlxuICAgKlxuICAgKiAqIFRoZSBjYW5jZWxsYXRpb24gcHJvY2VzcyBjaGVja3Mgd2hldGhlciB0aGVyZSBhcmUgdW5zYXZlZCBjaGFuZ2VzIGluIHRoZSBmb3JtLiBJZiB0aGVyZSBhcmUgY2hhbmdlcywgdGhlIGRpYWxvZyB3aWxsIGFwcGVhci5cbiAgICpcbiAgICogKiBJZiBubyBjaGFuZ2VzIGFyZSBkZXRlY3RlZCwgdGhlIGNhbmNlbGxhdGlvbiBwcm9jZWVkcyB3aXRob3V0IHNob3dpbmcgdGhlIGNvbmZpcm1hdGlvbiBkaWFsb2cuXG4gICAqL1xuICBjb25maXJtYXRpb25NZXNzYWdlPzogeyBpMThuOiBzdHJpbmcgfTtcbn1cbiJdfQ==
|