@cuby-ui/core 0.0.84 → 0.0.85
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 +24 -24
- package/components/accordion/accordion-item/accordion-item.component.d.ts +9 -9
- package/components/accordion/accordion.component.d.ts +5 -5
- package/components/accordion/accordion.module.d.ts +11 -11
- package/components/accordion/index.d.ts +3 -3
- package/components/alert/alert.component.d.ts +13 -13
- package/components/alert/alert.interfaces.d.ts +9 -9
- package/components/alert/alert.module.d.ts +11 -11
- package/components/alert/alert.service.d.ts +7 -7
- package/components/alert/alert.tokens.d.ts +15 -15
- package/components/alert/alert.types.d.ts +3 -3
- package/components/alert/alerts.component.d.ts +17 -17
- package/components/alert/index.d.ts +8 -8
- package/components/badge/badge.component.d.ts +10 -10
- package/components/badge/badge.module.d.ts +8 -8
- package/components/badge/badge.options.d.ts +8 -8
- package/components/badge/index.d.ts +2 -2
- package/components/banner/banner.component.d.ts +21 -21
- package/components/banner/banner.module.d.ts +11 -11
- package/components/banner/banner.options.d.ts +13 -13
- package/components/banner/index.d.ts +3 -3
- package/components/breadcrumbs/breadcrumb/breadcrumb.component.d.ts +6 -6
- package/components/breadcrumbs/breadcrumbs.component.d.ts +7 -7
- package/components/breadcrumbs/breadcrumbs.module.d.ts +10 -10
- package/components/breadcrumbs/index.d.ts +3 -3
- package/components/button/button.component.d.ts +30 -30
- package/components/button/button.module.d.ts +9 -9
- package/components/button/button.options.d.ts +9 -9
- package/components/button/index.d.ts +3 -3
- package/components/button-group/button-group.component.d.ts +5 -5
- package/components/button-group/button-group.module.d.ts +7 -7
- package/components/button-group/index.d.ts +2 -2
- package/components/checkbox/checkbox.component.d.ts +5 -5
- package/components/checkbox/checkbox.module.d.ts +7 -7
- package/components/checkbox/index.d.ts +2 -2
- package/components/context-menu/context-menu.component.d.ts +37 -37
- package/components/context-menu/context-menu.module.d.ts +9 -9
- package/components/context-menu/index.d.ts +2 -2
- package/components/dialog/dialog-actions/dialog-actions.component.d.ts +5 -5
- package/components/dialog/dialog.component.d.ts +33 -33
- package/components/dialog/dialog.interfaces.d.ts +8 -8
- package/components/dialog/dialog.module.d.ts +12 -12
- package/components/dialog/dialog.service.d.ts +7 -7
- package/components/dialog/dialog.tokens.d.ts +8 -8
- package/components/dialog/dialogs.component.d.ts +16 -16
- package/components/dialog/index.d.ts +7 -7
- package/components/form-field/form-field.component.d.ts +5 -5
- package/components/form-field/form-field.module.d.ts +7 -7
- package/components/form-field/index.d.ts +2 -2
- package/components/hint/hint.component.d.ts +7 -7
- package/components/hint/hint.module.d.ts +7 -7
- package/components/hint/index.d.ts +2 -2
- package/components/icon-button/icon-button.component.d.ts +13 -13
- package/components/icon-button/icon-button.module.d.ts +9 -9
- package/components/icon-button/index.d.ts +2 -2
- package/components/index.d.ts +24 -24
- package/components/input-number/index.d.ts +2 -2
- package/components/input-number/input-number.component.d.ts +55 -55
- package/components/input-number/input-number.module.d.ts +11 -11
- package/components/input-number/input-number.options.d.ts +9 -9
- package/components/input-password/index.d.ts +2 -2
- package/components/input-password/input-password.component.d.ts +31 -31
- package/components/input-password/input-password.module.d.ts +11 -11
- package/components/input-text/index.d.ts +2 -2
- package/components/input-text/input-text.component.d.ts +31 -31
- package/components/input-text/input-text.module.d.ts +11 -11
- package/components/label/index.d.ts +2 -2
- package/components/label/label.component.d.ts +6 -6
- package/components/label/label.module.d.ts +8 -8
- package/components/notification/index.d.ts +3 -3
- package/components/notification/notification.component.d.ts +13 -13
- package/components/notification/notification.module.d.ts +10 -10
- package/components/notification/notification.options.d.ts +13 -13
- package/components/radio/index.d.ts +2 -2
- package/components/radio/radio.component.d.ts +5 -5
- package/components/radio/radio.module.d.ts +7 -7
- package/components/root/index.d.ts +2 -2
- package/components/root/root.component.d.ts +11 -11
- package/components/root/root.module.d.ts +10 -10
- package/components/select/index.d.ts +2 -2
- package/components/select/select.component.d.ts +44 -44
- package/components/select/select.module.d.ts +10 -10
- package/components/svg/index.d.ts +2 -2
- package/components/svg/svg.component.d.ts +16 -16
- package/components/svg/svg.module.d.ts +8 -8
- package/components/textarea/index.d.ts +2 -2
- package/components/textarea/textarea.component.d.ts +10 -10
- package/components/textarea/textarea.module.d.ts +7 -7
- package/components/toggle/index.d.ts +2 -2
- package/components/toggle/toggle.component.d.ts +5 -5
- package/components/toggle/toggle.module.d.ts +7 -7
- package/directives/index.d.ts +1 -1
- package/directives/text-field-controller/index.d.ts +8 -8
- package/directives/text-field-controller/text-field-controller.module.d.ts +11 -11
- package/directives/text-field-controller/text-field-controller.provider.d.ts +4 -4
- package/directives/text-field-controller/text-field-icon-left.directive.d.ts +9 -9
- package/directives/text-field-controller/text-field-id.directive.d.ts +8 -8
- package/directives/text-field-controller/text-field-is-error.directive.d.ts +8 -8
- package/directives/text-field-controller/text-field-placeholder.directive.d.ts +8 -8
- package/directives/text-field-controller/text-field-size.directive.d.ts +9 -9
- package/directives/text-field-controller/text-field.controller.d.ts +20 -20
- package/esm2020/components/accordion/accordion-item/accordion-item.component.mjs +22 -22
- package/esm2020/components/accordion/accordion.component.mjs +11 -11
- package/esm2020/components/accordion/accordion.module.mjs +37 -37
- package/esm2020/components/accordion/index.mjs +4 -4
- package/esm2020/components/alert/alert.component.mjs +37 -37
- package/esm2020/components/alert/alert.interfaces.mjs +2 -2
- package/esm2020/components/alert/alert.module.mjs +40 -40
- package/esm2020/components/alert/alert.service.mjs +17 -17
- package/esm2020/components/alert/alert.tokens.mjs +19 -19
- package/esm2020/components/alert/alert.types.mjs +2 -2
- package/esm2020/components/alert/alerts.component.mjs +36 -36
- package/esm2020/components/alert/index.mjs +9 -9
- package/esm2020/components/badge/badge.component.mjs +31 -31
- package/esm2020/components/badge/badge.module.mjs +18 -18
- package/esm2020/components/badge/badge.options.mjs +8 -8
- package/esm2020/components/badge/index.mjs +3 -3
- package/esm2020/components/banner/banner.component.mjs +68 -68
- package/esm2020/components/banner/banner.module.mjs +31 -31
- package/esm2020/components/banner/banner.options.mjs +6 -6
- package/esm2020/components/banner/index.mjs +4 -4
- package/esm2020/components/breadcrumbs/breadcrumb/breadcrumb.component.mjs +16 -16
- package/esm2020/components/breadcrumbs/breadcrumbs.component.mjs +17 -17
- package/esm2020/components/breadcrumbs/breadcrumbs.module.mjs +33 -33
- package/esm2020/components/breadcrumbs/index.mjs +4 -4
- package/esm2020/components/button/button.component.mjs +104 -104
- package/esm2020/components/button/button.module.mjs +24 -24
- package/esm2020/components/button/button.options.mjs +10 -10
- package/esm2020/components/button/index.mjs +4 -4
- package/esm2020/components/button-group/button-group.component.mjs +11 -11
- package/esm2020/components/button-group/button-group.module.mjs +16 -16
- package/esm2020/components/button-group/index.mjs +3 -3
- package/esm2020/components/checkbox/checkbox.component.mjs +11 -11
- package/esm2020/components/checkbox/checkbox.module.mjs +16 -16
- package/esm2020/components/checkbox/index.mjs +3 -3
- package/esm2020/components/context-menu/context-menu.component.mjs +135 -135
- package/esm2020/components/context-menu/context-menu.module.mjs +24 -24
- package/esm2020/components/context-menu/index.mjs +3 -3
- package/esm2020/components/dialog/dialog-actions/dialog-actions.component.mjs +11 -11
- package/esm2020/components/dialog/dialog.component.mjs +65 -65
- package/esm2020/components/dialog/dialog.interfaces.mjs +2 -2
- package/esm2020/components/dialog/dialog.module.mjs +41 -41
- package/esm2020/components/dialog/dialog.service.mjs +17 -17
- package/esm2020/components/dialog/dialog.tokens.mjs +11 -11
- package/esm2020/components/dialog/dialogs.component.mjs +33 -33
- package/esm2020/components/dialog/index.mjs +8 -8
- package/esm2020/components/form-field/form-field.component.mjs +11 -11
- package/esm2020/components/form-field/form-field.module.mjs +16 -16
- package/esm2020/components/form-field/index.mjs +3 -3
- package/esm2020/components/hint/hint.component.mjs +19 -19
- package/esm2020/components/hint/hint.module.mjs +16 -16
- package/esm2020/components/hint/index.mjs +3 -3
- package/esm2020/components/icon-button/icon-button.component.mjs +32 -32
- package/esm2020/components/icon-button/icon-button.module.mjs +24 -24
- package/esm2020/components/icon-button/index.mjs +3 -3
- package/esm2020/components/index.mjs +25 -25
- package/esm2020/components/input-number/index.mjs +3 -3
- package/esm2020/components/input-number/input-number.component.mjs +204 -204
- package/esm2020/components/input-number/input-number.module.mjs +33 -33
- package/esm2020/components/input-number/input-number.options.mjs +11 -11
- package/esm2020/components/input-password/index.mjs +3 -3
- package/esm2020/components/input-password/input-password.component.mjs +89 -89
- package/esm2020/components/input-password/input-password.module.mjs +33 -33
- package/esm2020/components/input-text/index.mjs +3 -3
- package/esm2020/components/input-text/input-text.component.mjs +87 -87
- package/esm2020/components/input-text/input-text.module.mjs +33 -33
- package/esm2020/components/label/index.mjs +3 -3
- package/esm2020/components/label/label.component.mjs +17 -17
- package/esm2020/components/label/label.module.mjs +18 -18
- package/esm2020/components/notification/index.mjs +4 -4
- package/esm2020/components/notification/notification.component.mjs +51 -51
- package/esm2020/components/notification/notification.module.mjs +27 -27
- package/esm2020/components/notification/notification.options.mjs +6 -6
- package/esm2020/components/radio/index.mjs +3 -3
- package/esm2020/components/radio/radio.component.mjs +11 -11
- package/esm2020/components/radio/radio.module.mjs +16 -16
- package/esm2020/components/root/index.mjs +3 -3
- package/esm2020/components/root/root.component.mjs +30 -30
- package/esm2020/components/root/root.module.mjs +28 -28
- package/esm2020/components/select/index.mjs +3 -3
- package/esm2020/components/select/select.component.mjs +115 -114
- package/esm2020/components/select/select.module.mjs +29 -29
- package/esm2020/components/svg/index.mjs +3 -3
- package/esm2020/components/svg/svg.component.mjs +50 -50
- package/esm2020/components/svg/svg.module.mjs +18 -18
- package/esm2020/components/textarea/index.mjs +3 -3
- package/esm2020/components/textarea/textarea.component.mjs +35 -35
- package/esm2020/components/textarea/textarea.module.mjs +16 -16
- package/esm2020/components/toggle/index.mjs +3 -3
- package/esm2020/components/toggle/toggle.component.mjs +11 -11
- package/esm2020/components/toggle/toggle.module.mjs +16 -16
- package/esm2020/cuby-ui-core.mjs +4 -4
- package/esm2020/directives/index.mjs +2 -2
- package/esm2020/directives/text-field-controller/index.mjs +9 -9
- package/esm2020/directives/text-field-controller/text-field-controller.module.mjs +40 -40
- package/esm2020/directives/text-field-controller/text-field-controller.provider.mjs +24 -24
- package/esm2020/directives/text-field-controller/text-field-icon-left.directive.mjs +21 -21
- package/esm2020/directives/text-field-controller/text-field-id.directive.mjs +21 -21
- package/esm2020/directives/text-field-controller/text-field-is-error.directive.mjs +24 -24
- package/esm2020/directives/text-field-controller/text-field-placeholder.directive.mjs +21 -21
- package/esm2020/directives/text-field-controller/text-field-size.directive.mjs +24 -24
- package/esm2020/directives/text-field-controller/text-field.controller.mjs +25 -25
- package/esm2020/index.mjs +7 -7
- package/esm2020/interfaces/context-menu-item.mjs +2 -2
- package/esm2020/interfaces/index.mjs +3 -3
- package/esm2020/interfaces/option.mjs +2 -2
- package/esm2020/services/index.mjs +3 -3
- package/esm2020/services/theme.options.mjs +6 -6
- package/esm2020/services/theme.service.mjs +30 -30
- package/esm2020/types/appearance.mjs +2 -2
- package/esm2020/types/hint-type.mjs +2 -2
- package/esm2020/types/index.mjs +8 -8
- package/esm2020/types/position.mjs +2 -2
- package/esm2020/types/resizing.mjs +2 -2
- package/esm2020/types/shape.mjs +2 -2
- package/esm2020/types/size.mjs +2 -2
- package/esm2020/types/status.mjs +2 -2
- package/esm2020/utils/format/index.mjs +3 -3
- package/esm2020/utils/format/remove-spaces.mjs +4 -4
- package/esm2020/utils/format/replace.mjs +5 -5
- package/esm2020/utils/index.mjs +2 -2
- package/fesm2015/cuby-ui-core.mjs +1859 -1858
- package/fesm2015/cuby-ui-core.mjs.map +1 -1
- package/fesm2020/cuby-ui-core.mjs +1859 -1858
- package/fesm2020/cuby-ui-core.mjs.map +1 -1
- package/fonts/Inter-Bold.svg +25443 -25443
- package/fonts/Inter-Medium.svg +25400 -25400
- package/fonts/Inter-Regular.svg +24341 -24341
- package/fonts/Inter-SemiBold.svg +25459 -25459
- package/index.d.ts +6 -6
- package/interfaces/context-menu-item.d.ts +7 -7
- package/interfaces/index.d.ts +2 -2
- package/interfaces/option.d.ts +4 -4
- package/package.json +1 -1
- package/services/index.d.ts +2 -2
- package/services/theme.options.d.ts +5 -5
- package/services/theme.service.d.ts +12 -12
- package/styles/fonts.scss +51 -51
- package/styles/global.scss +9 -9
- package/styles/mixins/buttons.scss +12 -12
- package/styles/mixins/headings.scss +115 -115
- package/styles/mixins/inputs.scss +95 -95
- package/styles/mixins/lists.scss +5 -5
- package/styles/mixins/paddings.scss +35 -35
- package/styles/mixins/shadows.scss +38 -38
- package/styles/mixins/texts.scss +219 -219
- package/styles/theme.scss +150 -150
- package/styles/variables/colors.scss +125 -125
- package/types/appearance.d.ts +8 -8
- package/types/hint-type.d.ts +1 -1
- package/types/index.d.ts +7 -7
- package/types/position.d.ts +2 -2
- package/types/resizing.d.ts +2 -2
- package/types/shape.d.ts +1 -1
- package/types/size.d.ts +4 -4
- package/types/status.d.ts +1 -1
- package/utils/format/index.d.ts +2 -2
- package/utils/format/remove-spaces.d.ts +1 -1
- package/utils/format/replace.d.ts +1 -1
- package/utils/index.d.ts +1 -1
|
@@ -1,135 +1,135 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, inject, Input } from '@angular/core';
|
|
2
|
-
import { DOCUMENT } from '@angular/common';
|
|
3
|
-
import { fromEvent, take, takeUntil } from 'rxjs';
|
|
4
|
-
import { CuiDestroyService, CuiClickOutsideDirective, CuiTargetDirective, CUI_WINDOW } from '@cuby-ui/cdk';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@cuby-ui/cdk";
|
|
7
|
-
import * as i2 from "@angular/common";
|
|
8
|
-
import * as i3 from "../svg/svg.component";
|
|
9
|
-
export class CuiContextMenuComponent {
|
|
10
|
-
constructor() {
|
|
11
|
-
this.changeDetectorRef = inject(ChangeDetectorRef);
|
|
12
|
-
this.element = inject(ElementRef).nativeElement;
|
|
13
|
-
this.document = inject(DOCUMENT);
|
|
14
|
-
this.documentElement = this.document.documentElement;
|
|
15
|
-
this.window = inject(CUI_WINDOW);
|
|
16
|
-
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
17
|
-
this.cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });
|
|
18
|
-
this.cuiTargetDirective = inject(CuiTargetDirective, { self: true });
|
|
19
|
-
this.EXTRA_OFFSET_LEFT = 0;
|
|
20
|
-
this.EXTRA_OFFSET_TOP = 0;
|
|
21
|
-
this.isVisible = false;
|
|
22
|
-
this.isHidden = false;
|
|
23
|
-
}
|
|
24
|
-
ngOnInit() {
|
|
25
|
-
this.initClickOutsideSubscription();
|
|
26
|
-
}
|
|
27
|
-
ngAfterViewInit() {
|
|
28
|
-
this.initTargetElementListener();
|
|
29
|
-
}
|
|
30
|
-
onSelect(item) {
|
|
31
|
-
this.isVisible = false;
|
|
32
|
-
item.command?.();
|
|
33
|
-
}
|
|
34
|
-
onClose() {
|
|
35
|
-
this.close();
|
|
36
|
-
}
|
|
37
|
-
onStopClickPropagation(event) {
|
|
38
|
-
event.stopPropagation();
|
|
39
|
-
}
|
|
40
|
-
trackByFn(_, item) {
|
|
41
|
-
return item.label;
|
|
42
|
-
}
|
|
43
|
-
initClickOutsideSubscription() {
|
|
44
|
-
this.cuiClickOutsideDirective.cuiClickOutside
|
|
45
|
-
.pipe(takeUntil(this.destroy$))
|
|
46
|
-
.subscribe((target) => {
|
|
47
|
-
if (this.target.contains(target)) {
|
|
48
|
-
return;
|
|
49
|
-
}
|
|
50
|
-
this.isVisible = false;
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
initTargetElementListener() {
|
|
54
|
-
this.targetEventListener = ({ clientX, clientY }) => {
|
|
55
|
-
this.isVisible = !this.isVisible;
|
|
56
|
-
if (this.isVisible) {
|
|
57
|
-
this.changePosition(clientX, clientY);
|
|
58
|
-
this.initHidingSubscription();
|
|
59
|
-
}
|
|
60
|
-
this.changeDetectorRef.markForCheck();
|
|
61
|
-
};
|
|
62
|
-
this.cuiTargetDirective.clicked
|
|
63
|
-
.pipe(takeUntil(this.destroy$))
|
|
64
|
-
.subscribe(this.targetEventListener);
|
|
65
|
-
}
|
|
66
|
-
initHidingSubscription() {
|
|
67
|
-
this.initHidingFromWindowEvent('scroll');
|
|
68
|
-
this.initHidingFromWindowEvent('resize');
|
|
69
|
-
}
|
|
70
|
-
initHidingFromWindowEvent(eventName) {
|
|
71
|
-
fromEvent(this.window, eventName)
|
|
72
|
-
.pipe(take(1))
|
|
73
|
-
.subscribe(() => {
|
|
74
|
-
this.close();
|
|
75
|
-
this.changeDetectorRef.markForCheck();
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
close() {
|
|
79
|
-
this.isVisible = false;
|
|
80
|
-
}
|
|
81
|
-
changePosition(x, y) {
|
|
82
|
-
this.isHidden = true;
|
|
83
|
-
setTimeout(() => {
|
|
84
|
-
const { clientWidth, clientHeight } = this.documentElement;
|
|
85
|
-
const width = this.element.offsetWidth;
|
|
86
|
-
const height = this.element.offsetHeight;
|
|
87
|
-
let left = x;
|
|
88
|
-
let top = y;
|
|
89
|
-
if (left + width > clientWidth) {
|
|
90
|
-
left -= width;
|
|
91
|
-
}
|
|
92
|
-
if (top + height > clientHeight) {
|
|
93
|
-
top -= height;
|
|
94
|
-
}
|
|
95
|
-
left = Math.max(left, this.EXTRA_OFFSET_LEFT);
|
|
96
|
-
top = Math.max(top, this.EXTRA_OFFSET_TOP);
|
|
97
|
-
this.isHidden = false;
|
|
98
|
-
this.clientX = left;
|
|
99
|
-
this.clientY = top;
|
|
100
|
-
this.changeDetectorRef.markForCheck();
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
CuiContextMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
105
|
-
CuiContextMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiContextMenuComponent, selector: "cui-context-menu[items][target]", inputs: { items: "items", target: "target" }, host: { listeners: { "window:resize": "onClose()", "click": "onStopClickPropagation($event)" }, properties: { "class._hidden": "this.isHidden", "style.left.px": "this.clientX", "style.top.px": "this.clientY" } }, providers: [CuiDestroyService], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }, { directive: i1.CuiTargetDirective, inputs: ["ccTarget", "target"] }], ngImport: i0, template: "<ul\n *ngIf=\"isVisible\"\n class=\"c-ul\"\n>\n <li\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [style.color]=\"item.color\"\n >\n <button\n class=\"c-button\"\n (click)=\"onSelect(item)\"\n >\n <cui-svg\n *ngIf=\"item.icon\"\n [icon]=\"item.icon\"\n [color]=\"item.color\"\n ></cui-svg>\n <span>{{ item.label }}</span>\n </button>\n </li>\n</ul>\n", styles: [":host{position:fixed;z-index:2;display:block;width:268px;border-radius:8px}:host._hidden{visibility:hidden}.c-ul{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:inherit;background:var(--cui-base-0);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-button:hover{background:var(--cui-base-50)}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
106
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuComponent, decorators: [{
|
|
107
|
-
type: Component,
|
|
108
|
-
args: [{ selector: 'cui-context-menu[items][target]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [CuiDestroyService], hostDirectives: [
|
|
109
|
-
CuiClickOutsideDirective,
|
|
110
|
-
{
|
|
111
|
-
directive: CuiTargetDirective,
|
|
112
|
-
inputs: ['ccTarget: target']
|
|
113
|
-
}
|
|
114
|
-
], template: "<ul\n *ngIf=\"isVisible\"\n class=\"c-ul\"\n>\n <li\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [style.color]=\"item.color\"\n >\n <button\n class=\"c-button\"\n (click)=\"onSelect(item)\"\n >\n <cui-svg\n *ngIf=\"item.icon\"\n [icon]=\"item.icon\"\n [color]=\"item.color\"\n ></cui-svg>\n <span>{{ item.label }}</span>\n </button>\n </li>\n</ul>\n", styles: [":host{position:fixed;z-index:2;display:block;width:268px;border-radius:8px}:host._hidden{visibility:hidden}.c-ul{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:inherit;background:var(--cui-base-0);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-button:hover{background:var(--cui-base-50)}}\n"] }]
|
|
115
|
-
}], propDecorators: { items: [{
|
|
116
|
-
type: Input
|
|
117
|
-
}], target: [{
|
|
118
|
-
type: Input
|
|
119
|
-
}], isHidden: [{
|
|
120
|
-
type: HostBinding,
|
|
121
|
-
args: ['class._hidden']
|
|
122
|
-
}], clientX: [{
|
|
123
|
-
type: HostBinding,
|
|
124
|
-
args: ['style.left.px']
|
|
125
|
-
}], clientY: [{
|
|
126
|
-
type: HostBinding,
|
|
127
|
-
args: ['style.top.px']
|
|
128
|
-
}], onClose: [{
|
|
129
|
-
type: HostListener,
|
|
130
|
-
args: ['window:resize']
|
|
131
|
-
}], onStopClickPropagation: [{
|
|
132
|
-
type: HostListener,
|
|
133
|
-
args: ['click', ['$event']]
|
|
134
|
-
}] } });
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/context-menu/context-menu.component.ts","../../../../../projects/core/components/context-menu/context-menu.component.html"],"names":[],"mappings":"AACA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EACN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAElD,OAAO,EAAE,iBAAiB,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;;;;;AAkB3G,MAAM,OAAO,uBAAuB;IAdpC;QAemB,sBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC9C,YAAO,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,aAAa,CAAC;QAC3C,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5B,oBAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;QAChD,WAAM,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAC5B,aAAQ,GAAG,MAAM,CAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QACrD,6BAAwB,GAAG,MAAM,CAAC,wBAAwB,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAC5E,uBAAkB,GAAG,MAAM,CAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;QAE9D,sBAAiB,GAAG,CAAC,CAAC;QACtB,qBAAgB,GAAG,CAAC,CAAC;QAE9B,cAAS,GAAG,KAAK,CAAC;QAU5B,aAAQ,GAAY,KAAK,CAAC;KA+G3B;IAvGQ,QAAQ;QACb,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACtC,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAES,QAAQ,CAAC,IAAwB;QACzC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAEvB,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;IACnB,CAAC;IAGS,OAAO;QACf,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAGS,sBAAsB,CAAC,KAAiB;QAChD,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAES,SAAS,CAAC,CAAS,EAAE,IAAwB;QACrD,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAEO,4BAA4B;QAClC,IAAI,CAAC,wBAAwB,CAAC,eAAe;aAC1C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpB,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;gBAChC,OAAO;aACR;YAED,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,CAAC,CAAA;IACN,CAAC;IAEO,yBAAyB;QAC/B,IAAI,CAAC,mBAAmB,GAAG,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE;YAClD,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;YAEjC,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBACtC,IAAI,CAAC,sBAAsB,EAAE,CAAC;aAC/B;YAED,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,CAAC;QAEF,IAAI,CAAC,kBAAkB,CAAC,OAAO;aAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACzC,CAAC;IAEO,sBAAsB;QAC5B,IAAI,CAAC,yBAAyB,CAAC,QAAQ,CAAC,CAAC;QACzC,IAAI,CAAC,yBAAyB,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC;IAEO,yBAAyB,CAAC,SAA+B;QAC/D,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC;aAC9B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACb,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAEO,cAAc,CAAC,CAAS,EAAE,CAAS;QACzC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAErB,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC;YAC3D,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;YACvC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;YACzC,IAAI,IAAI,GAAG,CAAC,CAAC;YACb,IAAI,GAAG,GAAG,CAAC,CAAC;YAEZ,IAAI,IAAI,GAAG,KAAK,GAAG,WAAW,EAAE;gBAC9B,IAAI,IAAI,KAAK,CAAC;aACf;YAED,IAAI,GAAG,GAAG,MAAM,GAAG,YAAY,EAAE;gBAC/B,GAAG,IAAI,MAAM,CAAC;aACf;YAED,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC9C,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAE3C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;YAEnB,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;;qHArIU,uBAAuB;yGAAvB,uBAAuB,6TATvB,CAAC,iBAAiB,CAAC,8JCvBhC,yaAqBA;4FDWa,uBAAuB;kBAdnC,SAAS;+BACE,iCAAiC,mBAG1B,uBAAuB,CAAC,MAAM,aACpC,CAAC,iBAAiB,CAAC,kBACd;wBACd,wBAAwB;wBACxB;4BACE,SAAS,EAAE,kBAAkB;4BAC7B,MAAM,EAAE,CAAC,kBAAkB,CAAC;yBAC7B;qBACF;8BAmBM,KAAK;sBADX,KAAK;gBAIC,MAAM;sBADZ,KAAK;gBAIN,QAAQ;sBADP,WAAW;uBAAC,eAAe;gBAIlB,OAAO;sBADhB,WAAW;uBAAC,eAAe;gBAIlB,OAAO;sBADhB,WAAW;uBAAC,cAAc;gBAkBjB,OAAO;sBADhB,YAAY;uBAAC,eAAe;gBAMnB,sBAAsB;sBAD/B,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import type { OnInit, AfterViewInit } from '@angular/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  inject,\n  Input\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { fromEvent, take, takeUntil } from 'rxjs';\n\nimport { CuiDestroyService, CuiClickOutsideDirective, CuiTargetDirective, CUI_WINDOW } from '@cuby-ui/cdk';\n\nimport type { CuiContextMenuItem } from '../../interfaces';\n\n@Component({\n  selector: 'cui-context-menu[items][target]',\n  templateUrl: './context-menu.component.html',\n  styleUrls: ['./context-menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [CuiDestroyService],\n  hostDirectives: [\n    CuiClickOutsideDirective,\n    {\n      directive: CuiTargetDirective,\n      inputs: ['ccTarget: target']\n    }\n  ],\n})\nexport class CuiContextMenuComponent implements OnInit, AfterViewInit {\n  private readonly changeDetectorRef = inject(ChangeDetectorRef);\n  private readonly element = inject(ElementRef).nativeElement;\n  private readonly document = inject(DOCUMENT);\n  private readonly documentElement = this.document.documentElement;\n  private readonly window = inject(CUI_WINDOW);\n  private readonly destroy$ = inject(CuiDestroyService, { self: true });\n  private readonly cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });\n  private readonly cuiTargetDirective = inject(CuiTargetDirective, { self: true });\n\n  protected readonly EXTRA_OFFSET_LEFT = 0;\n  protected readonly EXTRA_OFFSET_TOP = 0;\n\n  protected isVisible = false;\n  protected targetEventListener!: (event: MouseEvent) => void;\n\n  @Input()\n  public items!: CuiContextMenuItem[];\n\n  @Input()\n  public target!: HTMLElement;\n\n  @HostBinding('class._hidden')\n  isHidden: boolean = false;\n\n  @HostBinding('style.left.px')\n  protected clientX?: number;\n\n  @HostBinding('style.top.px')\n  protected clientY?: number;\n\n  public ngOnInit(): void {\n    this.initClickOutsideSubscription();\n  }\n\n  public ngAfterViewInit(): void {\n    this.initTargetElementListener();\n  }\n\n  protected onSelect(item: CuiContextMenuItem): void {\n    this.isVisible = false;\n\n    item.command?.();\n  }\n\n  @HostListener('window:resize')\n  protected onClose(): void {\n    this.close();\n  }\n\n  @HostListener('click', ['$event'])\n  protected onStopClickPropagation(event: MouseEvent): void {\n    event.stopPropagation();\n  }\n\n  protected trackByFn(_: number, item: CuiContextMenuItem): string {\n    return item.label;\n  }\n\n  private initClickOutsideSubscription(): void {\n    this.cuiClickOutsideDirective.cuiClickOutside\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((target) => {\n        if (this.target.contains(target)) {\n          return;\n        }\n\n        this.isVisible = false;\n      })\n  }\n\n  private initTargetElementListener(): void {\n    this.targetEventListener = ({ clientX, clientY }) => {\n      this.isVisible = !this.isVisible;\n\n      if (this.isVisible) {\n        this.changePosition(clientX, clientY);\n        this.initHidingSubscription();\n      }\n\n      this.changeDetectorRef.markForCheck();\n    };\n\n    this.cuiTargetDirective.clicked\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(this.targetEventListener);\n  }\n\n  private initHidingSubscription(): void {\n    this.initHidingFromWindowEvent('scroll');\n    this.initHidingFromWindowEvent('resize');\n  }\n\n  private initHidingFromWindowEvent(eventName: keyof WindowEventMap): void {\n    fromEvent(this.window, eventName)\n      .pipe(take(1))\n      .subscribe(() => {\n        this.close();\n        this.changeDetectorRef.markForCheck();\n      });\n  }\n\n  private close(): void {\n    this.isVisible = false;\n  }\n\n  private changePosition(x: number, y: number): void {\n    this.isHidden = true;\n\n    setTimeout(() => {\n      const { clientWidth, clientHeight } = this.documentElement;\n      const width = this.element.offsetWidth;\n      const height = this.element.offsetHeight;\n      let left = x;\n      let top = y;\n\n      if (left + width > clientWidth) {\n        left -= width;\n      }\n\n      if (top + height > clientHeight) {\n        top -= height;\n      }\n\n      left = Math.max(left, this.EXTRA_OFFSET_LEFT);\n      top = Math.max(top, this.EXTRA_OFFSET_TOP);\n\n      this.isHidden = false;\n      this.clientX = left;\n      this.clientY = top;\n\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n}\n","<ul\n  *ngIf=\"isVisible\"\n  class=\"c-ul\"\n>\n  <li\n    *ngFor=\"let item of items; trackBy: trackByFn\"\n    [style.color]=\"item.color\"\n  >\n    <button\n      class=\"c-button\"\n      (click)=\"onSelect(item)\"\n    >\n      <cui-svg\n        *ngIf=\"item.icon\"\n        [icon]=\"item.icon\"\n        [color]=\"item.color\"\n      ></cui-svg>\n      <span>{{ item.label }}</span>\n    </button>\n  </li>\n</ul>\n"]}
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, inject, Input } from '@angular/core';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { fromEvent, take, takeUntil } from 'rxjs';
|
|
4
|
+
import { CuiDestroyService, CuiClickOutsideDirective, CuiTargetDirective, CUI_WINDOW } from '@cuby-ui/cdk';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@cuby-ui/cdk";
|
|
7
|
+
import * as i2 from "@angular/common";
|
|
8
|
+
import * as i3 from "../svg/svg.component";
|
|
9
|
+
export class CuiContextMenuComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.changeDetectorRef = inject(ChangeDetectorRef);
|
|
12
|
+
this.element = inject(ElementRef).nativeElement;
|
|
13
|
+
this.document = inject(DOCUMENT);
|
|
14
|
+
this.documentElement = this.document.documentElement;
|
|
15
|
+
this.window = inject(CUI_WINDOW);
|
|
16
|
+
this.destroy$ = inject(CuiDestroyService, { self: true });
|
|
17
|
+
this.cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });
|
|
18
|
+
this.cuiTargetDirective = inject(CuiTargetDirective, { self: true });
|
|
19
|
+
this.EXTRA_OFFSET_LEFT = 0;
|
|
20
|
+
this.EXTRA_OFFSET_TOP = 0;
|
|
21
|
+
this.isVisible = false;
|
|
22
|
+
this.isHidden = false;
|
|
23
|
+
}
|
|
24
|
+
ngOnInit() {
|
|
25
|
+
this.initClickOutsideSubscription();
|
|
26
|
+
}
|
|
27
|
+
ngAfterViewInit() {
|
|
28
|
+
this.initTargetElementListener();
|
|
29
|
+
}
|
|
30
|
+
onSelect(item) {
|
|
31
|
+
this.isVisible = false;
|
|
32
|
+
item.command?.();
|
|
33
|
+
}
|
|
34
|
+
onClose() {
|
|
35
|
+
this.close();
|
|
36
|
+
}
|
|
37
|
+
onStopClickPropagation(event) {
|
|
38
|
+
event.stopPropagation();
|
|
39
|
+
}
|
|
40
|
+
trackByFn(_, item) {
|
|
41
|
+
return item.label;
|
|
42
|
+
}
|
|
43
|
+
initClickOutsideSubscription() {
|
|
44
|
+
this.cuiClickOutsideDirective.cuiClickOutside
|
|
45
|
+
.pipe(takeUntil(this.destroy$))
|
|
46
|
+
.subscribe((target) => {
|
|
47
|
+
if (this.target.contains(target)) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
this.isVisible = false;
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
initTargetElementListener() {
|
|
54
|
+
this.targetEventListener = ({ clientX, clientY }) => {
|
|
55
|
+
this.isVisible = !this.isVisible;
|
|
56
|
+
if (this.isVisible) {
|
|
57
|
+
this.changePosition(clientX, clientY);
|
|
58
|
+
this.initHidingSubscription();
|
|
59
|
+
}
|
|
60
|
+
this.changeDetectorRef.markForCheck();
|
|
61
|
+
};
|
|
62
|
+
this.cuiTargetDirective.clicked
|
|
63
|
+
.pipe(takeUntil(this.destroy$))
|
|
64
|
+
.subscribe(this.targetEventListener);
|
|
65
|
+
}
|
|
66
|
+
initHidingSubscription() {
|
|
67
|
+
this.initHidingFromWindowEvent('scroll');
|
|
68
|
+
this.initHidingFromWindowEvent('resize');
|
|
69
|
+
}
|
|
70
|
+
initHidingFromWindowEvent(eventName) {
|
|
71
|
+
fromEvent(this.window, eventName)
|
|
72
|
+
.pipe(take(1))
|
|
73
|
+
.subscribe(() => {
|
|
74
|
+
this.close();
|
|
75
|
+
this.changeDetectorRef.markForCheck();
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
close() {
|
|
79
|
+
this.isVisible = false;
|
|
80
|
+
}
|
|
81
|
+
changePosition(x, y) {
|
|
82
|
+
this.isHidden = true;
|
|
83
|
+
setTimeout(() => {
|
|
84
|
+
const { clientWidth, clientHeight } = this.documentElement;
|
|
85
|
+
const width = this.element.offsetWidth;
|
|
86
|
+
const height = this.element.offsetHeight;
|
|
87
|
+
let left = x;
|
|
88
|
+
let top = y;
|
|
89
|
+
if (left + width > clientWidth) {
|
|
90
|
+
left -= width;
|
|
91
|
+
}
|
|
92
|
+
if (top + height > clientHeight) {
|
|
93
|
+
top -= height;
|
|
94
|
+
}
|
|
95
|
+
left = Math.max(left, this.EXTRA_OFFSET_LEFT);
|
|
96
|
+
top = Math.max(top, this.EXTRA_OFFSET_TOP);
|
|
97
|
+
this.isHidden = false;
|
|
98
|
+
this.clientX = left;
|
|
99
|
+
this.clientY = top;
|
|
100
|
+
this.changeDetectorRef.markForCheck();
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
CuiContextMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
105
|
+
CuiContextMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiContextMenuComponent, selector: "cui-context-menu[items][target]", inputs: { items: "items", target: "target" }, host: { listeners: { "window:resize": "onClose()", "click": "onStopClickPropagation($event)" }, properties: { "class._hidden": "this.isHidden", "style.left.px": "this.clientX", "style.top.px": "this.clientY" } }, providers: [CuiDestroyService], hostDirectives: [{ directive: i1.CuiClickOutsideDirective }, { directive: i1.CuiTargetDirective, inputs: ["ccTarget", "target"] }], ngImport: i0, template: "<ul\r\n *ngIf=\"isVisible\"\r\n class=\"c-ul\"\r\n>\r\n <li\r\n *ngFor=\"let item of items; trackBy: trackByFn\"\r\n [style.color]=\"item.color\"\r\n >\r\n <button\r\n class=\"c-button\"\r\n (click)=\"onSelect(item)\"\r\n >\r\n <cui-svg\r\n *ngIf=\"item.icon\"\r\n [icon]=\"item.icon\"\r\n [color]=\"item.color\"\r\n ></cui-svg>\r\n <span>{{ item.label }}</span>\r\n </button>\r\n </li>\r\n</ul>\r\n", styles: [":host{position:fixed;z-index:2;display:block;width:268px;border-radius:8px}:host._hidden{visibility:hidden}.c-ul{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:inherit;background:var(--cui-base-0);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-button:hover{background:var(--cui-base-50)}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
106
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuComponent, decorators: [{
|
|
107
|
+
type: Component,
|
|
108
|
+
args: [{ selector: 'cui-context-menu[items][target]', changeDetection: ChangeDetectionStrategy.OnPush, providers: [CuiDestroyService], hostDirectives: [
|
|
109
|
+
CuiClickOutsideDirective,
|
|
110
|
+
{
|
|
111
|
+
directive: CuiTargetDirective,
|
|
112
|
+
inputs: ['ccTarget: target']
|
|
113
|
+
}
|
|
114
|
+
], template: "<ul\r\n *ngIf=\"isVisible\"\r\n class=\"c-ul\"\r\n>\r\n <li\r\n *ngFor=\"let item of items; trackBy: trackByFn\"\r\n [style.color]=\"item.color\"\r\n >\r\n <button\r\n class=\"c-button\"\r\n (click)=\"onSelect(item)\"\r\n >\r\n <cui-svg\r\n *ngIf=\"item.icon\"\r\n [icon]=\"item.icon\"\r\n [color]=\"item.color\"\r\n ></cui-svg>\r\n <span>{{ item.label }}</span>\r\n </button>\r\n </li>\r\n</ul>\r\n", styles: [":host{position:fixed;z-index:2;display:block;width:268px;border-radius:8px}:host._hidden{visibility:hidden}.c-ul{padding:7px 0;margin:0;list-style:none;font-weight:400;font-size:14px;line-height:20px;box-shadow:0 1px 4px #0000000a,0 1px 4px #0000000a;border:1px solid var(--cui-base-200);border-radius:inherit;background:var(--cui-base-0);color:var(--cui-base-900);font-family:var(--cui-main-font)}.c-button{padding:8px 11px 8px 0;border:0;outline:none;cursor:pointer;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;padding:8px 11px;width:100%;display:flex;align-items:center;gap:12px}.c-button:active{background:var(--cui-base-50)}@media (hover: hover){.c-button:hover{background:var(--cui-base-50)}}\n"] }]
|
|
115
|
+
}], propDecorators: { items: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], target: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], isHidden: [{
|
|
120
|
+
type: HostBinding,
|
|
121
|
+
args: ['class._hidden']
|
|
122
|
+
}], clientX: [{
|
|
123
|
+
type: HostBinding,
|
|
124
|
+
args: ['style.left.px']
|
|
125
|
+
}], clientY: [{
|
|
126
|
+
type: HostBinding,
|
|
127
|
+
args: ['style.top.px']
|
|
128
|
+
}], onClose: [{
|
|
129
|
+
type: HostListener,
|
|
130
|
+
args: ['window:resize']
|
|
131
|
+
}], onStopClickPropagation: [{
|
|
132
|
+
type: HostListener,
|
|
133
|
+
args: ['click', ['$event']]
|
|
134
|
+
}] } });
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/context-menu/context-menu.component.ts","../../../../../projects/core/components/context-menu/context-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import type { OnInit, AfterViewInit } from '@angular/core';\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  inject,\r\n  Input\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { fromEvent, take, takeUntil } from 'rxjs';\r\n\r\nimport { CuiDestroyService, CuiClickOutsideDirective, CuiTargetDirective, CUI_WINDOW } from '@cuby-ui/cdk';\r\n\r\nimport type { CuiContextMenuItem } from '../../interfaces';\r\n\r\n@Component({\r\n  selector: 'cui-context-menu[items][target]',\r\n  templateUrl: './context-menu.component.html',\r\n  styleUrls: ['./context-menu.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [CuiDestroyService],\r\n  hostDirectives: [\r\n    CuiClickOutsideDirective,\r\n    {\r\n      directive: CuiTargetDirective,\r\n      inputs: ['ccTarget: target']\r\n    }\r\n  ],\r\n})\r\nexport class CuiContextMenuComponent implements OnInit, AfterViewInit {\r\n  private readonly changeDetectorRef = inject(ChangeDetectorRef);\r\n  private readonly element = inject(ElementRef).nativeElement;\r\n  private readonly document = inject(DOCUMENT);\r\n  private readonly documentElement = this.document.documentElement;\r\n  private readonly window = inject(CUI_WINDOW);\r\n  private readonly destroy$ = inject(CuiDestroyService, { self: true });\r\n  private readonly cuiClickOutsideDirective = inject(CuiClickOutsideDirective, { self: true });\r\n  private readonly cuiTargetDirective = inject(CuiTargetDirective, { self: true });\r\n\r\n  protected readonly EXTRA_OFFSET_LEFT = 0;\r\n  protected readonly EXTRA_OFFSET_TOP = 0;\r\n\r\n  protected isVisible = false;\r\n  protected targetEventListener!: (event: MouseEvent) => void;\r\n\r\n  @Input()\r\n  public items!: CuiContextMenuItem[];\r\n\r\n  @Input()\r\n  public target!: HTMLElement;\r\n\r\n  @HostBinding('class._hidden')\r\n  isHidden: boolean = false;\r\n\r\n  @HostBinding('style.left.px')\r\n  protected clientX?: number;\r\n\r\n  @HostBinding('style.top.px')\r\n  protected clientY?: number;\r\n\r\n  public ngOnInit(): void {\r\n    this.initClickOutsideSubscription();\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    this.initTargetElementListener();\r\n  }\r\n\r\n  protected onSelect(item: CuiContextMenuItem): void {\r\n    this.isVisible = false;\r\n\r\n    item.command?.();\r\n  }\r\n\r\n  @HostListener('window:resize')\r\n  protected onClose(): void {\r\n    this.close();\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  protected onStopClickPropagation(event: MouseEvent): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  protected trackByFn(_: number, item: CuiContextMenuItem): string {\r\n    return item.label;\r\n  }\r\n\r\n  private initClickOutsideSubscription(): void {\r\n    this.cuiClickOutsideDirective.cuiClickOutside\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((target) => {\r\n        if (this.target.contains(target)) {\r\n          return;\r\n        }\r\n\r\n        this.isVisible = false;\r\n      })\r\n  }\r\n\r\n  private initTargetElementListener(): void {\r\n    this.targetEventListener = ({ clientX, clientY }) => {\r\n      this.isVisible = !this.isVisible;\r\n\r\n      if (this.isVisible) {\r\n        this.changePosition(clientX, clientY);\r\n        this.initHidingSubscription();\r\n      }\r\n\r\n      this.changeDetectorRef.markForCheck();\r\n    };\r\n\r\n    this.cuiTargetDirective.clicked\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(this.targetEventListener);\r\n  }\r\n\r\n  private initHidingSubscription(): void {\r\n    this.initHidingFromWindowEvent('scroll');\r\n    this.initHidingFromWindowEvent('resize');\r\n  }\r\n\r\n  private initHidingFromWindowEvent(eventName: keyof WindowEventMap): void {\r\n    fromEvent(this.window, eventName)\r\n      .pipe(take(1))\r\n      .subscribe(() => {\r\n        this.close();\r\n        this.changeDetectorRef.markForCheck();\r\n      });\r\n  }\r\n\r\n  private close(): void {\r\n    this.isVisible = false;\r\n  }\r\n\r\n  private changePosition(x: number, y: number): void {\r\n    this.isHidden = true;\r\n\r\n    setTimeout(() => {\r\n      const { clientWidth, clientHeight } = this.documentElement;\r\n      const width = this.element.offsetWidth;\r\n      const height = this.element.offsetHeight;\r\n      let left = x;\r\n      let top = y;\r\n\r\n      if (left + width > clientWidth) {\r\n        left -= width;\r\n      }\r\n\r\n      if (top + height > clientHeight) {\r\n        top -= height;\r\n      }\r\n\r\n      left = Math.max(left, this.EXTRA_OFFSET_LEFT);\r\n      top = Math.max(top, this.EXTRA_OFFSET_TOP);\r\n\r\n      this.isHidden = false;\r\n      this.clientX = left;\r\n      this.clientY = top;\r\n\r\n      this.changeDetectorRef.markForCheck();\r\n    });\r\n  }\r\n}\r\n","<ul\r\n  *ngIf=\"isVisible\"\r\n  class=\"c-ul\"\r\n>\r\n  <li\r\n    *ngFor=\"let item of items; trackBy: trackByFn\"\r\n    [style.color]=\"item.color\"\r\n  >\r\n    <button\r\n      class=\"c-button\"\r\n      (click)=\"onSelect(item)\"\r\n    >\r\n      <cui-svg\r\n        *ngIf=\"item.icon\"\r\n        [icon]=\"item.icon\"\r\n        [color]=\"item.color\"\r\n      ></cui-svg>\r\n      <span>{{ item.label }}</span>\r\n    </button>\r\n  </li>\r\n</ul>\r\n"]}
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { CuiContextMenuComponent } from './context-menu.component';
|
|
4
|
-
import { CuiSvgModule } from '../svg';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export class CuiContextMenuModule {
|
|
7
|
-
}
|
|
8
|
-
CuiContextMenuModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9
|
-
CuiContextMenuModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuModule, declarations: [CuiContextMenuComponent], imports: [CommonModule,
|
|
10
|
-
CuiSvgModule], exports: [CuiContextMenuComponent] });
|
|
11
|
-
CuiContextMenuModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuModule, imports: [CommonModule,
|
|
12
|
-
CuiSvgModule] });
|
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuModule, decorators: [{
|
|
14
|
-
type: NgModule,
|
|
15
|
-
args: [{
|
|
16
|
-
imports: [
|
|
17
|
-
CommonModule,
|
|
18
|
-
CuiSvgModule
|
|
19
|
-
],
|
|
20
|
-
declarations: [CuiContextMenuComponent],
|
|
21
|
-
exports: [CuiContextMenuComponent]
|
|
22
|
-
}]
|
|
23
|
-
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { CuiContextMenuComponent } from './context-menu.component';
|
|
4
|
+
import { CuiSvgModule } from '../svg';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class CuiContextMenuModule {
|
|
7
|
+
}
|
|
8
|
+
CuiContextMenuModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9
|
+
CuiContextMenuModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuModule, declarations: [CuiContextMenuComponent], imports: [CommonModule,
|
|
10
|
+
CuiSvgModule], exports: [CuiContextMenuComponent] });
|
|
11
|
+
CuiContextMenuModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuModule, imports: [CommonModule,
|
|
12
|
+
CuiSvgModule] });
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiContextMenuModule, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
imports: [
|
|
17
|
+
CommonModule,
|
|
18
|
+
CuiSvgModule
|
|
19
|
+
],
|
|
20
|
+
declarations: [CuiContextMenuComponent],
|
|
21
|
+
exports: [CuiContextMenuComponent]
|
|
22
|
+
}]
|
|
23
|
+
}] });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1tZW51Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9jb250ZXh0LW1lbnUvY29udGV4dC1tZW51Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sUUFBUSxDQUFDOztBQVV0QyxNQUFNLE9BQU8sb0JBQW9COztrSEFBcEIsb0JBQW9CO21IQUFwQixvQkFBb0IsaUJBSGhCLHVCQUF1QixhQUhwQyxZQUFZO1FBQ1osWUFBWSxhQUdKLHVCQUF1QjttSEFFdEIsb0JBQW9CLFlBTjdCLFlBQVk7UUFDWixZQUFZOzRGQUtILG9CQUFvQjtrQkFSaEMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixZQUFZO3FCQUNiO29CQUNELFlBQVksRUFBRSxDQUFDLHVCQUF1QixDQUFDO29CQUN2QyxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztpQkFDbkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuaW1wb3J0IHsgQ3VpQ29udGV4dE1lbnVDb21wb25lbnQgfSBmcm9tICcuL2NvbnRleHQtbWVudS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDdWlTdmdNb2R1bGUgfSBmcm9tICcuLi9zdmcnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBDdWlTdmdNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW0N1aUNvbnRleHRNZW51Q29tcG9uZW50XSxcclxuICBleHBvcnRzOiBbQ3VpQ29udGV4dE1lbnVDb21wb25lbnRdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDdWlDb250ZXh0TWVudU1vZHVsZSB7XHJcbn1cclxuIl19
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from './context-menu.component';
|
|
2
|
-
export * from './context-menu.module';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export * from './context-menu.component';
|
|
2
|
+
export * from './context-menu.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvY29udGV4dC1tZW51L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1tZW51LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1tZW51Lm1vZHVsZSc7XHJcbiJdfQ==
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class CuiDialogActionsComponent {
|
|
4
|
-
}
|
|
5
|
-
CuiDialogActionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiDialogActionsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
-
CuiDialogActionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiDialogActionsComponent, selector: "cui-dialog-actions", ngImport: i0, template: "<div class=\"c-divider\"></div>\n<div class=\"c-content\">\n <ng-content />\n</div>\n", styles: [":host{padding-right:23px;padding-left:23px;padding-bottom:15px;display:block}.c-divider{position:relative;left:-24px;width:calc(100% + 48px);height:1px;margin-bottom:15px;background:var(--cui-base-200)}.c-content{display:flex;align-items:center;justify-content:flex-end;gap:12px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
7
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiDialogActionsComponent, decorators: [{
|
|
8
|
-
type: Component,
|
|
9
|
-
args: [{ selector: 'cui-dialog-actions', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"c-divider\"></div>\n<div class=\"c-content\">\n <ng-content />\n</div>\n", styles: [":host{padding-right:23px;padding-left:23px;padding-bottom:15px;display:block}.c-divider{position:relative;left:-24px;width:calc(100% + 48px);height:1px;margin-bottom:15px;background:var(--cui-base-200)}.c-content{display:flex;align-items:center;justify-content:flex-end;gap:12px}\n"] }]
|
|
10
|
-
}] });
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CuiDialogActionsComponent {
|
|
4
|
+
}
|
|
5
|
+
CuiDialogActionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiDialogActionsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
CuiDialogActionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiDialogActionsComponent, selector: "cui-dialog-actions", ngImport: i0, template: "<div class=\"c-divider\"></div>\r\n<div class=\"c-content\">\r\n <ng-content />\r\n</div>\r\n", styles: [":host{padding-right:23px;padding-left:23px;padding-bottom:15px;display:block}.c-divider{position:relative;left:-24px;width:calc(100% + 48px);height:1px;margin-bottom:15px;background:var(--cui-base-200)}.c-content{display:flex;align-items:center;justify-content:flex-end;gap:12px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiDialogActionsComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'cui-dialog-actions', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"c-divider\"></div>\r\n<div class=\"c-content\">\r\n <ng-content />\r\n</div>\r\n", styles: [":host{padding-right:23px;padding-left:23px;padding-bottom:15px;display:block}.c-divider{position:relative;left:-24px;width:calc(100% + 48px);height:1px;margin-bottom:15px;background:var(--cui-base-200)}.c-content{display:flex;align-items:center;justify-content:flex-end;gap:12px}\n"] }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWFjdGlvbnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2RpYWxvZy9kaWFsb2ctYWN0aW9ucy9kaWFsb2ctYWN0aW9ucy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZGlhbG9nL2RpYWxvZy1hY3Rpb25zL2RpYWxvZy1hY3Rpb25zLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFRbkUsTUFBTSxPQUFPLHlCQUF5Qjs7dUhBQXpCLHlCQUF5QjsyR0FBekIseUJBQXlCLDBEQ1J0QyxnR0FJQTs0RkRJYSx5QkFBeUI7a0JBTnJDLFNBQVM7K0JBQ0Usb0JBQW9CLG1CQUdiLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2N1aS1kaWFsb2ctYWN0aW9ucycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2RpYWxvZy1hY3Rpb25zLnRlbXBsYXRlLmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2RpYWxvZy1hY3Rpb25zLnN0eWxlLnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ3VpRGlhbG9nQWN0aW9uc0NvbXBvbmVudCB7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImMtZGl2aWRlclwiPjwvZGl2PlxyXG48ZGl2IGNsYXNzPVwiYy1jb250ZW50XCI+XHJcbiAgPG5nLWNvbnRlbnQgLz5cclxuPC9kaXY+XHJcbiJdfQ==
|
|
@@ -1,65 +1,65 @@
|
|
|
1
|
-
import { HostBinding } from '@angular/core';
|
|
2
|
-
import { DOCUMENT } from '@angular/common';
|
|
3
|
-
import { ChangeDetectionStrategy, Component, inject, TemplateRef } from '@angular/core';
|
|
4
|
-
import { CUI_DIALOG_CONTEXT } from './dialog.tokens';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@angular/common";
|
|
7
|
-
export const ContentType = {
|
|
8
|
-
String: 'string',
|
|
9
|
-
Template: 'template',
|
|
10
|
-
Component: 'component'
|
|
11
|
-
};
|
|
12
|
-
export class CuiDialogComponent {
|
|
13
|
-
constructor() {
|
|
14
|
-
this.document = inject(DOCUMENT);
|
|
15
|
-
this.context = inject(CUI_DIALOG_CONTEXT);
|
|
16
|
-
this.ContentType = ContentType;
|
|
17
|
-
this.contentType = ContentType.Component;
|
|
18
|
-
}
|
|
19
|
-
get size() {
|
|
20
|
-
return this.context.size;
|
|
21
|
-
}
|
|
22
|
-
ngOnInit() {
|
|
23
|
-
this.initBodyScrollHiding();
|
|
24
|
-
this.initContentType();
|
|
25
|
-
}
|
|
26
|
-
ngOnDestroy() {
|
|
27
|
-
this.destroyBodyScrollHiding();
|
|
28
|
-
}
|
|
29
|
-
get contentTemplateRef() {
|
|
30
|
-
return this.context.content;
|
|
31
|
-
}
|
|
32
|
-
get componentType() {
|
|
33
|
-
return this.context.content;
|
|
34
|
-
}
|
|
35
|
-
onClose() {
|
|
36
|
-
this.context.$implicit.next(false);
|
|
37
|
-
}
|
|
38
|
-
initContentType() {
|
|
39
|
-
const content = this.context.content;
|
|
40
|
-
switch (true) {
|
|
41
|
-
case (typeof content === 'string'):
|
|
42
|
-
this.contentType = ContentType.String;
|
|
43
|
-
return;
|
|
44
|
-
case (content instanceof TemplateRef):
|
|
45
|
-
this.contentType = ContentType.Template;
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
initBodyScrollHiding() {
|
|
50
|
-
this.document.body.style.overflow = 'hidden';
|
|
51
|
-
}
|
|
52
|
-
destroyBodyScrollHiding() {
|
|
53
|
-
this.document.body.style.overflow = '';
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
CuiDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
57
|
-
CuiDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiDialogComponent, selector: "cui-dialog", host: { properties: { "attr.data-size": "this.size" } }, ngImport: i0, template: "<ng-container [ngSwitch]=\"contentType\">\n <ng-container *ngSwitchCase=\"ContentType.String\">\n {{ context.content }}\n </ng-container>\n <ng-container *ngSwitchCase=\"ContentType.Template\">\n <ng-container *ngTemplateOutlet=\"contentTemplateRef; context: context\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"ContentType.Component\">\n <div class=\"c-component-container\">\n <ng-container *ngComponentOutlet=\"componentType\"></ng-container>\n </div>\n </ng-container>\n</ng-container>\n", styles: [":host{box-shadow:0 2px 4px -1px #0000000f,0 4px 6px -1px #0000001a;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;box-sizing:border-box;max-height:calc(100vh - 180px);width:100%;border-radius:12px;background:var(--cui-base-0);font-family:var(--cui-main-font)}:host[data-size=auto]{width:auto}:host[data-size=xl]{max-width:1080px}.c-component-container{display:contents}.c-component-container ::ng-deep>*{display:contents}\n"], dependencies: [{ kind: "directive", type: i1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
58
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiDialogComponent, decorators: [{
|
|
59
|
-
type: Component,
|
|
60
|
-
args: [{ selector: 'cui-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"contentType\">\n <ng-container *ngSwitchCase=\"ContentType.String\">\n {{ context.content }}\n </ng-container>\n <ng-container *ngSwitchCase=\"ContentType.Template\">\n <ng-container *ngTemplateOutlet=\"contentTemplateRef; context: context\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"ContentType.Component\">\n <div class=\"c-component-container\">\n <ng-container *ngComponentOutlet=\"componentType\"></ng-container>\n </div>\n </ng-container>\n</ng-container>\n", styles: [":host{box-shadow:0 2px 4px -1px #0000000f,0 4px 6px -1px #0000001a;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;box-sizing:border-box;max-height:calc(100vh - 180px);width:100%;border-radius:12px;background:var(--cui-base-0);font-family:var(--cui-main-font)}:host[data-size=auto]{width:auto}:host[data-size=xl]{max-width:1080px}.c-component-container{display:contents}.c-component-container ::ng-deep>*{display:contents}\n"] }]
|
|
61
|
-
}], propDecorators: { size: [{
|
|
62
|
-
type: HostBinding,
|
|
63
|
-
args: ['attr.data-size']
|
|
64
|
-
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { HostBinding } from '@angular/core';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, inject, TemplateRef } from '@angular/core';
|
|
4
|
+
import { CUI_DIALOG_CONTEXT } from './dialog.tokens';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
export const ContentType = {
|
|
8
|
+
String: 'string',
|
|
9
|
+
Template: 'template',
|
|
10
|
+
Component: 'component'
|
|
11
|
+
};
|
|
12
|
+
export class CuiDialogComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.document = inject(DOCUMENT);
|
|
15
|
+
this.context = inject(CUI_DIALOG_CONTEXT);
|
|
16
|
+
this.ContentType = ContentType;
|
|
17
|
+
this.contentType = ContentType.Component;
|
|
18
|
+
}
|
|
19
|
+
get size() {
|
|
20
|
+
return this.context.size;
|
|
21
|
+
}
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
this.initBodyScrollHiding();
|
|
24
|
+
this.initContentType();
|
|
25
|
+
}
|
|
26
|
+
ngOnDestroy() {
|
|
27
|
+
this.destroyBodyScrollHiding();
|
|
28
|
+
}
|
|
29
|
+
get contentTemplateRef() {
|
|
30
|
+
return this.context.content;
|
|
31
|
+
}
|
|
32
|
+
get componentType() {
|
|
33
|
+
return this.context.content;
|
|
34
|
+
}
|
|
35
|
+
onClose() {
|
|
36
|
+
this.context.$implicit.next(false);
|
|
37
|
+
}
|
|
38
|
+
initContentType() {
|
|
39
|
+
const content = this.context.content;
|
|
40
|
+
switch (true) {
|
|
41
|
+
case (typeof content === 'string'):
|
|
42
|
+
this.contentType = ContentType.String;
|
|
43
|
+
return;
|
|
44
|
+
case (content instanceof TemplateRef):
|
|
45
|
+
this.contentType = ContentType.Template;
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
initBodyScrollHiding() {
|
|
50
|
+
this.document.body.style.overflow = 'hidden';
|
|
51
|
+
}
|
|
52
|
+
destroyBodyScrollHiding() {
|
|
53
|
+
this.document.body.style.overflow = '';
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
CuiDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
57
|
+
CuiDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CuiDialogComponent, selector: "cui-dialog", host: { properties: { "attr.data-size": "this.size" } }, ngImport: i0, template: "<ng-container [ngSwitch]=\"contentType\">\r\n <ng-container *ngSwitchCase=\"ContentType.String\">\r\n {{ context.content }}\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"ContentType.Template\">\r\n <ng-container *ngTemplateOutlet=\"contentTemplateRef; context: context\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"ContentType.Component\">\r\n <div class=\"c-component-container\">\r\n <ng-container *ngComponentOutlet=\"componentType\"></ng-container>\r\n </div>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{box-shadow:0 2px 4px -1px #0000000f,0 4px 6px -1px #0000001a;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;box-sizing:border-box;max-height:calc(100vh - 180px);width:100%;border-radius:12px;background:var(--cui-base-0);font-family:var(--cui-main-font)}:host[data-size=auto]{width:auto}:host[data-size=xl]{max-width:1080px}.c-component-container{display:contents}.c-component-container ::ng-deep>*{display:contents}\n"], dependencies: [{ kind: "directive", type: i1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CuiDialogComponent, decorators: [{
|
|
59
|
+
type: Component,
|
|
60
|
+
args: [{ selector: 'cui-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container [ngSwitch]=\"contentType\">\r\n <ng-container *ngSwitchCase=\"ContentType.String\">\r\n {{ context.content }}\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"ContentType.Template\">\r\n <ng-container *ngTemplateOutlet=\"contentTemplateRef; context: context\"></ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"ContentType.Component\">\r\n <div class=\"c-component-container\">\r\n <ng-container *ngComponentOutlet=\"componentType\"></ng-container>\r\n </div>\r\n </ng-container>\r\n</ng-container>\r\n", styles: [":host{box-shadow:0 2px 4px -1px #0000000f,0 4px 6px -1px #0000001a;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;box-sizing:border-box;max-height:calc(100vh - 180px);width:100%;border-radius:12px;background:var(--cui-base-0);font-family:var(--cui-main-font)}:host[data-size=auto]{width:auto}:host[data-size=xl]{max-width:1080px}.c-component-container{display:contents}.c-component-container ::ng-deep>*{display:contents}\n"] }]
|
|
61
|
+
}], propDecorators: { size: [{
|
|
62
|
+
type: HostBinding,
|
|
63
|
+
args: ['attr.data-size']
|
|
64
|
+
}] } });
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9kaWFsb2cvZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9kaWFsb2cvZGlhbG9nLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBUSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBSXhGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7QUFFckQsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHO0lBQ3pCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLFFBQVEsRUFBRSxVQUFVO0lBQ3BCLFNBQVMsRUFBRSxXQUFXO0NBQ2QsQ0FBQztBQVVYLE1BQU0sT0FBTyxrQkFBa0I7SUFOL0I7UUFPcUIsYUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUM1QixZQUFPLEdBQUcsTUFBTSxDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFFckMsZ0JBQVcsR0FBRyxXQUFXLENBQUM7UUFFbkMsZ0JBQVcsR0FBaUIsV0FBVyxDQUFDLFNBQVMsQ0FBQztLQW1EN0Q7SUFqREMsSUFDYyxJQUFJO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7SUFDM0IsQ0FBQztJQUVNLFFBQVE7UUFDYixJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztRQUM1QixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVELElBQWMsa0JBQWtCO1FBQzlCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUErQixDQUFDO0lBQ3RELENBQUM7SUFFRCxJQUFjLGFBQWE7UUFDekIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQXdCLENBQUM7SUFDL0MsQ0FBQztJQUVTLE9BQU87UUFDZixJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVPLGVBQWU7UUFDckIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUM7UUFFckMsUUFBUSxJQUFJLEVBQUU7WUFDWixLQUFLLENBQUMsT0FBTyxPQUFPLEtBQUssUUFBUSxDQUFDO2dCQUNoQyxJQUFJLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQyxNQUFNLENBQUM7Z0JBRXRDLE9BQU87WUFFVCxLQUFLLENBQUMsT0FBTyxZQUFZLFdBQVcsQ0FBQztnQkFDbkMsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUMsUUFBUSxDQUFDO2dCQUV4QyxPQUFPO1NBQ1Y7SUFDSCxDQUFDO0lBRU8sb0JBQW9CO1FBQzFCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO0lBQy9DLENBQUM7SUFFTyx1QkFBdUI7UUFDN0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDekMsQ0FBQzs7Z0hBeERVLGtCQUFrQjtvR0FBbEIsa0JBQWtCLDJHQ3ZCL0IscWpCQWFBOzRGRFVhLGtCQUFrQjtrQkFOOUIsU0FBUzsrQkFDRSxZQUFZLG1CQUdMLHVCQUF1QixDQUFDLE1BQU07OEJBV2pDLElBQUk7c0JBRGpCLFdBQVc7dUJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBIb3N0QmluZGluZywgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBET0NVTUVOVCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHR5cGUgeyBDdWlWYWx1ZU9mIH0gZnJvbSAnQGN1YnktdWkvY2RrJztcclxuXHJcbmltcG9ydCB0eXBlIHsgQ3VpRGlhbG9nU2l6ZSB9IGZyb20gJy4vZGlhbG9nLmludGVyZmFjZXMnO1xyXG5pbXBvcnQgeyBDVUlfRElBTE9HX0NPTlRFWFQgfSBmcm9tICcuL2RpYWxvZy50b2tlbnMnO1xyXG5cclxuZXhwb3J0IGNvbnN0IENvbnRlbnRUeXBlID0ge1xyXG4gIFN0cmluZzogJ3N0cmluZycsXHJcbiAgVGVtcGxhdGU6ICd0ZW1wbGF0ZScsXHJcbiAgQ29tcG9uZW50OiAnY29tcG9uZW50J1xyXG59IGFzIGNvbnN0O1xyXG5cclxuZXhwb3J0IHR5cGUgSUNvbnRlbnRUeXBlID0gQ3VpVmFsdWVPZjx0eXBlb2YgQ29udGVudFR5cGU+O1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjdWktZGlhbG9nJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZGlhbG9nLnRlbXBsYXRlLmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2RpYWxvZy5zdHlsZS5zY3NzJ10sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIEN1aURpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcclxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgZG9jdW1lbnQgPSBpbmplY3QoRE9DVU1FTlQpO1xyXG4gIHByb3RlY3RlZCByZWFkb25seSBjb250ZXh0ID0gaW5qZWN0KENVSV9ESUFMT0dfQ09OVEVYVCk7XHJcblxyXG4gIHByb3RlY3RlZCByZWFkb25seSBDb250ZW50VHlwZSA9IENvbnRlbnRUeXBlO1xyXG5cclxuICBwcm90ZWN0ZWQgY29udGVudFR5cGU6IElDb250ZW50VHlwZSA9IENvbnRlbnRUeXBlLkNvbXBvbmVudDtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtc2l6ZScpXHJcbiAgcHJvdGVjdGVkIGdldCBzaXplKCk6IEN1aURpYWxvZ1NpemUge1xyXG4gICAgcmV0dXJuIHRoaXMuY29udGV4dC5zaXplO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5pbml0Qm9keVNjcm9sbEhpZGluZygpO1xyXG4gICAgdGhpcy5pbml0Q29udGVudFR5cGUoKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMuZGVzdHJveUJvZHlTY3JvbGxIaWRpbmcoKTtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBnZXQgY29udGVudFRlbXBsYXRlUmVmKCk6IFRlbXBsYXRlUmVmPHVua25vd24+IHtcclxuICAgIHJldHVybiB0aGlzLmNvbnRleHQuY29udGVudCBhcyBUZW1wbGF0ZVJlZjx1bmtub3duPjtcclxuICB9XHJcblxyXG4gIHByb3RlY3RlZCBnZXQgY29tcG9uZW50VHlwZSgpOiBUeXBlPHVua25vd24+IHtcclxuICAgIHJldHVybiB0aGlzLmNvbnRleHQuY29udGVudCBhcyBUeXBlPHVua25vd24+O1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIG9uQ2xvc2UoKTogdm9pZCB7XHJcbiAgICB0aGlzLmNvbnRleHQuJGltcGxpY2l0Lm5leHQoZmFsc2UpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBpbml0Q29udGVudFR5cGUoKTogdm9pZCB7XHJcbiAgICBjb25zdCBjb250ZW50ID0gdGhpcy5jb250ZXh0LmNvbnRlbnQ7XHJcblxyXG4gICAgc3dpdGNoICh0cnVlKSB7XHJcbiAgICAgIGNhc2UgKHR5cGVvZiBjb250ZW50ID09PSAnc3RyaW5nJyk6XHJcbiAgICAgICAgdGhpcy5jb250ZW50VHlwZSA9IENvbnRlbnRUeXBlLlN0cmluZztcclxuXHJcbiAgICAgICAgcmV0dXJuO1xyXG5cclxuICAgICAgY2FzZSAoY29udGVudCBpbnN0YW5jZW9mIFRlbXBsYXRlUmVmKTpcclxuICAgICAgICB0aGlzLmNvbnRlbnRUeXBlID0gQ29udGVudFR5cGUuVGVtcGxhdGU7XHJcblxyXG4gICAgICAgIHJldHVybjtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHByaXZhdGUgaW5pdEJvZHlTY3JvbGxIaWRpbmcoKTogdm9pZCB7XHJcbiAgICB0aGlzLmRvY3VtZW50LmJvZHkuc3R5bGUub3ZlcmZsb3cgPSAnaGlkZGVuJztcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZGVzdHJveUJvZHlTY3JvbGxIaWRpbmcoKTogdm9pZCB7XHJcbiAgICB0aGlzLmRvY3VtZW50LmJvZHkuc3R5bGUub3ZlcmZsb3cgPSAnJztcclxuICB9XHJcbn1cclxuIiwiPG5nLWNvbnRhaW5lciBbbmdTd2l0Y2hdPVwiY29udGVudFR5cGVcIj5cclxuICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCJDb250ZW50VHlwZS5TdHJpbmdcIj5cclxuICAgIHt7IGNvbnRleHQuY29udGVudCB9fVxyXG4gIDwvbmctY29udGFpbmVyPlxyXG4gIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIkNvbnRlbnRUeXBlLlRlbXBsYXRlXCI+XHJcbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiY29udGVudFRlbXBsYXRlUmVmOyBjb250ZXh0OiBjb250ZXh0XCI+PC9uZy1jb250YWluZXI+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbiAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiQ29udGVudFR5cGUuQ29tcG9uZW50XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiYy1jb21wb25lbnQtY29udGFpbmVyXCI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nQ29tcG9uZW50T3V0bGV0PVwiY29tcG9uZW50VHlwZVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9kaXY+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcbjwvbmctY29udGFpbmVyPlxyXG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmludGVyZmFjZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZGlhbG9nL2RpYWxvZy5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUT0RPOiDQmNGB0L/QvtC70YzQt9C+0LLQsNGC0Ywg0LIg0LHRg9C00YPRidC10LwgQ3VpU2l6ZS3RgtC40L/
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmludGVyZmFjZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZGlhbG9nL2RpYWxvZy5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUT0RPOiDQmNGB0L/QvtC70YzQt9C+0LLQsNGC0Ywg0LIg0LHRg9C00YPRidC10LwgQ3VpU2l6ZS3RgtC40L/Ri1xyXG5pbXBvcnQgdHlwZSB7IEN1aVBvcG92ZXJDb250ZXh0IH0gZnJvbSAnQGN1YnktdWkvY2RrJztcclxuXHJcbmV4cG9ydCB0eXBlIEN1aURpYWxvZ1NpemUgPSAneGwnIHwgJ2F1dG8nO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDdWlEaWFsb2dPcHRpb25zPEkgPSBhbnk+IHtcclxuICByZWFkb25seSBzaXplOiBDdWlEaWFsb2dTaXplO1xyXG4gIHJlYWRvbmx5IGRhdGE6IEk7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ3VpRGlhbG9nQ29udGV4dDxJID0gdW5kZWZpbmVkPiBleHRlbmRzIEN1aVBvcG92ZXJDb250ZXh0LCBDdWlEaWFsb2dPcHRpb25zPEk+IHt9Il19
|