@netwin/angular-datetime-picker 18.1.0 → 19.0.0-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -27
- package/assets/style/picker.min.css +1 -1
- package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +7 -13
- package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +1 -4
- package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +21 -36
- package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +1 -2
- package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +9 -12
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +12 -25
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +1 -2
- package/esm2022/lib/date-time/calendar-body.component.mjs +22 -31
- package/esm2022/lib/date-time/calendar-month-view.component.mjs +13 -29
- package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +11 -17
- package/esm2022/lib/date-time/calendar-year-view.component.mjs +11 -19
- package/esm2022/lib/date-time/calendar.component.mjs +16 -27
- package/esm2022/lib/date-time/date-time-inline.component.mjs +262 -108
- package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +4 -11
- package/esm2022/lib/date-time/date-time.module.mjs +12 -36
- package/esm2022/lib/date-time/options-provider.mjs +1 -1
- package/esm2022/lib/date-time/timer-box.component.mjs +6 -16
- package/esm2022/lib/date-time/timer.component.mjs +18 -17
- package/esm2022/lib/types/date-view.mjs +19 -0
- package/esm2022/lib/types/index.mjs +4 -0
- package/esm2022/lib/types/picker-type.mjs +2 -0
- package/esm2022/lib/types/select-mode.mjs +2 -0
- package/esm2022/lib/utils/array.utils.mjs +2 -9
- package/esm2022/lib/utils/constants.mjs +1 -4
- package/esm2022/lib/utils/date.utils.mjs +1 -4
- package/esm2022/public_api.mjs +13 -20
- package/fesm2022/netwin-angular-datetime-picker.mjs +2653 -5112
- package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -1
- package/lib/date-time/adapter/date-time-adapter.class.d.ts +16 -26
- package/lib/date-time/adapter/date-time-format.class.d.ts +8 -12
- package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +7 -18
- package/lib/date-time/adapter/native-date-time-format.class.d.ts +0 -3
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +6 -17
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +0 -3
- package/lib/date-time/calendar-body.component.d.ts +21 -26
- package/lib/date-time/calendar-month-view.component.d.ts +19 -24
- package/lib/date-time/calendar-multi-year-view.component.d.ts +7 -8
- package/lib/date-time/calendar-year-view.component.d.ts +8 -9
- package/lib/date-time/calendar.component.d.ts +15 -21
- package/lib/date-time/date-time-inline.component.d.ts +164 -74
- package/lib/date-time/date-time-picker-intl.service.d.ts +0 -4
- package/lib/date-time/date-time.module.d.ts +11 -18
- package/lib/date-time/timer-box.component.d.ts +4 -5
- package/lib/date-time/timer.component.d.ts +6 -9
- package/lib/types/date-view.d.ts +17 -0
- package/lib/types/index.d.ts +3 -0
- package/lib/types/picker-type.d.ts +7 -0
- package/lib/types/select-mode.d.ts +8 -0
- package/lib/utils/array.utils.d.ts +0 -3
- package/lib/utils/constants.d.ts +0 -3
- package/lib/utils/date.utils.d.ts +0 -3
- package/package.json +1 -1
- package/public_api.d.ts +12 -19
- package/esm2022/lib/date-time/date-time-picker-container.component.mjs +0 -405
- package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +0 -598
- package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +0 -64
- package/esm2022/lib/date-time/date-time-picker.animations.mjs +0 -21
- package/esm2022/lib/date-time/date-time-picker.component.mjs +0 -564
- package/esm2022/lib/date-time/date-time.class.mjs +0 -176
- package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +0 -28
- package/esm2022/lib/dialog/dialog-config.class.mjs +0 -59
- package/esm2022/lib/dialog/dialog-container.component.mjs +0 -232
- package/esm2022/lib/dialog/dialog-ref.class.mjs +0 -134
- package/esm2022/lib/dialog/dialog.module.mjs +0 -26
- package/esm2022/lib/dialog/dialog.service.mjs +0 -228
- package/esm2022/lib/utils/index.mjs +0 -5
- package/esm2022/lib/utils/object.utils.mjs +0 -26
- package/lib/date-time/date-time-picker-container.component.d.ts +0 -130
- package/lib/date-time/date-time-picker-input.directive.d.ts +0 -164
- package/lib/date-time/date-time-picker-trigger.directive.d.ts +0 -23
- package/lib/date-time/date-time-picker.animations.d.ts +0 -8
- package/lib/date-time/date-time-picker.component.d.ts +0 -173
- package/lib/date-time/date-time.class.d.ts +0 -103
- package/lib/date-time/numberedFixLen.pipe.d.ts +0 -10
- package/lib/dialog/dialog-config.class.d.ts +0 -169
- package/lib/dialog/dialog-container.component.d.ts +0 -58
- package/lib/dialog/dialog-ref.class.d.ts +0 -51
- package/lib/dialog/dialog.module.d.ts +0 -11
- package/lib/dialog/dialog.service.d.ts +0 -76
- package/lib/utils/index.d.ts +0 -4
- package/lib/utils/object.utils.d.ts +0 -11
|
@@ -1,134 +0,0 @@
|
|
|
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
|
|
39
|
-
.keydownEvents()
|
|
40
|
-
.pipe(filter((event) => event.keyCode === ESCAPE && !this.disableClose))
|
|
41
|
-
.subscribe(() => this.close());
|
|
42
|
-
if (location) {
|
|
43
|
-
this.locationChanged = location.subscribe(() => {
|
|
44
|
-
if (this.container.config.closeOnNavigation) {
|
|
45
|
-
this.close();
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
close(dialogResult) {
|
|
51
|
-
this.result = dialogResult;
|
|
52
|
-
this.container.animationStateChanged
|
|
53
|
-
.pipe(filter((event) => event.phaseName === 'start'), take(1))
|
|
54
|
-
.subscribe(() => {
|
|
55
|
-
this._beforeClose$.next(dialogResult);
|
|
56
|
-
this._beforeClose$.complete();
|
|
57
|
-
this.overlayRef.detachBackdrop();
|
|
58
|
-
});
|
|
59
|
-
this.container.startExitAnimation();
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Gets an observable that emits when the overlay's backdrop has been clicked.
|
|
63
|
-
*/
|
|
64
|
-
backdropClick() {
|
|
65
|
-
return this.overlayRef.backdropClick();
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Gets an observable that emits when keydown events are targeted on the overlay.
|
|
69
|
-
*/
|
|
70
|
-
keydownEvents() {
|
|
71
|
-
return this.overlayRef.keydownEvents();
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Updates the dialog's position.
|
|
75
|
-
* @param position New dialog position.
|
|
76
|
-
*/
|
|
77
|
-
updatePosition(position) {
|
|
78
|
-
const strategy = this.getPositionStrategy();
|
|
79
|
-
if (position && (position.left || position.right)) {
|
|
80
|
-
if (position.left) {
|
|
81
|
-
strategy.left(position.left);
|
|
82
|
-
}
|
|
83
|
-
else {
|
|
84
|
-
strategy.right(position.right);
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
else {
|
|
88
|
-
strategy.centerHorizontally();
|
|
89
|
-
}
|
|
90
|
-
if (position && (position.top || position.bottom)) {
|
|
91
|
-
if (position.top) {
|
|
92
|
-
strategy.top(position.top);
|
|
93
|
-
}
|
|
94
|
-
else {
|
|
95
|
-
strategy.bottom(position.bottom);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
strategy.centerVertically();
|
|
100
|
-
}
|
|
101
|
-
this.overlayRef.updatePosition();
|
|
102
|
-
return this;
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Updates the dialog's width and height.
|
|
106
|
-
* @param width New width of the dialog.
|
|
107
|
-
* @param height New height of the dialog.
|
|
108
|
-
*/
|
|
109
|
-
updateSize(width = 'auto', height = 'auto') {
|
|
110
|
-
this.getPositionStrategy().width(width).height(height);
|
|
111
|
-
this.overlayRef.updatePosition();
|
|
112
|
-
return this;
|
|
113
|
-
}
|
|
114
|
-
isAnimating() {
|
|
115
|
-
return this.container.isAnimating;
|
|
116
|
-
}
|
|
117
|
-
beforeOpen() {
|
|
118
|
-
return this._beforeOpen$.asObservable();
|
|
119
|
-
}
|
|
120
|
-
afterOpen() {
|
|
121
|
-
return this._afterOpen$.asObservable();
|
|
122
|
-
}
|
|
123
|
-
beforeClose() {
|
|
124
|
-
return this._beforeClose$.asObservable();
|
|
125
|
-
}
|
|
126
|
-
afterClosed() {
|
|
127
|
-
return this._afterClosed$.asObservable();
|
|
128
|
-
}
|
|
129
|
-
/** Fetches the position strategy object from the overlay ref. */
|
|
130
|
-
getPositionStrategy() {
|
|
131
|
-
return this.overlayRef.getConfig().positionStrategy;
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
//# 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  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(\n    private overlayRef: OverlayRef,\n    private container: OwlDialogContainerComponent,\n    public readonly id: string,\n    location?: Location\n  ) {\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\n      .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): void {\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      if (position.left) {\n        strategy.left(position.left);\n      } else {\n        strategy.right(position.right);\n      }\n    } else {\n      strategy.centerHorizontally();\n    }\n\n    if (position && (position.top || position.bottom)) {\n      if (position.top) {\n        strategy.top(position.top);\n      } else {\n        strategy.bottom(position.bottom);\n      }\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"]}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* dialog.module
|
|
3
|
-
*/
|
|
4
|
-
import { A11yModule } from '@angular/cdk/a11y';
|
|
5
|
-
import { OverlayModule } from '@angular/cdk/overlay';
|
|
6
|
-
import { PortalModule } from '@angular/cdk/portal';
|
|
7
|
-
import { CommonModule } from '@angular/common';
|
|
8
|
-
import { NgModule } from '@angular/core';
|
|
9
|
-
import { OwlDialogContainerComponent } from './dialog-container.component';
|
|
10
|
-
import { OWL_DIALOG_SCROLL_STRATEGY_PROVIDER, OwlDialogService } from './dialog.service';
|
|
11
|
-
import * as i0 from "@angular/core";
|
|
12
|
-
export class OwlDialogModule {
|
|
13
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
14
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.7", ngImport: i0, type: OwlDialogModule, declarations: [OwlDialogContainerComponent], imports: [CommonModule, A11yModule, OverlayModule, PortalModule] }); }
|
|
15
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDialogModule, providers: [OWL_DIALOG_SCROLL_STRATEGY_PROVIDER, OwlDialogService], imports: [CommonModule, A11yModule, OverlayModule, PortalModule] }); }
|
|
16
|
-
}
|
|
17
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDialogModule, decorators: [{
|
|
18
|
-
type: NgModule,
|
|
19
|
-
args: [{
|
|
20
|
-
imports: [CommonModule, A11yModule, OverlayModule, PortalModule],
|
|
21
|
-
exports: [],
|
|
22
|
-
declarations: [OwlDialogContainerComponent],
|
|
23
|
-
providers: [OWL_DIALOG_SCROLL_STRATEGY_PROVIDER, OwlDialogService]
|
|
24
|
-
}]
|
|
25
|
-
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3BpY2tlci9zcmMvbGliL2RpYWxvZy9kaWFsb2cubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0UsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7O0FBUXpGLE1BQU0sT0FBTyxlQUFlOzhHQUFmLGVBQWU7K0dBQWYsZUFBZSxpQkFIWCwyQkFBMkIsYUFGaEMsWUFBWSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsWUFBWTsrR0FLcEQsZUFBZSxhQUZmLENBQUMsbUNBQW1DLEVBQUUsZ0JBQWdCLENBQUMsWUFIeEQsWUFBWSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsWUFBWTs7MkZBS3BELGVBQWU7a0JBTjNCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsWUFBWSxDQUFDO29CQUNoRSxPQUFPLEVBQUUsRUFBRTtvQkFDWCxZQUFZLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztvQkFDM0MsU0FBUyxFQUFFLENBQUMsbUNBQW1DLEVBQUUsZ0JBQWdCLENBQUM7aUJBQ25FIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBkaWFsb2cubW9kdWxlXG4gKi9cblxuaW1wb3J0IHsgQTExeU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBQb3J0YWxNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT3dsRGlhbG9nQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi9kaWFsb2ctY29udGFpbmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBPV0xfRElBTE9HX1NDUk9MTF9TVFJBVEVHWV9QUk9WSURFUiwgT3dsRGlhbG9nU2VydmljZSB9IGZyb20gJy4vZGlhbG9nLnNlcnZpY2UnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBBMTF5TW9kdWxlLCBPdmVybGF5TW9kdWxlLCBQb3J0YWxNb2R1bGVdLFxuICBleHBvcnRzOiBbXSxcbiAgZGVjbGFyYXRpb25zOiBbT3dsRGlhbG9nQ29udGFpbmVyQ29tcG9uZW50XSxcbiAgcHJvdmlkZXJzOiBbT1dMX0RJQUxPR19TQ1JPTExfU1RSQVRFR1lfUFJPVklERVIsIE93bERpYWxvZ1NlcnZpY2VdXG59KVxuZXhwb3J0IGNsYXNzIE93bERpYWxvZ01vZHVsZSB7fVxuIl19
|
|
@@ -1,228 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* dialog.service
|
|
3
|
-
*/
|
|
4
|
-
import { Overlay, OverlayConfig } from '@angular/cdk/overlay';
|
|
5
|
-
import { ComponentPortal, PortalInjector } from '@angular/cdk/portal';
|
|
6
|
-
import { Inject, Injectable, InjectionToken, Optional, SkipSelf, TemplateRef } from '@angular/core';
|
|
7
|
-
import { Subject, defer } from 'rxjs';
|
|
8
|
-
import { startWith } from 'rxjs/operators';
|
|
9
|
-
import { extendObject } from '../utils';
|
|
10
|
-
import { OwlDialogConfig } from './dialog-config.class';
|
|
11
|
-
import { OwlDialogContainerComponent } from './dialog-container.component';
|
|
12
|
-
import { OwlDialogRef } from './dialog-ref.class';
|
|
13
|
-
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "@angular/cdk/overlay";
|
|
15
|
-
import * as i2 from "@angular/common";
|
|
16
|
-
export const OWL_DIALOG_DATA = new InjectionToken('OwlDialogData');
|
|
17
|
-
/**
|
|
18
|
-
* Injection token that determines the scroll handling while the dialog is open.
|
|
19
|
-
* */
|
|
20
|
-
export const OWL_DIALOG_SCROLL_STRATEGY = new InjectionToken('owl-dialog-scroll-strategy');
|
|
21
|
-
export function OWL_DIALOG_SCROLL_STRATEGY_PROVIDER_FACTORY(overlay) {
|
|
22
|
-
const fn = () => overlay.scrollStrategies.block();
|
|
23
|
-
return fn;
|
|
24
|
-
}
|
|
25
|
-
/** @docs-private */
|
|
26
|
-
export const OWL_DIALOG_SCROLL_STRATEGY_PROVIDER = {
|
|
27
|
-
provide: OWL_DIALOG_SCROLL_STRATEGY,
|
|
28
|
-
deps: [Overlay],
|
|
29
|
-
useFactory: OWL_DIALOG_SCROLL_STRATEGY_PROVIDER_FACTORY
|
|
30
|
-
};
|
|
31
|
-
/**
|
|
32
|
-
* Injection token that can be used to specify default dialog options.
|
|
33
|
-
* */
|
|
34
|
-
export const OWL_DIALOG_DEFAULT_OPTIONS = new InjectionToken('owl-dialog-default-options');
|
|
35
|
-
// eslint-disable-next-line @angular-eslint/use-injectable-provided-in
|
|
36
|
-
export class OwlDialogService {
|
|
37
|
-
/** Keeps track of the currently-open dialogs. */
|
|
38
|
-
get openDialogs() {
|
|
39
|
-
return this.parentDialog ? this.parentDialog.openDialogs : this._openDialogsAtThisLevel;
|
|
40
|
-
}
|
|
41
|
-
/** Stream that emits when a dialog has been opened. */
|
|
42
|
-
get beforeOpen() {
|
|
43
|
-
return this.parentDialog ? this.parentDialog.beforeOpen : this._beforeOpenAtThisLevel;
|
|
44
|
-
}
|
|
45
|
-
/** Stream that emits when a dialog has been opened. */
|
|
46
|
-
get afterOpen() {
|
|
47
|
-
return this.parentDialog ? this.parentDialog.afterOpen : this._afterOpenAtThisLevel;
|
|
48
|
-
}
|
|
49
|
-
get #afterAllClosed() {
|
|
50
|
-
const parent = this.parentDialog;
|
|
51
|
-
return parent ? parent.#afterAllClosed : this._afterAllClosedAtThisLevel;
|
|
52
|
-
}
|
|
53
|
-
constructor(overlay, injector, location, scrollStrategy, defaultOptions, parentDialog, overlayContainer) {
|
|
54
|
-
this.overlay = overlay;
|
|
55
|
-
this.injector = injector;
|
|
56
|
-
this.location = location;
|
|
57
|
-
this.defaultOptions = defaultOptions;
|
|
58
|
-
this.parentDialog = parentDialog;
|
|
59
|
-
this.overlayContainer = overlayContainer;
|
|
60
|
-
this.ariaHiddenElements = new Map();
|
|
61
|
-
this._openDialogsAtThisLevel = [];
|
|
62
|
-
this._beforeOpenAtThisLevel = new Subject();
|
|
63
|
-
this._afterOpenAtThisLevel = new Subject();
|
|
64
|
-
this._afterAllClosedAtThisLevel = new Subject();
|
|
65
|
-
/**
|
|
66
|
-
* Stream that emits when all open dialog have finished closing.
|
|
67
|
-
* Will emit on subscribe if there are no open dialogs to begin with.
|
|
68
|
-
*/
|
|
69
|
-
this.afterAllClosed = defer(() => this._openDialogsAtThisLevel.length ? this.#afterAllClosed : this.#afterAllClosed.pipe(startWith(undefined)));
|
|
70
|
-
this.scrollStrategy = scrollStrategy;
|
|
71
|
-
if (!parentDialog && location) {
|
|
72
|
-
location.subscribe(() => this.closeAll());
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
open(componentOrTemplateRef, config) {
|
|
76
|
-
config = applyConfigDefaults(config, this.defaultOptions);
|
|
77
|
-
if (config.id && this.getDialogById(config.id)) {
|
|
78
|
-
throw Error(`Dialog with id "${config.id}" exists already. The dialog id must be unique.`);
|
|
79
|
-
}
|
|
80
|
-
const overlayRef = this.createOverlay(config);
|
|
81
|
-
const dialogContainer = this.attachDialogContainer(overlayRef, config);
|
|
82
|
-
const dialogRef = this.attachDialogContent(componentOrTemplateRef, dialogContainer, overlayRef, config);
|
|
83
|
-
if (!this.openDialogs.length) {
|
|
84
|
-
this.hideNonDialogContentFromAssistiveTechnology();
|
|
85
|
-
}
|
|
86
|
-
this.openDialogs.push(dialogRef);
|
|
87
|
-
dialogRef.afterClosed().subscribe(() => this.removeOpenDialog(dialogRef));
|
|
88
|
-
this.beforeOpen.next(dialogRef);
|
|
89
|
-
this.afterOpen.next(dialogRef);
|
|
90
|
-
return dialogRef;
|
|
91
|
-
}
|
|
92
|
-
/**
|
|
93
|
-
* Closes all of the currently-open dialogs.
|
|
94
|
-
*/
|
|
95
|
-
closeAll() {
|
|
96
|
-
let i = this.openDialogs.length;
|
|
97
|
-
while (i--) {
|
|
98
|
-
this.openDialogs[i].close();
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
/**
|
|
102
|
-
* Finds an open dialog by its id.
|
|
103
|
-
* @param id ID to use when looking up the dialog.
|
|
104
|
-
*/
|
|
105
|
-
getDialogById(id) {
|
|
106
|
-
return this.openDialogs.find((dialog) => dialog.id === id);
|
|
107
|
-
}
|
|
108
|
-
attachDialogContent(componentOrTemplateRef, dialogContainer, overlayRef, config) {
|
|
109
|
-
const dialogRef = new OwlDialogRef(overlayRef, dialogContainer, config.id, this.location);
|
|
110
|
-
if (config.hasBackdrop) {
|
|
111
|
-
overlayRef.backdropClick().subscribe(() => {
|
|
112
|
-
if (!dialogRef.disableClose) {
|
|
113
|
-
dialogRef.close();
|
|
114
|
-
}
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
if (!(componentOrTemplateRef instanceof TemplateRef)) {
|
|
118
|
-
const injector = this.createInjector(config, dialogRef, dialogContainer);
|
|
119
|
-
const contentRef = dialogContainer.attachComponentPortal(new ComponentPortal(componentOrTemplateRef, undefined, injector));
|
|
120
|
-
dialogRef.componentInstance = contentRef.instance;
|
|
121
|
-
}
|
|
122
|
-
dialogRef.updateSize(config.width, config.height).updatePosition(config.position);
|
|
123
|
-
return dialogRef;
|
|
124
|
-
}
|
|
125
|
-
createInjector(config, dialogRef, dialogContainer) {
|
|
126
|
-
const userInjector = config?.viewContainerRef?.injector;
|
|
127
|
-
const injectionTokens = new WeakMap();
|
|
128
|
-
injectionTokens.set(OwlDialogRef, dialogRef);
|
|
129
|
-
injectionTokens.set(OwlDialogContainerComponent, dialogContainer);
|
|
130
|
-
injectionTokens.set(OWL_DIALOG_DATA, config.data);
|
|
131
|
-
return new PortalInjector(userInjector || this.injector, injectionTokens);
|
|
132
|
-
}
|
|
133
|
-
createOverlay(config) {
|
|
134
|
-
const overlayConfig = this.getOverlayConfig(config);
|
|
135
|
-
return this.overlay.create(overlayConfig);
|
|
136
|
-
}
|
|
137
|
-
attachDialogContainer(overlayRef, config) {
|
|
138
|
-
const containerPortal = new ComponentPortal(OwlDialogContainerComponent, config.viewContainerRef);
|
|
139
|
-
const containerRef = overlayRef.attach(containerPortal);
|
|
140
|
-
containerRef.instance.setConfig(config);
|
|
141
|
-
return containerRef.instance;
|
|
142
|
-
}
|
|
143
|
-
getOverlayConfig(dialogConfig) {
|
|
144
|
-
const state = new OverlayConfig({
|
|
145
|
-
positionStrategy: this.overlay.position().global(),
|
|
146
|
-
scrollStrategy: dialogConfig.scrollStrategy || this.scrollStrategy(),
|
|
147
|
-
panelClass: dialogConfig.paneClass,
|
|
148
|
-
hasBackdrop: dialogConfig.hasBackdrop,
|
|
149
|
-
minWidth: dialogConfig.minWidth,
|
|
150
|
-
minHeight: dialogConfig.minHeight,
|
|
151
|
-
maxWidth: dialogConfig.maxWidth,
|
|
152
|
-
maxHeight: dialogConfig.maxHeight
|
|
153
|
-
});
|
|
154
|
-
if (dialogConfig.backdropClass) {
|
|
155
|
-
state.backdropClass = dialogConfig.backdropClass;
|
|
156
|
-
}
|
|
157
|
-
return state;
|
|
158
|
-
}
|
|
159
|
-
removeOpenDialog(dialogRef) {
|
|
160
|
-
const index = this._openDialogsAtThisLevel.indexOf(dialogRef);
|
|
161
|
-
if (index > -1) {
|
|
162
|
-
this.openDialogs.splice(index, 1);
|
|
163
|
-
// If all the dialogs were closed, remove/restore the `aria-hidden`
|
|
164
|
-
// to a the siblings and emit to the `afterAllClosed` stream.
|
|
165
|
-
if (!this.openDialogs.length) {
|
|
166
|
-
this.ariaHiddenElements.forEach((previousValue, element) => {
|
|
167
|
-
if (previousValue) {
|
|
168
|
-
element.setAttribute('aria-hidden', previousValue);
|
|
169
|
-
}
|
|
170
|
-
else {
|
|
171
|
-
element.removeAttribute('aria-hidden');
|
|
172
|
-
}
|
|
173
|
-
});
|
|
174
|
-
this.ariaHiddenElements.clear();
|
|
175
|
-
this.#afterAllClosed.next();
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
/**
|
|
180
|
-
* Hides all of the content that isn't an overlay from assistive technology.
|
|
181
|
-
*/
|
|
182
|
-
hideNonDialogContentFromAssistiveTechnology() {
|
|
183
|
-
const overlayContainer = this.overlayContainer.getContainerElement();
|
|
184
|
-
// Ensure that the overlay container is attached to the DOM.
|
|
185
|
-
if (overlayContainer.parentElement) {
|
|
186
|
-
const siblings = overlayContainer.parentElement.children;
|
|
187
|
-
for (let i = siblings.length - 1; i > -1; i--) {
|
|
188
|
-
const sibling = siblings[i];
|
|
189
|
-
if (sibling !== overlayContainer &&
|
|
190
|
-
sibling.nodeName !== 'SCRIPT' &&
|
|
191
|
-
sibling.nodeName !== 'STYLE' &&
|
|
192
|
-
!sibling.hasAttribute('aria-live')) {
|
|
193
|
-
this.ariaHiddenElements.set(sibling, sibling.getAttribute('aria-hidden'));
|
|
194
|
-
sibling.setAttribute('aria-hidden', 'true');
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDialogService, deps: [{ token: i1.Overlay }, { token: i0.Injector }, { token: i2.Location, optional: true }, { token: OWL_DIALOG_SCROLL_STRATEGY }, { token: OWL_DIALOG_DEFAULT_OPTIONS, optional: true }, { token: OwlDialogService, optional: true, skipSelf: true }, { token: i1.OverlayContainer }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
200
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDialogService }); }
|
|
201
|
-
}
|
|
202
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDialogService, decorators: [{
|
|
203
|
-
type: Injectable
|
|
204
|
-
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.Injector }, { type: i2.Location, decorators: [{
|
|
205
|
-
type: Optional
|
|
206
|
-
}] }, { type: undefined, decorators: [{
|
|
207
|
-
type: Inject,
|
|
208
|
-
args: [OWL_DIALOG_SCROLL_STRATEGY]
|
|
209
|
-
}] }, { type: undefined, decorators: [{
|
|
210
|
-
type: Optional
|
|
211
|
-
}, {
|
|
212
|
-
type: Inject,
|
|
213
|
-
args: [OWL_DIALOG_DEFAULT_OPTIONS]
|
|
214
|
-
}] }, { type: OwlDialogService, decorators: [{
|
|
215
|
-
type: Optional
|
|
216
|
-
}, {
|
|
217
|
-
type: SkipSelf
|
|
218
|
-
}] }, { type: i1.OverlayContainer }] });
|
|
219
|
-
/**
|
|
220
|
-
* Applies default options to the dialog config.
|
|
221
|
-
* @param config Config to be modified.
|
|
222
|
-
* @param defaultOptions Default config setting
|
|
223
|
-
* @returns The new configuration object.
|
|
224
|
-
*/
|
|
225
|
-
function applyConfigDefaults(config, defaultOptions) {
|
|
226
|
-
return extendObject(new OwlDialogConfig(), config, defaultOptions);
|
|
227
|
-
}
|
|
228
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/dialog/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * dialog.service\n */\n\nimport {\n  BlockScrollStrategy,\n  Overlay,\n  OverlayConfig,\n  OverlayContainer,\n  OverlayRef,\n  ScrollStrategy\n} from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType, PortalInjector } from '@angular/cdk/portal';\nimport { Location } from '@angular/common';\nimport {\n  ComponentRef,\n  Inject,\n  Injectable,\n  InjectionToken,\n  Injector,\n  Optional,\n  SkipSelf,\n  TemplateRef\n} from '@angular/core';\nimport { Observable, Subject, defer } from 'rxjs';\nimport { startWith } from 'rxjs/operators';\nimport { extendObject } from '../utils';\nimport { OwlDialogConfig, OwlDialogConfigInterface } from './dialog-config.class';\nimport { OwlDialogContainerComponent } from './dialog-container.component';\nimport { OwlDialogRef } from './dialog-ref.class';\n\nexport const OWL_DIALOG_DATA = new InjectionToken<any>('OwlDialogData');\n\n/**\n * Injection token that determines the scroll handling while the dialog is open.\n * */\nexport const OWL_DIALOG_SCROLL_STRATEGY = new InjectionToken<() => ScrollStrategy>('owl-dialog-scroll-strategy');\n\nexport function OWL_DIALOG_SCROLL_STRATEGY_PROVIDER_FACTORY(overlay: Overlay): () => ScrollStrategy {\n  const fn = (): BlockScrollStrategy => overlay.scrollStrategies.block();\n  return fn;\n}\n\n/** @docs-private */\nexport const OWL_DIALOG_SCROLL_STRATEGY_PROVIDER = {\n  provide: OWL_DIALOG_SCROLL_STRATEGY,\n  deps: [Overlay],\n  useFactory: OWL_DIALOG_SCROLL_STRATEGY_PROVIDER_FACTORY\n};\n\n/**\n * Injection token that can be used to specify default dialog options.\n * */\nexport const OWL_DIALOG_DEFAULT_OPTIONS = new InjectionToken<OwlDialogConfig>('owl-dialog-default-options');\n\n// eslint-disable-next-line @angular-eslint/use-injectable-provided-in\n@Injectable()\nexport class OwlDialogService {\n  private ariaHiddenElements = new Map<Element, string | null>();\n\n  private _openDialogsAtThisLevel: Array<OwlDialogRef<any>> = [];\n  private _beforeOpenAtThisLevel = new Subject<OwlDialogRef<any>>();\n  private _afterOpenAtThisLevel = new Subject<OwlDialogRef<any>>();\n  private _afterAllClosedAtThisLevel = new Subject<void>();\n\n  /** Keeps track of the currently-open dialogs. */\n  public get openDialogs(): Array<OwlDialogRef<any>> {\n    return this.parentDialog ? this.parentDialog.openDialogs : this._openDialogsAtThisLevel;\n  }\n\n  /** Stream that emits when a dialog has been opened. */\n  public get beforeOpen(): Subject<OwlDialogRef<any>> {\n    return this.parentDialog ? this.parentDialog.beforeOpen : this._beforeOpenAtThisLevel;\n  }\n\n  /** Stream that emits when a dialog has been opened. */\n  public get afterOpen(): Subject<OwlDialogRef<any>> {\n    return this.parentDialog ? this.parentDialog.afterOpen : this._afterOpenAtThisLevel;\n  }\n\n  get #afterAllClosed(): Subject<void> {\n    const parent = this.parentDialog;\n    return parent ? parent.#afterAllClosed : this._afterAllClosedAtThisLevel;\n  }\n\n  /**\n   * Stream that emits when all open dialog have finished closing.\n   * Will emit on subscribe if there are no open dialogs to begin with.\n   */\n\n  public afterAllClosed: Observable<void> = defer(() =>\n    this._openDialogsAtThisLevel.length ? this.#afterAllClosed : this.#afterAllClosed.pipe(startWith(undefined))\n  );\n\n  private readonly scrollStrategy: () => ScrollStrategy;\n\n  constructor(\n    private overlay: Overlay,\n    private injector: Injector,\n    @Optional() private location: Location,\n    @Inject(OWL_DIALOG_SCROLL_STRATEGY) scrollStrategy: any,\n    @Optional()\n    @Inject(OWL_DIALOG_DEFAULT_OPTIONS)\n    private defaultOptions: OwlDialogConfigInterface,\n    @Optional()\n    @SkipSelf()\n    private parentDialog: OwlDialogService,\n    private overlayContainer: OverlayContainer\n  ) {\n    this.scrollStrategy = scrollStrategy;\n    if (!parentDialog && location) {\n      location.subscribe(() => this.closeAll());\n    }\n  }\n\n  public open<T>(\n    componentOrTemplateRef: ComponentType<T> | TemplateRef<T>,\n    config?: OwlDialogConfigInterface\n  ): OwlDialogRef<any> {\n    config = applyConfigDefaults(config, this.defaultOptions);\n\n    if (config.id && this.getDialogById(config.id)) {\n      throw Error(`Dialog with id \"${config.id}\" exists already. The dialog id must be unique.`);\n    }\n\n    const overlayRef = this.createOverlay(config);\n    const dialogContainer = this.attachDialogContainer(overlayRef, config);\n    const dialogRef = this.attachDialogContent<T>(componentOrTemplateRef, dialogContainer, overlayRef, config);\n\n    if (!this.openDialogs.length) {\n      this.hideNonDialogContentFromAssistiveTechnology();\n    }\n\n    this.openDialogs.push(dialogRef);\n    dialogRef.afterClosed().subscribe(() => this.removeOpenDialog(dialogRef));\n    this.beforeOpen.next(dialogRef);\n    this.afterOpen.next(dialogRef);\n    return dialogRef;\n  }\n\n  /**\n   * Closes all of the currently-open dialogs.\n   */\n  public closeAll(): void {\n    let i = this.openDialogs.length;\n\n    while (i--) {\n      this.openDialogs[i].close();\n    }\n  }\n\n  /**\n   * Finds an open dialog by its id.\n   * @param id ID to use when looking up the dialog.\n   */\n  public getDialogById(id: string): OwlDialogRef<any> | undefined {\n    return this.openDialogs.find((dialog) => dialog.id === id);\n  }\n\n  private attachDialogContent<T>(\n    componentOrTemplateRef: ComponentType<T> | TemplateRef<T>,\n    dialogContainer: OwlDialogContainerComponent,\n    overlayRef: OverlayRef,\n    config: OwlDialogConfigInterface\n  ): OwlDialogRef<T> {\n    const dialogRef = new OwlDialogRef<T>(overlayRef, dialogContainer, config.id, this.location);\n\n    if (config.hasBackdrop) {\n      overlayRef.backdropClick().subscribe(() => {\n        if (!dialogRef.disableClose) {\n          dialogRef.close();\n        }\n      });\n    }\n\n    if (!(componentOrTemplateRef instanceof TemplateRef)) {\n      const injector = this.createInjector<T>(config, dialogRef, dialogContainer);\n      const contentRef = dialogContainer.attachComponentPortal(\n        new ComponentPortal(componentOrTemplateRef, undefined, injector)\n      );\n      dialogRef.componentInstance = contentRef.instance;\n    }\n\n    dialogRef.updateSize(config.width, config.height).updatePosition(config.position);\n\n    return dialogRef;\n  }\n\n  private createInjector<T>(\n    config: OwlDialogConfigInterface,\n    dialogRef: OwlDialogRef<T>,\n    dialogContainer: OwlDialogContainerComponent\n  ): PortalInjector {\n    const userInjector = config?.viewContainerRef?.injector;\n    const injectionTokens = new WeakMap();\n\n    injectionTokens.set(OwlDialogRef, dialogRef);\n    injectionTokens.set(OwlDialogContainerComponent, dialogContainer);\n    injectionTokens.set(OWL_DIALOG_DATA, config.data);\n\n    return new PortalInjector(userInjector || this.injector, injectionTokens);\n  }\n\n  private createOverlay(config: OwlDialogConfigInterface): OverlayRef {\n    const overlayConfig = this.getOverlayConfig(config);\n    return this.overlay.create(overlayConfig);\n  }\n\n  private attachDialogContainer(overlayRef: OverlayRef, config: OwlDialogConfigInterface): OwlDialogContainerComponent {\n    const containerPortal = new ComponentPortal(OwlDialogContainerComponent, config.viewContainerRef);\n    const containerRef: ComponentRef<OwlDialogContainerComponent> = overlayRef.attach(containerPortal);\n    containerRef.instance.setConfig(config);\n\n    return containerRef.instance;\n  }\n\n  private getOverlayConfig(dialogConfig: OwlDialogConfigInterface): OverlayConfig {\n    const state = new OverlayConfig({\n      positionStrategy: this.overlay.position().global(),\n      scrollStrategy: dialogConfig.scrollStrategy || this.scrollStrategy(),\n      panelClass: dialogConfig.paneClass,\n      hasBackdrop: dialogConfig.hasBackdrop,\n      minWidth: dialogConfig.minWidth,\n      minHeight: dialogConfig.minHeight,\n      maxWidth: dialogConfig.maxWidth,\n      maxHeight: dialogConfig.maxHeight\n    });\n\n    if (dialogConfig.backdropClass) {\n      state.backdropClass = dialogConfig.backdropClass;\n    }\n\n    return state;\n  }\n\n  private removeOpenDialog(dialogRef: OwlDialogRef<any>): void {\n    const index = this._openDialogsAtThisLevel.indexOf(dialogRef);\n\n    if (index > -1) {\n      this.openDialogs.splice(index, 1);\n      // If all the dialogs were closed, remove/restore the `aria-hidden`\n      // to a the siblings and emit to the `afterAllClosed` stream.\n      if (!this.openDialogs.length) {\n        this.ariaHiddenElements.forEach((previousValue, element) => {\n          if (previousValue) {\n            element.setAttribute('aria-hidden', previousValue);\n          } else {\n            element.removeAttribute('aria-hidden');\n          }\n        });\n\n        this.ariaHiddenElements.clear();\n        this.#afterAllClosed.next();\n      }\n    }\n  }\n\n  /**\n   * Hides all of the content that isn't an overlay from assistive technology.\n   */\n  private hideNonDialogContentFromAssistiveTechnology(): void {\n    const overlayContainer = this.overlayContainer.getContainerElement();\n\n    // Ensure that the overlay container is attached to the DOM.\n    if (overlayContainer.parentElement) {\n      const siblings = overlayContainer.parentElement.children;\n\n      for (let i = siblings.length - 1; i > -1; i--) {\n        const sibling = siblings[i];\n\n        if (\n          sibling !== overlayContainer &&\n          sibling.nodeName !== 'SCRIPT' &&\n          sibling.nodeName !== 'STYLE' &&\n          !sibling.hasAttribute('aria-live')\n        ) {\n          this.ariaHiddenElements.set(sibling, sibling.getAttribute('aria-hidden'));\n          sibling.setAttribute('aria-hidden', 'true');\n        }\n      }\n    }\n  }\n}\n\n/**\n * Applies default options to the dialog config.\n * @param config Config to be modified.\n * @param defaultOptions Default config setting\n * @returns The new configuration object.\n */\nfunction applyConfigDefaults(\n  config?: OwlDialogConfigInterface,\n  defaultOptions?: OwlDialogConfigInterface\n): OwlDialogConfig {\n  return extendObject(new OwlDialogConfig(), config, defaultOptions);\n}\n"]}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* index
|
|
3
|
-
*/
|
|
4
|
-
export * from './object.utils';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9waWNrZXIvc3JjL2xpYi91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIGluZGV4XG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9vYmplY3QudXRpbHMnO1xuIl19
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* object.utils
|
|
3
|
-
*/
|
|
4
|
-
/**
|
|
5
|
-
* Extends an object with the *enumerable* and *own* properties of one or more source objects,
|
|
6
|
-
* similar to Object.assign.
|
|
7
|
-
*
|
|
8
|
-
* @param dest The object which will have properties copied to it.
|
|
9
|
-
* @param sources The source objects from which properties will be copied.
|
|
10
|
-
*/
|
|
11
|
-
export function extendObject(dest, ...sources) {
|
|
12
|
-
if (dest == null) {
|
|
13
|
-
throw TypeError('Cannot convert undefined or null to object');
|
|
14
|
-
}
|
|
15
|
-
for (const source of sources) {
|
|
16
|
-
if (source != null) {
|
|
17
|
-
for (const key in source) {
|
|
18
|
-
if (Object.hasOwn(source, key)) {
|
|
19
|
-
dest[key] = source[key];
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
return dest;
|
|
25
|
-
}
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2JqZWN0LnV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcGlja2VyL3NyYy9saWIvdXRpbHMvb2JqZWN0LnV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUg7Ozs7OztHQU1HO0FBQ0gsTUFBTSxVQUFVLFlBQVksQ0FBbUIsSUFBTyxFQUFFLEdBQUcsT0FBc0I7SUFDL0UsSUFBSSxJQUFJLElBQUksSUFBSSxFQUFFLENBQUM7UUFDakIsTUFBTSxTQUFTLENBQUMsNENBQTRDLENBQUMsQ0FBQztJQUNoRSxDQUFDO0lBRUQsS0FBSyxNQUFNLE1BQU0sSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUM3QixJQUFJLE1BQU0sSUFBSSxJQUFJLEVBQUUsQ0FBQztZQUNuQixLQUFLLE1BQU0sR0FBRyxJQUFJLE1BQU0sRUFBRSxDQUFDO2dCQUN6QixJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUM7b0JBQy9CLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQzFCLENBQUM7WUFDSCxDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIG9iamVjdC51dGlsc1xuICovXG5cbi8qKlxuICogRXh0ZW5kcyBhbiBvYmplY3Qgd2l0aCB0aGUgKmVudW1lcmFibGUqIGFuZCAqb3duKiBwcm9wZXJ0aWVzIG9mIG9uZSBvciBtb3JlIHNvdXJjZSBvYmplY3RzLFxuICogc2ltaWxhciB0byBPYmplY3QuYXNzaWduLlxuICpcbiAqIEBwYXJhbSBkZXN0IFRoZSBvYmplY3Qgd2hpY2ggd2lsbCBoYXZlIHByb3BlcnRpZXMgY29waWVkIHRvIGl0LlxuICogQHBhcmFtIHNvdXJjZXMgVGhlIHNvdXJjZSBvYmplY3RzIGZyb20gd2hpY2ggcHJvcGVydGllcyB3aWxsIGJlIGNvcGllZC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGV4dGVuZE9iamVjdDxUIGV4dGVuZHMgb2JqZWN0PihkZXN0OiBULCAuLi5zb3VyY2VzOiBBcnJheTxvYmplY3Q+KTogVCB7XG4gIGlmIChkZXN0ID09IG51bGwpIHtcbiAgICB0aHJvdyBUeXBlRXJyb3IoJ0Nhbm5vdCBjb252ZXJ0IHVuZGVmaW5lZCBvciBudWxsIHRvIG9iamVjdCcpO1xuICB9XG5cbiAgZm9yIChjb25zdCBzb3VyY2Ugb2Ygc291cmNlcykge1xuICAgIGlmIChzb3VyY2UgIT0gbnVsbCkge1xuICAgICAgZm9yIChjb25zdCBrZXkgaW4gc291cmNlKSB7XG4gICAgICAgIGlmIChPYmplY3QuaGFzT3duKHNvdXJjZSwga2V5KSkge1xuICAgICAgICAgIGRlc3Rba2V5XSA9IHNvdXJjZVtrZXldO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGRlc3Q7XG59XG4iXX0=
|
|
@@ -1,130 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* date-time-picker-container.component
|
|
3
|
-
*/
|
|
4
|
-
import { AnimationEvent } from '@angular/animations';
|
|
5
|
-
import { AfterContentInit, AfterViewInit, ChangeDetectorRef, ElementRef, OnInit } from '@angular/core';
|
|
6
|
-
import { Observable } from 'rxjs';
|
|
7
|
-
import { DateTimeAdapter } from './adapter/date-time-adapter.class';
|
|
8
|
-
import { OwlCalendarComponent } from './calendar.component';
|
|
9
|
-
import { OwlDateTimeIntl } from './date-time-picker-intl.service';
|
|
10
|
-
import { OwlDateTime, PickerType } from './date-time.class';
|
|
11
|
-
import { OwlTimerComponent } from './timer.component';
|
|
12
|
-
import * as i0 from "@angular/core";
|
|
13
|
-
export declare class OwlDateTimeContainerComponent<T> implements OnInit, AfterContentInit, AfterViewInit {
|
|
14
|
-
private cdRef;
|
|
15
|
-
private elmRef;
|
|
16
|
-
private pickerIntl;
|
|
17
|
-
private dateTimeAdapter;
|
|
18
|
-
calendar: OwlCalendarComponent<T>;
|
|
19
|
-
timer: OwlTimerComponent<T>;
|
|
20
|
-
picker: OwlDateTime<T>;
|
|
21
|
-
activeSelectedIndex: number;
|
|
22
|
-
private retainStartTime;
|
|
23
|
-
private retainEndTime;
|
|
24
|
-
/**
|
|
25
|
-
* Stream emits when try to hide picker
|
|
26
|
-
* */
|
|
27
|
-
private hidePicker$;
|
|
28
|
-
get hidePickerStream(): Observable<any>;
|
|
29
|
-
/**
|
|
30
|
-
* Stream emits when try to confirm the selected value
|
|
31
|
-
* */
|
|
32
|
-
private confirmSelected$;
|
|
33
|
-
get confirmSelectedStream(): Observable<any>;
|
|
34
|
-
private beforePickerOpened$;
|
|
35
|
-
get beforePickerOpenedStream(): Observable<any>;
|
|
36
|
-
private pickerOpened$;
|
|
37
|
-
get pickerOpenedStream(): Observable<any>;
|
|
38
|
-
/**
|
|
39
|
-
* The current picker moment. This determines which time period is shown and which date is
|
|
40
|
-
* highlighted when using keyboard navigation.
|
|
41
|
-
*/
|
|
42
|
-
private _clamPickerMoment;
|
|
43
|
-
get pickerMoment(): T;
|
|
44
|
-
set pickerMoment(value: T);
|
|
45
|
-
get pickerType(): PickerType;
|
|
46
|
-
get cancelLabel(): string;
|
|
47
|
-
get setLabel(): string;
|
|
48
|
-
/**
|
|
49
|
-
* The range 'from' label
|
|
50
|
-
* */
|
|
51
|
-
get fromLabel(): string;
|
|
52
|
-
/**
|
|
53
|
-
* The range 'to' label
|
|
54
|
-
* */
|
|
55
|
-
get toLabel(): string;
|
|
56
|
-
/**
|
|
57
|
-
* The range 'from' formatted value
|
|
58
|
-
* */
|
|
59
|
-
get fromFormattedValue(): string;
|
|
60
|
-
/**
|
|
61
|
-
* The range 'to' formatted value
|
|
62
|
-
* */
|
|
63
|
-
get toFormattedValue(): string;
|
|
64
|
-
/**
|
|
65
|
-
* Cases in which the control buttons show in the picker
|
|
66
|
-
* 1) picker mode is 'dialog'
|
|
67
|
-
* 2) picker type is NOT 'calendar' and the picker mode is NOT 'inline'
|
|
68
|
-
* */
|
|
69
|
-
get showControlButtons(): boolean;
|
|
70
|
-
get containerElm(): HTMLElement;
|
|
71
|
-
get owlDTContainerClass(): boolean;
|
|
72
|
-
get owlDTPopupContainerClass(): boolean;
|
|
73
|
-
get owlDTDialogContainerClass(): boolean;
|
|
74
|
-
get owlDTInlineContainerClass(): boolean;
|
|
75
|
-
get owlDTContainerDisabledClass(): boolean;
|
|
76
|
-
get owlDTContainerId(): string;
|
|
77
|
-
get owlDTContainerAnimation(): any;
|
|
78
|
-
constructor(cdRef: ChangeDetectorRef, elmRef: ElementRef, pickerIntl: OwlDateTimeIntl, dateTimeAdapter: DateTimeAdapter<T>);
|
|
79
|
-
ngOnInit(): void;
|
|
80
|
-
ngAfterContentInit(): void;
|
|
81
|
-
ngAfterViewInit(): void;
|
|
82
|
-
handleContainerAnimationStart(event: AnimationEvent): void;
|
|
83
|
-
handleContainerAnimationDone(event: AnimationEvent): void;
|
|
84
|
-
dateSelected(date: T): void;
|
|
85
|
-
timeSelected(time: T): void;
|
|
86
|
-
/**
|
|
87
|
-
* Handle click on cancel button
|
|
88
|
-
*/
|
|
89
|
-
onCancelClicked(event: any): void;
|
|
90
|
-
/**
|
|
91
|
-
* Handle click on set button
|
|
92
|
-
*/
|
|
93
|
-
onSetClicked(event: any): void;
|
|
94
|
-
/**
|
|
95
|
-
* Handle click on inform radio group
|
|
96
|
-
*/
|
|
97
|
-
handleClickOnInfoGroup(event: any, index: number): void;
|
|
98
|
-
/**
|
|
99
|
-
* Handle click on inform radio group
|
|
100
|
-
*/
|
|
101
|
-
handleKeydownOnInfoGroup(event: any, next: any, index: number): void;
|
|
102
|
-
/**
|
|
103
|
-
* Set the value of activeSelectedIndex
|
|
104
|
-
*/
|
|
105
|
-
private setActiveSelectedIndex;
|
|
106
|
-
private initPicker;
|
|
107
|
-
/**
|
|
108
|
-
* Select calendar date in single mode,
|
|
109
|
-
* it returns null when date is not selected.
|
|
110
|
-
*/
|
|
111
|
-
private dateSelectedInSingleMode;
|
|
112
|
-
/**
|
|
113
|
-
* Select dates in range Mode
|
|
114
|
-
*/
|
|
115
|
-
private dateSelectedInRangeMode;
|
|
116
|
-
/**
|
|
117
|
-
* Update the given calendar date's time and check if it is valid
|
|
118
|
-
* Because the calendar date has 00:00:00 as default time, if the picker type is 'both',
|
|
119
|
-
* we need to update the given calendar date's time before selecting it.
|
|
120
|
-
* if it is valid, return the updated dateTime
|
|
121
|
-
* if it is not valid, return null
|
|
122
|
-
*/
|
|
123
|
-
private updateAndCheckCalendarDate;
|
|
124
|
-
/**
|
|
125
|
-
* Focus to the picker
|
|
126
|
-
* */
|
|
127
|
-
private focusPicker;
|
|
128
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<OwlDateTimeContainerComponent<any>, [null, null, null, { optional: true; }]>;
|
|
129
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<OwlDateTimeContainerComponent<any>, "owl-date-time-container", ["owlDateTimeContainer"], {}, {}, never, never, false, never>;
|
|
130
|
-
}
|