@alauda/ui 6.4.8-beta.8 → 6.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +59 -0
- package/core/animation/animation-consts.d.ts +5 -0
- package/dialog/confirm-dialog/confirm-dialog-config.d.ts +2 -1
- package/dialog/dialog-animations.d.ts +31 -0
- package/dialog/dialog-config.d.ts +5 -1
- package/dialog/dialog.component.d.ts +31 -4
- package/dialog/dialog.service.d.ts +1 -0
- package/esm2020/back-top/back-top.component.mjs +2 -2
- package/esm2020/core/animation/animation-consts.mjs +7 -0
- package/esm2020/date-picker/date-picker/date-picker.component.mjs +4 -4
- package/esm2020/date-picker/range-picker/range-picker.component.mjs +4 -4
- package/esm2020/date-picker/trigger/trigger.component.mjs +3 -3
- package/esm2020/dialog/confirm-dialog/confirm-dialog-config.mjs +4 -2
- package/esm2020/dialog/dialog-animations.mjs +58 -0
- package/esm2020/dialog/dialog-config.mjs +8 -2
- package/esm2020/dialog/dialog-ref.mjs +11 -6
- package/esm2020/dialog/dialog.component.mjs +108 -11
- package/esm2020/dialog/dialog.service.mjs +7 -2
- package/esm2020/icon/icons.mjs +2 -2
- package/esm2020/input/input.module.mjs +1 -5
- package/esm2020/input/number-input/number-input.component.mjs +10 -9
- package/esm2020/input/search/search.component.mjs +3 -3
- package/esm2020/input/tags-input/tags-input.component.mjs +2 -2
- package/esm2020/select/multi-select/multi-select.component.mjs +2 -2
- package/esm2020/table/table-scroll.directive.mjs +39 -25
- package/esm2020/table/table.component.mjs +2 -2
- package/esm2020/table/table.module.mjs +6 -6
- package/esm2020/tooltip/base-tooltip.mjs +14 -10
- package/esm2020/utils/animations.mjs +2 -0
- package/esm2020/utils/fn.mjs +11 -1
- package/fesm2015/alauda-ui.mjs +291 -87
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +291 -87
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/icon/icons.d.ts +1 -1
- package/input/input.module.d.ts +5 -6
- package/input/number-input/number-input.component.d.ts +3 -2
- package/package.json +1 -1
- package/table/table-scroll.directive.d.ts +10 -7
- package/table/table.module.d.ts +1 -1
- package/theme/_base-var.scss +8 -1
- package/theme/_mixin.scss +40 -3
- package/tooltip/base-tooltip.d.ts +6 -4
- package/utils/animations.d.ts +2 -0
- package/utils/fn.d.ts +4 -0
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { animate, query, state, style, transition, trigger, } from '@angular/animations';
|
|
2
|
+
import { AnimationDuration } from '../core/animation/animation-consts';
|
|
3
|
+
import { getAnimationQueryMetadatas } from '../utils/animations';
|
|
4
|
+
export const ZOOM_CLASS_NAME_MAP = {
|
|
5
|
+
enter: 'aui-zoom-enter',
|
|
6
|
+
enterActive: 'aui-zoom-enter-active',
|
|
7
|
+
leave: 'aui-zoom-leave',
|
|
8
|
+
leaveActive: 'aui-zoom-leave-active',
|
|
9
|
+
};
|
|
10
|
+
export const ZOOM_SLOW_CLASS_NAME_MAP = {
|
|
11
|
+
enter: 'aui-zoom-slow-enter',
|
|
12
|
+
enterActive: 'aui-zoom-slow-enter-active',
|
|
13
|
+
leave: 'aui-zoom-slow-leave',
|
|
14
|
+
leaveActive: 'aui-zoom-slow-leave-active',
|
|
15
|
+
};
|
|
16
|
+
export const FADE_CLASS_NAME_MAP = {
|
|
17
|
+
enter: 'aui-fade-enter',
|
|
18
|
+
enterActive: 'aui-fade-enter-active',
|
|
19
|
+
leave: 'aui-fade-leave',
|
|
20
|
+
leaveActive: 'aui-fade-leave-active',
|
|
21
|
+
};
|
|
22
|
+
export const FADE_SLOW_CLASS_NAME_MAP = {
|
|
23
|
+
enter: 'aui-fade-slow-enter',
|
|
24
|
+
enterActive: 'aui-fade-slow-enter-active',
|
|
25
|
+
leave: 'aui-fade-slow-leave',
|
|
26
|
+
leaveActive: 'aui-fade-slow-leave-active',
|
|
27
|
+
};
|
|
28
|
+
export const ANIMATION_DURATION_BASE_CLASSES = [
|
|
29
|
+
'.aui-dialog--small',
|
|
30
|
+
'.aui-dialog--medium',
|
|
31
|
+
'.aui-dialog--fit-content',
|
|
32
|
+
];
|
|
33
|
+
export const ANIMATION_DURATION_SLOW_CLASSES = [
|
|
34
|
+
'.aui-dialog--big',
|
|
35
|
+
'.aui-dialog--large',
|
|
36
|
+
'.aui-dialog--fullscreen',
|
|
37
|
+
'.aui-dialog--fit-viewport',
|
|
38
|
+
];
|
|
39
|
+
const getAnimationQueryMetadata = (duration) => (className) => query(className, animate(duration, style({})), {
|
|
40
|
+
optional: true,
|
|
41
|
+
});
|
|
42
|
+
export const dialogAnimations = {
|
|
43
|
+
dialogContainer: trigger('dialogContainer', [
|
|
44
|
+
state('void, exit', style({})),
|
|
45
|
+
state('enter', style({})),
|
|
46
|
+
transition('* => enter', [
|
|
47
|
+
...getAnimationQueryMetadatas(ANIMATION_DURATION_BASE_CLASSES, getAnimationQueryMetadata(AnimationDuration.Base)),
|
|
48
|
+
...getAnimationQueryMetadatas(ANIMATION_DURATION_SLOW_CLASSES, getAnimationQueryMetadata(AnimationDuration.Slow)),
|
|
49
|
+
]),
|
|
50
|
+
transition('* => void, * => exit', [
|
|
51
|
+
...getAnimationQueryMetadatas(ANIMATION_DURATION_BASE_CLASSES, getAnimationQueryMetadata(AnimationDuration.Base)),
|
|
52
|
+
...getAnimationQueryMetadatas(ANIMATION_DURATION_SLOW_CLASSES, getAnimationQueryMetadata(AnimationDuration.Slow)),
|
|
53
|
+
]),
|
|
54
|
+
]),
|
|
55
|
+
};
|
|
56
|
+
// Whitelist dom elements that are allowed to transition with transform
|
|
57
|
+
export const WHITELIST_TRANSFORM_ANIMATION_ELEMENTS = ['BUTTON'];
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWFuaW1hdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZGlhbG9nL2RpYWxvZy1hbmltYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxPQUFPLEVBRVAsS0FBSyxFQUNMLEtBQUssRUFDTCxLQUFLLEVBQ0wsVUFBVSxFQUNWLE9BQU8sR0FDUixNQUFNLHFCQUFxQixDQUFDO0FBRTdCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRWpFLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHO0lBQ2pDLEtBQUssRUFBRSxnQkFBZ0I7SUFDdkIsV0FBVyxFQUFFLHVCQUF1QjtJQUNwQyxLQUFLLEVBQUUsZ0JBQWdCO0lBQ3ZCLFdBQVcsRUFBRSx1QkFBdUI7Q0FDckMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHO0lBQ3RDLEtBQUssRUFBRSxxQkFBcUI7SUFDNUIsV0FBVyxFQUFFLDRCQUE0QjtJQUN6QyxLQUFLLEVBQUUscUJBQXFCO0lBQzVCLFdBQVcsRUFBRSw0QkFBNEI7Q0FDMUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHO0lBQ2pDLEtBQUssRUFBRSxnQkFBZ0I7SUFDdkIsV0FBVyxFQUFFLHVCQUF1QjtJQUNwQyxLQUFLLEVBQUUsZ0JBQWdCO0lBQ3ZCLFdBQVcsRUFBRSx1QkFBdUI7Q0FDckMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHO0lBQ3RDLEtBQUssRUFBRSxxQkFBcUI7SUFDNUIsV0FBVyxFQUFFLDRCQUE0QjtJQUN6QyxLQUFLLEVBQUUscUJBQXFCO0lBQzVCLFdBQVcsRUFBRSw0QkFBNEI7Q0FDMUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUFHO0lBQzdDLG9CQUFvQjtJQUNwQixxQkFBcUI7SUFDckIsMEJBQTBCO0NBQzNCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRztJQUM3QyxrQkFBa0I7SUFDbEIsb0JBQW9CO0lBQ3BCLHlCQUF5QjtJQUN6QiwyQkFBMkI7Q0FDNUIsQ0FBQztBQUVGLE1BQU0seUJBQXlCLEdBQUcsQ0FBQyxRQUFnQixFQUFFLEVBQUUsQ0FBQyxDQUFDLFNBQWlCLEVBQUUsRUFBRSxDQUM1RSxLQUFLLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUU7SUFDN0MsUUFBUSxFQUFFLElBQUk7Q0FDZixDQUFDLENBQUM7QUFFTCxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FFekI7SUFDRixlQUFlLEVBQUUsT0FBTyxDQUFDLGlCQUFpQixFQUFFO1FBQzFDLEtBQUssQ0FBQyxZQUFZLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzlCLEtBQUssQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ3pCLFVBQVUsQ0FBQyxZQUFZLEVBQUU7WUFDdkIsR0FBRywwQkFBMEIsQ0FDM0IsK0JBQStCLEVBQy9CLHlCQUF5QixDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUNsRDtZQUNELEdBQUcsMEJBQTBCLENBQzNCLCtCQUErQixFQUMvQix5QkFBeUIsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsQ0FDbEQ7U0FDRixDQUFDO1FBQ0YsVUFBVSxDQUFDLHNCQUFzQixFQUFFO1lBQ2pDLEdBQUcsMEJBQTBCLENBQzNCLCtCQUErQixFQUMvQix5QkFBeUIsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsQ0FDbEQ7WUFDRCxHQUFHLDBCQUEwQixDQUMzQiwrQkFBK0IsRUFDL0IseUJBQXlCLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLENBQ2xEO1NBQ0YsQ0FBQztLQUNILENBQUM7Q0FDSCxDQUFDO0FBRUYsdUVBQXVFO0FBQ3ZFLE1BQU0sQ0FBQyxNQUFNLHNDQUFzQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBhbmltYXRlLFxuICBBbmltYXRpb25UcmlnZ2VyTWV0YWRhdGEsXG4gIHF1ZXJ5LFxuICBzdGF0ZSxcbiAgc3R5bGUsXG4gIHRyYW5zaXRpb24sXG4gIHRyaWdnZXIsXG59IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuXG5pbXBvcnQgeyBBbmltYXRpb25EdXJhdGlvbiB9IGZyb20gJy4uL2NvcmUvYW5pbWF0aW9uL2FuaW1hdGlvbi1jb25zdHMnO1xuaW1wb3J0IHsgZ2V0QW5pbWF0aW9uUXVlcnlNZXRhZGF0YXMgfSBmcm9tICcuLi91dGlscy9hbmltYXRpb25zJztcblxuZXhwb3J0IGNvbnN0IFpPT01fQ0xBU1NfTkFNRV9NQVAgPSB7XG4gIGVudGVyOiAnYXVpLXpvb20tZW50ZXInLFxuICBlbnRlckFjdGl2ZTogJ2F1aS16b29tLWVudGVyLWFjdGl2ZScsXG4gIGxlYXZlOiAnYXVpLXpvb20tbGVhdmUnLFxuICBsZWF2ZUFjdGl2ZTogJ2F1aS16b29tLWxlYXZlLWFjdGl2ZScsXG59O1xuXG5leHBvcnQgY29uc3QgWk9PTV9TTE9XX0NMQVNTX05BTUVfTUFQID0ge1xuICBlbnRlcjogJ2F1aS16b29tLXNsb3ctZW50ZXInLFxuICBlbnRlckFjdGl2ZTogJ2F1aS16b29tLXNsb3ctZW50ZXItYWN0aXZlJyxcbiAgbGVhdmU6ICdhdWktem9vbS1zbG93LWxlYXZlJyxcbiAgbGVhdmVBY3RpdmU6ICdhdWktem9vbS1zbG93LWxlYXZlLWFjdGl2ZScsXG59O1xuXG5leHBvcnQgY29uc3QgRkFERV9DTEFTU19OQU1FX01BUCA9IHtcbiAgZW50ZXI6ICdhdWktZmFkZS1lbnRlcicsXG4gIGVudGVyQWN0aXZlOiAnYXVpLWZhZGUtZW50ZXItYWN0aXZlJyxcbiAgbGVhdmU6ICdhdWktZmFkZS1sZWF2ZScsXG4gIGxlYXZlQWN0aXZlOiAnYXVpLWZhZGUtbGVhdmUtYWN0aXZlJyxcbn07XG5cbmV4cG9ydCBjb25zdCBGQURFX1NMT1dfQ0xBU1NfTkFNRV9NQVAgPSB7XG4gIGVudGVyOiAnYXVpLWZhZGUtc2xvdy1lbnRlcicsXG4gIGVudGVyQWN0aXZlOiAnYXVpLWZhZGUtc2xvdy1lbnRlci1hY3RpdmUnLFxuICBsZWF2ZTogJ2F1aS1mYWRlLXNsb3ctbGVhdmUnLFxuICBsZWF2ZUFjdGl2ZTogJ2F1aS1mYWRlLXNsb3ctbGVhdmUtYWN0aXZlJyxcbn07XG5cbmV4cG9ydCBjb25zdCBBTklNQVRJT05fRFVSQVRJT05fQkFTRV9DTEFTU0VTID0gW1xuICAnLmF1aS1kaWFsb2ctLXNtYWxsJyxcbiAgJy5hdWktZGlhbG9nLS1tZWRpdW0nLFxuICAnLmF1aS1kaWFsb2ctLWZpdC1jb250ZW50Jyxcbl07XG5cbmV4cG9ydCBjb25zdCBBTklNQVRJT05fRFVSQVRJT05fU0xPV19DTEFTU0VTID0gW1xuICAnLmF1aS1kaWFsb2ctLWJpZycsXG4gICcuYXVpLWRpYWxvZy0tbGFyZ2UnLFxuICAnLmF1aS1kaWFsb2ctLWZ1bGxzY3JlZW4nLFxuICAnLmF1aS1kaWFsb2ctLWZpdC12aWV3cG9ydCcsXG5dO1xuXG5jb25zdCBnZXRBbmltYXRpb25RdWVyeU1ldGFkYXRhID0gKGR1cmF0aW9uOiBzdHJpbmcpID0+IChjbGFzc05hbWU6IHN0cmluZykgPT5cbiAgcXVlcnkoY2xhc3NOYW1lLCBhbmltYXRlKGR1cmF0aW9uLCBzdHlsZSh7fSkpLCB7XG4gICAgb3B0aW9uYWw6IHRydWUsXG4gIH0pO1xuXG5leHBvcnQgY29uc3QgZGlhbG9nQW5pbWF0aW9uczoge1xuICByZWFkb25seSBkaWFsb2dDb250YWluZXI6IEFuaW1hdGlvblRyaWdnZXJNZXRhZGF0YTtcbn0gPSB7XG4gIGRpYWxvZ0NvbnRhaW5lcjogdHJpZ2dlcignZGlhbG9nQ29udGFpbmVyJywgW1xuICAgIHN0YXRlKCd2b2lkLCBleGl0Jywgc3R5bGUoe30pKSxcbiAgICBzdGF0ZSgnZW50ZXInLCBzdHlsZSh7fSkpLFxuICAgIHRyYW5zaXRpb24oJyogPT4gZW50ZXInLCBbXG4gICAgICAuLi5nZXRBbmltYXRpb25RdWVyeU1ldGFkYXRhcyhcbiAgICAgICAgQU5JTUFUSU9OX0RVUkFUSU9OX0JBU0VfQ0xBU1NFUyxcbiAgICAgICAgZ2V0QW5pbWF0aW9uUXVlcnlNZXRhZGF0YShBbmltYXRpb25EdXJhdGlvbi5CYXNlKSxcbiAgICAgICksXG4gICAgICAuLi5nZXRBbmltYXRpb25RdWVyeU1ldGFkYXRhcyhcbiAgICAgICAgQU5JTUFUSU9OX0RVUkFUSU9OX1NMT1dfQ0xBU1NFUyxcbiAgICAgICAgZ2V0QW5pbWF0aW9uUXVlcnlNZXRhZGF0YShBbmltYXRpb25EdXJhdGlvbi5TbG93KSxcbiAgICAgICksXG4gICAgXSksXG4gICAgdHJhbnNpdGlvbignKiA9PiB2b2lkLCAqID0+IGV4aXQnLCBbXG4gICAgICAuLi5nZXRBbmltYXRpb25RdWVyeU1ldGFkYXRhcyhcbiAgICAgICAgQU5JTUFUSU9OX0RVUkFUSU9OX0JBU0VfQ0xBU1NFUyxcbiAgICAgICAgZ2V0QW5pbWF0aW9uUXVlcnlNZXRhZGF0YShBbmltYXRpb25EdXJhdGlvbi5CYXNlKSxcbiAgICAgICksXG4gICAgICAuLi5nZXRBbmltYXRpb25RdWVyeU1ldGFkYXRhcyhcbiAgICAgICAgQU5JTUFUSU9OX0RVUkFUSU9OX1NMT1dfQ0xBU1NFUyxcbiAgICAgICAgZ2V0QW5pbWF0aW9uUXVlcnlNZXRhZGF0YShBbmltYXRpb25EdXJhdGlvbi5TbG93KSxcbiAgICAgICksXG4gICAgXSksXG4gIF0pLFxufTtcblxuLy8gV2hpdGVsaXN0IGRvbSBlbGVtZW50cyB0aGF0IGFyZSBhbGxvd2VkIHRvIHRyYW5zaXRpb24gd2l0aCB0cmFuc2Zvcm1cbmV4cG9ydCBjb25zdCBXSElURUxJU1RfVFJBTlNGT1JNX0FOSU1BVElPTl9FTEVNRU5UUyA9IFsnQlVUVE9OJ107XG4iXX0=
|
|
@@ -1,9 +1,15 @@
|
|
|
1
1
|
import { DialogSize } from './dialog.types';
|
|
2
|
-
export class
|
|
2
|
+
export class BaseDialogConfig {
|
|
3
3
|
constructor() {
|
|
4
|
+
this.noAnimation = false;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
export class DialogConfig extends BaseDialogConfig {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
4
10
|
this.size = DialogSize.Big;
|
|
5
11
|
this.hasBackdrop = true;
|
|
6
12
|
this.fitViewport = false;
|
|
7
13
|
}
|
|
8
14
|
}
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaWFsb2cvZGlhbG9nLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFNUMsTUFBTSxPQUFPLGdCQUFnQjtJQUE3QjtRQUNFLGdCQUFXLEdBQUksS0FBSyxDQUFDO0lBQ3ZCLENBQUM7Q0FBQTtBQUVELE1BQU0sT0FBTyxZQUFzQixTQUFRLGdCQUFnQjtJQUEzRDs7UUFJRSxTQUFJLEdBQWdCLFVBQVUsQ0FBQyxHQUFHLENBQUM7UUFDbkMsZ0JBQVcsR0FBSSxJQUFJLENBQUM7UUFDcEIsZ0JBQVcsR0FBSSxLQUFLLENBQUM7SUFFdkIsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEaWFsb2dTaXplIH0gZnJvbSAnLi9kaWFsb2cudHlwZXMnO1xuXG5leHBvcnQgY2xhc3MgQmFzZURpYWxvZ0NvbmZpZyB7XG4gIG5vQW5pbWF0aW9uPyA9IGZhbHNlO1xufVxuXG5leHBvcnQgY2xhc3MgRGlhbG9nQ29uZmlnPEQgPSBhbnk+IGV4dGVuZHMgQmFzZURpYWxvZ0NvbmZpZyB7XG4gIGlkPzogbnVtYmVyO1xuICB2aWV3Q29udGFpbmVyUmVmPzogVmlld0NvbnRhaW5lclJlZjtcbiAgZGF0YT86IEQ7XG4gIHNpemU/OiBEaWFsb2dTaXplID0gRGlhbG9nU2l6ZS5CaWc7XG4gIGhhc0JhY2tkcm9wPyA9IHRydWU7XG4gIGZpdFZpZXdwb3J0PyA9IGZhbHNlO1xuICBjdXN0b21DbGFzcz86IHN0cmluZztcbn1cbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CdkScrollable, } from '@angular/cdk/overlay';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
2
|
+
import { filter, Subject, take } from 'rxjs';
|
|
3
3
|
let uniqueId = 0;
|
|
4
4
|
export class DialogRef {
|
|
5
5
|
constructor(overlayRef, dialogInstance, scrollDispatcher, ngZone) {
|
|
@@ -14,10 +14,15 @@ export class DialogRef {
|
|
|
14
14
|
}
|
|
15
15
|
close(result = null) {
|
|
16
16
|
this.scrollable.ngOnDestroy();
|
|
17
|
-
this.
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
17
|
+
this.dialogInstance.animationStateChanged
|
|
18
|
+
.pipe(filter(event => event.phaseName === 'done' && event.toState === 'exit'), take(1))
|
|
19
|
+
.subscribe(() => {
|
|
20
|
+
this.overlayRef.detachBackdrop();
|
|
21
|
+
this.overlayRef.dispose();
|
|
22
|
+
this.afterClosed$.next(result);
|
|
23
|
+
this.afterClosed$.complete();
|
|
24
|
+
});
|
|
25
|
+
this.dialogInstance.startExitAnimation();
|
|
21
26
|
}
|
|
22
27
|
afterOpen() {
|
|
23
28
|
return this.afterOpen$.asObservable();
|
|
@@ -40,4 +45,4 @@ export class DialogRef {
|
|
|
40
45
|
.positionStrategy;
|
|
41
46
|
}
|
|
42
47
|
}
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXJlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaWFsb2cvZGlhbG9nLXJlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsYUFBYSxHQUtkLE1BQU0sc0JBQXNCLENBQUM7QUFFOUIsT0FBTyxFQUFFLE1BQU0sRUFBYyxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBSXpELElBQUksUUFBUSxHQUFHLENBQUMsQ0FBQztBQUVqQixNQUFNLE9BQU8sU0FBUztJQVNwQixZQUNtQixVQUFzQixFQUNoQyxjQUErQixFQUN0QyxnQkFBa0MsRUFDbEMsTUFBYztRQUhHLGVBQVUsR0FBVixVQUFVLENBQVk7UUFDaEMsbUJBQWMsR0FBZCxjQUFjLENBQWlCO1FBVC9CLE9BQUUsR0FBRyxjQUFjLFFBQVEsRUFBRSxFQUFFLENBQUM7UUFFeEIsZUFBVSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDakMsaUJBQVksR0FBRyxJQUFJLE9BQU8sRUFBSyxDQUFDO1FBVS9DLGNBQWMsQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUM1QixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksYUFBYSxDQUNqQyxFQUFFLGFBQWEsRUFBRSxVQUFVLENBQUMsY0FBYyxFQUFFLEVBQzVDLGdCQUFnQixFQUNoQixNQUFNLENBQ1AsQ0FBQztRQUNGLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUVELEtBQUssQ0FBQyxTQUFZLElBQUk7UUFDcEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUU5QixJQUFJLENBQUMsY0FBYyxDQUFDLHFCQUFxQjthQUN0QyxJQUFJLENBQ0gsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLFNBQVMsS0FBSyxNQUFNLElBQUksS0FBSyxDQUFDLE9BQU8sS0FBSyxNQUFNLENBQUMsRUFDdkUsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUNSO2FBQ0EsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxVQUFVLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDakMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUMxQixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUMvQixJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO1FBQ0wsSUFBSSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBQzNDLENBQUM7SUFFRCxTQUFTO1FBQ1AsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3hDLENBQUM7SUFFRCxXQUFXO1FBQ1QsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzFDLENBQUM7SUFFRCxjQUFjO1FBQ1osSUFBSSxDQUFDLG1CQUFtQixFQUFFLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM5QyxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ2pDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELFVBQVU7UUFDUixJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztRQUMzQixJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ2pDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVPLG1CQUFtQjtRQUN6QixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxFQUFFO2FBQy9CLGdCQUEwQyxDQUFDO0lBQ2hELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENka1Njcm9sbGFibGUsXG4gIENvbXBvbmVudFR5cGUsXG4gIEdsb2JhbFBvc2l0aW9uU3RyYXRlZ3ksXG4gIE92ZXJsYXlSZWYsXG4gIFNjcm9sbERpc3BhdGNoZXIsXG59IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IE5nWm9uZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZmlsdGVyLCBPYnNlcnZhYmxlLCBTdWJqZWN0LCB0YWtlIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IERpYWxvZ0NvbXBvbmVudCB9IGZyb20gJy4vZGlhbG9nLmNvbXBvbmVudCc7XG5cbmxldCB1bmlxdWVJZCA9IDA7XG5cbmV4cG9ydCBjbGFzcyBEaWFsb2dSZWY8VCA9IENvbXBvbmVudFR5cGU8YW55PiwgUiA9IGFueT4ge1xuICBjb21wb25lbnRJbnN0YW5jZT86IFQ7XG4gIHJlYWRvbmx5IGlkID0gYGF1aS1kaWFsb2ctJHt1bmlxdWVJZCsrfWA7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBhZnRlck9wZW4kID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcbiAgcHJpdmF0ZSByZWFkb25seSBhZnRlckNsb3NlZCQgPSBuZXcgU3ViamVjdDxSPigpO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgc2Nyb2xsYWJsZTogQ2RrU2Nyb2xsYWJsZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IG92ZXJsYXlSZWY6IE92ZXJsYXlSZWYsXG4gICAgcHVibGljIGRpYWxvZ0luc3RhbmNlOiBEaWFsb2dDb21wb25lbnQsXG4gICAgc2Nyb2xsRGlzcGF0Y2hlcjogU2Nyb2xsRGlzcGF0Y2hlcixcbiAgICBuZ1pvbmU6IE5nWm9uZSxcbiAgKSB7XG4gICAgZGlhbG9nSW5zdGFuY2UuaWQgPSB0aGlzLmlkO1xuICAgIHRoaXMuc2Nyb2xsYWJsZSA9IG5ldyBDZGtTY3JvbGxhYmxlKFxuICAgICAgeyBuYXRpdmVFbGVtZW50OiBvdmVybGF5UmVmLm92ZXJsYXlFbGVtZW50IH0sXG4gICAgICBzY3JvbGxEaXNwYXRjaGVyLFxuICAgICAgbmdab25lLFxuICAgICk7XG4gICAgdGhpcy5zY3JvbGxhYmxlLm5nT25Jbml0KCk7XG4gIH1cblxuICBjbG9zZShyZXN1bHQ6IFIgPSBudWxsKTogdm9pZCB7XG4gICAgdGhpcy5zY3JvbGxhYmxlLm5nT25EZXN0cm95KCk7XG5cbiAgICB0aGlzLmRpYWxvZ0luc3RhbmNlLmFuaW1hdGlvblN0YXRlQ2hhbmdlZFxuICAgICAgLnBpcGUoXG4gICAgICAgIGZpbHRlcihldmVudCA9PiBldmVudC5waGFzZU5hbWUgPT09ICdkb25lJyAmJiBldmVudC50b1N0YXRlID09PSAnZXhpdCcpLFxuICAgICAgICB0YWtlKDEpLFxuICAgICAgKVxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgIHRoaXMub3ZlcmxheVJlZi5kZXRhY2hCYWNrZHJvcCgpO1xuICAgICAgICB0aGlzLm92ZXJsYXlSZWYuZGlzcG9zZSgpO1xuICAgICAgICB0aGlzLmFmdGVyQ2xvc2VkJC5uZXh0KHJlc3VsdCk7XG4gICAgICAgIHRoaXMuYWZ0ZXJDbG9zZWQkLmNvbXBsZXRlKCk7XG4gICAgICB9KTtcbiAgICB0aGlzLmRpYWxvZ0luc3RhbmNlLnN0YXJ0RXhpdEFuaW1hdGlvbigpO1xuICB9XG5cbiAgYWZ0ZXJPcGVuKCk6IE9ic2VydmFibGU8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLmFmdGVyT3BlbiQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBhZnRlckNsb3NlZCgpOiBPYnNlcnZhYmxlPFI+IHtcbiAgICByZXR1cm4gdGhpcy5hZnRlckNsb3NlZCQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICB1cGRhdGVQb3NpdGlvbigpOiB0aGlzIHtcbiAgICB0aGlzLmdldFBvc2l0aW9uU3RyYXRlZ3koKS50b3AoJzAnKS5sZWZ0KCcwJyk7XG4gICAgdGhpcy5vdmVybGF5UmVmLnVwZGF0ZVBvc2l0aW9uKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICB1cGRhdGVTaXplKCk6IHRoaXMge1xuICAgIHRoaXMuZ2V0UG9zaXRpb25TdHJhdGVneSgpO1xuICAgIHRoaXMub3ZlcmxheVJlZi51cGRhdGVQb3NpdGlvbigpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXRQb3NpdGlvblN0cmF0ZWd5KCk6IEdsb2JhbFBvc2l0aW9uU3RyYXRlZ3kge1xuICAgIHJldHVybiB0aGlzLm92ZXJsYXlSZWYuZ2V0Q29uZmlnKClcbiAgICAgIC5wb3NpdGlvblN0cmF0ZWd5IGFzIEdsb2JhbFBvc2l0aW9uU3RyYXRlZ3k7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,15 +1,20 @@
|
|
|
1
1
|
import { CdkPortalOutlet, } from '@angular/cdk/portal';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
3
|
-
import { buildBem } from '../utils';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { buildBem, getElementOffset } from '../utils';
|
|
4
|
+
import { dialogAnimations, FADE_CLASS_NAME_MAP, FADE_SLOW_CLASS_NAME_MAP, ZOOM_CLASS_NAME_MAP, ZOOM_SLOW_CLASS_NAME_MAP, ANIMATION_DURATION_BASE_CLASSES, WHITELIST_TRANSFORM_ANIMATION_ELEMENTS, } from './dialog-animations';
|
|
4
5
|
import { throwDialogContentAlreadyAttachedError } from './utils';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/common";
|
|
7
8
|
import * as i2 from "@angular/cdk/portal";
|
|
8
9
|
export class DialogComponent {
|
|
9
|
-
constructor(elementRef) {
|
|
10
|
+
constructor(elementRef, render) {
|
|
10
11
|
this.elementRef = elementRef;
|
|
12
|
+
this.render = render;
|
|
11
13
|
this.bem = buildBem('aui-dialog');
|
|
12
14
|
this.hidden = false;
|
|
15
|
+
// animation state
|
|
16
|
+
this.state = 'enter';
|
|
17
|
+
this.animationStateChanged = new EventEmitter();
|
|
13
18
|
}
|
|
14
19
|
get id() {
|
|
15
20
|
return this._id;
|
|
@@ -18,15 +23,25 @@ export class DialogComponent {
|
|
|
18
23
|
this.elementRef.nativeElement.dataset.id = value;
|
|
19
24
|
}
|
|
20
25
|
get rootClass() {
|
|
21
|
-
return `${this.bem.block(this.config.size)} ${this.config.fitViewport ? this.bem.modifier('fit-viewport') : ''}`;
|
|
26
|
+
return `${this.bem.block(this.config.size)} ${this.config.fitViewport ? this.bem.modifier('fit-viewport') : ''} ${this.config.customClass || ''}`;
|
|
22
27
|
}
|
|
23
28
|
get customStyle() {
|
|
24
29
|
return this.hidden
|
|
25
30
|
? {
|
|
26
|
-
|
|
31
|
+
opacity: 0,
|
|
27
32
|
}
|
|
28
33
|
: {};
|
|
29
34
|
}
|
|
35
|
+
get zoomClassMap() {
|
|
36
|
+
return ANIMATION_DURATION_BASE_CLASSES.includes(this.config.size)
|
|
37
|
+
? ZOOM_CLASS_NAME_MAP
|
|
38
|
+
: ZOOM_SLOW_CLASS_NAME_MAP;
|
|
39
|
+
}
|
|
40
|
+
get fadeClassMap() {
|
|
41
|
+
return ANIMATION_DURATION_BASE_CLASSES.includes(this.config.size)
|
|
42
|
+
? FADE_CLASS_NAME_MAP
|
|
43
|
+
: FADE_SLOW_CLASS_NAME_MAP;
|
|
44
|
+
}
|
|
30
45
|
attachComponentPortal(portal) {
|
|
31
46
|
if (this.portalOutlet.hasAttached()) {
|
|
32
47
|
throwDialogContentAlreadyAttachedError();
|
|
@@ -41,19 +56,101 @@ export class DialogComponent {
|
|
|
41
56
|
this.blurActiveElement();
|
|
42
57
|
return this.portalOutlet.attachTemplatePortal(portal);
|
|
43
58
|
}
|
|
59
|
+
onAnimationDone(event) {
|
|
60
|
+
this.cleanAnimationClass();
|
|
61
|
+
this.animationStateChanged.emit(event);
|
|
62
|
+
}
|
|
63
|
+
onAnimationStart(event) {
|
|
64
|
+
if (event.toState === 'enter') {
|
|
65
|
+
this.setEnterAnimationClass();
|
|
66
|
+
}
|
|
67
|
+
else if (event.toState === 'exit') {
|
|
68
|
+
this.setExitAnimationClass();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
startExitAnimation() {
|
|
72
|
+
this.state = 'exit';
|
|
73
|
+
}
|
|
44
74
|
blurActiveElement() {
|
|
75
|
+
const activeElement = document.activeElement;
|
|
45
76
|
if (document) {
|
|
46
|
-
|
|
77
|
+
this.elementFocusedBeforeModalWasOpened =
|
|
78
|
+
WHITELIST_TRANSFORM_ANIMATION_ELEMENTS.includes(activeElement.tagName)
|
|
79
|
+
? activeElement
|
|
80
|
+
: null;
|
|
81
|
+
activeElement.blur();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
cleanAnimationClass() {
|
|
85
|
+
if (this.config.noAnimation) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
const backdropElement = this.overlayRef.backdropElement;
|
|
89
|
+
const modalElement = this.elementRef.nativeElement.firstElementChild;
|
|
90
|
+
if (backdropElement) {
|
|
91
|
+
backdropElement.classList.remove(this.fadeClassMap.enter);
|
|
92
|
+
backdropElement.classList.remove(this.fadeClassMap.enterActive);
|
|
93
|
+
}
|
|
94
|
+
modalElement.classList.remove(this.zoomClassMap.enter);
|
|
95
|
+
modalElement.classList.remove(this.zoomClassMap.enterActive);
|
|
96
|
+
modalElement.classList.remove(this.zoomClassMap.leave);
|
|
97
|
+
modalElement.classList.remove(this.zoomClassMap.leaveActive);
|
|
98
|
+
}
|
|
99
|
+
setEnterAnimationClass() {
|
|
100
|
+
if (this.config.noAnimation) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
this.setModalTransformOrigin();
|
|
104
|
+
const modalElement = this.elementRef.nativeElement.firstElementChild;
|
|
105
|
+
const backdropElement = this.overlayRef.backdropElement;
|
|
106
|
+
modalElement.classList.add(this.zoomClassMap.enter);
|
|
107
|
+
modalElement.classList.add(this.zoomClassMap.enterActive);
|
|
108
|
+
if (backdropElement) {
|
|
109
|
+
backdropElement.classList.add(this.fadeClassMap.enter);
|
|
110
|
+
backdropElement.classList.add(this.fadeClassMap.enterActive);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
setExitAnimationClass() {
|
|
114
|
+
if (this.config.noAnimation) {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
const modalElement = this.elementRef.nativeElement.firstElementChild;
|
|
118
|
+
modalElement.classList.add(this.zoomClassMap.leave);
|
|
119
|
+
modalElement.classList.add(this.zoomClassMap.leaveActive);
|
|
120
|
+
this.setMaskExitAnimationClass();
|
|
121
|
+
}
|
|
122
|
+
setMaskExitAnimationClass() {
|
|
123
|
+
const backdropElement = this.overlayRef.backdropElement;
|
|
124
|
+
if (backdropElement) {
|
|
125
|
+
backdropElement.classList.add(this.fadeClassMap.leave);
|
|
126
|
+
backdropElement.classList.add(this.fadeClassMap.leaveActive);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
setModalTransformOrigin() {
|
|
130
|
+
const modalElement = this.elementRef.nativeElement
|
|
131
|
+
.firstElementChild;
|
|
132
|
+
if (this.elementFocusedBeforeModalWasOpened) {
|
|
133
|
+
const previouslyDOMRect = this.elementFocusedBeforeModalWasOpened.getBoundingClientRect();
|
|
134
|
+
const lastPosition = getElementOffset(this.elementFocusedBeforeModalWasOpened);
|
|
135
|
+
const x = lastPosition.left + previouslyDOMRect.width / 2;
|
|
136
|
+
const y = lastPosition.top + previouslyDOMRect.height / 2;
|
|
137
|
+
const transformOrigin = `${x - modalElement.offsetLeft}px ${y - modalElement.offsetTop}px 0px`;
|
|
138
|
+
this.render.setStyle(modalElement, 'transform-origin', transformOrigin);
|
|
47
139
|
}
|
|
48
140
|
}
|
|
49
141
|
}
|
|
50
|
-
DialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DialogComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
51
|
-
DialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DialogComponent, selector: "aui-dialog", viewQueries: [{ propertyName: "portalOutlet", first: true, predicate: CdkPortalOutlet, descendants: true, static: true }], ngImport: i0, template: "<div\n [ngClass]=\"rootClass\"\n [ngStyle]=\"customStyle\"\n>\n <ng-template cdkPortalOutlet></ng-template>\n</div>\n", styles: [".cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex;max-width:100%;max-height:100%}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:1}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:rgba(0,0,0,.32)}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:0;visibility:visible}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}:root .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.4)}html[aui-theme-mode=light] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.4)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.75)}.cdk-overlay-pane.aui-dialog-overlay-pane{justify-content:center;
|
|
142
|
+
DialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DialogComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
|
143
|
+
DialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DialogComponent, selector: "aui-dialog", host: { listeners: { "@dialogContainer.start": "onAnimationStart($event)", "@dialogContainer.done": "onAnimationDone($event)" }, properties: { "@.disabled": "config.noAnimation", "@dialogContainer": "state" } }, viewQueries: [{ propertyName: "portalOutlet", first: true, predicate: CdkPortalOutlet, descendants: true, static: true }], ngImport: i0, template: "<div\n [ngClass]=\"rootClass\"\n [ngStyle]=\"customStyle\"\n>\n <ng-template cdkPortalOutlet></ng-template>\n</div>\n", styles: ["@keyframes aui-fade-in{0%{opacity:0}to{opacity:1}}@keyframes aui-fade-out{0%{opacity:1}to{opacity:0}}@keyframes aui-zoom-in{0%{transform:scale(.2);opacity:0}to{transform:scale(1);opacity:1}}@keyframes aui-zoom-out{0%{transform:scale(1)}to{transform:scale(.2);opacity:0}}.cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex;max-width:100%;max-height:100%}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:1}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:rgba(0,0,0,.32)}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:0;visibility:visible}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}:root .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.4)}html[aui-theme-mode=light] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.4)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.75)}.cdk-overlay-pane.aui-dialog-overlay-pane{display:flex;justify-content:center;align-items:normal}.cdk-overlay-pane.aui-dialog-overlay-pane::-webkit-scrollbar{width:4px;height:4px}.cdk-overlay-pane.aui-dialog-overlay-pane::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.cdk-overlay-pane.aui-dialog-overlay-pane::-webkit-scrollbar-corner{background-color:transparent}.cdk-overlay-pane.aui-dialog-overlay-pane--fit-viewport{display:flex;justify-content:center;align-items:center}.cdk-overlay-pane.aui-dialog-overlay-pane--fit-viewport::-webkit-scrollbar{width:4px;height:4px}.cdk-overlay-pane.aui-dialog-overlay-pane--fit-viewport::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.cdk-overlay-pane.aui-dialog-overlay-pane--fit-viewport::-webkit-scrollbar-corner{background-color:transparent}.aui-zoom-enter,.aui-zoom-leave{animation-duration:.24s;animation-fill-mode:both;animation-play-state:paused}.aui-zoom-enter.aui-zoom-enter-active,.aui-zoom-leave.aui-zoom-leave-active{animation-play-state:running;pointer-events:none}.aui-zoom-enter.aui-zoom-enter-active{animation-name:aui-zoom-in}.aui-zoom-leave.aui-zoom-leave-active{animation-name:aui-zoom-out}.aui-zoom-enter{opacity:0;animation-timing-function:cubic-bezier(0,0,.2,1)}.aui-zoom-leave{animation-timing-function:cubic-bezier(.38,0,.24,1)}.aui-zoom-slow-enter,.aui-zoom-slow-leave{animation-duration:.3s;animation-fill-mode:both;animation-play-state:paused}.aui-zoom-slow-enter.aui-zoom-slow-enter-active,.aui-zoom-slow-leave.aui-zoom-slow-leave-active{animation-play-state:running;pointer-events:none}.aui-zoom-slow-enter.aui-zoom-slow-enter-active{animation-name:aui-zoom-in}.aui-zoom-slow-leave.aui-zoom-slow-leave-active{animation-name:aui-zoom-out}.aui-zoom-slow-enter{opacity:0;animation-timing-function:cubic-bezier(0,0,.2,1)}.aui-zoom-slow-leave{animation-timing-function:cubic-bezier(.38,0,.24,1)}.aui-fade-enter,.aui-fade-leave{animation-duration:.24s;animation-fill-mode:both;animation-play-state:paused}.aui-fade-enter.aui-fade-enter-active,.aui-fade-leave.aui-fade-leave-active{animation-play-state:running;pointer-events:none}.aui-fade-enter.aui-fade-enter-active{animation-name:aui-fade-in}.aui-fade-leave.aui-fade-leave-active{animation-name:aui-fade-out}.aui-fade-enter{opacity:0;animation-timing-function:linear}.aui-fade-leave{animation-timing-function:linear}.aui-fade-slow-enter,.aui-fade-slow-leave{animation-duration:.3s;animation-fill-mode:both;animation-play-state:paused}.aui-fade-slow-enter.aui-fade-slow-enter-active,.aui-fade-slow-leave.aui-fade-slow-leave-active{animation-play-state:running;pointer-events:none}.aui-fade-slow-enter.aui-fade-slow-enter-active{animation-name:aui-fade-in}.aui-fade-slow-leave.aui-fade-slow-leave-active{animation-name:aui-fade-out}.aui-fade-slow-enter{opacity:0;animation-timing-function:linear}.aui-fade-slow-leave{animation-timing-function:linear}.aui-dialog{margin:18vh auto 20px;display:flex;flex-direction:column;background-color:rgb(var(--aui-color-n-10));border-radius:var(--aui-border-radius-l);overflow:hidden;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);color:rgb(var(--aui-color-main-text))}:root .aui-dialog{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-dialog{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-dialog{box-shadow:0 4px 16px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-dialog{box-shadow:0 4px 16px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-dialog aui-dialog-content{height:100%;overflow:auto}.aui-dialog aui-dialog-content::-webkit-scrollbar{width:4px;height:4px}.aui-dialog aui-dialog-content::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-dialog aui-dialog-content::-webkit-scrollbar-corner{background-color:transparent}.aui-dialog aui-dialog-content:first-child .aui-dialog__content{padding-top:20px}.aui-dialog aui-dialog-content:last-child .aui-dialog__content{padding-bottom:20px}.aui-dialog__header{margin:0 20px;padding:20px 0 16px;display:flex;justify-content:space-between}.aui-dialog__header.hasDivider{margin-bottom:16px;border-bottom:1px solid rgb(var(--aui-color-divider))}.aui-dialog__header-title{width:100%;font-size:var(--aui-font-size-xl);line-height:var(--aui-line-height-xl);color:rgb(var(--aui-color-main-text));font-weight:var(--aui-font-weight-bold)}.aui-dialog__header-title>aui-icon:first-child{font-size:var(--aui-icon-size-xl);margin-right:var(--aui-spacing-m)}.aui-dialog__header-title>aui-icon:first-child[icon=info_circle_s]{color:rgb(var(--aui-color-primary))}.aui-dialog__header-title>aui-icon:first-child[icon=check_circle_s]{color:rgb(var(--aui-color-green))}.aui-dialog__header-title>aui-icon:first-child[icon=exclamation_circle_s]{color:rgb(var(--aui-color-yellow))}.aui-dialog__header-title>aui-icon:first-child[icon=exclamation_triangle_s]{color:rgb(var(--aui-color-red))}.aui-dialog__header-close{margin-left:var(--aui-spacing-xl);line-height:var(--aui-line-height-xl);font-size:var(--aui-font-size-l);color:rgb(var(--aui-color-n-4));cursor:pointer}.aui-dialog__header-close:hover{color:rgb(var(--aui-color-primary))}.aui-dialog__content{padding:0 20px;min-height:80px}.aui-dialog__footer{padding:20px;display:flex;justify-content:flex-end}.aui-dialog--small{width:400px}.aui-dialog--medium{width:600px}.aui-dialog--big{width:800px}.aui-dialog--large{width:960px}.aui-dialog--fit-content{width:-moz-fit-content;width:fit-content}.aui-dialog--fullscreen{width:90vw;height:calc(100vh - 40px);margin:0}.aui-dialog--fit-viewport{max-width:90vw;max-height:calc(100vh - 40px);margin:0}.aui-dialog--fit-viewport .aui-dialog__header{margin:0;padding:20px 20px 16px;border-bottom:1px solid rgb(var(--aui-color-divider))}.aui-dialog--fit-viewport .aui-dialog__footer{padding-top:16px;border-top:1px solid rgb(var(--aui-color-divider))}.aui-dialog--fit-viewport aui-dialog-content:not(:first-child) .aui-dialog__content{padding-top:16px}.aui-dialog--fit-viewport aui-dialog-content:not(:last-child) .aui-dialog__content{padding-bottom:16px}.aui-dialog--fit-viewport>ng-component{display:flex;flex-direction:column;overflow:auto}.aui-dialog--fit-viewport>ng-component:after{clear:both}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [dialogAnimations.dialogContainer], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
|
52
144
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DialogComponent, decorators: [{
|
|
53
145
|
type: Component,
|
|
54
|
-
args: [{ selector: 'aui-dialog', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.Default, preserveWhitespaces: false,
|
|
55
|
-
|
|
146
|
+
args: [{ selector: 'aui-dialog', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.Default, preserveWhitespaces: false, animations: [dialogAnimations.dialogContainer], host: {
|
|
147
|
+
'[@.disabled]': 'config.noAnimation',
|
|
148
|
+
'[@dialogContainer]': 'state',
|
|
149
|
+
'(@dialogContainer.start)': 'onAnimationStart($event)',
|
|
150
|
+
'(@dialogContainer.done)': 'onAnimationDone($event)',
|
|
151
|
+
}, template: "<div\n [ngClass]=\"rootClass\"\n [ngStyle]=\"customStyle\"\n>\n <ng-template cdkPortalOutlet></ng-template>\n</div>\n", styles: ["@keyframes aui-fade-in{0%{opacity:0}to{opacity:1}}@keyframes aui-fade-out{0%{opacity:1}to{opacity:0}}@keyframes aui-zoom-in{0%{transform:scale(.2);opacity:0}to{transform:scale(1);opacity:1}}@keyframes aui-zoom-out{0%{transform:scale(1)}to{transform:scale(.2);opacity:0}}.cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;z-index:1000;display:flex;max-width:100%;max-height:100%}.cdk-overlay-backdrop{position:absolute;top:0;bottom:0;left:0;right:0;z-index:1000;pointer-events:auto;-webkit-tap-highlight-color:transparent;transition:opacity .4s cubic-bezier(.25,.8,.25,1);opacity:0}.cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:1}.cdk-high-contrast-active .cdk-overlay-backdrop.cdk-overlay-backdrop-showing{opacity:.6}.cdk-overlay-dark-backdrop{background:rgba(0,0,0,.32)}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing{opacity:0;visibility:visible}.cdk-overlay-connected-position-bounding-box{position:absolute;z-index:1000;display:flex;flex-direction:column;min-width:1px;min-height:1px}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}:root .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.4)}html[aui-theme-mode=light] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.4)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .cdk-overlay-backdrop.cdk-overlay-backdrop-showing.aui-dialog-backdrop{background-color:rgba(var(--aui-color-origin-shadow),.75)}.cdk-overlay-pane.aui-dialog-overlay-pane{display:flex;justify-content:center;align-items:normal}.cdk-overlay-pane.aui-dialog-overlay-pane::-webkit-scrollbar{width:4px;height:4px}.cdk-overlay-pane.aui-dialog-overlay-pane::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.cdk-overlay-pane.aui-dialog-overlay-pane::-webkit-scrollbar-corner{background-color:transparent}.cdk-overlay-pane.aui-dialog-overlay-pane--fit-viewport{display:flex;justify-content:center;align-items:center}.cdk-overlay-pane.aui-dialog-overlay-pane--fit-viewport::-webkit-scrollbar{width:4px;height:4px}.cdk-overlay-pane.aui-dialog-overlay-pane--fit-viewport::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.cdk-overlay-pane.aui-dialog-overlay-pane--fit-viewport::-webkit-scrollbar-corner{background-color:transparent}.aui-zoom-enter,.aui-zoom-leave{animation-duration:.24s;animation-fill-mode:both;animation-play-state:paused}.aui-zoom-enter.aui-zoom-enter-active,.aui-zoom-leave.aui-zoom-leave-active{animation-play-state:running;pointer-events:none}.aui-zoom-enter.aui-zoom-enter-active{animation-name:aui-zoom-in}.aui-zoom-leave.aui-zoom-leave-active{animation-name:aui-zoom-out}.aui-zoom-enter{opacity:0;animation-timing-function:cubic-bezier(0,0,.2,1)}.aui-zoom-leave{animation-timing-function:cubic-bezier(.38,0,.24,1)}.aui-zoom-slow-enter,.aui-zoom-slow-leave{animation-duration:.3s;animation-fill-mode:both;animation-play-state:paused}.aui-zoom-slow-enter.aui-zoom-slow-enter-active,.aui-zoom-slow-leave.aui-zoom-slow-leave-active{animation-play-state:running;pointer-events:none}.aui-zoom-slow-enter.aui-zoom-slow-enter-active{animation-name:aui-zoom-in}.aui-zoom-slow-leave.aui-zoom-slow-leave-active{animation-name:aui-zoom-out}.aui-zoom-slow-enter{opacity:0;animation-timing-function:cubic-bezier(0,0,.2,1)}.aui-zoom-slow-leave{animation-timing-function:cubic-bezier(.38,0,.24,1)}.aui-fade-enter,.aui-fade-leave{animation-duration:.24s;animation-fill-mode:both;animation-play-state:paused}.aui-fade-enter.aui-fade-enter-active,.aui-fade-leave.aui-fade-leave-active{animation-play-state:running;pointer-events:none}.aui-fade-enter.aui-fade-enter-active{animation-name:aui-fade-in}.aui-fade-leave.aui-fade-leave-active{animation-name:aui-fade-out}.aui-fade-enter{opacity:0;animation-timing-function:linear}.aui-fade-leave{animation-timing-function:linear}.aui-fade-slow-enter,.aui-fade-slow-leave{animation-duration:.3s;animation-fill-mode:both;animation-play-state:paused}.aui-fade-slow-enter.aui-fade-slow-enter-active,.aui-fade-slow-leave.aui-fade-slow-leave-active{animation-play-state:running;pointer-events:none}.aui-fade-slow-enter.aui-fade-slow-enter-active{animation-name:aui-fade-in}.aui-fade-slow-leave.aui-fade-slow-leave-active{animation-name:aui-fade-out}.aui-fade-slow-enter{opacity:0;animation-timing-function:linear}.aui-fade-slow-leave{animation-timing-function:linear}.aui-dialog{margin:18vh auto 20px;display:flex;flex-direction:column;background-color:rgb(var(--aui-color-n-10));border-radius:var(--aui-border-radius-l);overflow:hidden;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);color:rgb(var(--aui-color-main-text))}:root .aui-dialog{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}html[aui-theme-mode=light] .aui-dialog{box-shadow:0 2px 8px 0 rgba(var(--aui-color-origin-shadow),.2)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .aui-dialog{box-shadow:0 4px 16px 0 rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .aui-dialog{box-shadow:0 4px 16px 0 rgba(var(--aui-color-origin-shadow),.75)}.aui-dialog aui-dialog-content{height:100%;overflow:auto}.aui-dialog aui-dialog-content::-webkit-scrollbar{width:4px;height:4px}.aui-dialog aui-dialog-content::-webkit-scrollbar-thumb{border-radius:2px;background-color:rgba(var(--aui-color-n-1),.2)}.aui-dialog aui-dialog-content::-webkit-scrollbar-corner{background-color:transparent}.aui-dialog aui-dialog-content:first-child .aui-dialog__content{padding-top:20px}.aui-dialog aui-dialog-content:last-child .aui-dialog__content{padding-bottom:20px}.aui-dialog__header{margin:0 20px;padding:20px 0 16px;display:flex;justify-content:space-between}.aui-dialog__header.hasDivider{margin-bottom:16px;border-bottom:1px solid rgb(var(--aui-color-divider))}.aui-dialog__header-title{width:100%;font-size:var(--aui-font-size-xl);line-height:var(--aui-line-height-xl);color:rgb(var(--aui-color-main-text));font-weight:var(--aui-font-weight-bold)}.aui-dialog__header-title>aui-icon:first-child{font-size:var(--aui-icon-size-xl);margin-right:var(--aui-spacing-m)}.aui-dialog__header-title>aui-icon:first-child[icon=info_circle_s]{color:rgb(var(--aui-color-primary))}.aui-dialog__header-title>aui-icon:first-child[icon=check_circle_s]{color:rgb(var(--aui-color-green))}.aui-dialog__header-title>aui-icon:first-child[icon=exclamation_circle_s]{color:rgb(var(--aui-color-yellow))}.aui-dialog__header-title>aui-icon:first-child[icon=exclamation_triangle_s]{color:rgb(var(--aui-color-red))}.aui-dialog__header-close{margin-left:var(--aui-spacing-xl);line-height:var(--aui-line-height-xl);font-size:var(--aui-font-size-l);color:rgb(var(--aui-color-n-4));cursor:pointer}.aui-dialog__header-close:hover{color:rgb(var(--aui-color-primary))}.aui-dialog__content{padding:0 20px;min-height:80px}.aui-dialog__footer{padding:20px;display:flex;justify-content:flex-end}.aui-dialog--small{width:400px}.aui-dialog--medium{width:600px}.aui-dialog--big{width:800px}.aui-dialog--large{width:960px}.aui-dialog--fit-content{width:-moz-fit-content;width:fit-content}.aui-dialog--fullscreen{width:90vw;height:calc(100vh - 40px);margin:0}.aui-dialog--fit-viewport{max-width:90vw;max-height:calc(100vh - 40px);margin:0}.aui-dialog--fit-viewport .aui-dialog__header{margin:0;padding:20px 20px 16px;border-bottom:1px solid rgb(var(--aui-color-divider))}.aui-dialog--fit-viewport .aui-dialog__footer{padding-top:16px;border-top:1px solid rgb(var(--aui-color-divider))}.aui-dialog--fit-viewport aui-dialog-content:not(:first-child) .aui-dialog__content{padding-top:16px}.aui-dialog--fit-viewport aui-dialog-content:not(:last-child) .aui-dialog__content{padding-bottom:16px}.aui-dialog--fit-viewport>ng-component{display:flex;flex-direction:column;overflow:auto}.aui-dialog--fit-viewport>ng-component:after{clear:both}\n"] }]
|
|
152
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { portalOutlet: [{
|
|
56
153
|
type: ViewChild,
|
|
57
154
|
args: [CdkPortalOutlet, { static: true }]
|
|
58
155
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaWFsb2cvZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9kaWFsb2cvZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxlQUFlLEdBR2hCLE1BQU0scUJBQXFCLENBQUM7QUFDN0IsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBSVQsU0FBUyxFQUNULGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQU8sUUFBUSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBR3pDLE9BQU8sRUFBRSxzQ0FBc0MsRUFBRSxNQUFNLFNBQVMsQ0FBQzs7OztBQVdqRSxNQUFNLE9BQU8sZUFBZTtJQWtDMUIsWUFBNkIsVUFBbUM7UUFBbkMsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUE5QmhFLFFBQUcsR0FBUSxRQUFRLENBQUMsWUFBWSxDQUFDLENBQUM7UUFJbEMsV0FBTSxHQUFHLEtBQUssQ0FBQztJQTBCb0QsQ0FBQztJQXhCcEUsSUFBSSxFQUFFO1FBQ0osT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQ2xCLENBQUM7SUFFRCxJQUFJLEVBQUUsQ0FBQyxLQUFLO1FBQ1YsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLEVBQUUsR0FBRyxLQUFLLENBQUM7SUFDbkQsQ0FBQztJQUlELElBQUksU0FBUztRQUNYLE9BQU8sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUN4QyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQ2hFLEVBQUUsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFJLFdBQVc7UUFDYixPQUFPLElBQUksQ0FBQyxNQUFNO1lBQ2hCLENBQUMsQ0FBQztnQkFDRSxPQUFPLEVBQUUsTUFBTTthQUNoQjtZQUNILENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDVCxDQUFDO0lBSUQscUJBQXFCLENBQUksTUFBMEI7UUFDakQsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxFQUFFO1lBQ25DLHNDQUFzQyxFQUFFLENBQUM7U0FDMUM7UUFDRCxJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUN6QixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMscUJBQXFCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVELG9CQUFvQixDQUFJLE1BQXlCO1FBQy9DLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUNuQyxzQ0FBc0MsRUFBRSxDQUFDO1NBQzFDO1FBQ0QsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDekIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3hELENBQUM7SUFFTyxpQkFBaUI7UUFDdkIsSUFBSSxRQUFRLEVBQUU7WUFDWCxRQUFRLENBQUMsYUFBNkIsQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNoRDtJQUNILENBQUM7OzRHQXhEVSxlQUFlO2dHQUFmLGVBQWUsZ0dBQ2YsZUFBZSw4REM5QjVCLDBIQU1BOzJGRHVCYSxlQUFlO2tCQVQzQixTQUFTOytCQUNFLFlBQVksaUJBR1AsaUJBQWlCLENBQUMsSUFBSSxtQkFFcEIsdUJBQXVCLENBQUMsT0FBTyx1QkFDM0IsS0FBSztpR0FJMUIsWUFBWTtzQkFEWCxTQUFTO3VCQUFDLGVBQWUsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDZGtQb3J0YWxPdXRsZXQsXG4gIENvbXBvbmVudFBvcnRhbCxcbiAgVGVtcGxhdGVQb3J0YWwsXG59IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgQ29tcG9uZW50UmVmLFxuICBFbGVtZW50UmVmLFxuICBFbWJlZGRlZFZpZXdSZWYsXG4gIFZpZXdDaGlsZCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBCZW0sIGJ1aWxkQmVtIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5pbXBvcnQgeyBEaWFsb2dDb25maWcgfSBmcm9tICcuL2RpYWxvZy1jb25maWcnO1xuaW1wb3J0IHsgdGhyb3dEaWFsb2dDb250ZW50QWxyZWFkeUF0dGFjaGVkRXJyb3IgfSBmcm9tICcuL3V0aWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kaWFsb2cuY29tcG9uZW50LnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9wcmVmZXItb24tcHVzaC1jb21wb25lbnQtY2hhbmdlLWRldGVjdGlvblxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LkRlZmF1bHQsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBEaWFsb2dDb21wb25lbnQge1xuICBAVmlld0NoaWxkKENka1BvcnRhbE91dGxldCwgeyBzdGF0aWM6IHRydWUgfSlcbiAgcG9ydGFsT3V0bGV0OiBDZGtQb3J0YWxPdXRsZXQ7XG5cbiAgYmVtOiBCZW0gPSBidWlsZEJlbSgnYXVpLWRpYWxvZycpO1xuXG4gIGNvbmZpZzogRGlhbG9nQ29uZmlnO1xuXG4gIGhpZGRlbiA9IGZhbHNlO1xuXG4gIGdldCBpZCgpIHtcbiAgICByZXR1cm4gdGhpcy5faWQ7XG4gIH1cblxuICBzZXQgaWQodmFsdWUpIHtcbiAgICB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5kYXRhc2V0LmlkID0gdmFsdWU7XG4gIH1cblxuICBwcml2YXRlIHJlYWRvbmx5IF9pZDogc3RyaW5nO1xuXG4gIGdldCByb290Q2xhc3MoKSB7XG4gICAgcmV0dXJuIGAke3RoaXMuYmVtLmJsb2NrKHRoaXMuY29uZmlnLnNpemUpfSAke1xuICAgICAgdGhpcy5jb25maWcuZml0Vmlld3BvcnQgPyB0aGlzLmJlbS5tb2RpZmllcignZml0LXZpZXdwb3J0JykgOiAnJ1xuICAgIH1gO1xuICB9XG5cbiAgZ2V0IGN1c3RvbVN0eWxlKCkge1xuICAgIHJldHVybiB0aGlzLmhpZGRlblxuICAgICAgPyB7XG4gICAgICAgICAgZGlzcGxheTogJ25vbmUnLFxuICAgICAgICB9XG4gICAgICA6IHt9O1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50Pikge31cblxuICBhdHRhY2hDb21wb25lbnRQb3J0YWw8VD4ocG9ydGFsOiBDb21wb25lbnRQb3J0YWw8VD4pOiBDb21wb25lbnRSZWY8VD4ge1xuICAgIGlmICh0aGlzLnBvcnRhbE91dGxldC5oYXNBdHRhY2hlZCgpKSB7XG4gICAgICB0aHJvd0RpYWxvZ0NvbnRlbnRBbHJlYWR5QXR0YWNoZWRFcnJvcigpO1xuICAgIH1cbiAgICB0aGlzLmJsdXJBY3RpdmVFbGVtZW50KCk7XG4gICAgcmV0dXJuIHRoaXMucG9ydGFsT3V0bGV0LmF0dGFjaENvbXBvbmVudFBvcnRhbChwb3J0YWwpO1xuICB9XG5cbiAgYXR0YWNoVGVtcGxhdGVQb3J0YWw8VD4ocG9ydGFsOiBUZW1wbGF0ZVBvcnRhbDxUPik6IEVtYmVkZGVkVmlld1JlZjxUPiB7XG4gICAgaWYgKHRoaXMucG9ydGFsT3V0bGV0Lmhhc0F0dGFjaGVkKCkpIHtcbiAgICAgIHRocm93RGlhbG9nQ29udGVudEFscmVhZHlBdHRhY2hlZEVycm9yKCk7XG4gICAgfVxuICAgIHRoaXMuYmx1ckFjdGl2ZUVsZW1lbnQoKTtcbiAgICByZXR1cm4gdGhpcy5wb3J0YWxPdXRsZXQuYXR0YWNoVGVtcGxhdGVQb3J0YWwocG9ydGFsKTtcbiAgfVxuXG4gIHByaXZhdGUgYmx1ckFjdGl2ZUVsZW1lbnQoKSB7XG4gICAgaWYgKGRvY3VtZW50KSB7XG4gICAgICAoZG9jdW1lbnQuYWN0aXZlRWxlbWVudCBhcyBIVE1MRWxlbWVudCkuYmx1cigpO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdlxuICBbbmdDbGFzc109XCJyb290Q2xhc3NcIlxuICBbbmdTdHlsZV09XCJjdXN0b21TdHlsZVwiXG4+XG4gIDxuZy10ZW1wbGF0ZSBjZGtQb3J0YWxPdXRsZXQ+PC9uZy10ZW1wbGF0ZT5cbjwvZGl2PlxuIl19
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.component.js","sourceRoot":"","sources":["../../../src/dialog/dialog.component.ts","../../../src/dialog/dialog.component.html"],"names":[],"mappings":"AAEA,OAAO,EACL,eAAe,GAGhB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,uBAAuB,EACvB,SAAS,EAIT,YAAY,EACZ,SAAS,EACT,iBAAiB,GAElB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAO,QAAQ,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAE3D,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,wBAAwB,EACxB,mBAAmB,EACnB,wBAAwB,EACxB,+BAA+B,EAC/B,sCAAsC,GACvC,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,sCAAsC,EAAE,MAAM,SAAS,CAAC;;;;AAkBjE,MAAM,OAAO,eAAe;IAsD1B,YACmB,UAAmC,EACnC,MAAiB;QADjB,eAAU,GAAV,UAAU,CAAyB;QACnC,WAAM,GAAN,MAAM,CAAW;QApDpC,QAAG,GAAQ,QAAQ,CAAC,YAAY,CAAC,CAAC;QAIlC,WAAM,GAAG,KAAK,CAAC;QACf,kBAAkB;QAClB,UAAK,GAA8B,OAAO,CAAC;QAE3C,0BAAqB,GAAG,IAAI,YAAY,EAAkB,CAAC;IA6CxD,CAAC;IAvCJ,IAAI,EAAE;QACJ,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAED,IAAI,EAAE,CAAC,KAAK;QACV,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,GAAG,KAAK,CAAC;IACnD,CAAC;IAID,IAAI,SAAS;QACX,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IACxC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,EAChE,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,IAAI,EAAE,EAAE,CAAC;IACtC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,MAAM;YAChB,CAAC,CAAC;gBACE,OAAO,EAAE,CAAC;aACX;YACH,CAAC,CAAC,EAAE,CAAC;IACT,CAAC;IAED,IAAI,YAAY;QACd,OAAO,+BAA+B,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YAC/D,CAAC,CAAC,mBAAmB;YACrB,CAAC,CAAC,wBAAwB,CAAC;IAC/B,CAAC;IAED,IAAI,YAAY;QACd,OAAO,+BAA+B,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YAC/D,CAAC,CAAC,mBAAmB;YACrB,CAAC,CAAC,wBAAwB,CAAC;IAC/B,CAAC;IAOD,qBAAqB,CAAI,MAA0B;QACjD,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,EAAE;YACnC,sCAAsC,EAAE,CAAC;SAC1C;QACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;IACzD,CAAC;IAED,oBAAoB,CAAI,MAAyB;QAC/C,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,EAAE;YACnC,sCAAsC,EAAE,CAAC;SAC1C;QACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IACxD,CAAC;IAED,eAAe,CAAC,KAAqB;QACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,gBAAgB,CAAC,KAAqB;QACpC,IAAI,KAAK,CAAC,OAAO,KAAK,OAAO,EAAE;YAC7B,IAAI,CAAC,sBAAsB,EAAE,CAAC;SAC/B;aAAM,IAAI,KAAK,CAAC,OAAO,KAAK,MAAM,EAAE;YACnC,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;IACtB,CAAC;IAEO,iBAAiB;QACvB,MAAM,aAAa,GAAG,QAAQ,CAAC,aAA4B,CAAC;QAC5D,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,kCAAkC;gBACrC,sCAAsC,CAAC,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC;oBACpE,CAAC,CAAC,aAAa;oBACf,CAAC,CAAC,IAAI,CAAC;YACX,aAAa,CAAC,IAAI,EAAE,CAAC;SACtB;IACH,CAAC;IAEO,mBAAmB;QACzB,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YAC3B,OAAO;SACR;QACD,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC;QACxD,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,iBAAiB,CAAC;QAErE,IAAI,eAAe,EAAE;YACnB,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YAC1D,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;SACjE;QAED,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACvD,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QAC7D,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACvD,YAAY,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;IAC/D,CAAC;IAEO,sBAAsB;QAC5B,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YAC3B,OAAO;SACR;QAED,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAE/B,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,iBAAiB,CAAC;QACrE,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC;QACxD,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACpD,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QAE1D,IAAI,eAAe,EAAE;YACnB,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACvD,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;SAC9D;IACH,CAAC;IAEO,qBAAqB;QAC3B,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YAC3B,OAAO;SACR;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,iBAAiB,CAAC;QACrE,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACpD,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QAE1D,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAEO,yBAAyB;QAC/B,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC;QAExD,IAAI,eAAe,EAAE;YACnB,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACvD,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;SAC9D;IACH,CAAC;IAEO,uBAAuB;QAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa;aAC/C,iBAAmC,CAAC;QAEvC,IAAI,IAAI,CAAC,kCAAkC,EAAE;YAC3C,MAAM,iBAAiB,GACrB,IAAI,CAAC,kCAAkC,CAAC,qBAAqB,EAAE,CAAC;YAClE,MAAM,YAAY,GAAG,gBAAgB,CACnC,IAAI,CAAC,kCAAkC,CACxC,CAAC;YACF,MAAM,CAAC,GAAG,YAAY,CAAC,IAAI,GAAG,iBAAiB,CAAC,KAAK,GAAG,CAAC,CAAC;YAC1D,MAAM,CAAC,GAAG,YAAY,CAAC,GAAG,GAAG,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC;YAC1D,MAAM,eAAe,GAAG,GAAG,CAAC,GAAG,YAAY,CAAC,UAAU,MACpD,CAAC,GAAG,YAAY,CAAC,SACnB,QAAQ,CAAC;YACT,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,EAAE,kBAAkB,EAAE,eAAe,CAAC,CAAC;SACzE;IACH,CAAC;;4GAjLU,eAAe;gGAAf,eAAe,oTACf,eAAe,8DClD5B,0HAMA,gpRDmCc,CAAC,gBAAgB,CAAC,eAAe,CAAC;2FAQnC,eAAe;kBAhB3B,SAAS;+BACE,YAAY,iBAGP,iBAAiB,CAAC,IAAI,mBAEpB,uBAAuB,CAAC,OAAO,uBAC3B,KAAK,cACd,CAAC,gBAAgB,CAAC,eAAe,CAAC,QACxC;wBACJ,cAAc,EAAE,oBAAoB;wBACpC,oBAAoB,EAAE,OAAO;wBAC7B,0BAA0B,EAAE,0BAA0B;wBACtD,yBAAyB,EAAE,yBAAyB;qBACrD;yHAID,YAAY;sBADX,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport {\n  CdkPortalOutlet,\n  ComponentPortal,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  EventEmitter,\n  ViewChild,\n  ViewEncapsulation,\n  Renderer2,\n} from '@angular/core';\n\nimport { Bem, buildBem, getElementOffset } from '../utils';\n\nimport {\n  dialogAnimations,\n  FADE_CLASS_NAME_MAP,\n  FADE_SLOW_CLASS_NAME_MAP,\n  ZOOM_CLASS_NAME_MAP,\n  ZOOM_SLOW_CLASS_NAME_MAP,\n  ANIMATION_DURATION_BASE_CLASSES,\n  WHITELIST_TRANSFORM_ANIMATION_ELEMENTS,\n} from './dialog-animations';\nimport { DialogConfig } from './dialog-config';\nimport { throwDialogContentAlreadyAttachedError } from './utils';\n\n@Component({\n  selector: 'aui-dialog',\n  templateUrl: './dialog.component.html',\n  styleUrls: ['./dialog.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection\n  changeDetection: ChangeDetectionStrategy.Default,\n  preserveWhitespaces: false,\n  animations: [dialogAnimations.dialogContainer],\n  host: {\n    '[@.disabled]': 'config.noAnimation',\n    '[@dialogContainer]': 'state',\n    '(@dialogContainer.start)': 'onAnimationStart($event)',\n    '(@dialogContainer.done)': 'onAnimationDone($event)',\n  },\n})\nexport class DialogComponent {\n  @ViewChild(CdkPortalOutlet, { static: true })\n  portalOutlet: CdkPortalOutlet;\n\n  bem: Bem = buildBem('aui-dialog');\n\n  config: DialogConfig;\n\n  hidden = false;\n  // animation state\n  state: 'void' | 'enter' | 'exit' = 'enter';\n\n  animationStateChanged = new EventEmitter<AnimationEvent>();\n\n  elementFocusedBeforeModalWasOpened: HTMLElement;\n\n  overlayRef: OverlayRef;\n\n  get id() {\n    return this._id;\n  }\n\n  set id(value) {\n    this.elementRef.nativeElement.dataset.id = value;\n  }\n\n  private readonly _id: string;\n\n  get rootClass() {\n    return `${this.bem.block(this.config.size)} ${\n      this.config.fitViewport ? this.bem.modifier('fit-viewport') : ''\n    } ${this.config.customClass || ''}`;\n  }\n\n  get customStyle() {\n    return this.hidden\n      ? {\n          opacity: 0,\n        }\n      : {};\n  }\n\n  get zoomClassMap() {\n    return ANIMATION_DURATION_BASE_CLASSES.includes(this.config.size)\n      ? ZOOM_CLASS_NAME_MAP\n      : ZOOM_SLOW_CLASS_NAME_MAP;\n  }\n\n  get fadeClassMap() {\n    return ANIMATION_DURATION_BASE_CLASSES.includes(this.config.size)\n      ? FADE_CLASS_NAME_MAP\n      : FADE_SLOW_CLASS_NAME_MAP;\n  }\n\n  constructor(\n    private readonly elementRef: ElementRef<HTMLElement>,\n    private readonly render: Renderer2,\n  ) {}\n\n  attachComponentPortal<T>(portal: ComponentPortal<T>): ComponentRef<T> {\n    if (this.portalOutlet.hasAttached()) {\n      throwDialogContentAlreadyAttachedError();\n    }\n    this.blurActiveElement();\n    return this.portalOutlet.attachComponentPortal(portal);\n  }\n\n  attachTemplatePortal<T>(portal: TemplatePortal<T>): EmbeddedViewRef<T> {\n    if (this.portalOutlet.hasAttached()) {\n      throwDialogContentAlreadyAttachedError();\n    }\n    this.blurActiveElement();\n    return this.portalOutlet.attachTemplatePortal(portal);\n  }\n\n  onAnimationDone(event: AnimationEvent): void {\n    this.cleanAnimationClass();\n    this.animationStateChanged.emit(event);\n  }\n\n  onAnimationStart(event: AnimationEvent): void {\n    if (event.toState === 'enter') {\n      this.setEnterAnimationClass();\n    } else if (event.toState === 'exit') {\n      this.setExitAnimationClass();\n    }\n  }\n\n  startExitAnimation(): void {\n    this.state = 'exit';\n  }\n\n  private blurActiveElement() {\n    const activeElement = document.activeElement as HTMLElement;\n    if (document) {\n      this.elementFocusedBeforeModalWasOpened =\n        WHITELIST_TRANSFORM_ANIMATION_ELEMENTS.includes(activeElement.tagName)\n          ? activeElement\n          : null;\n      activeElement.blur();\n    }\n  }\n\n  private cleanAnimationClass(): void {\n    if (this.config.noAnimation) {\n      return;\n    }\n    const backdropElement = this.overlayRef.backdropElement;\n    const modalElement = this.elementRef.nativeElement.firstElementChild;\n\n    if (backdropElement) {\n      backdropElement.classList.remove(this.fadeClassMap.enter);\n      backdropElement.classList.remove(this.fadeClassMap.enterActive);\n    }\n\n    modalElement.classList.remove(this.zoomClassMap.enter);\n    modalElement.classList.remove(this.zoomClassMap.enterActive);\n    modalElement.classList.remove(this.zoomClassMap.leave);\n    modalElement.classList.remove(this.zoomClassMap.leaveActive);\n  }\n\n  private setEnterAnimationClass(): void {\n    if (this.config.noAnimation) {\n      return;\n    }\n\n    this.setModalTransformOrigin();\n\n    const modalElement = this.elementRef.nativeElement.firstElementChild;\n    const backdropElement = this.overlayRef.backdropElement;\n    modalElement.classList.add(this.zoomClassMap.enter);\n    modalElement.classList.add(this.zoomClassMap.enterActive);\n\n    if (backdropElement) {\n      backdropElement.classList.add(this.fadeClassMap.enter);\n      backdropElement.classList.add(this.fadeClassMap.enterActive);\n    }\n  }\n\n  private setExitAnimationClass(): void {\n    if (this.config.noAnimation) {\n      return;\n    }\n\n    const modalElement = this.elementRef.nativeElement.firstElementChild;\n    modalElement.classList.add(this.zoomClassMap.leave);\n    modalElement.classList.add(this.zoomClassMap.leaveActive);\n\n    this.setMaskExitAnimationClass();\n  }\n\n  private setMaskExitAnimationClass(): void {\n    const backdropElement = this.overlayRef.backdropElement;\n\n    if (backdropElement) {\n      backdropElement.classList.add(this.fadeClassMap.leave);\n      backdropElement.classList.add(this.fadeClassMap.leaveActive);\n    }\n  }\n\n  private setModalTransformOrigin(): void {\n    const modalElement = this.elementRef.nativeElement\n      .firstElementChild as HTMLDivElement;\n\n    if (this.elementFocusedBeforeModalWasOpened) {\n      const previouslyDOMRect =\n        this.elementFocusedBeforeModalWasOpened.getBoundingClientRect();\n      const lastPosition = getElementOffset(\n        this.elementFocusedBeforeModalWasOpened,\n      );\n      const x = lastPosition.left + previouslyDOMRect.width / 2;\n      const y = lastPosition.top + previouslyDOMRect.height / 2;\n      const transformOrigin = `${x - modalElement.offsetLeft}px ${\n        y - modalElement.offsetTop\n      }px 0px`;\n      this.render.setStyle(modalElement, 'transform-origin', transformOrigin);\n    }\n  }\n}\n","<div\n  [ngClass]=\"rootClass\"\n  [ngStyle]=\"customStyle\"\n>\n  <ng-template cdkPortalOutlet></ng-template>\n</div>\n"]}
|
|
@@ -33,6 +33,7 @@ export class DialogService {
|
|
|
33
33
|
confirm(config) {
|
|
34
34
|
const dialogRef = this.open(ConfirmDialogComponent, {
|
|
35
35
|
size: DialogSize.FitContent,
|
|
36
|
+
noAnimation: !!config.noAnimation,
|
|
36
37
|
});
|
|
37
38
|
dialogRef.componentInstance.setConfig(config);
|
|
38
39
|
return new Promise((resolve, reject) => {
|
|
@@ -74,7 +75,9 @@ export class DialogService {
|
|
|
74
75
|
scrollStrategy: this.overlay.scrollStrategies.block(),
|
|
75
76
|
hasBackdrop: dialogConfig.hasBackdrop && !this.openDialogs.length,
|
|
76
77
|
backdropClass: DialogService.DIALOG_BACKDROP_CLASS,
|
|
77
|
-
panelClass:
|
|
78
|
+
panelClass: dialogConfig.fitViewport || dialogConfig.size === DialogSize.Fullscreen
|
|
79
|
+
? DialogService.DIALOG_OVERLAY_PANE_FIT_VIEWPORT_CLASS
|
|
80
|
+
: DialogService.DIALOG_OVERLAY_PANE_CLASS,
|
|
78
81
|
width: '100vw',
|
|
79
82
|
height: '100vh',
|
|
80
83
|
};
|
|
@@ -83,6 +86,7 @@ export class DialogService {
|
|
|
83
86
|
const dialogPortal = new ComponentPortal(DialogComponent, config.viewContainerRef);
|
|
84
87
|
const dialogRef = overlayRef.attach(dialogPortal);
|
|
85
88
|
dialogRef.instance.config = config;
|
|
89
|
+
dialogRef.instance.overlayRef = overlayRef;
|
|
86
90
|
return dialogRef.instance;
|
|
87
91
|
}
|
|
88
92
|
attachDialogContent(compOrTempRef, dialogIns, overlayRef, config) {
|
|
@@ -122,9 +126,10 @@ export class DialogService {
|
|
|
122
126
|
}
|
|
123
127
|
DialogService.DIALOG_OVERLAY_PANE_CLASS = 'aui-dialog-overlay-pane';
|
|
124
128
|
DialogService.DIALOG_BACKDROP_CLASS = 'aui-dialog-backdrop';
|
|
129
|
+
DialogService.DIALOG_OVERLAY_PANE_FIT_VIEWPORT_CLASS = 'aui-dialog-overlay-pane--fit-viewport';
|
|
125
130
|
DialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DialogService, deps: [{ token: i1.Overlay }, { token: i0.Injector }, { token: i1.ScrollDispatcher }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
126
131
|
DialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DialogService });
|
|
127
132
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DialogService, decorators: [{
|
|
128
133
|
type: Injectable
|
|
129
134
|
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.Injector }, { type: i1.ScrollDispatcher }, { type: i0.NgZone }]; } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../src/dialog/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ScrollDispatcher,\n} from '@angular/cdk/overlay';\nimport {\n  ComponentPortal,\n  ComponentType,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  Injectable,\n  InjectionToken,\n  Injector,\n  NgZone,\n  TemplateRef,\n} from '@angular/core';\n\nimport { ConfirmDialogConfig } from './confirm-dialog/confirm-dialog-config';\nimport { ConfirmDialogComponent } from './confirm-dialog/confirm-dialog.component';\nimport { DialogConfig } from './dialog-config';\nimport { DialogRef } from './dialog-ref';\nimport { DialogComponent } from './dialog.component';\nimport { DialogSize } from './dialog.types';\n\nexport const DIALOG_DATA = new InjectionToken<any>('aui-dialog-data');\n\n@Injectable()\nexport class DialogService {\n  static readonly DIALOG_OVERLAY_PANE_CLASS = 'aui-dialog-overlay-pane';\n  static readonly DIALOG_BACKDROP_CLASS = 'aui-dialog-backdrop';\n\n  openDialogs: Array<DialogRef<any>> = [];\n\n  constructor(\n    private readonly overlay: Overlay,\n    private readonly injector: Injector,\n    private readonly scrollDispatcher: ScrollDispatcher,\n    private readonly ngZone: NgZone,\n  ) {}\n\n  open<T, D = any, R = any>(\n    compOrTempRef: ComponentType<T> | TemplateRef<T>,\n    config: DialogConfig<D> = null,\n  ): DialogRef<T, R> {\n    this.hiddenPrevDialog();\n\n    config = { ...new DialogConfig(), ...config };\n\n    const overlayRef = this.createOverlay(config);\n    const dialogIns = this.attachDialog(overlayRef, config);\n    const dialogRef = this.attachDialogContent<T, D, R>(\n      compOrTempRef,\n      dialogIns,\n      overlayRef,\n      config,\n    );\n    this.openDialogs.push(dialogRef);\n    dialogRef.updatePosition().updateSize();\n    dialogRef.afterClosed().subscribe(() => {\n      this.removeDialog(dialogRef);\n      this.showPrevDialog();\n    });\n\n    return dialogRef;\n  }\n\n  confirm<T = unknown, R = unknown>(\n    config: ConfirmDialogConfig<T, R>,\n  ): Promise<T> {\n    const dialogRef = this.open<\n      ConfirmDialogComponent<T, R>,\n      void,\n      { confirm: boolean; result: T | R }\n    >(ConfirmDialogComponent, {\n      size: DialogSize.FitContent,\n    });\n    dialogRef.componentInstance.setConfig(config);\n    return new Promise((resolve, reject) => {\n      dialogRef.afterClosed().subscribe(action => {\n        if (action.confirm) {\n          resolve(action.result as T);\n        } else {\n          // eslint-disable-next-line prefer-promise-reject-errors\n          reject(action.result as R);\n        }\n      });\n    });\n  }\n\n  closeAll() {\n    this.openDialogs.forEach(dialogRef => {\n      dialogRef.close();\n    });\n  }\n\n  private hiddenPrevDialog() {\n    if (this.openDialogs.length > 0) {\n      this.openDialogs[this.openDialogs.length - 1].dialogInstance.hidden =\n        true;\n    }\n  }\n\n  private showPrevDialog() {\n    if (this.openDialogs.length > 0) {\n      this.openDialogs[this.openDialogs.length - 1].dialogInstance.hidden =\n        false;\n    }\n  }\n\n  private createOverlay(config: DialogConfig): OverlayRef {\n    const overlayConfig = this.getOverlayConfig(config);\n    return this.overlay.create(overlayConfig);\n  }\n\n  private getOverlayConfig(dialogConfig: DialogConfig): OverlayConfig {\n    return {\n      positionStrategy: this.overlay.position().global(),\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n      hasBackdrop: dialogConfig.hasBackdrop && !this.openDialogs.length,\n      backdropClass: DialogService.DIALOG_BACKDROP_CLASS,\n      panelClass: DialogService.DIALOG_OVERLAY_PANE_CLASS,\n      width: '100vw',\n      height: '100vh',\n    };\n  }\n\n  private attachDialog(\n    overlayRef: OverlayRef,\n    config: DialogConfig,\n  ): DialogComponent {\n    const dialogPortal = new ComponentPortal(\n      DialogComponent,\n      config.viewContainerRef,\n    );\n    const dialogRef = overlayRef.attach(dialogPortal);\n    dialogRef.instance.config = config;\n    return dialogRef.instance;\n  }\n\n  private attachDialogContent<T, D, R>(\n    compOrTempRef: ComponentType<T> | TemplateRef<T>,\n    dialogIns: DialogComponent,\n    overlayRef: OverlayRef,\n    config: DialogConfig<D>,\n  ): DialogRef<T, R> {\n    const dialogRef = new DialogRef<T, R>(\n      overlayRef,\n      dialogIns,\n      this.scrollDispatcher,\n      this.ngZone,\n    );\n\n    if (compOrTempRef instanceof TemplateRef) {\n      dialogIns.attachTemplatePortal(\n        new TemplatePortal(compOrTempRef, null, {\n          $implicit: config.data,\n        } as any),\n      );\n    } else {\n      const injector = this.createInjector(config, dialogRef, dialogIns);\n      const contentRef = dialogIns.attachComponentPortal<T>(\n        new ComponentPortal(compOrTempRef, null, injector),\n      );\n      dialogRef.componentInstance = contentRef.instance;\n    }\n    return dialogRef;\n  }\n\n  private createInjector<T>(\n    config: DialogConfig,\n    dialogRef: DialogRef<T>,\n    dialogIns: DialogComponent,\n  ): Injector {\n    const userInjector = config?.viewContainerRef?.injector;\n    return Injector.create({\n      providers: [\n        {\n          provide: DialogRef,\n          useValue: dialogRef,\n        },\n        {\n          provide: DIALOG_DATA,\n          useValue: config.data || dialogIns,\n        },\n      ],\n      parent: userInjector || this.injector,\n    });\n  }\n\n  private removeDialog(dialogRef: DialogRef<any>) {\n    const index = this.openDialogs.indexOf(dialogRef);\n    this.openDialogs.splice(index, 1);\n  }\n}\n"]}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../src/dialog/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ScrollDispatcher,\n} from '@angular/cdk/overlay';\nimport {\n  ComponentPortal,\n  ComponentType,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  Injectable,\n  InjectionToken,\n  Injector,\n  NgZone,\n  TemplateRef,\n} from '@angular/core';\n\nimport { ConfirmDialogConfig } from './confirm-dialog/confirm-dialog-config';\nimport { ConfirmDialogComponent } from './confirm-dialog/confirm-dialog.component';\nimport { DialogConfig } from './dialog-config';\nimport { DialogRef } from './dialog-ref';\nimport { DialogComponent } from './dialog.component';\nimport { DialogSize } from './dialog.types';\n\nexport const DIALOG_DATA = new InjectionToken<any>('aui-dialog-data');\n\n@Injectable()\nexport class DialogService {\n  static readonly DIALOG_OVERLAY_PANE_CLASS = 'aui-dialog-overlay-pane';\n  static readonly DIALOG_BACKDROP_CLASS = 'aui-dialog-backdrop';\n  static readonly DIALOG_OVERLAY_PANE_FIT_VIEWPORT_CLASS =\n    'aui-dialog-overlay-pane--fit-viewport';\n\n  openDialogs: Array<DialogRef<any>> = [];\n\n  constructor(\n    private readonly overlay: Overlay,\n    private readonly injector: Injector,\n    private readonly scrollDispatcher: ScrollDispatcher,\n    private readonly ngZone: NgZone,\n  ) {}\n\n  open<T, D = any, R = any>(\n    compOrTempRef: ComponentType<T> | TemplateRef<T>,\n    config: DialogConfig<D> = null,\n  ): DialogRef<T, R> {\n    this.hiddenPrevDialog();\n\n    config = { ...new DialogConfig(), ...config };\n\n    const overlayRef = this.createOverlay(config);\n    const dialogIns = this.attachDialog(overlayRef, config);\n    const dialogRef = this.attachDialogContent<T, D, R>(\n      compOrTempRef,\n      dialogIns,\n      overlayRef,\n      config,\n    );\n    this.openDialogs.push(dialogRef);\n    dialogRef.updatePosition().updateSize();\n    dialogRef.afterClosed().subscribe(() => {\n      this.removeDialog(dialogRef);\n      this.showPrevDialog();\n    });\n\n    return dialogRef;\n  }\n\n  confirm<T = unknown, R = unknown>(\n    config: ConfirmDialogConfig<T, R>,\n  ): Promise<T> {\n    const dialogRef = this.open<\n      ConfirmDialogComponent<T, R>,\n      void,\n      { confirm: boolean; result: T | R }\n    >(ConfirmDialogComponent, {\n      size: DialogSize.FitContent,\n      noAnimation: !!config.noAnimation,\n    });\n    dialogRef.componentInstance.setConfig(config);\n    return new Promise((resolve, reject) => {\n      dialogRef.afterClosed().subscribe(action => {\n        if (action.confirm) {\n          resolve(action.result as T);\n        } else {\n          // eslint-disable-next-line prefer-promise-reject-errors\n          reject(action.result as R);\n        }\n      });\n    });\n  }\n\n  closeAll() {\n    this.openDialogs.forEach(dialogRef => {\n      dialogRef.close();\n    });\n  }\n\n  private hiddenPrevDialog() {\n    if (this.openDialogs.length > 0) {\n      this.openDialogs[this.openDialogs.length - 1].dialogInstance.hidden =\n        true;\n    }\n  }\n\n  private showPrevDialog() {\n    if (this.openDialogs.length > 0) {\n      this.openDialogs[this.openDialogs.length - 1].dialogInstance.hidden =\n        false;\n    }\n  }\n\n  private createOverlay(config: DialogConfig): OverlayRef {\n    const overlayConfig = this.getOverlayConfig(config);\n    return this.overlay.create(overlayConfig);\n  }\n\n  private getOverlayConfig(dialogConfig: DialogConfig): OverlayConfig {\n    return {\n      positionStrategy: this.overlay.position().global(),\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n      hasBackdrop: dialogConfig.hasBackdrop && !this.openDialogs.length,\n      backdropClass: DialogService.DIALOG_BACKDROP_CLASS,\n      panelClass:\n        dialogConfig.fitViewport || dialogConfig.size === DialogSize.Fullscreen\n          ? DialogService.DIALOG_OVERLAY_PANE_FIT_VIEWPORT_CLASS\n          : DialogService.DIALOG_OVERLAY_PANE_CLASS,\n      width: '100vw',\n      height: '100vh',\n    };\n  }\n\n  private attachDialog(\n    overlayRef: OverlayRef,\n    config: DialogConfig,\n  ): DialogComponent {\n    const dialogPortal = new ComponentPortal(\n      DialogComponent,\n      config.viewContainerRef,\n    );\n    const dialogRef = overlayRef.attach(dialogPortal);\n    dialogRef.instance.config = config;\n    dialogRef.instance.overlayRef = overlayRef;\n    return dialogRef.instance;\n  }\n\n  private attachDialogContent<T, D, R>(\n    compOrTempRef: ComponentType<T> | TemplateRef<T>,\n    dialogIns: DialogComponent,\n    overlayRef: OverlayRef,\n    config: DialogConfig<D>,\n  ): DialogRef<T, R> {\n    const dialogRef = new DialogRef<T, R>(\n      overlayRef,\n      dialogIns,\n      this.scrollDispatcher,\n      this.ngZone,\n    );\n\n    if (compOrTempRef instanceof TemplateRef) {\n      dialogIns.attachTemplatePortal(\n        new TemplatePortal(compOrTempRef, null, {\n          $implicit: config.data,\n        } as any),\n      );\n    } else {\n      const injector = this.createInjector(config, dialogRef, dialogIns);\n      const contentRef = dialogIns.attachComponentPortal<T>(\n        new ComponentPortal(compOrTempRef, null, injector),\n      );\n      dialogRef.componentInstance = contentRef.instance;\n    }\n    return dialogRef;\n  }\n\n  private createInjector<T>(\n    config: DialogConfig,\n    dialogRef: DialogRef<T>,\n    dialogIns: DialogComponent,\n  ): Injector {\n    const userInjector = config?.viewContainerRef?.injector;\n    return Injector.create({\n      providers: [\n        {\n          provide: DialogRef,\n          useValue: dialogRef,\n        },\n        {\n          provide: DIALOG_DATA,\n          useValue: config.data || dialogIns,\n        },\n      ],\n      parent: userInjector || this.injector,\n    });\n  }\n\n  private removeDialog(dialogRef: DialogRef<any>) {\n    const index = this.openDialogs.indexOf(dialogRef);\n    this.openDialogs.splice(index, 1);\n  }\n}\n"]}
|