ng-primitives 0.7.0 → 0.7.2
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/dialog/config/dialog.config.d.ts +43 -0
- package/dialog/dialog/dialog-ref.d.ts +40 -0
- package/dialog/dialog/dialog.directive.d.ts +29 -21
- package/dialog/dialog/dialog.service.d.ts +66 -0
- package/dialog/dialog-description/dialog-description.directive.d.ts +19 -0
- package/dialog/dialog-description/dialog-description.token.d.ts +14 -0
- package/dialog/dialog-overlay/dialog-overlay.directive.d.ts +8 -0
- package/dialog/{dialog-panel/dialog-panel.token.d.ts → dialog-overlay/dialog-overlay.token.d.ts} +4 -4
- package/dialog/dialog-title/dialog-title.directive.d.ts +14 -4
- package/dialog/dialog-trigger/dialog-trigger.directive.d.ts +24 -0
- package/dialog/dialog-trigger/dialog-trigger.token.d.ts +14 -0
- package/dialog/index.d.ts +8 -3
- package/esm2022/date-picker/date-picker-row-render/date-picker-row-render.directive.mjs +1 -2
- package/esm2022/dialog/config/dialog.config.mjs +28 -0
- package/esm2022/dialog/dialog/dialog-ref.mjs +44 -0
- package/esm2022/dialog/dialog/dialog.directive.mjs +59 -27
- package/esm2022/dialog/dialog/dialog.service.mjs +202 -0
- package/esm2022/dialog/dialog-description/dialog-description.directive.mjs +46 -0
- package/esm2022/dialog/dialog-description/dialog-description.token.mjs +16 -0
- package/esm2022/dialog/dialog-overlay/dialog-overlay.directive.mjs +35 -0
- package/esm2022/dialog/dialog-overlay/dialog-overlay.token.mjs +16 -0
- package/esm2022/dialog/dialog-title/dialog-title.directive.mjs +22 -7
- package/esm2022/dialog/dialog-trigger/dialog-trigger.directive.mjs +61 -0
- package/esm2022/dialog/dialog-trigger/dialog-trigger.token.mjs +16 -0
- package/esm2022/dialog/index.mjs +8 -3
- package/esm2022/internal/disabled/disabled.mjs +2 -2
- package/esm2022/utils/signals/async.mjs +3 -1
- package/fesm2022/ng-primitives-date-picker.mjs +0 -1
- package/fesm2022/ng-primitives-date-picker.mjs.map +1 -1
- package/fesm2022/ng-primitives-dialog.mjs +495 -46
- package/fesm2022/ng-primitives-dialog.mjs.map +1 -1
- package/fesm2022/ng-primitives-internal.mjs +1 -1
- package/fesm2022/ng-primitives-internal.mjs.map +1 -1
- package/fesm2022/ng-primitives-utils.mjs +2 -0
- package/fesm2022/ng-primitives-utils.mjs.map +1 -1
- package/package.json +7 -7
- package/dialog/dialog-panel/dialog-panel.directive.d.ts +0 -5
- package/esm2022/dialog/dialog-panel/dialog-panel.directive.mjs +0 -24
- package/esm2022/dialog/dialog-panel/dialog-panel.token.mjs +0 -16
|
@@ -1,34 +1,61 @@
|
|
|
1
|
-
import { booleanAttribute,
|
|
1
|
+
import { booleanAttribute, Directive, HostListener, input, signal } from '@angular/core';
|
|
2
|
+
import { NgpFocusTrap } from 'ng-primitives/focus-trap';
|
|
2
3
|
import { uniqueId } from 'ng-primitives/utils';
|
|
3
|
-
import {
|
|
4
|
+
import { injectDialogConfig } from '../config/dialog.config';
|
|
5
|
+
import { injectDialogRef } from './dialog-ref';
|
|
4
6
|
import { NgpDialogToken } from './dialog.token';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "ng-primitives/focus-trap";
|
|
6
9
|
export class NgpDialog {
|
|
7
10
|
constructor() {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
+
this.config = injectDialogConfig();
|
|
12
|
+
/** Access the dialog ref */
|
|
13
|
+
this.dialogRef = injectDialogRef();
|
|
14
|
+
/** The id of the dialog */
|
|
11
15
|
this.id = input(uniqueId('ngp-dialog'));
|
|
12
|
-
/**
|
|
13
|
-
|
|
14
|
-
*/
|
|
15
|
-
this.open = input(false, {
|
|
16
|
-
alias: 'ngpDialogOpen',
|
|
17
|
-
transform: booleanAttribute,
|
|
18
|
-
});
|
|
19
|
-
/**
|
|
20
|
-
* The type of the dialog.
|
|
21
|
-
*/
|
|
22
|
-
this.type = input('dialog', {
|
|
16
|
+
/** The dialog role. */
|
|
17
|
+
this.role = input(this.config.role, {
|
|
23
18
|
alias: 'ngpDialogRole',
|
|
24
19
|
});
|
|
25
|
-
/**
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
20
|
+
/** Whether the dialog is a modal. */
|
|
21
|
+
this.modal = input(this.config.modal ?? false, {
|
|
22
|
+
alias: 'ngpDialogModal',
|
|
23
|
+
transform: booleanAttribute,
|
|
24
|
+
});
|
|
25
|
+
/** The labelledby ids */
|
|
26
|
+
this.labelledBy = signal([]);
|
|
27
|
+
/** The describedby ids */
|
|
28
|
+
this.describedBy = signal([]);
|
|
29
|
+
}
|
|
30
|
+
ngOnDestroy() {
|
|
31
|
+
this.close();
|
|
32
|
+
}
|
|
33
|
+
/** Close the dialog. */
|
|
34
|
+
close() {
|
|
35
|
+
this.dialogRef.close();
|
|
36
|
+
}
|
|
37
|
+
/** Stop click events from propagating to the overlay */
|
|
38
|
+
onClick(event) {
|
|
39
|
+
event.stopPropagation();
|
|
40
|
+
}
|
|
41
|
+
/** @internal register a labelledby id */
|
|
42
|
+
setLabelledBy(id) {
|
|
43
|
+
this.labelledBy.update(ids => [...ids, id]);
|
|
44
|
+
}
|
|
45
|
+
/** @internal register a describedby id */
|
|
46
|
+
setDescribedBy(id) {
|
|
47
|
+
this.describedBy.update(ids => [...ids, id]);
|
|
48
|
+
}
|
|
49
|
+
/** @internal remove a labelledby id */
|
|
50
|
+
removeLabelledBy(id) {
|
|
51
|
+
this.labelledBy.update(ids => ids.filter(i => i !== id));
|
|
52
|
+
}
|
|
53
|
+
/** @internal remove a describedby id */
|
|
54
|
+
removeDescribedBy(id) {
|
|
55
|
+
this.describedBy.update(ids => ids.filter(i => i !== id));
|
|
29
56
|
}
|
|
30
57
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialog, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
31
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.
|
|
58
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.1", type: NgpDialog, isStandalone: true, selector: "[ngpDialog]", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, role: { classPropertyName: "role", publicName: "ngpDialogRole", isSignal: true, isRequired: false, transformFunction: null }, modal: { classPropertyName: "modal", publicName: "ngpDialogModal", isSignal: true, isRequired: false, transformFunction: null } }, host: { attributes: { "tabindex": "-1" }, listeners: { "click": "onClick($event)" }, properties: { "id": "id()", "attr.role": "role()", "attr.aria-modal": "modal()", "attr.aria-labelledby": "labelledBy().join(\" \")", "attr.aria-describedby": "describedBy().join(\" \")" } }, providers: [{ provide: NgpDialogToken, useExisting: NgpDialog }], exportAs: ["ngpDialog"], hostDirectives: [{ directive: i1.NgpFocusTrap }], ngImport: i0 }); }
|
|
32
59
|
}
|
|
33
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialog, decorators: [{
|
|
34
61
|
type: Directive,
|
|
@@ -37,13 +64,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
|
|
|
37
64
|
selector: '[ngpDialog]',
|
|
38
65
|
exportAs: 'ngpDialog',
|
|
39
66
|
providers: [{ provide: NgpDialogToken, useExisting: NgpDialog }],
|
|
67
|
+
hostDirectives: [NgpFocusTrap],
|
|
40
68
|
host: {
|
|
41
|
-
|
|
69
|
+
tabindex: '-1',
|
|
42
70
|
'[id]': 'id()',
|
|
43
|
-
'[attr.
|
|
44
|
-
'[attr.
|
|
45
|
-
'[attr.aria-labelledby]': '
|
|
71
|
+
'[attr.role]': 'role()',
|
|
72
|
+
'[attr.aria-modal]': 'modal()',
|
|
73
|
+
'[attr.aria-labelledby]': 'labelledBy().join(" ")',
|
|
74
|
+
'[attr.aria-describedby]': 'describedBy().join(" ")',
|
|
46
75
|
},
|
|
47
76
|
}]
|
|
48
|
-
}]
|
|
49
|
-
|
|
77
|
+
}], propDecorators: { onClick: [{
|
|
78
|
+
type: HostListener,
|
|
79
|
+
args: ['click', ['$event']]
|
|
80
|
+
}] } });
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL25nLXByaW1pdGl2ZXMvZGlhbG9nL3NyYy9kaWFsb2cvZGlhbG9nLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQWlCaEQsTUFBTSxPQUFPLFNBQVM7SUFmdEI7UUFnQm1CLFdBQU0sR0FBRyxrQkFBa0IsRUFBRSxDQUFDO1FBRS9DLDRCQUE0QjtRQUNYLGNBQVMsR0FBRyxlQUFlLEVBQUUsQ0FBQztRQUUvQywyQkFBMkI7UUFDbEIsT0FBRSxHQUFHLEtBQUssQ0FBUyxRQUFRLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQztRQUVwRCx1QkFBdUI7UUFDZCxTQUFJLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFO1lBQ3RDLEtBQUssRUFBRSxlQUFlO1NBQ3ZCLENBQUMsQ0FBQztRQUVILHFDQUFxQztRQUM1QixVQUFLLEdBQUcsS0FBSyxDQUF3QixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssSUFBSSxLQUFLLEVBQUU7WUFDeEUsS0FBSyxFQUFFLGdCQUFnQjtZQUN2QixTQUFTLEVBQUUsZ0JBQWdCO1NBQzVCLENBQUMsQ0FBQztRQUVILHlCQUF5QjtRQUNOLGVBQVUsR0FBRyxNQUFNLENBQVcsRUFBRSxDQUFDLENBQUM7UUFFckQsMEJBQTBCO1FBQ1AsZ0JBQVcsR0FBRyxNQUFNLENBQVcsRUFBRSxDQUFDLENBQUM7S0FvQ3ZEO0lBbENDLFdBQVc7UUFDVCxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDZixDQUFDO0lBRUQsd0JBQXdCO0lBQ3hCLEtBQUs7UUFDSCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCx3REFBd0Q7SUFFOUMsT0FBTyxDQUFDLEtBQVk7UUFDNUIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCx5Q0FBeUM7SUFDekMsYUFBYSxDQUFDLEVBQVU7UUFDdEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVELDBDQUEwQztJQUMxQyxjQUFjLENBQUMsRUFBVTtRQUN2QixJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRUQsdUNBQXVDO0lBQ3ZDLGdCQUFnQixDQUFDLEVBQVU7UUFDekIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUVELHdDQUF3QztJQUN4QyxpQkFBaUIsQ0FBQyxFQUFVO1FBQzFCLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzVELENBQUM7OEdBM0RVLFNBQVM7a0dBQVQsU0FBUyx3c0JBWFQsQ0FBQyxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxDQUFDOzsyRkFXckQsU0FBUztrQkFmckIsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLFFBQVEsRUFBRSxXQUFXO29CQUNyQixTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsV0FBVyxXQUFXLEVBQUUsQ0FBQztvQkFDaEUsY0FBYyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUM5QixJQUFJLEVBQUU7d0JBQ0osUUFBUSxFQUFFLElBQUk7d0JBQ2QsTUFBTSxFQUFFLE1BQU07d0JBQ2QsYUFBYSxFQUFFLFFBQVE7d0JBQ3ZCLG1CQUFtQixFQUFFLFNBQVM7d0JBQzlCLHdCQUF3QixFQUFFLHdCQUF3Qjt3QkFDbEQseUJBQXlCLEVBQUUseUJBQXlCO3FCQUNyRDtpQkFDRjs4QkFzQ1csT0FBTztzQkFEaEIsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCDCqSAyMDI0IEFuZ3VsYXIgUHJpbWl0aXZlcy5cbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9uZy1wcmltaXRpdmVzL25nLXByaW1pdGl2ZXNcbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgMi4wIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cbmltcG9ydCB7IEJvb2xlYW5JbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBib29sZWFuQXR0cmlidXRlLCBEaXJlY3RpdmUsIEhvc3RMaXN0ZW5lciwgaW5wdXQsIE9uRGVzdHJveSwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ3BGb2N1c1RyYXAgfSBmcm9tICduZy1wcmltaXRpdmVzL2ZvY3VzLXRyYXAnO1xuaW1wb3J0IHsgdW5pcXVlSWQgfSBmcm9tICduZy1wcmltaXRpdmVzL3V0aWxzJztcbmltcG9ydCB7IGluamVjdERpYWxvZ0NvbmZpZyB9IGZyb20gJy4uL2NvbmZpZy9kaWFsb2cuY29uZmlnJztcbmltcG9ydCB7IGluamVjdERpYWxvZ1JlZiB9IGZyb20gJy4vZGlhbG9nLXJlZic7XG5pbXBvcnQgeyBOZ3BEaWFsb2dUb2tlbiB9IGZyb20gJy4vZGlhbG9nLnRva2VuJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW25ncERpYWxvZ10nLFxuICBleHBvcnRBczogJ25ncERpYWxvZycsXG4gIHByb3ZpZGVyczogW3sgcHJvdmlkZTogTmdwRGlhbG9nVG9rZW4sIHVzZUV4aXN0aW5nOiBOZ3BEaWFsb2cgfV0sXG4gIGhvc3REaXJlY3RpdmVzOiBbTmdwRm9jdXNUcmFwXSxcbiAgaG9zdDoge1xuICAgIHRhYmluZGV4OiAnLTEnLFxuICAgICdbaWRdJzogJ2lkKCknLFxuICAgICdbYXR0ci5yb2xlXSc6ICdyb2xlKCknLFxuICAgICdbYXR0ci5hcmlhLW1vZGFsXSc6ICdtb2RhbCgpJyxcbiAgICAnW2F0dHIuYXJpYS1sYWJlbGxlZGJ5XSc6ICdsYWJlbGxlZEJ5KCkuam9pbihcIiBcIiknLFxuICAgICdbYXR0ci5hcmlhLWRlc2NyaWJlZGJ5XSc6ICdkZXNjcmliZWRCeSgpLmpvaW4oXCIgXCIpJyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgTmdwRGlhbG9nIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcHJpdmF0ZSByZWFkb25seSBjb25maWcgPSBpbmplY3REaWFsb2dDb25maWcoKTtcblxuICAvKiogQWNjZXNzIHRoZSBkaWFsb2cgcmVmICovXG4gIHByaXZhdGUgcmVhZG9ubHkgZGlhbG9nUmVmID0gaW5qZWN0RGlhbG9nUmVmKCk7XG5cbiAgLyoqIFRoZSBpZCBvZiB0aGUgZGlhbG9nICovXG4gIHJlYWRvbmx5IGlkID0gaW5wdXQ8c3RyaW5nPih1bmlxdWVJZCgnbmdwLWRpYWxvZycpKTtcblxuICAvKiogVGhlIGRpYWxvZyByb2xlLiAqL1xuICByZWFkb25seSByb2xlID0gaW5wdXQodGhpcy5jb25maWcucm9sZSwge1xuICAgIGFsaWFzOiAnbmdwRGlhbG9nUm9sZScsXG4gIH0pO1xuXG4gIC8qKiBXaGV0aGVyIHRoZSBkaWFsb2cgaXMgYSBtb2RhbC4gKi9cbiAgcmVhZG9ubHkgbW9kYWwgPSBpbnB1dDxib29sZWFuLCBCb29sZWFuSW5wdXQ+KHRoaXMuY29uZmlnLm1vZGFsID8/IGZhbHNlLCB7XG4gICAgYWxpYXM6ICduZ3BEaWFsb2dNb2RhbCcsXG4gICAgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlLFxuICB9KTtcblxuICAvKiogVGhlIGxhYmVsbGVkYnkgaWRzICovXG4gIHByb3RlY3RlZCByZWFkb25seSBsYWJlbGxlZEJ5ID0gc2lnbmFsPHN0cmluZ1tdPihbXSk7XG5cbiAgLyoqIFRoZSBkZXNjcmliZWRieSBpZHMgKi9cbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGRlc2NyaWJlZEJ5ID0gc2lnbmFsPHN0cmluZ1tdPihbXSk7XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5jbG9zZSgpO1xuICB9XG5cbiAgLyoqIENsb3NlIHRoZSBkaWFsb2cuICovXG4gIGNsb3NlKCk6IHZvaWQge1xuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKCk7XG4gIH1cblxuICAvKiogU3RvcCBjbGljayBldmVudHMgZnJvbSBwcm9wYWdhdGluZyB0byB0aGUgb3ZlcmxheSAqL1xuICBASG9zdExpc3RlbmVyKCdjbGljaycsIFsnJGV2ZW50J10pXG4gIHByb3RlY3RlZCBvbkNsaWNrKGV2ZW50OiBFdmVudCk6IHZvaWQge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICB9XG5cbiAgLyoqIEBpbnRlcm5hbCByZWdpc3RlciBhIGxhYmVsbGVkYnkgaWQgKi9cbiAgc2V0TGFiZWxsZWRCeShpZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5sYWJlbGxlZEJ5LnVwZGF0ZShpZHMgPT4gWy4uLmlkcywgaWRdKTtcbiAgfVxuXG4gIC8qKiBAaW50ZXJuYWwgcmVnaXN0ZXIgYSBkZXNjcmliZWRieSBpZCAqL1xuICBzZXREZXNjcmliZWRCeShpZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5kZXNjcmliZWRCeS51cGRhdGUoaWRzID0+IFsuLi5pZHMsIGlkXSk7XG4gIH1cblxuICAvKiogQGludGVybmFsIHJlbW92ZSBhIGxhYmVsbGVkYnkgaWQgKi9cbiAgcmVtb3ZlTGFiZWxsZWRCeShpZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5sYWJlbGxlZEJ5LnVwZGF0ZShpZHMgPT4gaWRzLmZpbHRlcihpID0+IGkgIT09IGlkKSk7XG4gIH1cblxuICAvKiogQGludGVybmFsIHJlbW92ZSBhIGRlc2NyaWJlZGJ5IGlkICovXG4gIHJlbW92ZURlc2NyaWJlZEJ5KGlkOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLmRlc2NyaWJlZEJ5LnVwZGF0ZShpZHMgPT4gaWRzLmZpbHRlcihpID0+IGkgIT09IGlkKSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the Apache 2.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
import { Overlay, OverlayConfig, OverlayContainer } from '@angular/cdk/overlay';
|
|
9
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
10
|
+
import { Injectable, Injector, inject, isDevMode, } from '@angular/core';
|
|
11
|
+
import { uniqueId } from 'ng-primitives/utils';
|
|
12
|
+
import { Subject, defer } from 'rxjs';
|
|
13
|
+
import { startWith } from 'rxjs/operators';
|
|
14
|
+
import { injectDialogConfig } from '../config/dialog.config';
|
|
15
|
+
import { NgpDialogRef } from './dialog-ref';
|
|
16
|
+
import * as i0 from "@angular/core";
|
|
17
|
+
/**
|
|
18
|
+
* This is based on the Angular CDK Dialog service.
|
|
19
|
+
* https://github.com/angular/components/blob/main/src/cdk/dialog/dialog.ts
|
|
20
|
+
*/
|
|
21
|
+
export class NgpDialogManager {
|
|
22
|
+
constructor() {
|
|
23
|
+
this.overlay = inject(Overlay);
|
|
24
|
+
this.defaultOptions = injectDialogConfig();
|
|
25
|
+
this.parentDialogManager = inject(NgpDialogManager, {
|
|
26
|
+
optional: true,
|
|
27
|
+
skipSelf: true,
|
|
28
|
+
});
|
|
29
|
+
this.overlayContainer = inject(OverlayContainer);
|
|
30
|
+
this.scrollStrategy = this.defaultOptions.scrollStrategy ?? this.overlay.scrollStrategies.block();
|
|
31
|
+
this.openDialogsAtThisLevel = [];
|
|
32
|
+
this.afterAllClosedAtThisLevel = new Subject();
|
|
33
|
+
this.afterOpenedAtThisLevel = new Subject();
|
|
34
|
+
this.ariaHiddenElements = new Map();
|
|
35
|
+
/**
|
|
36
|
+
* Stream that emits when all open dialog have finished closing.
|
|
37
|
+
* Will emit on subscribe if there are no open dialogs to begin with.
|
|
38
|
+
*/
|
|
39
|
+
this.afterAllClosed = defer(() => this.openDialogs.length
|
|
40
|
+
? this.getAfterAllClosed()
|
|
41
|
+
: this.getAfterAllClosed().pipe(startWith(undefined)));
|
|
42
|
+
}
|
|
43
|
+
/** Keeps track of the currently-open dialogs. */
|
|
44
|
+
get openDialogs() {
|
|
45
|
+
return this.parentDialogManager
|
|
46
|
+
? this.parentDialogManager.openDialogs
|
|
47
|
+
: this.openDialogsAtThisLevel;
|
|
48
|
+
}
|
|
49
|
+
/** Stream that emits when a dialog has been opened. */
|
|
50
|
+
get afterOpened() {
|
|
51
|
+
return this.parentDialogManager
|
|
52
|
+
? this.parentDialogManager.afterOpened
|
|
53
|
+
: this.afterOpenedAtThisLevel;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Opens a modal dialog containing the given template.
|
|
57
|
+
*/
|
|
58
|
+
open(templateRef, config) {
|
|
59
|
+
const defaults = this.defaultOptions;
|
|
60
|
+
config = { ...defaults, ...config };
|
|
61
|
+
config.id = config.id ?? uniqueId('ngp-dialog');
|
|
62
|
+
if (config.id && this.getDialogById(config.id) && isDevMode()) {
|
|
63
|
+
throw Error(`Dialog with id "${config.id}" exists already. The dialog id must be unique.`);
|
|
64
|
+
}
|
|
65
|
+
const overlayConfig = this.getOverlayConfig(config);
|
|
66
|
+
const overlayRef = this.overlay.create(overlayConfig);
|
|
67
|
+
const dialogRef = new NgpDialogRef(overlayRef, config);
|
|
68
|
+
const injector = this.createInjector(config, dialogRef, undefined);
|
|
69
|
+
const context = {
|
|
70
|
+
$implicit: dialogRef,
|
|
71
|
+
close: dialogRef.close.bind(dialogRef),
|
|
72
|
+
};
|
|
73
|
+
overlayRef.attach(new TemplatePortal(templateRef, config.viewContainerRef, context, injector));
|
|
74
|
+
// If this is the first dialog that we're opening, hide all the non-overlay content.
|
|
75
|
+
if (!this.openDialogs.length) {
|
|
76
|
+
this.hideNonDialogContentFromAssistiveTechnology();
|
|
77
|
+
}
|
|
78
|
+
this.openDialogs.push(dialogRef);
|
|
79
|
+
dialogRef.closed.subscribe(() => this.removeOpenDialog(dialogRef, true));
|
|
80
|
+
this.afterOpened.next(dialogRef);
|
|
81
|
+
return dialogRef;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Closes all of the currently-open dialogs.
|
|
85
|
+
*/
|
|
86
|
+
closeAll() {
|
|
87
|
+
reverseForEach(this.openDialogs, dialog => dialog.close());
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Finds an open dialog by its id.
|
|
91
|
+
* @param id ID to use when looking up the dialog.
|
|
92
|
+
*/
|
|
93
|
+
getDialogById(id) {
|
|
94
|
+
return this.openDialogs.find(dialog => dialog.id === id);
|
|
95
|
+
}
|
|
96
|
+
ngOnDestroy() {
|
|
97
|
+
// Make one pass over all the dialogs that need to be untracked, but should not be closed. We
|
|
98
|
+
// want to stop tracking the open dialog even if it hasn't been closed, because the tracking
|
|
99
|
+
// determines when `aria-hidden` is removed from elements outside the dialog.
|
|
100
|
+
reverseForEach(this.openDialogsAtThisLevel, dialog => {
|
|
101
|
+
// Check for `false` specifically since we want `undefined` to be interpreted as `true`.
|
|
102
|
+
this.removeOpenDialog(dialog, false);
|
|
103
|
+
});
|
|
104
|
+
// Make a second pass and close the remaining dialogs. We do this second pass in order to
|
|
105
|
+
// correctly dispatch the `afterAllClosed` event in case we have a mixed array of dialogs
|
|
106
|
+
// that should be closed and dialogs that should not.
|
|
107
|
+
reverseForEach(this.openDialogsAtThisLevel, dialog => dialog.close());
|
|
108
|
+
this.afterAllClosedAtThisLevel.complete();
|
|
109
|
+
this.afterOpenedAtThisLevel.complete();
|
|
110
|
+
this.openDialogsAtThisLevel = [];
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Creates an overlay config from a dialog config.
|
|
114
|
+
*/
|
|
115
|
+
getOverlayConfig(config) {
|
|
116
|
+
const state = new OverlayConfig({
|
|
117
|
+
positionStrategy: this.overlay.position().global().centerHorizontally().centerVertically(),
|
|
118
|
+
scrollStrategy: config.scrollStrategy || this.scrollStrategy,
|
|
119
|
+
hasBackdrop: false,
|
|
120
|
+
disposeOnNavigation: config.closeOnNavigation,
|
|
121
|
+
});
|
|
122
|
+
return state;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Creates a custom injector to be used inside the dialog. This allows a component loaded inside
|
|
126
|
+
* of a dialog to close itself and, optionally, to return a value.
|
|
127
|
+
*/
|
|
128
|
+
createInjector(config, dialogRef, fallbackInjector) {
|
|
129
|
+
const userInjector = config.injector || config.viewContainerRef?.injector;
|
|
130
|
+
const providers = [{ provide: NgpDialogRef, useValue: dialogRef }];
|
|
131
|
+
return Injector.create({ parent: userInjector || fallbackInjector, providers });
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Removes a dialog from the array of open dialogs.
|
|
135
|
+
*/
|
|
136
|
+
removeOpenDialog(dialogRef, emitEvent) {
|
|
137
|
+
const index = this.openDialogs.indexOf(dialogRef);
|
|
138
|
+
if (index > -1) {
|
|
139
|
+
this.openDialogs.splice(index, 1);
|
|
140
|
+
// If all the dialogs were closed, remove/restore the `aria-hidden`
|
|
141
|
+
// to a the siblings and emit to the `afterAllClosed` stream.
|
|
142
|
+
if (!this.openDialogs.length) {
|
|
143
|
+
this.ariaHiddenElements.forEach((previousValue, element) => {
|
|
144
|
+
if (previousValue) {
|
|
145
|
+
element.setAttribute('aria-hidden', previousValue);
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
element.removeAttribute('aria-hidden');
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
this.ariaHiddenElements.clear();
|
|
152
|
+
if (emitEvent) {
|
|
153
|
+
this.getAfterAllClosed().next();
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
/** Hides all of the content that isn't an overlay from assistive technology. */
|
|
159
|
+
hideNonDialogContentFromAssistiveTechnology() {
|
|
160
|
+
const overlayContainer = this.overlayContainer.getContainerElement();
|
|
161
|
+
// Ensure that the overlay container is attached to the DOM.
|
|
162
|
+
if (overlayContainer.parentElement) {
|
|
163
|
+
const siblings = overlayContainer.parentElement.children;
|
|
164
|
+
for (let i = siblings.length - 1; i > -1; i--) {
|
|
165
|
+
const sibling = siblings[i];
|
|
166
|
+
if (sibling !== overlayContainer &&
|
|
167
|
+
sibling.nodeName !== 'SCRIPT' &&
|
|
168
|
+
sibling.nodeName !== 'STYLE' &&
|
|
169
|
+
!sibling.hasAttribute('aria-live')) {
|
|
170
|
+
this.ariaHiddenElements.set(sibling, sibling.getAttribute('aria-hidden'));
|
|
171
|
+
sibling.setAttribute('aria-hidden', 'true');
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
getAfterAllClosed() {
|
|
177
|
+
const parent = this.parentDialogManager;
|
|
178
|
+
return parent ? parent.getAfterAllClosed() : this.afterAllClosedAtThisLevel;
|
|
179
|
+
}
|
|
180
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogManager, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
181
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogManager, providedIn: 'root' }); }
|
|
182
|
+
}
|
|
183
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogManager, decorators: [{
|
|
184
|
+
type: Injectable,
|
|
185
|
+
args: [{
|
|
186
|
+
providedIn: 'root',
|
|
187
|
+
}]
|
|
188
|
+
}] });
|
|
189
|
+
/**
|
|
190
|
+
* Executes a callback against all elements in an array while iterating in reverse.
|
|
191
|
+
* Useful if the array is being modified as it is being iterated.
|
|
192
|
+
*/
|
|
193
|
+
function reverseForEach(items, callback) {
|
|
194
|
+
let i = items.length;
|
|
195
|
+
while (i--) {
|
|
196
|
+
callback(items[i]);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
export function injectDialogManager() {
|
|
200
|
+
return inject(NgpDialogManager);
|
|
201
|
+
}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../../packages/ng-primitives/dialog/src/dialog/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Copyright © 2024 Angular Primitives.\n * https://github.com/ng-primitives/ng-primitives\n *\n * This source code is licensed under the Apache 2.0 license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { Overlay, OverlayConfig, OverlayContainer, ScrollStrategy } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport {\n  Injectable,\n  Injector,\n  OnDestroy,\n  StaticProvider,\n  TemplateRef,\n  inject,\n  isDevMode,\n} from '@angular/core';\nimport { uniqueId } from 'ng-primitives/utils';\nimport { Observable, Subject, defer } from 'rxjs';\nimport { startWith } from 'rxjs/operators';\nimport { NgpDialogConfig, injectDialogConfig } from '../config/dialog.config';\nimport { NgpDialogRef } from './dialog-ref';\n\n/**\n * This is based on the Angular CDK Dialog service.\n * https://github.com/angular/components/blob/main/src/cdk/dialog/dialog.ts\n */\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class NgpDialogManager implements OnDestroy {\n  private readonly overlay = inject(Overlay);\n  private readonly defaultOptions = injectDialogConfig();\n  private readonly parentDialogManager = inject(NgpDialogManager, {\n    optional: true,\n    skipSelf: true,\n  });\n  private readonly overlayContainer = inject(OverlayContainer);\n  private readonly scrollStrategy: ScrollStrategy =\n    this.defaultOptions.scrollStrategy ?? this.overlay.scrollStrategies.block();\n\n  private openDialogsAtThisLevel: NgpDialogRef[] = [];\n  private readonly afterAllClosedAtThisLevel = new Subject<void>();\n  private readonly afterOpenedAtThisLevel = new Subject<NgpDialogRef>();\n  private ariaHiddenElements = new Map<Element, string | null>();\n\n  /** Keeps track of the currently-open dialogs. */\n  get openDialogs(): readonly NgpDialogRef[] {\n    return this.parentDialogManager\n      ? this.parentDialogManager.openDialogs\n      : this.openDialogsAtThisLevel;\n  }\n\n  /** Stream that emits when a dialog has been opened. */\n  get afterOpened(): Subject<NgpDialogRef> {\n    return this.parentDialogManager\n      ? this.parentDialogManager.afterOpened\n      : this.afterOpenedAtThisLevel;\n  }\n\n  /**\n   * Stream that emits when all open dialog have finished closing.\n   * Will emit on subscribe if there are no open dialogs to begin with.\n   */\n  readonly afterAllClosed: Observable<void> = defer(() =>\n    this.openDialogs.length\n      ? this.getAfterAllClosed()\n      : this.getAfterAllClosed().pipe(startWith(undefined)),\n  );\n\n  /**\n   * Opens a modal dialog containing the given template.\n   */\n  open(templateRef: TemplateRef<NgpDialogContext>, config?: NgpDialogConfig): NgpDialogRef {\n    const defaults = this.defaultOptions;\n    config = { ...defaults, ...config };\n    config.id = config.id ?? uniqueId('ngp-dialog');\n\n    if (config.id && this.getDialogById(config.id) && isDevMode()) {\n      throw Error(`Dialog with id \"${config.id}\" exists already. The dialog id must be unique.`);\n    }\n\n    const overlayConfig = this.getOverlayConfig(config);\n    const overlayRef = this.overlay.create(overlayConfig);\n    const dialogRef = new NgpDialogRef(overlayRef, config);\n    const injector = this.createInjector(config, dialogRef, undefined);\n    const context: NgpDialogContext = {\n      $implicit: dialogRef,\n      close: dialogRef.close.bind(dialogRef),\n    };\n\n    overlayRef.attach(new TemplatePortal(templateRef, config.viewContainerRef!, context, injector));\n\n    // If this is the first dialog that we're opening, hide all the non-overlay content.\n    if (!this.openDialogs.length) {\n      this.hideNonDialogContentFromAssistiveTechnology();\n    }\n\n    (this.openDialogs as NgpDialogRef[]).push(dialogRef);\n    dialogRef.closed.subscribe(() => this.removeOpenDialog(dialogRef, true));\n    this.afterOpened.next(dialogRef);\n\n    return dialogRef;\n  }\n\n  /**\n   * Closes all of the currently-open dialogs.\n   */\n  closeAll(): void {\n    reverseForEach(this.openDialogs, dialog => dialog.close());\n  }\n\n  /**\n   * Finds an open dialog by its id.\n   * @param id ID to use when looking up the dialog.\n   */\n  getDialogById(id: string): NgpDialogRef | undefined {\n    return this.openDialogs.find(dialog => dialog.id === id);\n  }\n\n  ngOnDestroy(): void {\n    // Make one pass over all the dialogs that need to be untracked, but should not be closed. We\n    // want to stop tracking the open dialog even if it hasn't been closed, because the tracking\n    // determines when `aria-hidden` is removed from elements outside the dialog.\n    reverseForEach(this.openDialogsAtThisLevel, dialog => {\n      // Check for `false` specifically since we want `undefined` to be interpreted as `true`.\n      this.removeOpenDialog(dialog, false);\n    });\n\n    // Make a second pass and close the remaining dialogs. We do this second pass in order to\n    // correctly dispatch the `afterAllClosed` event in case we have a mixed array of dialogs\n    // that should be closed and dialogs that should not.\n    reverseForEach(this.openDialogsAtThisLevel, dialog => dialog.close());\n\n    this.afterAllClosedAtThisLevel.complete();\n    this.afterOpenedAtThisLevel.complete();\n    this.openDialogsAtThisLevel = [];\n  }\n\n  /**\n   * Creates an overlay config from a dialog config.\n   */\n  private getOverlayConfig(config: NgpDialogConfig): OverlayConfig {\n    const state = new OverlayConfig({\n      positionStrategy: this.overlay.position().global().centerHorizontally().centerVertically(),\n      scrollStrategy: config.scrollStrategy || this.scrollStrategy,\n      hasBackdrop: false,\n      disposeOnNavigation: config.closeOnNavigation,\n    });\n\n    return state;\n  }\n\n  /**\n   * Creates a custom injector to be used inside the dialog. This allows a component loaded inside\n   * of a dialog to close itself and, optionally, to return a value.\n   */\n  private createInjector(\n    config: NgpDialogConfig,\n    dialogRef: NgpDialogRef,\n    fallbackInjector: Injector | undefined,\n  ): Injector {\n    const userInjector = config.injector || config.viewContainerRef?.injector;\n    const providers: StaticProvider[] = [{ provide: NgpDialogRef, useValue: dialogRef }];\n\n    return Injector.create({ parent: userInjector || fallbackInjector, providers });\n  }\n\n  /**\n   * Removes a dialog from the array of open dialogs.\n   */\n  private removeOpenDialog(dialogRef: NgpDialogRef, emitEvent: boolean) {\n    const index = this.openDialogs.indexOf(dialogRef);\n\n    if (index > -1) {\n      (this.openDialogs as NgpDialogRef[]).splice(index, 1);\n\n      // If all the dialogs were closed, remove/restore the `aria-hidden`\n      // to a the siblings and emit to the `afterAllClosed` stream.\n      if (!this.openDialogs.length) {\n        this.ariaHiddenElements.forEach((previousValue, element) => {\n          if (previousValue) {\n            element.setAttribute('aria-hidden', previousValue);\n          } else {\n            element.removeAttribute('aria-hidden');\n          }\n        });\n\n        this.ariaHiddenElements.clear();\n\n        if (emitEvent) {\n          this.getAfterAllClosed().next();\n        }\n      }\n    }\n  }\n\n  /** Hides all of the content that isn't an overlay from assistive technology. */\n  private hideNonDialogContentFromAssistiveTechnology() {\n    const overlayContainer = this.overlayContainer.getContainerElement();\n\n    // Ensure that the overlay container is attached to the DOM.\n    if (overlayContainer.parentElement) {\n      const siblings = overlayContainer.parentElement.children;\n\n      for (let i = siblings.length - 1; i > -1; i--) {\n        const sibling = siblings[i];\n\n        if (\n          sibling !== overlayContainer &&\n          sibling.nodeName !== 'SCRIPT' &&\n          sibling.nodeName !== 'STYLE' &&\n          !sibling.hasAttribute('aria-live')\n        ) {\n          this.ariaHiddenElements.set(sibling, sibling.getAttribute('aria-hidden'));\n          sibling.setAttribute('aria-hidden', 'true');\n        }\n      }\n    }\n  }\n\n  private getAfterAllClosed(): Subject<void> {\n    const parent = this.parentDialogManager;\n    return parent ? parent.getAfterAllClosed() : this.afterAllClosedAtThisLevel;\n  }\n}\n\n/**\n * Executes a callback against all elements in an array while iterating in reverse.\n * Useful if the array is being modified as it is being iterated.\n */\nfunction reverseForEach<T>(items: T[] | readonly T[], callback: (current: T) => void) {\n  let i = items.length;\n\n  while (i--) {\n    callback(items[i]);\n  }\n}\n\nexport interface NgpDialogContext {\n  $implicit: NgpDialogRef;\n  close: () => void;\n}\n\nexport function injectDialogManager(): NgpDialogManager {\n  return inject(NgpDialogManager);\n}\n"]}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the Apache 2.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
import { Directive, input } from '@angular/core';
|
|
9
|
+
import { onChange, uniqueId } from 'ng-primitives/utils';
|
|
10
|
+
import { injectDialog } from '../dialog/dialog.token';
|
|
11
|
+
import { NgpDialogDescriptionToken } from './dialog-description.token';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
export class NgpDialogDescription {
|
|
14
|
+
constructor() {
|
|
15
|
+
/** Access the dialog */
|
|
16
|
+
this.dialog = injectDialog();
|
|
17
|
+
/** The id of the descriptions. */
|
|
18
|
+
this.id = input(uniqueId('ngp-dialog-description'));
|
|
19
|
+
onChange(this.id, (id, prevId) => {
|
|
20
|
+
if (prevId) {
|
|
21
|
+
this.dialog.removeDescribedBy(prevId);
|
|
22
|
+
}
|
|
23
|
+
if (id) {
|
|
24
|
+
this.dialog.setDescribedBy(id);
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
ngOnDestroy() {
|
|
29
|
+
this.dialog.removeDescribedBy(this.id());
|
|
30
|
+
}
|
|
31
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogDescription, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
32
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.1", type: NgpDialogDescription, isStandalone: true, selector: "[ngpDialogDescription]", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "id": "id()" } }, providers: [{ provide: NgpDialogDescriptionToken, useExisting: NgpDialogDescription }], exportAs: ["ngpDialogDescription"], ngImport: i0 }); }
|
|
33
|
+
}
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogDescription, decorators: [{
|
|
35
|
+
type: Directive,
|
|
36
|
+
args: [{
|
|
37
|
+
standalone: true,
|
|
38
|
+
selector: '[ngpDialogDescription]',
|
|
39
|
+
exportAs: 'ngpDialogDescription',
|
|
40
|
+
providers: [{ provide: NgpDialogDescriptionToken, useExisting: NgpDialogDescription }],
|
|
41
|
+
host: {
|
|
42
|
+
'[id]': 'id()',
|
|
43
|
+
},
|
|
44
|
+
}]
|
|
45
|
+
}], ctorParameters: () => [] });
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWRlc2NyaXB0aW9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL25nLXByaW1pdGl2ZXMvZGlhbG9nL3NyYy9kaWFsb2ctZGVzY3JpcHRpb24vZGlhbG9nLWRlc2NyaXB0aW9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN0RCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFXdkUsTUFBTSxPQUFPLG9CQUFvQjtJQU8vQjtRQU5BLHdCQUF3QjtRQUNQLFdBQU0sR0FBRyxZQUFZLEVBQUUsQ0FBQztRQUV6QyxrQ0FBa0M7UUFDekIsT0FBRSxHQUFHLEtBQUssQ0FBUyxRQUFRLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxDQUFDO1FBRzlELFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsRUFBRSxFQUFFLE1BQU0sRUFBRSxFQUFFO1lBQy9CLElBQUksTUFBTSxFQUFFLENBQUM7Z0JBQ1gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUN4QyxDQUFDO1lBRUQsSUFBSSxFQUFFLEVBQUUsQ0FBQztnQkFDUCxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUNqQyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDM0MsQ0FBQzs4R0FyQlUsb0JBQW9CO2tHQUFwQixvQkFBb0Isd09BTHBCLENBQUMsRUFBRSxPQUFPLEVBQUUseUJBQXlCLEVBQUUsV0FBVyxFQUFFLG9CQUFvQixFQUFFLENBQUM7OzJGQUszRSxvQkFBb0I7a0JBVGhDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFNBQVMsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLFdBQVcsc0JBQXNCLEVBQUUsQ0FBQztvQkFDdEYsSUFBSSxFQUFFO3dCQUNKLE1BQU0sRUFBRSxNQUFNO3FCQUNmO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgwqkgMjAyNCBBbmd1bGFyIFByaW1pdGl2ZXMuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vbmctcHJpbWl0aXZlcy9uZy1wcmltaXRpdmVzXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIDIuMCBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5pbXBvcnQgeyBEaXJlY3RpdmUsIGlucHV0LCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IG9uQ2hhbmdlLCB1bmlxdWVJZCB9IGZyb20gJ25nLXByaW1pdGl2ZXMvdXRpbHMnO1xuaW1wb3J0IHsgaW5qZWN0RGlhbG9nIH0gZnJvbSAnLi4vZGlhbG9nL2RpYWxvZy50b2tlbic7XG5pbXBvcnQgeyBOZ3BEaWFsb2dEZXNjcmlwdGlvblRva2VuIH0gZnJvbSAnLi9kaWFsb2ctZGVzY3JpcHRpb24udG9rZW4nO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdbbmdwRGlhbG9nRGVzY3JpcHRpb25dJyxcbiAgZXhwb3J0QXM6ICduZ3BEaWFsb2dEZXNjcmlwdGlvbicsXG4gIHByb3ZpZGVyczogW3sgcHJvdmlkZTogTmdwRGlhbG9nRGVzY3JpcHRpb25Ub2tlbiwgdXNlRXhpc3Rpbmc6IE5ncERpYWxvZ0Rlc2NyaXB0aW9uIH1dLFxuICBob3N0OiB7XG4gICAgJ1tpZF0nOiAnaWQoKScsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIE5ncERpYWxvZ0Rlc2NyaXB0aW9uIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgLyoqIEFjY2VzcyB0aGUgZGlhbG9nICovXG4gIHByaXZhdGUgcmVhZG9ubHkgZGlhbG9nID0gaW5qZWN0RGlhbG9nKCk7XG5cbiAgLyoqIFRoZSBpZCBvZiB0aGUgZGVzY3JpcHRpb25zLiAqL1xuICByZWFkb25seSBpZCA9IGlucHV0PHN0cmluZz4odW5pcXVlSWQoJ25ncC1kaWFsb2ctZGVzY3JpcHRpb24nKSk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgb25DaGFuZ2UodGhpcy5pZCwgKGlkLCBwcmV2SWQpID0+IHtcbiAgICAgIGlmIChwcmV2SWQpIHtcbiAgICAgICAgdGhpcy5kaWFsb2cucmVtb3ZlRGVzY3JpYmVkQnkocHJldklkKTtcbiAgICAgIH1cblxuICAgICAgaWYgKGlkKSB7XG4gICAgICAgIHRoaXMuZGlhbG9nLnNldERlc2NyaWJlZEJ5KGlkKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuZGlhbG9nLnJlbW92ZURlc2NyaWJlZEJ5KHRoaXMuaWQoKSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the Apache 2.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
import { InjectionToken, inject } from '@angular/core';
|
|
9
|
+
export const NgpDialogDescriptionToken = new InjectionToken('NgpDialogDescriptionToken');
|
|
10
|
+
/**
|
|
11
|
+
* Inject the DialogDescription directive instance
|
|
12
|
+
*/
|
|
13
|
+
export function injectDialogDescription() {
|
|
14
|
+
return inject(NgpDialogDescriptionToken);
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWRlc2NyaXB0aW9uLnRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbmctcHJpbWl0aXZlcy9kaWFsb2cvc3JjL2RpYWxvZy1kZXNjcmlwdGlvbi9kaWFsb2ctZGVzY3JpcHRpb24udG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBQ0gsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdkQsTUFBTSxDQUFDLE1BQU0seUJBQXlCLEdBQUcsSUFBSSxjQUFjLENBQ3pELDJCQUEyQixDQUM1QixDQUFDO0FBRUY7O0dBRUc7QUFDSCxNQUFNLFVBQVUsdUJBQXVCO0lBQ3JDLE9BQU8sTUFBTSxDQUFDLHlCQUF5QixDQUFDLENBQUM7QUFDM0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IMKpIDIwMjQgQW5ndWxhciBQcmltaXRpdmVzLlxuICogaHR0cHM6Ly9naXRodWIuY29tL25nLXByaW1pdGl2ZXMvbmctcHJpbWl0aXZlc1xuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSAyLjAgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUgeyBOZ3BEaWFsb2dEZXNjcmlwdGlvbiB9IGZyb20gJy4vZGlhbG9nLWRlc2NyaXB0aW9uLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCBjb25zdCBOZ3BEaWFsb2dEZXNjcmlwdGlvblRva2VuID0gbmV3IEluamVjdGlvblRva2VuPE5ncERpYWxvZ0Rlc2NyaXB0aW9uPihcbiAgJ05ncERpYWxvZ0Rlc2NyaXB0aW9uVG9rZW4nLFxuKTtcblxuLyoqXG4gKiBJbmplY3QgdGhlIERpYWxvZ0Rlc2NyaXB0aW9uIGRpcmVjdGl2ZSBpbnN0YW5jZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0RGlhbG9nRGVzY3JpcHRpb24oKTogTmdwRGlhbG9nRGVzY3JpcHRpb24ge1xuICByZXR1cm4gaW5qZWN0KE5ncERpYWxvZ0Rlc2NyaXB0aW9uVG9rZW4pO1xufVxuIl19
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the Apache 2.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
import { Directive, HostListener } from '@angular/core';
|
|
9
|
+
import { injectDialogRef } from '../dialog/dialog-ref';
|
|
10
|
+
import { NgpDialogOverlayToken } from './dialog-overlay.token';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
export class NgpDialogOverlay {
|
|
13
|
+
constructor() {
|
|
14
|
+
/** Access the dialog ref. */
|
|
15
|
+
this.dialogRef = injectDialogRef();
|
|
16
|
+
}
|
|
17
|
+
close() {
|
|
18
|
+
this.dialogRef.close();
|
|
19
|
+
}
|
|
20
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogOverlay, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
21
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.1", type: NgpDialogOverlay, isStandalone: true, selector: "[ngpDialogOverlay]", host: { listeners: { "click": "close()" } }, providers: [{ provide: NgpDialogOverlayToken, useExisting: NgpDialogOverlay }], exportAs: ["ngpDialogOverlay"], ngImport: i0 }); }
|
|
22
|
+
}
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogOverlay, decorators: [{
|
|
24
|
+
type: Directive,
|
|
25
|
+
args: [{
|
|
26
|
+
standalone: true,
|
|
27
|
+
selector: '[ngpDialogOverlay]',
|
|
28
|
+
exportAs: 'ngpDialogOverlay',
|
|
29
|
+
providers: [{ provide: NgpDialogOverlayToken, useExisting: NgpDialogOverlay }],
|
|
30
|
+
}]
|
|
31
|
+
}], propDecorators: { close: [{
|
|
32
|
+
type: HostListener,
|
|
33
|
+
args: ['click']
|
|
34
|
+
}] } });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLW92ZXJsYXkuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbmctcHJpbWl0aXZlcy9kaWFsb2cvc3JjL2RpYWxvZy1vdmVybGF5L2RpYWxvZy1vdmVybGF5LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBUS9ELE1BQU0sT0FBTyxnQkFBZ0I7SUFON0I7UUFPRSw2QkFBNkI7UUFDWixjQUFTLEdBQUcsZUFBZSxFQUFFLENBQUM7S0FNaEQ7SUFIVyxLQUFLO1FBQ2IsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN6QixDQUFDOzhHQVBVLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLDhHQUZoQixDQUFDLEVBQUUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxDQUFDOzsyRkFFbkUsZ0JBQWdCO2tCQU41QixTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxXQUFXLGtCQUFrQixFQUFFLENBQUM7aUJBQy9FOzhCQU1XLEtBQUs7c0JBRGQsWUFBWTt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgwqkgMjAyNCBBbmd1bGFyIFByaW1pdGl2ZXMuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vbmctcHJpbWl0aXZlcy9uZy1wcmltaXRpdmVzXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIDIuMCBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5pbXBvcnQgeyBEaXJlY3RpdmUsIEhvc3RMaXN0ZW5lciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5qZWN0RGlhbG9nUmVmIH0gZnJvbSAnLi4vZGlhbG9nL2RpYWxvZy1yZWYnO1xuaW1wb3J0IHsgTmdwRGlhbG9nT3ZlcmxheVRva2VuIH0gZnJvbSAnLi9kaWFsb2ctb3ZlcmxheS50b2tlbic7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ1tuZ3BEaWFsb2dPdmVybGF5XScsXG4gIGV4cG9ydEFzOiAnbmdwRGlhbG9nT3ZlcmxheScsXG4gIHByb3ZpZGVyczogW3sgcHJvdmlkZTogTmdwRGlhbG9nT3ZlcmxheVRva2VuLCB1c2VFeGlzdGluZzogTmdwRGlhbG9nT3ZlcmxheSB9XSxcbn0pXG5leHBvcnQgY2xhc3MgTmdwRGlhbG9nT3ZlcmxheSB7XG4gIC8qKiBBY2Nlc3MgdGhlIGRpYWxvZyByZWYuICovXG4gIHByaXZhdGUgcmVhZG9ubHkgZGlhbG9nUmVmID0gaW5qZWN0RGlhbG9nUmVmKCk7XG5cbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snKVxuICBwcm90ZWN0ZWQgY2xvc2UoKTogdm9pZCB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright © 2024 Angular Primitives.
|
|
3
|
+
* https://github.com/ng-primitives/ng-primitives
|
|
4
|
+
*
|
|
5
|
+
* This source code is licensed under the Apache 2.0 license found in the
|
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
|
7
|
+
*/
|
|
8
|
+
import { InjectionToken, inject } from '@angular/core';
|
|
9
|
+
export const NgpDialogOverlayToken = new InjectionToken('NgpDialogOverlayToken');
|
|
10
|
+
/**
|
|
11
|
+
* Inject the DialogOverlay directive instance
|
|
12
|
+
*/
|
|
13
|
+
export function injectDialogOverlay() {
|
|
14
|
+
return inject(NgpDialogOverlayToken);
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLW92ZXJsYXkudG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9uZy1wcmltaXRpdmVzL2RpYWxvZy9zcmMvZGlhbG9nLW92ZXJsYXkvZGlhbG9nLW92ZXJsYXkudG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBQ0gsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHdkQsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsSUFBSSxjQUFjLENBQW1CLHVCQUF1QixDQUFDLENBQUM7QUFFbkc7O0dBRUc7QUFDSCxNQUFNLFVBQVUsbUJBQW1CO0lBQ2pDLE9BQU8sTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7QUFDdkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IMKpIDIwMjQgQW5ndWxhciBQcmltaXRpdmVzLlxuICogaHR0cHM6Ly9naXRodWIuY29tL25nLXByaW1pdGl2ZXMvbmctcHJpbWl0aXZlc1xuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSAyLjAgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqL1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUgeyBOZ3BEaWFsb2dPdmVybGF5IH0gZnJvbSAnLi9kaWFsb2ctb3ZlcmxheS5kaXJlY3RpdmUnO1xuXG5leHBvcnQgY29uc3QgTmdwRGlhbG9nT3ZlcmxheVRva2VuID0gbmV3IEluamVjdGlvblRva2VuPE5ncERpYWxvZ092ZXJsYXk+KCdOZ3BEaWFsb2dPdmVybGF5VG9rZW4nKTtcblxuLyoqXG4gKiBJbmplY3QgdGhlIERpYWxvZ092ZXJsYXkgZGlyZWN0aXZlIGluc3RhbmNlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3REaWFsb2dPdmVybGF5KCk6IE5ncERpYWxvZ092ZXJsYXkge1xuICByZXR1cm4gaW5qZWN0KE5ncERpYWxvZ092ZXJsYXlUb2tlbik7XG59XG4iXX0=
|
|
@@ -6,18 +6,30 @@
|
|
|
6
6
|
* LICENSE file in the root directory of this source tree.
|
|
7
7
|
*/
|
|
8
8
|
import { Directive, input } from '@angular/core';
|
|
9
|
-
import { uniqueId } from 'ng-primitives/utils';
|
|
9
|
+
import { onChange, uniqueId } from 'ng-primitives/utils';
|
|
10
|
+
import { injectDialog } from '../dialog/dialog.token';
|
|
10
11
|
import { NgpDialogTitleToken } from './dialog-title.token';
|
|
11
12
|
import * as i0 from "@angular/core";
|
|
12
13
|
export class NgpDialogTitle {
|
|
13
14
|
constructor() {
|
|
14
|
-
/**
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
/** Access the dialog. */
|
|
16
|
+
this.dialog = injectDialog();
|
|
17
|
+
/** The id of the title. */
|
|
17
18
|
this.id = input(uniqueId('ngp-dialog-title'));
|
|
19
|
+
onChange(this.id, (id, prevId) => {
|
|
20
|
+
if (prevId) {
|
|
21
|
+
this.dialog.removeLabelledBy(prevId);
|
|
22
|
+
}
|
|
23
|
+
if (id) {
|
|
24
|
+
this.dialog.setLabelledBy(id);
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
ngOnDestroy() {
|
|
29
|
+
this.dialog.removeLabelledBy(this.id());
|
|
18
30
|
}
|
|
19
31
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogTitle, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
20
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.1", type: NgpDialogTitle, isStandalone: true, selector: "[ngpDialogTitle]", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null } }, providers: [{ provide: NgpDialogTitleToken, useExisting: NgpDialogTitle }], exportAs: ["ngpDialogTitle"], ngImport: i0 }); }
|
|
32
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.1.1", type: NgpDialogTitle, isStandalone: true, selector: "[ngpDialogTitle]", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "id": "id()" } }, providers: [{ provide: NgpDialogTitleToken, useExisting: NgpDialogTitle }], exportAs: ["ngpDialogTitle"], ngImport: i0 }); }
|
|
21
33
|
}
|
|
22
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgpDialogTitle, decorators: [{
|
|
23
35
|
type: Directive,
|
|
@@ -26,6 +38,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
|
|
|
26
38
|
selector: '[ngpDialogTitle]',
|
|
27
39
|
exportAs: 'ngpDialogTitle',
|
|
28
40
|
providers: [{ provide: NgpDialogTitleToken, useExisting: NgpDialogTitle }],
|
|
41
|
+
host: {
|
|
42
|
+
'[id]': 'id()',
|
|
43
|
+
},
|
|
29
44
|
}]
|
|
30
|
-
}] });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
}], ctorParameters: () => [] });
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXRpdGxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL25nLXByaW1pdGl2ZXMvZGlhbG9nL3NyYy9kaWFsb2ctdGl0bGUvZGlhbG9nLXRpdGxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFDSCxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN0RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFXM0QsTUFBTSxPQUFPLGNBQWM7SUFPekI7UUFOQSx5QkFBeUI7UUFDUixXQUFNLEdBQUcsWUFBWSxFQUFFLENBQUM7UUFFekMsMkJBQTJCO1FBQ2xCLE9BQUUsR0FBRyxLQUFLLENBQVMsUUFBUSxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQztRQUd4RCxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUMvQixJQUFJLE1BQU0sRUFBRSxDQUFDO2dCQUNYLElBQUksQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDdkMsQ0FBQztZQUVELElBQUksRUFBRSxFQUFFLENBQUM7Z0JBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDaEMsQ0FBQztRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsTUFBTSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzFDLENBQUM7OEdBckJVLGNBQWM7a0dBQWQsY0FBYyxrT0FMZCxDQUFDLEVBQUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsQ0FBQzs7MkZBSy9ELGNBQWM7a0JBVDFCLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLFNBQVMsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFdBQVcsZ0JBQWdCLEVBQUUsQ0FBQztvQkFDMUUsSUFBSSxFQUFFO3dCQUNKLE1BQU0sRUFBRSxNQUFNO3FCQUNmO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgwqkgMjAyNCBBbmd1bGFyIFByaW1pdGl2ZXMuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vbmctcHJpbWl0aXZlcy9uZy1wcmltaXRpdmVzXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIDIuMCBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICovXG5pbXBvcnQgeyBEaXJlY3RpdmUsIGlucHV0LCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IG9uQ2hhbmdlLCB1bmlxdWVJZCB9IGZyb20gJ25nLXByaW1pdGl2ZXMvdXRpbHMnO1xuaW1wb3J0IHsgaW5qZWN0RGlhbG9nIH0gZnJvbSAnLi4vZGlhbG9nL2RpYWxvZy50b2tlbic7XG5pbXBvcnQgeyBOZ3BEaWFsb2dUaXRsZVRva2VuIH0gZnJvbSAnLi9kaWFsb2ctdGl0bGUudG9rZW4nO1xuXG5ARGlyZWN0aXZlKHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdbbmdwRGlhbG9nVGl0bGVdJyxcbiAgZXhwb3J0QXM6ICduZ3BEaWFsb2dUaXRsZScsXG4gIHByb3ZpZGVyczogW3sgcHJvdmlkZTogTmdwRGlhbG9nVGl0bGVUb2tlbiwgdXNlRXhpc3Rpbmc6IE5ncERpYWxvZ1RpdGxlIH1dLFxuICBob3N0OiB7XG4gICAgJ1tpZF0nOiAnaWQoKScsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIE5ncERpYWxvZ1RpdGxlIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgLyoqIEFjY2VzcyB0aGUgZGlhbG9nLiAqL1xuICBwcml2YXRlIHJlYWRvbmx5IGRpYWxvZyA9IGluamVjdERpYWxvZygpO1xuXG4gIC8qKiBUaGUgaWQgb2YgdGhlIHRpdGxlLiAqL1xuICByZWFkb25seSBpZCA9IGlucHV0PHN0cmluZz4odW5pcXVlSWQoJ25ncC1kaWFsb2ctdGl0bGUnKSk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgb25DaGFuZ2UodGhpcy5pZCwgKGlkLCBwcmV2SWQpID0+IHtcbiAgICAgIGlmIChwcmV2SWQpIHtcbiAgICAgICAgdGhpcy5kaWFsb2cucmVtb3ZlTGFiZWxsZWRCeShwcmV2SWQpO1xuICAgICAgfVxuXG4gICAgICBpZiAoaWQpIHtcbiAgICAgICAgdGhpcy5kaWFsb2cuc2V0TGFiZWxsZWRCeShpZCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLmRpYWxvZy5yZW1vdmVMYWJlbGxlZEJ5KHRoaXMuaWQoKSk7XG4gIH1cbn1cbiJdfQ==
|