@ng-matero/extensions 14.5.0 → 14.6.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/core/datetime/datetime-adapter.d.ts +1 -1
- package/datetimepicker/_datetimepicker-theme.scss +40 -12
- package/datetimepicker/calendar.d.ts +28 -17
- package/datetimepicker/calendar.scss +73 -91
- package/datetimepicker/clock.d.ts +27 -14
- package/datetimepicker/clock.scss +2 -1
- package/datetimepicker/datetimepicker-content.scss +21 -6
- package/datetimepicker/datetimepicker-intl.d.ts +51 -0
- package/datetimepicker/datetimepicker-module.d.ts +13 -12
- package/datetimepicker/datetimepicker-toggle.d.ts +6 -4
- package/datetimepicker/datetimepicker-types.d.ts +4 -0
- package/datetimepicker/datetimepicker.d.ts +13 -3
- package/datetimepicker/public-api.d.ts +1 -0
- package/datetimepicker/time.d.ts +130 -0
- package/datetimepicker/time.scss +81 -0
- package/esm2020/core/datetime/datetime-adapter.mjs +1 -1
- package/esm2020/datetimepicker/calendar-body.mjs +3 -3
- package/esm2020/datetimepicker/calendar.mjs +81 -33
- package/esm2020/datetimepicker/clock.mjs +96 -45
- package/esm2020/datetimepicker/datetimepicker-intl.mjs +63 -0
- package/esm2020/datetimepicker/datetimepicker-module.mjs +8 -1
- package/esm2020/datetimepicker/datetimepicker-toggle.mjs +9 -6
- package/esm2020/datetimepicker/datetimepicker-types.mjs +1 -1
- package/esm2020/datetimepicker/datetimepicker.mjs +22 -6
- package/esm2020/datetimepicker/public-api.mjs +2 -1
- package/esm2020/datetimepicker/time.mjs +453 -0
- package/esm2020/grid/grid.interface.mjs +1 -1
- package/fesm2015/mtxCore.mjs.map +1 -1
- package/fesm2015/mtxDatetimepicker.mjs +720 -91
- package/fesm2015/mtxDatetimepicker.mjs.map +1 -1
- package/fesm2020/mtxCore.mjs.map +1 -1
- package/fesm2020/mtxDatetimepicker.mjs +715 -91
- package/fesm2020/mtxDatetimepicker.mjs.map +1 -1
- package/grid/grid.interface.d.ts +0 -1
- package/package.json +1 -1
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { AfterContentInit, ChangeDetectorRef, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';
|
|
2
2
|
import { BooleanInput } from '@angular/cdk/coercion';
|
|
3
3
|
import { MatButton } from '@angular/material/button';
|
|
4
|
-
import { MatDatepickerIntl } from '@angular/material/datepicker';
|
|
5
4
|
import { MtxDatetimepicker } from './datetimepicker';
|
|
5
|
+
import { MtxDatetimepickerIntl } from './datetimepicker-intl';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
/** Can be used to override the icon of a `mtxDatetimepickerToggle`. */
|
|
8
8
|
export declare class MtxDatetimepickerToggleIcon {
|
|
@@ -10,13 +10,15 @@ export declare class MtxDatetimepickerToggleIcon {
|
|
|
10
10
|
static ɵdir: i0.ɵɵDirectiveDeclaration<MtxDatetimepickerToggleIcon, "[mtxDatetimepickerToggleIcon]", never, {}, {}, never, never, false>;
|
|
11
11
|
}
|
|
12
12
|
export declare class MtxDatetimepickerToggle<D> implements AfterContentInit, OnChanges, OnDestroy {
|
|
13
|
-
_intl:
|
|
13
|
+
_intl: MtxDatetimepickerIntl;
|
|
14
14
|
private _changeDetectorRef;
|
|
15
15
|
private _stateChanges;
|
|
16
16
|
/** Datetimepicker instance that the button will toggle. */
|
|
17
17
|
datetimepicker: MtxDatetimepicker<D>;
|
|
18
18
|
/** Tabindex for the toggle. */
|
|
19
19
|
tabIndex: number;
|
|
20
|
+
/** Screen-reader label for the button. */
|
|
21
|
+
ariaLabel?: string;
|
|
20
22
|
/** Whether the toggle button is disabled. */
|
|
21
23
|
get disabled(): boolean;
|
|
22
24
|
set disabled(value: boolean);
|
|
@@ -27,7 +29,7 @@ export declare class MtxDatetimepickerToggle<D> implements AfterContentInit, OnC
|
|
|
27
29
|
_customIcon: MtxDatetimepickerToggleIcon;
|
|
28
30
|
/** Underlying button element. */
|
|
29
31
|
_button: MatButton;
|
|
30
|
-
constructor(_intl:
|
|
32
|
+
constructor(_intl: MtxDatetimepickerIntl, _changeDetectorRef: ChangeDetectorRef);
|
|
31
33
|
ngOnChanges(changes: SimpleChanges): void;
|
|
32
34
|
ngOnDestroy(): void;
|
|
33
35
|
ngAfterContentInit(): void;
|
|
@@ -36,5 +38,5 @@ export declare class MtxDatetimepickerToggle<D> implements AfterContentInit, OnC
|
|
|
36
38
|
static ngAcceptInputType_disabled: BooleanInput;
|
|
37
39
|
static ngAcceptInputType_disableRipple: BooleanInput;
|
|
38
40
|
static ɵfac: i0.ɵɵFactoryDeclaration<MtxDatetimepickerToggle<any>, never>;
|
|
39
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<MtxDatetimepickerToggle<any>, "mtx-datetimepicker-toggle", ["mtxDatetimepickerToggle"], { "datetimepicker": "for"; "tabIndex": "tabIndex"; "disabled": "disabled"; "disableRipple": "disableRipple"; }, {}, ["_customIcon"], ["[mtxDatetimepickerToggleIcon]"], false>;
|
|
41
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MtxDatetimepickerToggle<any>, "mtx-datetimepicker-toggle", ["mtxDatetimepickerToggle"], { "datetimepicker": "for"; "tabIndex": "tabIndex"; "ariaLabel": "aria-label"; "disabled": "disabled"; "disableRipple": "disableRipple"; }, {}, ["_customIcon"], ["[mtxDatetimepickerToggleIcon]"], false>;
|
|
40
42
|
}
|
|
@@ -1,2 +1,6 @@
|
|
|
1
1
|
/** Possible types for datetimepicker. */
|
|
2
2
|
export declare type MtxDatetimepickerType = 'date' | 'time' | 'month' | 'year' | 'datetime';
|
|
3
|
+
/** Possible views for datetimepicker calendar. */
|
|
4
|
+
export declare type MtxCalendarView = 'clock' | 'month' | 'year' | 'multi-year';
|
|
5
|
+
/** Possible types for AM / PM */
|
|
6
|
+
export declare type MtxAMPM = 'AM' | 'PM';
|
|
@@ -5,10 +5,10 @@ import { Overlay, ScrollStrategy } from '@angular/cdk/overlay';
|
|
|
5
5
|
import { CanColor, ThemePalette } from '@angular/material/core';
|
|
6
6
|
import { Subject } from 'rxjs';
|
|
7
7
|
import { DatetimeAdapter } from '@ng-matero/extensions/core';
|
|
8
|
-
import {
|
|
8
|
+
import { MtxCalendar } from './calendar';
|
|
9
9
|
import { MtxDatetimepickerFilterType } from './datetimepicker-filtertype';
|
|
10
10
|
import { MtxDatetimepickerInput } from './datetimepicker-input';
|
|
11
|
-
import { MtxDatetimepickerType } from './datetimepicker-types';
|
|
11
|
+
import { MtxCalendarView, MtxDatetimepickerType } from './datetimepicker-types';
|
|
12
12
|
import * as i0 from "@angular/core";
|
|
13
13
|
/** Possible modes for datetimepicker dropdown display. */
|
|
14
14
|
export declare type MtxDatetimepickerMode = 'auto' | 'portrait' | 'landscape';
|
|
@@ -47,6 +47,8 @@ export declare class MtxDatetimepickerContent<D> extends _MtxDatetimepickerConte
|
|
|
47
47
|
_animationState: 'enter-dropdown' | 'enter-dialog' | 'void';
|
|
48
48
|
/** Emits when an animation has finished. */
|
|
49
49
|
readonly _animationDone: Subject<void>;
|
|
50
|
+
/** Id of the label for the `role="dialog"` element. */
|
|
51
|
+
_dialogLabelId: string | null;
|
|
50
52
|
constructor(elementRef: ElementRef, _changeDetectorRef: ChangeDetectorRef);
|
|
51
53
|
ngOnInit(): void;
|
|
52
54
|
ngAfterContentInit(): void;
|
|
@@ -137,6 +139,13 @@ export declare class MtxDatetimepicker<D> implements OnDestroy {
|
|
|
137
139
|
get touchUi(): boolean;
|
|
138
140
|
set touchUi(value: boolean);
|
|
139
141
|
private _touchUi;
|
|
142
|
+
/**
|
|
143
|
+
* Whether the calendar is in time mode. In time mode the calendar clock gets time input
|
|
144
|
+
* elements rather then just clock. When `touchUi` is enabled this will be disabled.
|
|
145
|
+
*/
|
|
146
|
+
get timeInput(): boolean;
|
|
147
|
+
set timeInput(value: boolean);
|
|
148
|
+
private _timeInput;
|
|
140
149
|
/** Whether the datetimepicker pop-up should be disabled. */
|
|
141
150
|
get disabled(): boolean;
|
|
142
151
|
set disabled(value: boolean);
|
|
@@ -199,8 +208,9 @@ export declare class MtxDatetimepicker<D> implements OnDestroy {
|
|
|
199
208
|
static ngAcceptInputType_disabled: BooleanInput;
|
|
200
209
|
static ngAcceptInputType_opened: BooleanInput;
|
|
201
210
|
static ngAcceptInputType_touchUi: BooleanInput;
|
|
211
|
+
static ngAcceptInputType_timeInput: BooleanInput;
|
|
202
212
|
static ngAcceptInputType_restoreFocus: BooleanInput;
|
|
203
213
|
static ɵfac: i0.ɵɵFactoryDeclaration<MtxDatetimepicker<any>, [null, null, null, null, { optional: true; }, { optional: true; }]>;
|
|
204
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<MtxDatetimepicker<any>, "mtx-datetimepicker", ["mtxDatetimepicker"], { "multiYearSelector": "multiYearSelector"; "twelvehour": "twelvehour"; "startView": "startView"; "mode": "mode"; "timeInterval": "timeInterval"; "preventSameDateTimeSelection": "preventSameDateTimeSelection"; "panelClass": "panelClass"; "opened": "opened"; "color": "color"; "startAt": "startAt"; "type": "type"; "touchUi": "touchUi"; "disabled": "disabled"; "xPosition": "xPosition"; "yPosition": "yPosition"; "restoreFocus": "restoreFocus"; }, { "selectedChanged": "selectedChanged"; "openedStream": "opened"; "closedStream": "closed"; "viewChanged": "viewChanged"; }, never, never, false>;
|
|
214
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MtxDatetimepicker<any>, "mtx-datetimepicker", ["mtxDatetimepicker"], { "multiYearSelector": "multiYearSelector"; "twelvehour": "twelvehour"; "startView": "startView"; "mode": "mode"; "timeInterval": "timeInterval"; "preventSameDateTimeSelection": "preventSameDateTimeSelection"; "panelClass": "panelClass"; "opened": "opened"; "color": "color"; "startAt": "startAt"; "type": "type"; "touchUi": "touchUi"; "timeInput": "timeInput"; "disabled": "disabled"; "xPosition": "xPosition"; "yPosition": "yPosition"; "restoreFocus": "restoreFocus"; }, { "selectedChanged": "selectedChanged"; "openedStream": "opened"; "closedStream": "closed"; "viewChanged": "viewChanged"; }, never, never, false>;
|
|
205
215
|
}
|
|
206
216
|
export {};
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { BooleanInput, NumberInput } from '@angular/cdk/coercion';
|
|
2
|
+
import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';
|
|
3
|
+
import { DatetimeAdapter } from '@ng-matero/extensions/core';
|
|
4
|
+
import { SubscriptionLike } from 'rxjs';
|
|
5
|
+
import { MtxClockView } from './clock';
|
|
6
|
+
import { MtxDatetimepickerFilterType } from './datetimepicker-filtertype';
|
|
7
|
+
import { MtxDatetimepickerIntl } from './datetimepicker-intl';
|
|
8
|
+
import { MtxAMPM } from './datetimepicker-types';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export declare class MtxTimeInput implements OnDestroy {
|
|
11
|
+
private element;
|
|
12
|
+
private cdr;
|
|
13
|
+
set timeInterval(value: NumberInput);
|
|
14
|
+
private _interval;
|
|
15
|
+
set timeMin(value: NumberInput);
|
|
16
|
+
private _min;
|
|
17
|
+
set timeMax(value: NumberInput);
|
|
18
|
+
private _max;
|
|
19
|
+
set timeValue(value: NumberInput);
|
|
20
|
+
timeValueChanged: EventEmitter<NumberInput>;
|
|
21
|
+
private _value;
|
|
22
|
+
private keyDownListener;
|
|
23
|
+
private keyPressListener;
|
|
24
|
+
private inputEventListener;
|
|
25
|
+
constructor(element: ElementRef, cdr: ChangeDetectorRef);
|
|
26
|
+
get hasFocus(): any;
|
|
27
|
+
get inputElement(): HTMLInputElement;
|
|
28
|
+
get valid(): boolean;
|
|
29
|
+
get invalid(): boolean;
|
|
30
|
+
blur(): void;
|
|
31
|
+
focus(): void;
|
|
32
|
+
/**
|
|
33
|
+
* Write value to inputElement
|
|
34
|
+
* @param value NumberInput
|
|
35
|
+
*/
|
|
36
|
+
writeValue(value: NumberInput): void;
|
|
37
|
+
/**
|
|
38
|
+
* Writes value to placeholder
|
|
39
|
+
* @param value NumberInput
|
|
40
|
+
*/
|
|
41
|
+
writePlaceholder(value: NumberInput): void;
|
|
42
|
+
keyDownHandler(event: KeyboardEvent): void;
|
|
43
|
+
/**
|
|
44
|
+
* Prevent non number inputs in the inputElement with the exception of Enter/BackSpace
|
|
45
|
+
* @param event KeyboardEvent
|
|
46
|
+
*/
|
|
47
|
+
keyPressHandler(event: KeyboardEvent): void;
|
|
48
|
+
inputChangedHandler(): void;
|
|
49
|
+
clampInputValue(): void;
|
|
50
|
+
/**
|
|
51
|
+
* Remove event listeners on destruction
|
|
52
|
+
*/
|
|
53
|
+
ngOnDestroy(): void;
|
|
54
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<MtxTimeInput, never>;
|
|
55
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<MtxTimeInput, "input.mtx-time-input", ["mtxTimeInput"], { "timeInterval": "timeInterval"; "timeMin": "timeMin"; "timeMax": "timeMax"; "timeValue": "timeValue"; }, { "timeValueChanged": "timeValueChanged"; }, never, never, false>;
|
|
56
|
+
}
|
|
57
|
+
export declare class MtxTime<D> implements OnChanges, AfterViewInit, OnDestroy {
|
|
58
|
+
private _adapter;
|
|
59
|
+
private _changeDetectorRef;
|
|
60
|
+
protected _datetimepickerIntl: MtxDatetimepickerIntl;
|
|
61
|
+
/** Emits when the currently selected date changes. */
|
|
62
|
+
readonly selectedChange: EventEmitter<D>;
|
|
63
|
+
/** Emits when any date changes. */
|
|
64
|
+
readonly activeDateChange: EventEmitter<D>;
|
|
65
|
+
/** Emits when any date is selected. */
|
|
66
|
+
readonly _userSelection: EventEmitter<void>;
|
|
67
|
+
/** Emits when AM/PM button are clicked. */
|
|
68
|
+
readonly ampmChange: EventEmitter<MtxAMPM>;
|
|
69
|
+
/** Emits when AM/PM button are clicked. */
|
|
70
|
+
readonly clockViewChange: EventEmitter<MtxClockView>;
|
|
71
|
+
/** A function used to filter which dates are selectable. */
|
|
72
|
+
dateFilter: (date: D, type: MtxDatetimepickerFilterType) => boolean;
|
|
73
|
+
/** Step over minutes. */
|
|
74
|
+
interval: number;
|
|
75
|
+
protected hourInputElement: ElementRef<HTMLInputElement> | undefined;
|
|
76
|
+
protected hourInputDirective: MtxTimeInput | undefined;
|
|
77
|
+
protected minuteInputElement: ElementRef<HTMLInputElement> | undefined;
|
|
78
|
+
protected minuteInputDirective: MtxTimeInput | undefined;
|
|
79
|
+
datetimepickerIntlChangesSubscription: SubscriptionLike;
|
|
80
|
+
/** Whether the clock uses 12 hour format. */
|
|
81
|
+
get twelvehour(): boolean;
|
|
82
|
+
set twelvehour(value: boolean);
|
|
83
|
+
private _twelvehour;
|
|
84
|
+
/** Whether the time is now in AM or PM. */
|
|
85
|
+
AMPM: MtxAMPM;
|
|
86
|
+
/**
|
|
87
|
+
* The date to display in this clock view.
|
|
88
|
+
*/
|
|
89
|
+
get activeDate(): D;
|
|
90
|
+
set activeDate(value: D);
|
|
91
|
+
private _activeDate;
|
|
92
|
+
/** The currently selected date. */
|
|
93
|
+
get selected(): D | null;
|
|
94
|
+
set selected(value: D | null);
|
|
95
|
+
private _selected;
|
|
96
|
+
/** The minimum selectable date. */
|
|
97
|
+
get minDate(): D | null;
|
|
98
|
+
set minDate(value: D | null);
|
|
99
|
+
private _minDate;
|
|
100
|
+
/** The maximum selectable date. */
|
|
101
|
+
get maxDate(): D | null;
|
|
102
|
+
set maxDate(value: D | null);
|
|
103
|
+
private _maxDate;
|
|
104
|
+
/** Whether the clock should be started in hour or minute view. */
|
|
105
|
+
get clockView(): MtxClockView;
|
|
106
|
+
set clockView(value: MtxClockView);
|
|
107
|
+
/** Whether the clock is in hour view. */
|
|
108
|
+
private _clockView;
|
|
109
|
+
get isHourView(): boolean;
|
|
110
|
+
get isMinuteView(): boolean;
|
|
111
|
+
get hour(): string;
|
|
112
|
+
get minute(): string;
|
|
113
|
+
prefixWithZero(value: number): string;
|
|
114
|
+
constructor(_adapter: DatetimeAdapter<D>, _changeDetectorRef: ChangeDetectorRef, _datetimepickerIntl: MtxDatetimepickerIntl);
|
|
115
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
116
|
+
ngAfterViewInit(): void;
|
|
117
|
+
focusInputElement(): void;
|
|
118
|
+
handleHourInputChange(value: NumberInput): void;
|
|
119
|
+
updateHourForAmPm(value: number): number;
|
|
120
|
+
handleMinuteInputChange(value: NumberInput): void;
|
|
121
|
+
handleFocus(clockView: MtxClockView): void;
|
|
122
|
+
_timeSelected(date: D): void;
|
|
123
|
+
_onActiveDateChange(date: D): void;
|
|
124
|
+
handleOk(): void;
|
|
125
|
+
handleCancel(): void;
|
|
126
|
+
ngOnDestroy(): void;
|
|
127
|
+
static ngAcceptInputType_twelvehour: BooleanInput;
|
|
128
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<MtxTime<any>, never>;
|
|
129
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MtxTime<any>, "mtx-time", ["mtxTime"], { "dateFilter": "dateFilter"; "interval": "interval"; "twelvehour": "twelvehour"; "AMPM": "AMPM"; "activeDate": "activeDate"; "selected": "selected"; "minDate": "minDate"; "maxDate": "maxDate"; "clockView": "clockView"; }, { "selectedChange": "selectedChange"; "activeDateChange": "activeDateChange"; "_userSelection": "_userSelection"; "ampmChange": "ampmChange"; "clockViewChange": "clockViewChange"; }, never, never, false>;
|
|
130
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
$time-font-size: 36px;
|
|
2
|
+
$time-border-radius: 8px;
|
|
3
|
+
$time-input-width: 72px;
|
|
4
|
+
$time-input-height: 56px;
|
|
5
|
+
$time-seperator-width: 24px;
|
|
6
|
+
$time-ampm-width: 40px;
|
|
7
|
+
|
|
8
|
+
.mtx-time {
|
|
9
|
+
display: block;
|
|
10
|
+
outline: none;
|
|
11
|
+
user-select: none;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.mtx-time-input-wrapper {
|
|
15
|
+
padding: 8px 0;
|
|
16
|
+
text-align: center;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.mtx-time-input-inner {
|
|
20
|
+
display: inline-flex;
|
|
21
|
+
height: $time-input-height;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.mtx-time-input {
|
|
25
|
+
box-sizing: border-box;
|
|
26
|
+
width: $time-input-width;
|
|
27
|
+
height: 100%;
|
|
28
|
+
padding: 0;
|
|
29
|
+
font-size: $time-font-size;
|
|
30
|
+
text-align: center;
|
|
31
|
+
border-radius: $time-border-radius;
|
|
32
|
+
border: 2px solid transparent;
|
|
33
|
+
appearance: none;
|
|
34
|
+
outline: none;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.mtx-time-seperator {
|
|
38
|
+
display: inline-flex;
|
|
39
|
+
justify-content: center;
|
|
40
|
+
align-items: center;
|
|
41
|
+
width: $time-seperator-width;
|
|
42
|
+
font-size: $time-font-size;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// AM/PM buttons
|
|
46
|
+
.mtx-time-ampm {
|
|
47
|
+
display: inline-flex;
|
|
48
|
+
flex-direction: column;
|
|
49
|
+
margin-left: 12px;
|
|
50
|
+
|
|
51
|
+
[dir='rtl'] & {
|
|
52
|
+
margin-left: auto;
|
|
53
|
+
margin-right: 12px;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
.mtx-time-am,
|
|
57
|
+
.mtx-time-pm {
|
|
58
|
+
flex: 1;
|
|
59
|
+
width: $time-ampm-width;
|
|
60
|
+
min-width: auto;
|
|
61
|
+
padding: 0;
|
|
62
|
+
line-height: normal;
|
|
63
|
+
border-width: 1px;
|
|
64
|
+
border-style: solid;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
.mtx-time-am {
|
|
68
|
+
border-radius: $time-border-radius $time-border-radius 0 0;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
.mtx-time-pm {
|
|
72
|
+
border-radius: 0 0 $time-border-radius $time-border-radius;
|
|
73
|
+
border-top: none;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
.mtx-time-button-wrapper {
|
|
78
|
+
display: flex;
|
|
79
|
+
justify-content: flex-end;
|
|
80
|
+
padding-top: 8px;
|
|
81
|
+
}
|
|
@@ -129,4 +129,4 @@ export class DatetimeAdapter extends DateAdapter {
|
|
|
129
129
|
return date;
|
|
130
130
|
}
|
|
131
131
|
}
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-adapter.js","sourceRoot":"","sources":["../../../../../projects/extensions/core/datetime/datetime-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,MAAM,OAAgB,eAAmB,SAAQ,WAAc;IAC7D,YAAsB,SAAyB;QAC7C,KAAK,EAAE,CAAC;QADY,cAAS,GAAT,SAAS,CAAgB;IAE/C,CAAC;IA0BD,kBAAkB,CAAC,GAAQ;QACzB,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;IACpE,CAAC;IAED,eAAe,CAAC,KAAQ,EAAE,MAAS,EAAE,oBAA6B,IAAI;QACpE,OAAO,CACL,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,MAAM,CAAC;YAC/B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;YAC1C,CAAC,iBAAiB,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CACtE,CAAC;IACJ,CAAC;IAED,YAAY,CAAC,KAAe,EAAE,MAAgB;QAC5C,IAAI,KAAK,IAAI,MAAM,EAAE;YACnB,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACvC,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YACzC,IAAI,UAAU,IAAI,WAAW,EAAE;gBAC7B,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aAC7C;YACD,OAAO,UAAU,KAAK,WAAW,CAAC;SACnC;QACD,OAAO,KAAK,KAAK,MAAM,CAAC;IAC1B,CAAC;IAED,QAAQ,CAAC,KAAQ,EAAE,MAAS;QAC1B,OAAO,KAAK,IAAI,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACzE,CAAC;IAED,OAAO,CAAC,KAAQ,EAAE,MAAS;QACzB,OAAO,CACL,KAAK;YACL,MAAM;YACN,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;YAC5C,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,MAAM,CAAC,CACrC,CAAC;IACJ,CAAC;IAED,QAAQ,CAAC,KAAQ,EAAE,MAAS;QAC1B,OAAO,CACL,KAAK,IAAI,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAC/F,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,KAAQ,EAAE,MAAS;QAC5B,OAAO,CACL,KAAK;YACL,MAAM;YACN,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;YAChD,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,CAC7B,CAAC;IACJ,CAAC;IAED,gBAAgB,CAAC,KAAe,EAAE,MAAgB;QAChD,IAAI,KAAK,IAAI,MAAM,EAAE;YACnB,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACvC,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YACzC,IAAI,UAAU,IAAI,WAAW,EAAE;gBAC7B,OAAO,CAAC,CACN,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAC3F,CAAC;aACH;YACD,OAAO,UAAU,KAAK,WAAW,CAAC;SACnC;QACD,OAAO,KAAK,KAAK,MAAM,CAAC;IAC1B,CAAC;IAED,WAAW;IACX,KAAK,CAAC,IAAO;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,gBAAgB,CAAC,IAAO,EAAE,KAAa;QACrC,OAAO,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACtD,CAAC;IAED,iBAAiB,CAAC,IAAO,EAAE,MAAc;QACvC,OAAO,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IACxD,CAAC;IAED,eAAe,CAAC,IAAO,EAAE,IAAY;QACnC,OAAO,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACpD,CAAC;IAED,OAAO,CAAC,IAAO;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,QAAQ,CAAC,IAAO;QACd,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,OAAO,CAAC,IAAO;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,YAAY,CAAC,IAAO;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAC3C,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,OAAO,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;IACvC,CAAC;IAED,iBAAiB,CAAC,KAAU;QAC1B,OAAO,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC;IAED,WAAW,CAAC,IAAO;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,SAAS,CAAC,iBAAiB,EAAE,CAAC;IAC5C,CAAC;IAED,iBAAiB,CAAC,IAAO;QACvB,OAAO,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAChD,CAAC;IAED,UAAU,CAAC,IAAY,EAAE,KAAa,EAAE,IAAY;QAClD,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,KAAK;QACH,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,KAAU,EAAE,WAAgB;QAChC,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IAClD,CAAC;IAED,MAAM,CAAC,IAAO,EAAE,aAAkB;QAChC,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC;IACpD,CAAC;IAED,SAAS,CAAC,IAAO;QACf,OAAO,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACxC,CAAC;IAED,cAAc,CAAC,GAAQ;QACrB,OAAO,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,CAAC,IAAO;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;IAED,SAAS,CAAC,IAAO,EAAE,GAAc,EAAE,GAAc;QAC/C,IAAI,GAAG,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE;YAC9C,OAAO,GAAG,CAAC;SACZ;QACD,IAAI,GAAG,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE;YAC9C,OAAO,GAAG,CAAC;SACZ;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF","sourcesContent":["import { DateAdapter } from '@angular/material/core';\n\nexport abstract class DatetimeAdapter<D> extends DateAdapter<D> {\n  constructor(protected _delegate: DateAdapter<D>) {\n    super();\n  }\n\n  abstract getHour(date: D): number;\n\n  abstract getMinute(date: D): number;\n\n  abstract getFirstDateOfMonth(date: D): D;\n\n  abstract isInNextMonth(startDate: D, endDate: D): boolean;\n\n  abstract getHourNames(): string[];\n\n  abstract getMinuteNames(): string[];\n\n  abstract addCalendarHours(date: D, months: number): D;\n\n  abstract addCalendarMinutes(date: D, months: number): D;\n\n  abstract createDatetime(\n    year: number,\n    month: number,\n    date: number,\n    hour: number,\n    minute: number\n  ): D;\n\n  getValidDateOrNull(obj: any): D | null {\n    return this.isDateInstance(obj) && this.isValid(obj) ? obj : null;\n  }\n\n  compareDatetime(first: D, second: D, respectMinutePart: boolean = true): number | boolean {\n    return (\n      this.compareDate(first, second) ||\n      this.getHour(first) - this.getHour(second) ||\n      (respectMinutePart && this.getMinute(first) - this.getMinute(second))\n    );\n  }\n\n  sameDatetime(first: D | null, second: D | null): boolean {\n    if (first && second) {\n      const firstValid = this.isValid(first);\n      const secondValid = this.isValid(second);\n      if (firstValid && secondValid) {\n        return !this.compareDatetime(first, second);\n      }\n      return firstValid === secondValid;\n    }\n    return first === second;\n  }\n\n  sameYear(first: D, second: D) {\n    return first && second && this.getYear(first) === this.getYear(second);\n  }\n\n  sameDay(first: D, second: D) {\n    return (\n      first &&\n      second &&\n      this.getDate(first) === this.getDate(second) &&\n      this.sameMonthAndYear(first, second)\n    );\n  }\n\n  sameHour(first: D, second: D) {\n    return (\n      first && second && this.getHour(first) === this.getHour(second) && this.sameDay(first, second)\n    );\n  }\n\n  sameMinute(first: D, second: D) {\n    return (\n      first &&\n      second &&\n      this.getMinute(first) === this.getMinute(second) &&\n      this.sameHour(first, second)\n    );\n  }\n\n  sameMonthAndYear(first: D | null, second: D | null): boolean {\n    if (first && second) {\n      const firstValid = this.isValid(first);\n      const secondValid = this.isValid(second);\n      if (firstValid && secondValid) {\n        return !(\n          this.getYear(first) - this.getYear(second) || this.getMonth(first) - this.getMonth(second)\n        );\n      }\n      return firstValid === secondValid;\n    }\n    return first === second;\n  }\n\n  // delegate\n  clone(date: D): D {\n    return this._delegate.clone(date);\n  }\n\n  addCalendarYears(date: D, years: number): D {\n    return this._delegate.addCalendarYears(date, years);\n  }\n\n  addCalendarMonths(date: D, months: number): D {\n    return this._delegate.addCalendarMonths(date, months);\n  }\n\n  addCalendarDays(date: D, days: number): D {\n    return this._delegate.addCalendarDays(date, days);\n  }\n\n  getYear(date: D): number {\n    return this._delegate.getYear(date);\n  }\n\n  getMonth(date: D): number {\n    return this._delegate.getMonth(date);\n  }\n\n  getDate(date: D): number {\n    return this._delegate.getDate(date);\n  }\n\n  getDayOfWeek(date: D): number {\n    return this._delegate.getDayOfWeek(date);\n  }\n\n  getMonthNames(style: any): string[] {\n    return this._delegate.getMonthNames(style);\n  }\n\n  getDateNames(): string[] {\n    return this._delegate.getDateNames();\n  }\n\n  getDayOfWeekNames(style: any): string[] {\n    return this._delegate.getDayOfWeekNames(style);\n  }\n\n  getYearName(date: D): string {\n    return this._delegate.getYearName(date);\n  }\n\n  getFirstDayOfWeek(): number {\n    return this._delegate.getFirstDayOfWeek();\n  }\n\n  getNumDaysInMonth(date: D): number {\n    return this._delegate.getNumDaysInMonth(date);\n  }\n\n  createDate(year: number, month: number, date: number): D {\n    return this._delegate.createDate(year, month, date);\n  }\n\n  today(): D {\n    return this._delegate.today();\n  }\n\n  parse(value: any, parseFormat: any): D | null {\n    return this._delegate.parse(value, parseFormat);\n  }\n\n  format(date: D, displayFormat: any): string {\n    return this._delegate.format(date, displayFormat);\n  }\n\n  toIso8601(date: D): string {\n    return this._delegate.toIso8601(date);\n  }\n\n  isDateInstance(obj: any): boolean {\n    return this._delegate.isDateInstance(obj);\n  }\n\n  isValid(date: D): boolean {\n    return this._delegate.isValid(date);\n  }\n\n  invalid(): D {\n    return this._delegate.invalid();\n  }\n\n  clampDate(date: D, min?: D | null, max?: D | null): D {\n    if (min && this.compareDatetime(date, min) < 0) {\n      return min;\n    }\n    if (max && this.compareDatetime(date, max) > 0) {\n      return max;\n    }\n    return date;\n  }\n}\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-adapter.js","sourceRoot":"","sources":["../../../../../projects/extensions/core/datetime/datetime-adapter.ts"],"names":[],"mappings":"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","sourcesContent":["import { DateAdapter } from '@angular/material/core';\n\nexport abstract class DatetimeAdapter<D> extends DateAdapter<D> {\n  constructor(protected _delegate: DateAdapter<D>) {\n    super();\n  }\n\n  abstract getHour(date: D): number;\n\n  abstract getMinute(date: D): number;\n\n  abstract getFirstDateOfMonth(date: D): D;\n\n  abstract isInNextMonth(startDate: D, endDate: D): boolean;\n\n  abstract getHourNames(): string[];\n\n  abstract getMinuteNames(): string[];\n\n  abstract addCalendarHours(date: D, months: number): D;\n\n  abstract addCalendarMinutes(date: D, minutes: number): D;\n\n  abstract createDatetime(\n    year: number,\n    month: number,\n    date: number,\n    hour: number,\n    minute: number\n  ): D;\n\n  getValidDateOrNull(obj: any): D | null {\n    return this.isDateInstance(obj) && this.isValid(obj) ? obj : null;\n  }\n\n  compareDatetime(first: D, second: D, respectMinutePart: boolean = true): number | boolean {\n    return (\n      this.compareDate(first, second) ||\n      this.getHour(first) - this.getHour(second) ||\n      (respectMinutePart && this.getMinute(first) - this.getMinute(second))\n    );\n  }\n\n  sameDatetime(first: D | null, second: D | null): boolean {\n    if (first && second) {\n      const firstValid = this.isValid(first);\n      const secondValid = this.isValid(second);\n      if (firstValid && secondValid) {\n        return !this.compareDatetime(first, second);\n      }\n      return firstValid === secondValid;\n    }\n    return first === second;\n  }\n\n  sameYear(first: D, second: D) {\n    return first && second && this.getYear(first) === this.getYear(second);\n  }\n\n  sameDay(first: D, second: D) {\n    return (\n      first &&\n      second &&\n      this.getDate(first) === this.getDate(second) &&\n      this.sameMonthAndYear(first, second)\n    );\n  }\n\n  sameHour(first: D, second: D) {\n    return (\n      first && second && this.getHour(first) === this.getHour(second) && this.sameDay(first, second)\n    );\n  }\n\n  sameMinute(first: D, second: D) {\n    return (\n      first &&\n      second &&\n      this.getMinute(first) === this.getMinute(second) &&\n      this.sameHour(first, second)\n    );\n  }\n\n  sameMonthAndYear(first: D | null, second: D | null): boolean {\n    if (first && second) {\n      const firstValid = this.isValid(first);\n      const secondValid = this.isValid(second);\n      if (firstValid && secondValid) {\n        return !(\n          this.getYear(first) - this.getYear(second) || this.getMonth(first) - this.getMonth(second)\n        );\n      }\n      return firstValid === secondValid;\n    }\n    return first === second;\n  }\n\n  // delegate\n  clone(date: D): D {\n    return this._delegate.clone(date);\n  }\n\n  addCalendarYears(date: D, years: number): D {\n    return this._delegate.addCalendarYears(date, years);\n  }\n\n  addCalendarMonths(date: D, months: number): D {\n    return this._delegate.addCalendarMonths(date, months);\n  }\n\n  addCalendarDays(date: D, days: number): D {\n    return this._delegate.addCalendarDays(date, days);\n  }\n\n  getYear(date: D): number {\n    return this._delegate.getYear(date);\n  }\n\n  getMonth(date: D): number {\n    return this._delegate.getMonth(date);\n  }\n\n  getDate(date: D): number {\n    return this._delegate.getDate(date);\n  }\n\n  getDayOfWeek(date: D): number {\n    return this._delegate.getDayOfWeek(date);\n  }\n\n  getMonthNames(style: any): string[] {\n    return this._delegate.getMonthNames(style);\n  }\n\n  getDateNames(): string[] {\n    return this._delegate.getDateNames();\n  }\n\n  getDayOfWeekNames(style: any): string[] {\n    return this._delegate.getDayOfWeekNames(style);\n  }\n\n  getYearName(date: D): string {\n    return this._delegate.getYearName(date);\n  }\n\n  getFirstDayOfWeek(): number {\n    return this._delegate.getFirstDayOfWeek();\n  }\n\n  getNumDaysInMonth(date: D): number {\n    return this._delegate.getNumDaysInMonth(date);\n  }\n\n  createDate(year: number, month: number, date: number): D {\n    return this._delegate.createDate(year, month, date);\n  }\n\n  today(): D {\n    return this._delegate.today();\n  }\n\n  parse(value: any, parseFormat: any): D | null {\n    return this._delegate.parse(value, parseFormat);\n  }\n\n  format(date: D, displayFormat: any): string {\n    return this._delegate.format(date, displayFormat);\n  }\n\n  toIso8601(date: D): string {\n    return this._delegate.toIso8601(date);\n  }\n\n  isDateInstance(obj: any): boolean {\n    return this._delegate.isDateInstance(obj);\n  }\n\n  isValid(date: D): boolean {\n    return this._delegate.isValid(date);\n  }\n\n  invalid(): D {\n    return this._delegate.invalid();\n  }\n\n  clampDate(date: D, min?: D | null, max?: D | null): D {\n    if (min && this.compareDatetime(date, min) < 0) {\n      return min;\n    }\n    if (max && this.compareDatetime(date, max) > 0) {\n      return max;\n    }\n    return date;\n  }\n}\n"]}
|
|
@@ -50,12 +50,12 @@ export class MtxCalendarBody {
|
|
|
50
50
|
}
|
|
51
51
|
}
|
|
52
52
|
/** @nocollapse */ MtxCalendarBody.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: MtxCalendarBody, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
-
/** @nocollapse */ MtxCalendarBody.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: MtxCalendarBody, selector: "[mtx-calendar-body]", inputs: { label: "label", rows: "rows", todayValue: "todayValue", selectedValue: "selectedValue", labelMinRequiredCells: "labelMinRequiredCells", numCols: "numCols", allowDisabledSelection: "allowDisabledSelection", activeCell: "activeCell" }, outputs: { selectedValueChange: "selectedValueChange" }, host: { classAttribute: "mtx-calendar-body" }, exportAs: ["mtxCalendarBody"], ngImport: i0, template: "<!--\n If there's not enough space in the first row, create a separate label row. We mark this row as\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n<tr *ngIf=\"_firstRowOffset < labelMinRequiredCells\" aria-hidden=\"true\">\n <td
|
|
53
|
+
/** @nocollapse */ MtxCalendarBody.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: MtxCalendarBody, selector: "[mtx-calendar-body]", inputs: { label: "label", rows: "rows", todayValue: "todayValue", selectedValue: "selectedValue", labelMinRequiredCells: "labelMinRequiredCells", numCols: "numCols", allowDisabledSelection: "allowDisabledSelection", activeCell: "activeCell" }, outputs: { selectedValueChange: "selectedValueChange" }, host: { classAttribute: "mtx-calendar-body" }, exportAs: ["mtxCalendarBody"], ngImport: i0, template: "<!--\n If there's not enough space in the first row, create a separate label row. We mark this row as\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n<tr *ngIf=\"_firstRowOffset < labelMinRequiredCells\" aria-hidden=\"true\">\n <td class=\"mtx-calendar-body-label\" [attr.colspan]=\"numCols\">{{ label }}</td>\n</tr>\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n<tr *ngFor=\"let row of rows; let rowIndex = index\" role=\"row\">\n <!--\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n -->\n <td *ngIf=\"rowIndex === 0 && _firstRowOffset\"\n class=\"mtx-calendar-body-label\" [attr.colspan]=\"_firstRowOffset\" aria-hidden=\"true\">\n {{ _firstRowOffset >= labelMinRequiredCells ? label : '' }}\n </td>\n <td *ngFor=\"let item of row; let colIndex = index\"\n role=\"gridcell\"\n class=\"mtx-calendar-body-cell\"\n [class.mtx-calendar-body-active]=\"_isActiveCell(rowIndex, colIndex)\"\n [class.mtx-calendar-body-disabled]=\"!item.enabled\"\n [tabindex]=\"_isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n [attr.data-mat-row]=\"rowIndex\"\n [attr.data-mat-col]=\"colIndex\"\n [attr.aria-label]=\"item.ariaLabel\"\n [attr.aria-disabled]=\"!item.enabled || null\"\n (click)=\"_cellClicked(item)\">\n <div class=\"mtx-calendar-body-cell-content\"\n [class.mtx-calendar-body-selected]=\"selectedValue === item.value\"\n [class.mtx-calendar-body-today]=\"todayValue === item.value\"\n [attr.aria-selected]=\"selectedValue === item.value\">\n {{ item.displayValue }}\n </div>\n </td>\n</tr>\n", styles: [".mtx-calendar-body{min-width:224px}.mtx-calendar-body-label{height:0;line-height:0;text-align:left;padding:7.1428571429% 4.7142857143%}[dir=rtl] .mtx-calendar-body-label{text-align:right}.mtx-calendar-body-cell{position:relative;width:14.2857142857%;height:0;line-height:0;padding:7.1428571429% 0;text-align:center;outline:none;cursor:pointer}.mtx-calendar-body-disabled{cursor:default;pointer-events:none}.mtx-calendar-body-cell-content{position:absolute;top:5%;left:5%;display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;border:1px solid transparent;border-radius:999px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
54
54
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: MtxCalendarBody, decorators: [{
|
|
55
55
|
type: Component,
|
|
56
56
|
args: [{ selector: '[mtx-calendar-body]', host: {
|
|
57
57
|
class: 'mtx-calendar-body',
|
|
58
|
-
}, exportAs: 'mtxCalendarBody', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--\n If there's not enough space in the first row, create a separate label row. We mark this row as\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n<tr *ngIf=\"_firstRowOffset < labelMinRequiredCells\" aria-hidden=\"true\">\n <td
|
|
58
|
+
}, exportAs: 'mtxCalendarBody', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--\n If there's not enough space in the first row, create a separate label row. We mark this row as\n aria-hidden because we don't want it to be read out as one of the weeks in the month.\n-->\n<tr *ngIf=\"_firstRowOffset < labelMinRequiredCells\" aria-hidden=\"true\">\n <td class=\"mtx-calendar-body-label\" [attr.colspan]=\"numCols\">{{ label }}</td>\n</tr>\n\n<!-- Create the first row separately so we can include a special spacer cell. -->\n<tr *ngFor=\"let row of rows; let rowIndex = index\" role=\"row\">\n <!--\n We mark this cell as aria-hidden so it doesn't get read out as one of the days in the week.\n -->\n <td *ngIf=\"rowIndex === 0 && _firstRowOffset\"\n class=\"mtx-calendar-body-label\" [attr.colspan]=\"_firstRowOffset\" aria-hidden=\"true\">\n {{ _firstRowOffset >= labelMinRequiredCells ? label : '' }}\n </td>\n <td *ngFor=\"let item of row; let colIndex = index\"\n role=\"gridcell\"\n class=\"mtx-calendar-body-cell\"\n [class.mtx-calendar-body-active]=\"_isActiveCell(rowIndex, colIndex)\"\n [class.mtx-calendar-body-disabled]=\"!item.enabled\"\n [tabindex]=\"_isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n [attr.data-mat-row]=\"rowIndex\"\n [attr.data-mat-col]=\"colIndex\"\n [attr.aria-label]=\"item.ariaLabel\"\n [attr.aria-disabled]=\"!item.enabled || null\"\n (click)=\"_cellClicked(item)\">\n <div class=\"mtx-calendar-body-cell-content\"\n [class.mtx-calendar-body-selected]=\"selectedValue === item.value\"\n [class.mtx-calendar-body-today]=\"todayValue === item.value\"\n [attr.aria-selected]=\"selectedValue === item.value\">\n {{ item.displayValue }}\n </div>\n </td>\n</tr>\n", styles: [".mtx-calendar-body{min-width:224px}.mtx-calendar-body-label{height:0;line-height:0;text-align:left;padding:7.1428571429% 4.7142857143%}[dir=rtl] .mtx-calendar-body-label{text-align:right}.mtx-calendar-body-cell{position:relative;width:14.2857142857%;height:0;line-height:0;padding:7.1428571429% 0;text-align:center;outline:none;cursor:pointer}.mtx-calendar-body-disabled{cursor:default;pointer-events:none}.mtx-calendar-body-cell-content{position:absolute;top:5%;left:5%;display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:90%;height:90%;border:1px solid transparent;border-radius:999px}\n"] }]
|
|
59
59
|
}], propDecorators: { label: [{
|
|
60
60
|
type: Input
|
|
61
61
|
}], rows: [{
|
|
@@ -75,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
75
75
|
}], selectedValueChange: [{
|
|
76
76
|
type: Output
|
|
77
77
|
}] } });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItYm9keS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvZGF0ZXRpbWVwaWNrZXIvY2FsZW5kYXItYm9keS50cyIsIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvZGF0ZXRpbWVwaWNrZXIvY2FsZW5kYXItYm9keS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBQ0wsTUFBTSxFQUNOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7O0FBRXZCOzs7R0FHRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBQzFCLFlBQ1MsS0FBYSxFQUNiLFlBQW9CLEVBQ3BCLFNBQWlCLEVBQ2pCLE9BQWdCO1FBSGhCLFVBQUssR0FBTCxLQUFLLENBQVE7UUFDYixpQkFBWSxHQUFaLFlBQVksQ0FBUTtRQUNwQixjQUFTLEdBQVQsU0FBUyxDQUFRO1FBQ2pCLFlBQU8sR0FBUCxPQUFPLENBQVM7SUFDdEIsQ0FBQztDQUNMO0FBRUQ7OztHQUdHO0FBWUgsTUFBTSxPQUFPLGVBQWU7SUFYNUI7UUEyQkUsMENBQTBDO1FBQ2pDLFlBQU8sR0FBRyxDQUFDLENBQUM7UUFFckIsb0RBQW9EO1FBQzNDLDJCQUFzQixHQUFHLEtBQUssQ0FBQztRQUV4Qyx1REFBdUQ7UUFDOUMsZUFBVSxHQUFHLENBQUMsQ0FBQztRQUV4QiwwQ0FBMEM7UUFDaEMsd0JBQW1CLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztLQTBCNUQ7SUF4QkMsMkVBQTJFO0lBQzNFLElBQUksZUFBZTtRQUNqQixPQUFPLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNO1lBQ3pELENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTTtZQUNwQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ1IsQ0FBQztJQUVELFlBQVksQ0FBQyxJQUFxQjtRQUNoQyxJQUFJLENBQUMsSUFBSSxDQUFDLHNCQUFzQixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNqRCxPQUFPO1NBQ1I7UUFDRCxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRUQsYUFBYSxDQUFDLFFBQWdCLEVBQUUsUUFBZ0I7UUFDOUMsSUFBSSxVQUFVLEdBQUcsUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLEdBQUcsUUFBUSxDQUFDO1FBRXBELHNFQUFzRTtRQUN0RSxJQUFJLFFBQVEsRUFBRTtZQUNaLFVBQVUsSUFBSSxJQUFJLENBQUMsZUFBZSxDQUFDO1NBQ3BDO1FBRUQsT0FBTyxVQUFVLEtBQUssSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUN4QyxDQUFDOzsrSEFuRFUsZUFBZTttSEFBZixlQUFlLHNiQ3JDNUIsMnJEQW9DQTsyRkRDYSxlQUFlO2tCQVgzQixTQUFTOytCQUNFLHFCQUFxQixRQUd6Qjt3QkFDSixLQUFLLEVBQUUsbUJBQW1CO3FCQUMzQixZQUNTLGlCQUFpQixpQkFDWixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUl0QyxLQUFLO3NCQUFiLEtBQUs7Z0JBR0csSUFBSTtzQkFBWixLQUFLO2dCQUdHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBR0csYUFBYTtzQkFBckIsS0FBSztnQkFHRyxxQkFBcUI7c0JBQTdCLEtBQUs7Z0JBR0csT0FBTztzQkFBZixLQUFLO2dCQUdHLHNCQUFzQjtzQkFBOUIsS0FBSztnQkFHRyxVQUFVO3NCQUFsQixLQUFLO2dCQUdJLG1CQUFtQjtzQkFBNUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEFuIGludGVybmFsIGNsYXNzIHRoYXQgcmVwcmVzZW50cyB0aGUgZGF0YSBjb3JyZXNwb25kaW5nIHRvIGEgc2luZ2xlIGNhbGVuZGFyIGNlbGwuXG4gKiBAZG9jcy1wcml2YXRlXG4gKi9cbmV4cG9ydCBjbGFzcyBNdHhDYWxlbmRhckNlbGwge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgdmFsdWU6IG51bWJlcixcbiAgICBwdWJsaWMgZGlzcGxheVZhbHVlOiBzdHJpbmcsXG4gICAgcHVibGljIGFyaWFMYWJlbDogc3RyaW5nLFxuICAgIHB1YmxpYyBlbmFibGVkOiBib29sZWFuXG4gICkge31cbn1cblxuLyoqXG4gKiBBbiBpbnRlcm5hbCBjb21wb25lbnQgdXNlZCB0byBkaXNwbGF5IGNhbGVuZGFyIGRhdGEgaW4gYSB0YWJsZS5cbiAqIEBkb2NzLXByaXZhdGVcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnW210eC1jYWxlbmRhci1ib2R5XScsXG4gIHRlbXBsYXRlVXJsOiAnY2FsZW5kYXItYm9keS5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJ2NhbGVuZGFyLWJvZHkuc2NzcyddLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdtdHgtY2FsZW5kYXItYm9keScsXG4gIH0sXG4gIGV4cG9ydEFzOiAnbXR4Q2FsZW5kYXJCb2R5JyxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIE10eENhbGVuZGFyQm9keSB7XG4gIC8qKiBUaGUgbGFiZWwgZm9yIHRoZSB0YWJsZS4gKGUuZy4gXCJKYW4gMjAxN1wiKS4gKi9cbiAgQElucHV0KCkgbGFiZWwhOiBzdHJpbmc7XG5cbiAgLyoqIFRoZSBjZWxscyB0byBkaXNwbGF5IGluIHRoZSB0YWJsZS4gKi9cbiAgQElucHV0KCkgcm93cyE6IE10eENhbGVuZGFyQ2VsbFtdW107XG5cbiAgLyoqIFRoZSB2YWx1ZSBpbiB0aGUgdGFibGUgdGhhdCBjb3JyZXNwb25kcyB0byB0b2RheS4gKi9cbiAgQElucHV0KCkgdG9kYXlWYWx1ZSE6IG51bWJlcjtcblxuICAvKiogVGhlIHZhbHVlIGluIHRoZSB0YWJsZSB0aGF0IGlzIGN1cnJlbnRseSBzZWxlY3RlZC4gKi9cbiAgQElucHV0KCkgc2VsZWN0ZWRWYWx1ZSE6IG51bWJlcjtcblxuICAvKiogVGhlIG1pbmltdW0gbnVtYmVyIG9mIGZyZWUgY2VsbHMgbmVlZGVkIHRvIGZpdCB0aGUgbGFiZWwgaW4gdGhlIGZpcnN0IHJvdy4gKi9cbiAgQElucHV0KCkgbGFiZWxNaW5SZXF1aXJlZENlbGxzITogbnVtYmVyO1xuXG4gIC8qKiBUaGUgbnVtYmVyIG9mIGNvbHVtbnMgaW4gdGhlIHRhYmxlLiAqL1xuICBASW5wdXQoKSBudW1Db2xzID0gNztcblxuICAvKiogV2hldGhlciB0byBhbGxvdyBzZWxlY3Rpb24gb2YgZGlzYWJsZWQgY2VsbHMuICovXG4gIEBJbnB1dCgpIGFsbG93RGlzYWJsZWRTZWxlY3Rpb24gPSBmYWxzZTtcblxuICAvKiogVGhlIGNlbGwgbnVtYmVyIG9mIHRoZSBhY3RpdmUgY2VsbCBpbiB0aGUgdGFibGUuICovXG4gIEBJbnB1dCgpIGFjdGl2ZUNlbGwgPSAwO1xuXG4gIC8qKiBFbWl0cyB3aGVuIGEgbmV3IHZhbHVlIGlzIHNlbGVjdGVkLiAqL1xuICBAT3V0cHV0KCkgc2VsZWN0ZWRWYWx1ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xuXG4gIC8qKiBUaGUgbnVtYmVyIG9mIGJsYW5rIGNlbGxzIHRvIHB1dCBhdCB0aGUgYmVnaW5uaW5nIGZvciB0aGUgZmlyc3Qgcm93LiAqL1xuICBnZXQgX2ZpcnN0Um93T2Zmc2V0KCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMucm93cyAmJiB0aGlzLnJvd3MubGVuZ3RoICYmIHRoaXMucm93c1swXS5sZW5ndGhcbiAgICAgID8gdGhpcy5udW1Db2xzIC0gdGhpcy5yb3dzWzBdLmxlbmd0aFxuICAgICAgOiAwO1xuICB9XG5cbiAgX2NlbGxDbGlja2VkKGNlbGw6IE10eENhbGVuZGFyQ2VsbCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5hbGxvd0Rpc2FibGVkU2VsZWN0aW9uICYmICFjZWxsLmVuYWJsZWQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy5zZWxlY3RlZFZhbHVlQ2hhbmdlLmVtaXQoY2VsbC52YWx1ZSk7XG4gIH1cblxuICBfaXNBY3RpdmVDZWxsKHJvd0luZGV4OiBudW1iZXIsIGNvbEluZGV4OiBudW1iZXIpOiBib29sZWFuIHtcbiAgICBsZXQgY2VsbE51bWJlciA9IHJvd0luZGV4ICogdGhpcy5udW1Db2xzICsgY29sSW5kZXg7XG5cbiAgICAvLyBBY2NvdW50IGZvciB0aGUgZmFjdCB0aGF0IHRoZSBmaXJzdCByb3cgbWF5IG5vdCBoYXZlIGFzIG1hbnkgY2VsbHMuXG4gICAgaWYgKHJvd0luZGV4KSB7XG4gICAgICBjZWxsTnVtYmVyIC09IHRoaXMuX2ZpcnN0Um93T2Zmc2V0O1xuICAgIH1cblxuICAgIHJldHVybiBjZWxsTnVtYmVyID09PSB0aGlzLmFjdGl2ZUNlbGw7XG4gIH1cbn1cbiIsIjwhLS1cbiAgSWYgdGhlcmUncyBub3QgZW5vdWdoIHNwYWNlIGluIHRoZSBmaXJzdCByb3csIGNyZWF0ZSBhIHNlcGFyYXRlIGxhYmVsIHJvdy4gV2UgbWFyayB0aGlzIHJvdyBhc1xuICBhcmlhLWhpZGRlbiBiZWNhdXNlIHdlIGRvbid0IHdhbnQgaXQgdG8gYmUgcmVhZCBvdXQgYXMgb25lIG9mIHRoZSB3ZWVrcyBpbiB0aGUgbW9udGguXG4tLT5cbjx0ciAqbmdJZj1cIl9maXJzdFJvd09mZnNldCA8IGxhYmVsTWluUmVxdWlyZWRDZWxsc1wiIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPlxuICA8dGQgY2xhc3M9XCJtdHgtY2FsZW5kYXItYm9keS1sYWJlbFwiIFthdHRyLmNvbHNwYW5dPVwibnVtQ29sc1wiPnt7IGxhYmVsIH19PC90ZD5cbjwvdHI+XG5cbjwhLS0gQ3JlYXRlIHRoZSBmaXJzdCByb3cgc2VwYXJhdGVseSBzbyB3ZSBjYW4gaW5jbHVkZSBhIHNwZWNpYWwgc3BhY2VyIGNlbGwuIC0tPlxuPHRyICpuZ0Zvcj1cImxldCByb3cgb2Ygcm93czsgbGV0IHJvd0luZGV4ID0gaW5kZXhcIiByb2xlPVwicm93XCI+XG4gIDwhLS1cbiAgICBXZSBtYXJrIHRoaXMgY2VsbCBhcyBhcmlhLWhpZGRlbiBzbyBpdCBkb2Vzbid0IGdldCByZWFkIG91dCBhcyBvbmUgb2YgdGhlIGRheXMgaW4gdGhlIHdlZWsuXG4gIC0tPlxuICA8dGQgKm5nSWY9XCJyb3dJbmRleCA9PT0gMCAmJiBfZmlyc3RSb3dPZmZzZXRcIlxuICAgICAgY2xhc3M9XCJtdHgtY2FsZW5kYXItYm9keS1sYWJlbFwiIFthdHRyLmNvbHNwYW5dPVwiX2ZpcnN0Um93T2Zmc2V0XCIgYXJpYS1oaWRkZW49XCJ0cnVlXCI+XG4gICAge3sgX2ZpcnN0Um93T2Zmc2V0ID49IGxhYmVsTWluUmVxdWlyZWRDZWxscyA/IGxhYmVsIDogJycgfX1cbiAgPC90ZD5cbiAgPHRkICpuZ0Zvcj1cImxldCBpdGVtIG9mIHJvdzsgbGV0IGNvbEluZGV4ID0gaW5kZXhcIlxuICAgICAgcm9sZT1cImdyaWRjZWxsXCJcbiAgICAgIGNsYXNzPVwibXR4LWNhbGVuZGFyLWJvZHktY2VsbFwiXG4gICAgICBbY2xhc3MubXR4LWNhbGVuZGFyLWJvZHktYWN0aXZlXT1cIl9pc0FjdGl2ZUNlbGwocm93SW5kZXgsIGNvbEluZGV4KVwiXG4gICAgICBbY2xhc3MubXR4LWNhbGVuZGFyLWJvZHktZGlzYWJsZWRdPVwiIWl0ZW0uZW5hYmxlZFwiXG4gICAgICBbdGFiaW5kZXhdPVwiX2lzQWN0aXZlQ2VsbChyb3dJbmRleCwgY29sSW5kZXgpID8gMCA6IC0xXCJcbiAgICAgIFthdHRyLmRhdGEtbWF0LXJvd109XCJyb3dJbmRleFwiXG4gICAgICBbYXR0ci5kYXRhLW1hdC1jb2xdPVwiY29sSW5kZXhcIlxuICAgICAgW2F0dHIuYXJpYS1sYWJlbF09XCJpdGVtLmFyaWFMYWJlbFwiXG4gICAgICBbYXR0ci5hcmlhLWRpc2FibGVkXT1cIiFpdGVtLmVuYWJsZWQgfHwgbnVsbFwiXG4gICAgICAoY2xpY2spPVwiX2NlbGxDbGlja2VkKGl0ZW0pXCI+XG4gICAgPGRpdiBjbGFzcz1cIm10eC1jYWxlbmRhci1ib2R5LWNlbGwtY29udGVudFwiXG4gICAgICAgICBbY2xhc3MubXR4LWNhbGVuZGFyLWJvZHktc2VsZWN0ZWRdPVwic2VsZWN0ZWRWYWx1ZSA9PT0gaXRlbS52YWx1ZVwiXG4gICAgICAgICBbY2xhc3MubXR4LWNhbGVuZGFyLWJvZHktdG9kYXldPVwidG9kYXlWYWx1ZSA9PT0gaXRlbS52YWx1ZVwiXG4gICAgICAgICBbYXR0ci5hcmlhLXNlbGVjdGVkXT1cInNlbGVjdGVkVmFsdWUgPT09IGl0ZW0udmFsdWVcIj5cbiAgICAgIHt7IGl0ZW0uZGlzcGxheVZhbHVlIH19XG4gICAgPC9kaXY+XG4gIDwvdGQ+XG48L3RyPlxuIl19
|