@netwin/angular-datetime-picker 18.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +225 -0
- package/assets/style/picker.min.css +1 -0
- package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +121 -0
- package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +7 -0
- package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +261 -0
- package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +10 -0
- package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +39 -0
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +235 -0
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +10 -0
- package/esm2022/lib/date-time/calendar-body.component.mjs +147 -0
- package/esm2022/lib/date-time/calendar-month-view.component.mjs +451 -0
- package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +361 -0
- package/esm2022/lib/date-time/calendar-year-view.component.mjs +371 -0
- package/esm2022/lib/date-time/calendar.component.mjs +383 -0
- package/esm2022/lib/date-time/date-time-inline.component.mjs +296 -0
- package/esm2022/lib/date-time/date-time-picker-container.component.mjs +420 -0
- package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +638 -0
- package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +62 -0
- package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +69 -0
- package/esm2022/lib/date-time/date-time-picker.animations.mjs +21 -0
- package/esm2022/lib/date-time/date-time-picker.component.mjs +580 -0
- package/esm2022/lib/date-time/date-time.class.mjs +180 -0
- package/esm2022/lib/date-time/date-time.module.mjs +91 -0
- package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +28 -0
- package/esm2022/lib/date-time/options-provider.mjs +34 -0
- package/esm2022/lib/date-time/timer-box.component.mjs +135 -0
- package/esm2022/lib/date-time/timer.component.mjs +292 -0
- package/esm2022/lib/dialog/dialog-config.class.mjs +56 -0
- package/esm2022/lib/dialog/dialog-container.component.mjs +230 -0
- package/esm2022/lib/dialog/dialog-ref.class.mjs +123 -0
- package/esm2022/lib/dialog/dialog.module.mjs +34 -0
- package/esm2022/lib/dialog/dialog.service.mjs +245 -0
- package/esm2022/lib/utils/array.utils.mjs +12 -0
- package/esm2022/lib/utils/constants.mjs +55 -0
- package/esm2022/lib/utils/date.utils.mjs +49 -0
- package/esm2022/lib/utils/index.mjs +5 -0
- package/esm2022/lib/utils/object.utils.mjs +26 -0
- package/esm2022/netwin-angular-datetime-picker.mjs +5 -0
- package/esm2022/public_api.mjs +25 -0
- package/fesm2022/netwin-angular-datetime-picker.mjs +5913 -0
- package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/date-time/adapter/date-time-adapter.class.d.ts +193 -0
- package/lib/date-time/adapter/date-time-format.class.d.ts +15 -0
- package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +69 -0
- package/lib/date-time/adapter/native-date-time-format.class.d.ts +5 -0
- package/lib/date-time/adapter/native-date-time.module.d.ts +12 -0
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +64 -0
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +5 -0
- package/lib/date-time/calendar-body.component.d.ts +80 -0
- package/lib/date-time/calendar-month-view.component.d.ts +144 -0
- package/lib/date-time/calendar-multi-year-view.component.d.ts +111 -0
- package/lib/date-time/calendar-year-view.component.d.ts +123 -0
- package/lib/date-time/calendar.component.d.ts +155 -0
- package/lib/date-time/date-time-inline.component.d.ts +105 -0
- package/lib/date-time/date-time-picker-container.component.d.ts +130 -0
- package/lib/date-time/date-time-picker-input.directive.d.ts +167 -0
- package/lib/date-time/date-time-picker-intl.service.d.ts +51 -0
- package/lib/date-time/date-time-picker-trigger.directive.d.ts +24 -0
- package/lib/date-time/date-time-picker.animations.d.ts +8 -0
- package/lib/date-time/date-time-picker.component.d.ts +177 -0
- package/lib/date-time/date-time.class.d.ts +106 -0
- package/lib/date-time/date-time.module.d.ts +23 -0
- package/lib/date-time/numberedFixLen.pipe.d.ts +10 -0
- package/lib/date-time/options-provider.d.ts +23 -0
- package/lib/date-time/timer-box.component.d.ts +46 -0
- package/lib/date-time/timer.component.d.ts +132 -0
- package/lib/dialog/dialog-config.class.d.ts +169 -0
- package/lib/dialog/dialog-container.component.d.ts +59 -0
- package/lib/dialog/dialog-ref.class.d.ts +51 -0
- package/lib/dialog/dialog.module.d.ts +11 -0
- package/lib/dialog/dialog.service.d.ts +76 -0
- package/lib/utils/array.utils.d.ts +5 -0
- package/lib/utils/constants.d.ts +19 -0
- package/lib/utils/date.utils.d.ts +12 -0
- package/lib/utils/index.d.ts +4 -0
- package/lib/utils/object.utils.d.ts +11 -0
- package/package.json +51 -0
- package/public_api.d.ts +24 -0
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* dialog-container.component
|
|
3
|
+
*/
|
|
4
|
+
import { Component, EventEmitter, Inject, Optional, ViewChild } from '@angular/core';
|
|
5
|
+
import { animate, animateChild, keyframes, style, transition, trigger } from '@angular/animations';
|
|
6
|
+
import { DOCUMENT } from '@angular/common';
|
|
7
|
+
import { BasePortalOutlet, CdkPortalOutlet } from '@angular/cdk/portal';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/cdk/a11y";
|
|
10
|
+
import * as i2 from "@angular/cdk/portal";
|
|
11
|
+
const zoomFadeIn = {
|
|
12
|
+
opacity: 0,
|
|
13
|
+
transform: 'translateX({{ x }}) translateY({{ y }}) scale({{scale}})'
|
|
14
|
+
};
|
|
15
|
+
const zoomFadeInFrom = {
|
|
16
|
+
opacity: 0,
|
|
17
|
+
transform: 'translateX({{ x }}) translateY({{ y }}) scale({{scale}})',
|
|
18
|
+
transformOrigin: '{{ ox }} {{ oy }}'
|
|
19
|
+
};
|
|
20
|
+
export class OwlDialogContainerComponent extends BasePortalOutlet {
|
|
21
|
+
get config() {
|
|
22
|
+
return this._config;
|
|
23
|
+
}
|
|
24
|
+
get owlDialogContainerClass() {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
get owlDialogContainerTabIndex() {
|
|
28
|
+
return -1;
|
|
29
|
+
}
|
|
30
|
+
get owlDialogContainerId() {
|
|
31
|
+
return this._config.id;
|
|
32
|
+
}
|
|
33
|
+
get owlDialogContainerRole() {
|
|
34
|
+
return this._config.role || null;
|
|
35
|
+
}
|
|
36
|
+
get owlDialogContainerAriaLabelledby() {
|
|
37
|
+
return this.ariaLabelledBy;
|
|
38
|
+
}
|
|
39
|
+
get owlDialogContainerAriaDescribedby() {
|
|
40
|
+
return this._config.ariaDescribedBy || null;
|
|
41
|
+
}
|
|
42
|
+
get owlDialogContainerAnimation() {
|
|
43
|
+
return { value: this.state, params: this.params };
|
|
44
|
+
}
|
|
45
|
+
constructor(changeDetector, elementRef, focusTrapFactory, document) {
|
|
46
|
+
super();
|
|
47
|
+
this.changeDetector = changeDetector;
|
|
48
|
+
this.elementRef = elementRef;
|
|
49
|
+
this.focusTrapFactory = focusTrapFactory;
|
|
50
|
+
this.document = document;
|
|
51
|
+
this.portalOutlet = null;
|
|
52
|
+
/** ID of the element that should be considered as the dialog's label. */
|
|
53
|
+
this.ariaLabelledBy = null;
|
|
54
|
+
/** Emits when an animation state changes. */
|
|
55
|
+
this.animationStateChanged = new EventEmitter();
|
|
56
|
+
this.isAnimating = false;
|
|
57
|
+
this.state = 'enter';
|
|
58
|
+
// for animation purpose
|
|
59
|
+
this.params = {
|
|
60
|
+
x: '0px',
|
|
61
|
+
y: '0px',
|
|
62
|
+
ox: '50%',
|
|
63
|
+
oy: '50%',
|
|
64
|
+
scale: 0
|
|
65
|
+
};
|
|
66
|
+
// A variable to hold the focused element before the dialog was open.
|
|
67
|
+
// This would help us to refocus back to element when the dialog was closed.
|
|
68
|
+
this.elementFocusedBeforeDialogWasOpened = null;
|
|
69
|
+
}
|
|
70
|
+
ngOnInit() { }
|
|
71
|
+
/**
|
|
72
|
+
* Attach a ComponentPortal as content to this dialog container.
|
|
73
|
+
*/
|
|
74
|
+
attachComponentPortal(portal) {
|
|
75
|
+
if (this.portalOutlet.hasAttached()) {
|
|
76
|
+
throw Error('Attempting to attach dialog content after content is already attached');
|
|
77
|
+
}
|
|
78
|
+
this.savePreviouslyFocusedElement();
|
|
79
|
+
return this.portalOutlet.attachComponentPortal(portal);
|
|
80
|
+
}
|
|
81
|
+
attachTemplatePortal(portal) {
|
|
82
|
+
throw new Error('Method not implemented.');
|
|
83
|
+
}
|
|
84
|
+
setConfig(config) {
|
|
85
|
+
this._config = config;
|
|
86
|
+
if (config.event) {
|
|
87
|
+
this.calculateZoomOrigin(event);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
onAnimationStart(event) {
|
|
91
|
+
this.isAnimating = true;
|
|
92
|
+
this.animationStateChanged.emit(event);
|
|
93
|
+
}
|
|
94
|
+
onAnimationDone(event) {
|
|
95
|
+
if (event.toState === 'enter') {
|
|
96
|
+
this.trapFocus();
|
|
97
|
+
}
|
|
98
|
+
else if (event.toState === 'exit') {
|
|
99
|
+
this.restoreFocus();
|
|
100
|
+
}
|
|
101
|
+
this.animationStateChanged.emit(event);
|
|
102
|
+
this.isAnimating = false;
|
|
103
|
+
}
|
|
104
|
+
startExitAnimation() {
|
|
105
|
+
this.state = 'exit';
|
|
106
|
+
this.changeDetector.markForCheck();
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Calculate origin used in the `zoomFadeInFrom()`
|
|
110
|
+
* for animation purpose
|
|
111
|
+
*/
|
|
112
|
+
calculateZoomOrigin(event) {
|
|
113
|
+
if (!event) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
const clientX = event.clientX;
|
|
117
|
+
const clientY = event.clientY;
|
|
118
|
+
const wh = window.innerWidth / 2;
|
|
119
|
+
const hh = window.innerHeight / 2;
|
|
120
|
+
const x = clientX - wh;
|
|
121
|
+
const y = clientY - hh;
|
|
122
|
+
const ox = clientX / window.innerWidth;
|
|
123
|
+
const oy = clientY / window.innerHeight;
|
|
124
|
+
this.params.x = `${x}px`;
|
|
125
|
+
this.params.y = `${y}px`;
|
|
126
|
+
this.params.ox = `${ox * 100}%`;
|
|
127
|
+
this.params.oy = `${oy * 100}%`;
|
|
128
|
+
this.params.scale = 0;
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Save the focused element before dialog was open
|
|
133
|
+
*/
|
|
134
|
+
savePreviouslyFocusedElement() {
|
|
135
|
+
if (this.document) {
|
|
136
|
+
this.elementFocusedBeforeDialogWasOpened = this.document
|
|
137
|
+
.activeElement;
|
|
138
|
+
Promise.resolve().then(() => this.elementRef.nativeElement.focus());
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
trapFocus() {
|
|
142
|
+
if (!this.focusTrap) {
|
|
143
|
+
this.focusTrap = this.focusTrapFactory.create(this.elementRef.nativeElement);
|
|
144
|
+
}
|
|
145
|
+
if (this._config.autoFocus) {
|
|
146
|
+
this.focusTrap.focusInitialElementWhenReady();
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
restoreFocus() {
|
|
150
|
+
const toFocus = this.elementFocusedBeforeDialogWasOpened;
|
|
151
|
+
// We need the extra check, because IE can set the `activeElement` to null in some cases.
|
|
152
|
+
if (toFocus && typeof toFocus.focus === 'function') {
|
|
153
|
+
toFocus.focus();
|
|
154
|
+
}
|
|
155
|
+
if (this.focusTrap) {
|
|
156
|
+
this.focusTrap.destroy();
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlDialogContainerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.FocusTrapFactory }, { token: DOCUMENT, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
160
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: OwlDialogContainerComponent, selector: "owl-dialog-container", host: { listeners: { "@slideModal.start": "onAnimationStart($event)", "@slideModal.done": "onAnimationDone($event)" }, properties: { "class.owl-dialog-container": "owlDialogContainerClass", "attr.tabindex": "owlDialogContainerTabIndex", "attr.id": "owlDialogContainerId", "attr.role": "owlDialogContainerRole", "attr.aria-labelledby": "owlDialogContainerAriaLabelledby", "attr.aria-describedby": "owlDialogContainerAriaDescribedby", "@slideModal": "owlDialogContainerAnimation" } }, viewQueries: [{ propertyName: "portalOutlet", first: true, predicate: CdkPortalOutlet, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template [cdkPortalOutlet]></ng-template>\n", dependencies: [{ kind: "directive", type: i2.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }], animations: [
|
|
161
|
+
trigger('slideModal', [
|
|
162
|
+
transition('void => enter', [
|
|
163
|
+
style(zoomFadeInFrom),
|
|
164
|
+
animate('300ms cubic-bezier(0.35, 0, 0.25, 1)', style('*')),
|
|
165
|
+
animate('150ms', keyframes([
|
|
166
|
+
style({ transform: 'scale(1)', offset: 0 }),
|
|
167
|
+
style({ transform: 'scale(1.05)', offset: 0.3 }),
|
|
168
|
+
style({ transform: 'scale(.95)', offset: 0.8 }),
|
|
169
|
+
style({ transform: 'scale(1)', offset: 1.0 })
|
|
170
|
+
])),
|
|
171
|
+
animateChild()
|
|
172
|
+
], {
|
|
173
|
+
params: {
|
|
174
|
+
x: '0px',
|
|
175
|
+
y: '0px',
|
|
176
|
+
ox: '50%',
|
|
177
|
+
oy: '50%',
|
|
178
|
+
scale: 1
|
|
179
|
+
}
|
|
180
|
+
}),
|
|
181
|
+
transition('enter => exit', [animateChild(), animate(200, style(zoomFadeIn))], { params: { x: '0px', y: '0px', ox: '50%', oy: '50%' } })
|
|
182
|
+
])
|
|
183
|
+
] }); }
|
|
184
|
+
}
|
|
185
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlDialogContainerComponent, decorators: [{
|
|
186
|
+
type: Component,
|
|
187
|
+
args: [{ selector: 'owl-dialog-container', animations: [
|
|
188
|
+
trigger('slideModal', [
|
|
189
|
+
transition('void => enter', [
|
|
190
|
+
style(zoomFadeInFrom),
|
|
191
|
+
animate('300ms cubic-bezier(0.35, 0, 0.25, 1)', style('*')),
|
|
192
|
+
animate('150ms', keyframes([
|
|
193
|
+
style({ transform: 'scale(1)', offset: 0 }),
|
|
194
|
+
style({ transform: 'scale(1.05)', offset: 0.3 }),
|
|
195
|
+
style({ transform: 'scale(.95)', offset: 0.8 }),
|
|
196
|
+
style({ transform: 'scale(1)', offset: 1.0 })
|
|
197
|
+
])),
|
|
198
|
+
animateChild()
|
|
199
|
+
], {
|
|
200
|
+
params: {
|
|
201
|
+
x: '0px',
|
|
202
|
+
y: '0px',
|
|
203
|
+
ox: '50%',
|
|
204
|
+
oy: '50%',
|
|
205
|
+
scale: 1
|
|
206
|
+
}
|
|
207
|
+
}),
|
|
208
|
+
transition('enter => exit', [animateChild(), animate(200, style(zoomFadeIn))], { params: { x: '0px', y: '0px', ox: '50%', oy: '50%' } })
|
|
209
|
+
])
|
|
210
|
+
], host: {
|
|
211
|
+
'(@slideModal.start)': 'onAnimationStart($event)',
|
|
212
|
+
'(@slideModal.done)': 'onAnimationDone($event)',
|
|
213
|
+
'[class.owl-dialog-container]': 'owlDialogContainerClass',
|
|
214
|
+
'[attr.tabindex]': 'owlDialogContainerTabIndex',
|
|
215
|
+
'[attr.id]': 'owlDialogContainerId',
|
|
216
|
+
'[attr.role]': 'owlDialogContainerRole',
|
|
217
|
+
'[attr.aria-labelledby]': 'owlDialogContainerAriaLabelledby',
|
|
218
|
+
'[attr.aria-describedby]': 'owlDialogContainerAriaDescribedby',
|
|
219
|
+
'[@slideModal]': 'owlDialogContainerAnimation'
|
|
220
|
+
}, template: "<ng-template [cdkPortalOutlet]></ng-template>\n" }]
|
|
221
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.FocusTrapFactory }, { type: undefined, decorators: [{
|
|
222
|
+
type: Optional
|
|
223
|
+
}, {
|
|
224
|
+
type: Inject,
|
|
225
|
+
args: [DOCUMENT]
|
|
226
|
+
}] }], propDecorators: { portalOutlet: [{
|
|
227
|
+
type: ViewChild,
|
|
228
|
+
args: [CdkPortalOutlet, { static: true }]
|
|
229
|
+
}] } });
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-container.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/dialog/dialog-container.component.ts","../../../../../projects/picker/src/lib/dialog/dialog-container.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * dialog-container.component\n */\n\nimport {\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ElementRef,\n    EmbeddedViewRef,\n    EventEmitter,\n    Inject,\n    OnInit,\n    Optional,\n    ViewChild\n} from '@angular/core';\nimport {\n    animate,\n    animateChild,\n    AnimationEvent,\n    keyframes,\n    style,\n    transition,\n    trigger\n} from '@angular/animations';\nimport { DOCUMENT } from '@angular/common';\nimport { FocusTrap, FocusTrapFactory } from '@angular/cdk/a11y';\nimport {\n    BasePortalOutlet,\n    CdkPortalOutlet,\n    ComponentPortal,\n    TemplatePortal\n} from '@angular/cdk/portal';\nimport { OwlDialogConfigInterface } from './dialog-config.class';\n\nconst zoomFadeIn = {\n    opacity: 0,\n    transform: 'translateX({{ x }}) translateY({{ y }}) scale({{scale}})'\n};\nconst zoomFadeInFrom = {\n    opacity: 0,\n    transform: 'translateX({{ x }}) translateY({{ y }}) scale({{scale}})',\n    transformOrigin: '{{ ox }} {{ oy }}'\n};\n\n@Component({\n    selector: 'owl-dialog-container',\n    templateUrl: './dialog-container.component.html',\n    animations: [\n        trigger('slideModal', [\n            transition(\n                'void => enter',\n                [\n                    style(zoomFadeInFrom),\n                    animate('300ms cubic-bezier(0.35, 0, 0.25, 1)', style('*')),\n                    animate(\n                        '150ms',\n                        keyframes([\n                            style({ transform: 'scale(1)', offset: 0 }),\n                            style({ transform: 'scale(1.05)', offset: 0.3 }),\n                            style({ transform: 'scale(.95)', offset: 0.8 }),\n                            style({ transform: 'scale(1)', offset: 1.0 })\n                        ])\n                    ),\n                    animateChild()\n                ],\n                {\n                    params: {\n                        x: '0px',\n                        y: '0px',\n                        ox: '50%',\n                        oy: '50%',\n                        scale: 1\n                    }\n                }\n            ),\n            transition(\n                'enter => exit',\n                [animateChild(), animate(200, style(zoomFadeIn))],\n                { params: { x: '0px', y: '0px', ox: '50%', oy: '50%' } }\n            )\n        ])\n    ],\n    host: {\n        '(@slideModal.start)': 'onAnimationStart($event)',\n        '(@slideModal.done)': 'onAnimationDone($event)',\n        '[class.owl-dialog-container]': 'owlDialogContainerClass',\n        '[attr.tabindex]': 'owlDialogContainerTabIndex',\n        '[attr.id]': 'owlDialogContainerId',\n        '[attr.role]': 'owlDialogContainerRole',\n        '[attr.aria-labelledby]': 'owlDialogContainerAriaLabelledby',\n        '[attr.aria-describedby]': 'owlDialogContainerAriaDescribedby',\n        '[@slideModal]': 'owlDialogContainerAnimation'\n    }\n})\nexport class OwlDialogContainerComponent extends BasePortalOutlet\n    implements OnInit {\n    @ViewChild(CdkPortalOutlet, { static: true })\n    portalOutlet: CdkPortalOutlet | null = null;\n\n    /** The class that traps and manages focus within the dialog. */\n    private focusTrap: FocusTrap;\n\n    /** ID of the element that should be considered as the dialog's label. */\n    public ariaLabelledBy: string | null = null;\n\n    /** Emits when an animation state changes. */\n    public animationStateChanged = new EventEmitter<AnimationEvent>();\n\n    public isAnimating = false;\n\n    private _config: OwlDialogConfigInterface;\n    get config(): OwlDialogConfigInterface {\n        return this._config;\n    }\n\n    private state: 'void' | 'enter' | 'exit' = 'enter';\n\n    // for animation purpose\n    private params: any = {\n        x: '0px',\n        y: '0px',\n        ox: '50%',\n        oy: '50%',\n        scale: 0\n    };\n\n    // A variable to hold the focused element before the dialog was open.\n    // This would help us to refocus back to element when the dialog was closed.\n    private elementFocusedBeforeDialogWasOpened: HTMLElement | null = null;\n\n    get owlDialogContainerClass(): boolean {\n        return true;\n    }\n\n    get owlDialogContainerTabIndex(): number {\n        return -1;\n    }\n\n    get owlDialogContainerId(): string {\n        return this._config.id;\n    }\n\n    get owlDialogContainerRole(): string {\n        return this._config.role || null;\n    }\n\n    get owlDialogContainerAriaLabelledby(): string {\n        return this.ariaLabelledBy;\n    }\n\n    get owlDialogContainerAriaDescribedby(): string {\n        return this._config.ariaDescribedBy || null;\n    }\n\n    get owlDialogContainerAnimation(): any {\n        return { value: this.state, params: this.params };\n    }\n\n    constructor(\n        private changeDetector: ChangeDetectorRef,\n        private elementRef: ElementRef,\n        private focusTrapFactory: FocusTrapFactory,\n        @Optional()\n        @Inject(DOCUMENT)\n        private document: any\n    ) {\n        super();\n    }\n\n    public ngOnInit() {}\n\n    /**\n     * Attach a ComponentPortal as content to this dialog container.\n     */\n    public attachComponentPortal<T>(\n        portal: ComponentPortal<T>\n    ): ComponentRef<T> {\n        if (this.portalOutlet.hasAttached()) {\n            throw Error(\n                'Attempting to attach dialog content after content is already attached'\n            );\n        }\n\n        this.savePreviouslyFocusedElement();\n        return this.portalOutlet.attachComponentPortal(portal);\n    }\n\n    public attachTemplatePortal<C>(\n        portal: TemplatePortal<C>\n    ): EmbeddedViewRef<C> {\n        throw new Error('Method not implemented.');\n    }\n\n    public setConfig(config: OwlDialogConfigInterface): void {\n        this._config = config;\n\n        if (config.event) {\n            this.calculateZoomOrigin(event);\n        }\n    }\n\n    public onAnimationStart( event: AnimationEvent ): void {\n        this.isAnimating = true;\n        this.animationStateChanged.emit(event);\n    }\n\n    public onAnimationDone( event: AnimationEvent ): void {\n        if (event.toState === 'enter') {\n            this.trapFocus();\n        } else if (event.toState === 'exit') {\n            this.restoreFocus();\n        }\n\n        this.animationStateChanged.emit(event);\n        this.isAnimating = false;\n    }\n\n    public startExitAnimation() {\n        this.state = 'exit';\n        this.changeDetector.markForCheck();\n    }\n\n    /**\n     * Calculate origin used in the `zoomFadeInFrom()`\n     * for animation purpose\n     */\n    private calculateZoomOrigin(event: any): void {\n        if (!event) {\n            return;\n        }\n\n        const clientX = event.clientX;\n        const clientY = event.clientY;\n\n        const wh = window.innerWidth / 2;\n        const hh = window.innerHeight / 2;\n        const x = clientX - wh;\n        const y = clientY - hh;\n        const ox = clientX / window.innerWidth;\n        const oy = clientY / window.innerHeight;\n\n        this.params.x = `${x}px`;\n        this.params.y = `${y}px`;\n        this.params.ox = `${ox * 100}%`;\n        this.params.oy = `${oy * 100}%`;\n        this.params.scale = 0;\n\n        return;\n    }\n\n    /**\n     * Save the focused element before dialog was open\n     */\n    private savePreviouslyFocusedElement(): void {\n        if (this.document) {\n            this.elementFocusedBeforeDialogWasOpened = this.document\n                .activeElement as HTMLElement;\n\n            Promise.resolve().then(() => this.elementRef.nativeElement.focus());\n        }\n    }\n\n    private trapFocus(): void {\n        if (!this.focusTrap) {\n            this.focusTrap = this.focusTrapFactory.create(\n                this.elementRef.nativeElement\n            );\n        }\n\n        if (this._config.autoFocus) {\n            this.focusTrap.focusInitialElementWhenReady();\n        }\n    }\n\n    private restoreFocus(): void {\n        const toFocus = this.elementFocusedBeforeDialogWasOpened;\n\n        // We need the extra check, because IE can set the `activeElement` to null in some cases.\n        if (toFocus && typeof toFocus.focus === 'function') {\n            toFocus.focus();\n        }\n\n        if (this.focusTrap) {\n            this.focusTrap.destroy();\n        }\n    }\n}\n","<ng-template [cdkPortalOutlet]></ng-template>\n"]}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { ESCAPE } from '@angular/cdk/keycodes';
|
|
2
|
+
import { Subject, Subscription, filter, take } from 'rxjs';
|
|
3
|
+
export class OwlDialogRef {
|
|
4
|
+
constructor(overlayRef, container, id, location) {
|
|
5
|
+
this.overlayRef = overlayRef;
|
|
6
|
+
this.container = container;
|
|
7
|
+
this.id = id;
|
|
8
|
+
this._beforeClose$ = new Subject();
|
|
9
|
+
this._beforeOpen$ = new Subject();
|
|
10
|
+
this._afterOpen$ = new Subject();
|
|
11
|
+
this._afterClosed$ = new Subject();
|
|
12
|
+
/** Subscription to changes in the user's location. */
|
|
13
|
+
this.locationChanged = Subscription.EMPTY;
|
|
14
|
+
/** Whether the user is allowed to close the dialog. */
|
|
15
|
+
this.disableClose = true;
|
|
16
|
+
this.disableClose = this.container.config.disableClose;
|
|
17
|
+
this.container.animationStateChanged
|
|
18
|
+
.pipe(filter((event) => event.phaseName === 'start' && event.toState === 'enter'), take(1))
|
|
19
|
+
.subscribe(() => {
|
|
20
|
+
this._beforeOpen$.next(null);
|
|
21
|
+
this._beforeOpen$.complete();
|
|
22
|
+
});
|
|
23
|
+
this.container.animationStateChanged
|
|
24
|
+
.pipe(filter((event) => event.phaseName === 'done' && event.toState === 'enter'), take(1))
|
|
25
|
+
.subscribe(() => {
|
|
26
|
+
this._afterOpen$.next(null);
|
|
27
|
+
this._afterOpen$.complete();
|
|
28
|
+
});
|
|
29
|
+
this.container.animationStateChanged
|
|
30
|
+
.pipe(filter((event) => event.phaseName === 'done' && event.toState === 'exit'), take(1))
|
|
31
|
+
.subscribe(() => {
|
|
32
|
+
this.overlayRef.dispose();
|
|
33
|
+
this.locationChanged.unsubscribe();
|
|
34
|
+
this._afterClosed$.next(this.result);
|
|
35
|
+
this._afterClosed$.complete();
|
|
36
|
+
this.componentInstance = null;
|
|
37
|
+
});
|
|
38
|
+
this.overlayRef.keydownEvents()
|
|
39
|
+
.pipe(filter(event => event.keyCode === ESCAPE && !this.disableClose))
|
|
40
|
+
.subscribe(() => this.close());
|
|
41
|
+
if (location) {
|
|
42
|
+
this.locationChanged = location.subscribe(() => {
|
|
43
|
+
if (this.container.config.closeOnNavigation) {
|
|
44
|
+
this.close();
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
close(dialogResult) {
|
|
50
|
+
this.result = dialogResult;
|
|
51
|
+
this.container.animationStateChanged
|
|
52
|
+
.pipe(filter((event) => event.phaseName === 'start'), take(1))
|
|
53
|
+
.subscribe(() => {
|
|
54
|
+
this._beforeClose$.next(dialogResult);
|
|
55
|
+
this._beforeClose$.complete();
|
|
56
|
+
this.overlayRef.detachBackdrop();
|
|
57
|
+
});
|
|
58
|
+
this.container.startExitAnimation();
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Gets an observable that emits when the overlay's backdrop has been clicked.
|
|
62
|
+
*/
|
|
63
|
+
backdropClick() {
|
|
64
|
+
return this.overlayRef.backdropClick();
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Gets an observable that emits when keydown events are targeted on the overlay.
|
|
68
|
+
*/
|
|
69
|
+
keydownEvents() {
|
|
70
|
+
return this.overlayRef.keydownEvents();
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Updates the dialog's position.
|
|
74
|
+
* @param position New dialog position.
|
|
75
|
+
*/
|
|
76
|
+
updatePosition(position) {
|
|
77
|
+
const strategy = this.getPositionStrategy();
|
|
78
|
+
if (position && (position.left || position.right)) {
|
|
79
|
+
position.left ? strategy.left(position.left) : strategy.right(position.right);
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
strategy.centerHorizontally();
|
|
83
|
+
}
|
|
84
|
+
if (position && (position.top || position.bottom)) {
|
|
85
|
+
position.top ? strategy.top(position.top) : strategy.bottom(position.bottom);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
strategy.centerVertically();
|
|
89
|
+
}
|
|
90
|
+
this.overlayRef.updatePosition();
|
|
91
|
+
return this;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Updates the dialog's width and height.
|
|
95
|
+
* @param width New width of the dialog.
|
|
96
|
+
* @param height New height of the dialog.
|
|
97
|
+
*/
|
|
98
|
+
updateSize(width = 'auto', height = 'auto') {
|
|
99
|
+
this.getPositionStrategy().width(width).height(height);
|
|
100
|
+
this.overlayRef.updatePosition();
|
|
101
|
+
return this;
|
|
102
|
+
}
|
|
103
|
+
isAnimating() {
|
|
104
|
+
return this.container.isAnimating;
|
|
105
|
+
}
|
|
106
|
+
beforeOpen() {
|
|
107
|
+
return this._beforeOpen$.asObservable();
|
|
108
|
+
}
|
|
109
|
+
afterOpen() {
|
|
110
|
+
return this._afterOpen$.asObservable();
|
|
111
|
+
}
|
|
112
|
+
beforeClose() {
|
|
113
|
+
return this._beforeClose$.asObservable();
|
|
114
|
+
}
|
|
115
|
+
afterClosed() {
|
|
116
|
+
return this._afterClosed$.asObservable();
|
|
117
|
+
}
|
|
118
|
+
/** Fetches the position strategy object from the overlay ref. */
|
|
119
|
+
getPositionStrategy() {
|
|
120
|
+
return this.overlayRef.getConfig().positionStrategy;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-ref.class.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/dialog/dialog-ref.class.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * dialog-ref.class\n */\nimport { AnimationEvent } from '@angular/animations';\nimport { ESCAPE } from '@angular/cdk/keycodes';\nimport { GlobalPositionStrategy, OverlayRef } from '@angular/cdk/overlay';\nimport { Location } from '@angular/common';\nimport { Observable, Subject, Subscription, SubscriptionLike, filter, take } from 'rxjs';\nimport { DialogPosition } from './dialog-config.class';\nimport { OwlDialogContainerComponent } from './dialog-container.component';\n\nexport class OwlDialogRef<T> {\n\n    private result: any;\n\n    private _beforeClose$ = new Subject<any>();\n\n    private _beforeOpen$ = new Subject<any>();\n\n    private _afterOpen$ = new Subject<any>();\n\n    private _afterClosed$ = new Subject<any>();\n\n    /** Subscription to changes in the user's location. */\n    private locationChanged: SubscriptionLike = Subscription.EMPTY;\n\n    /**\n     * The instance of component opened into modal\n     * */\n    public componentInstance: T;\n\n    /** Whether the user is allowed to close the dialog. */\n    public disableClose = true;\n\n    constructor(private overlayRef: OverlayRef,\n        private container: OwlDialogContainerComponent,\n        public readonly id: string,\n        location?: Location) {\n        this.disableClose = this.container.config.disableClose;\n\n        this.container.animationStateChanged\n            .pipe(\n                filter(( event: AnimationEvent ) => event.phaseName === 'start' && event.toState === 'enter'),\n                take(1)\n            )\n            .subscribe(() => {\n                this._beforeOpen$.next(null);\n                this._beforeOpen$.complete();\n            });\n\n        this.container.animationStateChanged\n            .pipe(\n                filter(( event: AnimationEvent ) => event.phaseName === 'done' && event.toState === 'enter'),\n                take(1)\n            )\n            .subscribe(() => {\n                this._afterOpen$.next(null);\n                this._afterOpen$.complete();\n            });\n\n        this.container.animationStateChanged\n            .pipe(\n                filter((event: AnimationEvent) => event.phaseName === 'done' && event.toState === 'exit'),\n                take(1)\n            )\n            .subscribe(() => {\n                this.overlayRef.dispose();\n                this.locationChanged.unsubscribe();\n                this._afterClosed$.next(this.result);\n                this._afterClosed$.complete();\n                this.componentInstance = null;\n            });\n\n        this.overlayRef.keydownEvents()\n            .pipe(filter(event => event.keyCode === ESCAPE && !this.disableClose))\n            .subscribe(() => this.close());\n\n        if (location) {\n            this.locationChanged = location.subscribe(() => {\n                if (this.container.config.closeOnNavigation) {\n                    this.close();\n                }\n            });\n        }\n    }\n\n    public close(dialogResult?: any) {\n        this.result = dialogResult;\n\n        this.container.animationStateChanged\n            .pipe(\n                filter((event: AnimationEvent) => event.phaseName === 'start'),\n                take(1)\n            )\n            .subscribe(() => {\n                this._beforeClose$.next(dialogResult);\n                this._beforeClose$.complete();\n                this.overlayRef.detachBackdrop();\n            });\n\n        this.container.startExitAnimation();\n    }\n\n    /**\n     * Gets an observable that emits when the overlay's backdrop has been clicked.\n     */\n    public backdropClick(): Observable<any> {\n        return this.overlayRef.backdropClick();\n    }\n\n    /**\n     * Gets an observable that emits when keydown events are targeted on the overlay.\n     */\n    public keydownEvents(): Observable<KeyboardEvent> {\n        return this.overlayRef.keydownEvents();\n    }\n\n    /**\n     * Updates the dialog's position.\n     * @param position New dialog position.\n     */\n    public updatePosition(position?: DialogPosition): this {\n        const strategy = this.getPositionStrategy();\n\n        if (position && (position.left || position.right)) {\n            position.left ? strategy.left(position.left) : strategy.right(position.right);\n        } else {\n            strategy.centerHorizontally();\n        }\n\n        if (position && (position.top || position.bottom)) {\n            position.top ? strategy.top(position.top) : strategy.bottom(position.bottom);\n        } else {\n            strategy.centerVertically();\n        }\n\n        this.overlayRef.updatePosition();\n\n        return this;\n    }\n\n    /**\n     * Updates the dialog's width and height.\n     * @param width New width of the dialog.\n     * @param height New height of the dialog.\n     */\n    updateSize(width: string = 'auto', height: string = 'auto'): this {\n        this.getPositionStrategy().width(width).height(height);\n        this.overlayRef.updatePosition();\n        return this;\n    }\n\n    public isAnimating(): boolean {\n        return this.container.isAnimating;\n    }\n\n    public beforeOpen(): Observable<any> {\n        return this._beforeOpen$.asObservable();\n    }\n\n    public afterOpen(): Observable<any> {\n        return this._afterOpen$.asObservable();\n    }\n\n    public beforeClose(): Observable<any> {\n        return this._beforeClose$.asObservable();\n    }\n\n    public afterClosed(): Observable<any> {\n        return this._afterClosed$.asObservable();\n    }\n\n    /** Fetches the position strategy object from the overlay ref. */\n    private getPositionStrategy(): GlobalPositionStrategy {\n        return this.overlayRef.getConfig().positionStrategy as GlobalPositionStrategy;\n    }\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* dialog.module
|
|
3
|
+
*/
|
|
4
|
+
import { NgModule } from '@angular/core';
|
|
5
|
+
import { CommonModule } from '@angular/common';
|
|
6
|
+
import { A11yModule } from '@angular/cdk/a11y';
|
|
7
|
+
import { OverlayModule } from '@angular/cdk/overlay';
|
|
8
|
+
import { PortalModule } from '@angular/cdk/portal';
|
|
9
|
+
import { OWL_DIALOG_SCROLL_STRATEGY_PROVIDER, OwlDialogService } from './dialog.service';
|
|
10
|
+
import { OwlDialogContainerComponent } from './dialog-container.component';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
export class OwlDialogModule {
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
14
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.3", ngImport: i0, type: OwlDialogModule, declarations: [OwlDialogContainerComponent], imports: [CommonModule, A11yModule, OverlayModule, PortalModule] }); }
|
|
15
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlDialogModule, providers: [
|
|
16
|
+
OWL_DIALOG_SCROLL_STRATEGY_PROVIDER,
|
|
17
|
+
OwlDialogService,
|
|
18
|
+
], imports: [CommonModule, A11yModule, OverlayModule, PortalModule] }); }
|
|
19
|
+
}
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlDialogModule, decorators: [{
|
|
21
|
+
type: NgModule,
|
|
22
|
+
args: [{
|
|
23
|
+
imports: [CommonModule, A11yModule, OverlayModule, PortalModule],
|
|
24
|
+
exports: [],
|
|
25
|
+
declarations: [
|
|
26
|
+
OwlDialogContainerComponent,
|
|
27
|
+
],
|
|
28
|
+
providers: [
|
|
29
|
+
OWL_DIALOG_SCROLL_STRATEGY_PROVIDER,
|
|
30
|
+
OwlDialogService,
|
|
31
|
+
]
|
|
32
|
+
}]
|
|
33
|
+
}] });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3BpY2tlci9zcmMvbGliL2RpYWxvZy9kaWFsb2cubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDekYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7O0FBYTNFLE1BQU0sT0FBTyxlQUFlOzhHQUFmLGVBQWU7K0dBQWYsZUFBZSxpQkFQcEIsMkJBQTJCLGFBSHJCLFlBQVksRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLFlBQVk7K0dBVXRELGVBQWUsYUFMYjtZQUNQLG1DQUFtQztZQUNuQyxnQkFBZ0I7U0FDbkIsWUFSUyxZQUFZLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxZQUFZOzsyRkFVdEQsZUFBZTtrQkFYM0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxZQUFZLENBQUM7b0JBQ2hFLE9BQU8sRUFBRSxFQUFFO29CQUNYLFlBQVksRUFBRTt3QkFDViwyQkFBMkI7cUJBQzlCO29CQUNELFNBQVMsRUFBRTt3QkFDUCxtQ0FBbUM7d0JBQ25DLGdCQUFnQjtxQkFDbkI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIGRpYWxvZy5tb2R1bGVcbiAqL1xuXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEExMXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvYTExeSc7XG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgUG9ydGFsTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BvcnRhbCc7XG5pbXBvcnQgeyBPV0xfRElBTE9HX1NDUk9MTF9TVFJBVEVHWV9QUk9WSURFUiwgT3dsRGlhbG9nU2VydmljZSB9IGZyb20gJy4vZGlhbG9nLnNlcnZpY2UnO1xuaW1wb3J0IHsgT3dsRGlhbG9nQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi9kaWFsb2ctY29udGFpbmVyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQTExeU1vZHVsZSwgT3ZlcmxheU1vZHVsZSwgUG9ydGFsTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtcbiAgICAgICAgT3dsRGlhbG9nQ29udGFpbmVyQ29tcG9uZW50LFxuICAgIF0sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIE9XTF9ESUFMT0dfU0NST0xMX1NUUkFURUdZX1BST1ZJREVSLFxuICAgICAgICBPd2xEaWFsb2dTZXJ2aWNlLFxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgT3dsRGlhbG9nTW9kdWxlIHtcbn1cbiJdfQ==
|