@dereekb/dbx-form 9.24.3 → 9.24.5
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/LICENSE +1 -1
- package/calendar/lib/calendar.schedule.selection.component.d.ts +20 -6
- package/calendar/lib/calendar.schedule.selection.store.d.ts +18 -4
- package/esm2020/calendar/lib/calendar.schedule.selection.component.mjs +57 -32
- package/esm2020/calendar/lib/calendar.schedule.selection.dialog.component.mjs +3 -3
- package/esm2020/calendar/lib/calendar.schedule.selection.store.mjs +72 -31
- package/fesm2015/dereekb-dbx-form-calendar.mjs +129 -64
- package/fesm2015/dereekb-dbx-form-calendar.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-form-calendar.mjs +129 -64
- package/fesm2020/dereekb-dbx-form-calendar.mjs.map +1 -1
- package/mapbox/package.json +4 -4
- package/package.json +4 -4
package/LICENSE
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { EventEmitter, OnDestroy, OnInit } from '@angular/core';
|
|
2
|
-
import { CalendarEvent, CalendarMonthViewBeforeRenderEvent } from 'angular-calendar';
|
|
2
|
+
import { CalendarEvent, CalendarMonthViewBeforeRenderEvent, CalendarMonthViewDay } from 'angular-calendar';
|
|
3
3
|
import { Subject, Observable } from 'rxjs';
|
|
4
4
|
import { DbxCalendarEvent, DbxCalendarStore } from '@dereekb/dbx-web/calendar';
|
|
5
5
|
import { Maybe } from '@dereekb/util';
|
|
6
|
-
import { DbxCalendarScheduleSelectionStore } from './calendar.schedule.selection.store';
|
|
6
|
+
import { CalendarScheduleSelectionState, DbxCalendarScheduleSelectionStore } from './calendar.schedule.selection.store';
|
|
7
|
+
import { CalendarScheduleSelectionMetadata } from './calendar.schedule.selection';
|
|
7
8
|
import { DbxInjectionComponentConfig } from '@dereekb/dbx-core';
|
|
8
|
-
import { ObservableOrValueGetter } from '@dereekb/rxjs';
|
|
9
|
+
import { ObservableOrValue, ObservableOrValueGetter } from '@dereekb/rxjs';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
export interface DbxScheduleSelectionCalendarComponentConfig {
|
|
11
12
|
/**
|
|
@@ -16,7 +17,19 @@ export interface DbxScheduleSelectionCalendarComponentConfig {
|
|
|
16
17
|
* Configuration for displaying a custom selection button. When null/undefined/true is passed, will show the default DbxScheduleSelectionCalendarDatePopoverButtonComponent.
|
|
17
18
|
*/
|
|
18
19
|
readonly buttonInjectionConfig?: Maybe<ObservableOrValueGetter<Maybe<DbxInjectionComponentConfig<any> | boolean>>>;
|
|
20
|
+
/**
|
|
21
|
+
* Customize day function. When a new function is piped through the calendar is refreshed.
|
|
22
|
+
*/
|
|
23
|
+
readonly customizeDay?: Maybe<ObservableOrValue<Maybe<DbxScheduleSelectionCalendarBeforeMonthViewRenderModifyDayFunction>>>;
|
|
24
|
+
/**
|
|
25
|
+
* Optional full control over the beforeMonthViewRender
|
|
26
|
+
*/
|
|
27
|
+
readonly beforeMonthViewRenderFunctionFactory?: Maybe<ObservableOrValue<DbxScheduleSelectionCalendarBeforeMonthViewRenderFunctionFactory>>;
|
|
19
28
|
}
|
|
29
|
+
export declare type DbxScheduleSelectionCalendarBeforeMonthViewRenderModifyDayFunction = (viewDay: CalendarMonthViewDay<CalendarScheduleSelectionMetadata>, state: CalendarScheduleSelectionState) => void;
|
|
30
|
+
export declare type DbxScheduleSelectionCalendarBeforeMonthViewRenderFunction = (renderEvent: CalendarMonthViewBeforeRenderEvent) => void;
|
|
31
|
+
export declare type DbxScheduleSelectionCalendarBeforeMonthViewRenderFunctionFactory = (state: Observable<CalendarScheduleSelectionState>) => DbxScheduleSelectionCalendarBeforeMonthViewRenderFunction;
|
|
32
|
+
export declare function dbxScheduleSelectionCalendarBeforeMonthViewRenderFactory(inputModifyFn?: Maybe<DbxScheduleSelectionCalendarBeforeMonthViewRenderModifyDayFunction>): DbxScheduleSelectionCalendarBeforeMonthViewRenderFunctionFactory;
|
|
20
33
|
export declare class DbxScheduleSelectionCalendarComponent<T> implements OnInit, OnDestroy {
|
|
21
34
|
readonly calendarStore: DbxCalendarStore<T>;
|
|
22
35
|
readonly dbxCalendarScheduleSelectionStore: DbxCalendarScheduleSelectionStore;
|
|
@@ -24,15 +37,16 @@ export declare class DbxScheduleSelectionCalendarComponent<T> implements OnInit,
|
|
|
24
37
|
readonly showClearSelectionButton$: Observable<boolean>;
|
|
25
38
|
readonly datePopoverButtonInjectionConfig$: Observable<Maybe<DbxInjectionComponentConfig<any>>>;
|
|
26
39
|
clickEvent: EventEmitter<DbxCalendarEvent<T>>;
|
|
27
|
-
readonly state$: Observable<
|
|
40
|
+
readonly state$: Observable<CalendarScheduleSelectionState>;
|
|
41
|
+
readonly beforeMonthViewRender$: Observable<DbxScheduleSelectionCalendarBeforeMonthViewRenderFunction>;
|
|
28
42
|
readonly refresh$: Subject<undefined>;
|
|
29
43
|
readonly events$: Observable<CalendarEvent<any>[]>;
|
|
30
44
|
readonly viewDate$: Observable<Date>;
|
|
31
45
|
constructor(calendarStore: DbxCalendarStore<T>, dbxCalendarScheduleSelectionStore: DbxCalendarScheduleSelectionStore);
|
|
32
46
|
ngOnInit(): void;
|
|
33
47
|
ngOnDestroy(): void;
|
|
34
|
-
get config(): DbxScheduleSelectionCalendarComponentConfig
|
|
35
|
-
set config(config: DbxScheduleSelectionCalendarComponentConfig);
|
|
48
|
+
get config(): Maybe<DbxScheduleSelectionCalendarComponentConfig>;
|
|
49
|
+
set config(config: Maybe<DbxScheduleSelectionCalendarComponentConfig>);
|
|
36
50
|
dayClicked({ date }: {
|
|
37
51
|
date: Date;
|
|
38
52
|
}): void;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { DateBlockDayOfWeekFactory, DateBlockIndex, DateBlockRangeWithRange, DateOrDateBlockIndex, DateRange, DateScheduleDateFilterConfig, DateScheduleDayCode, DateScheduleRange, DateTimingRelativeIndexFactory, DateOrDateRangeOrDateBlockIndexOrDateBlockRange, DateTimezoneUtcNormalInstance } from '@dereekb/date';
|
|
1
|
+
import { DateBlockDayOfWeekFactory, DateBlockIndex, DateBlockRangeWithRange, DateOrDateBlockIndex, DateRange, DateScheduleDateFilterConfig, DateScheduleDayCode, DateScheduleRange, DateTimingRelativeIndexFactory, DateOrDateRangeOrDateBlockIndexOrDateBlockRange, DateTimezoneUtcNormalInstance, DateBlock, DateBlockDurationSpan } from '@dereekb/date';
|
|
2
2
|
import { Maybe, TimezoneString, DecisionFunction, IterableOrValue, MaybeMap, DayOfWeek, AllOrNoneSelection, ArrayOrValue } from '@dereekb/util';
|
|
3
3
|
import { ComponentStore } from '@ngrx/component-store';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
@@ -53,7 +53,7 @@ export interface CalendarScheduleSelectionState extends PartialCalendarScheduleS
|
|
|
53
53
|
*/
|
|
54
54
|
indexFactory: DateTimingRelativeIndexFactory;
|
|
55
55
|
/**
|
|
56
|
-
* Array of manually selected dates.
|
|
56
|
+
* Array of manually selected dates within the picked range. This is NOT the set of all selected indexes in terms of output.
|
|
57
57
|
*
|
|
58
58
|
* Values that exist outside of the "input" range are considered toggled on, while those
|
|
59
59
|
* that are selected within the range are considered toggled off.
|
|
@@ -63,7 +63,7 @@ export interface CalendarScheduleSelectionState extends PartialCalendarScheduleS
|
|
|
63
63
|
*
|
|
64
64
|
* These indexes are relative to the start date.
|
|
65
65
|
*/
|
|
66
|
-
|
|
66
|
+
toggledIndexes: Set<DateBlockIndex>;
|
|
67
67
|
/**
|
|
68
68
|
* Days of the schedule that are allowed to be picked.
|
|
69
69
|
*/
|
|
@@ -122,6 +122,9 @@ export declare class DbxCalendarScheduleSelectionStore extends ComponentStore<Ca
|
|
|
122
122
|
readonly inputEnd$: Observable<Maybe<Date>>;
|
|
123
123
|
readonly currentInputRange$: Observable<Maybe<CalendarScheduleSelectionInputDateRange>>;
|
|
124
124
|
readonly inputRange$: Observable<CalendarScheduleSelectionInputDateRange>;
|
|
125
|
+
/**
|
|
126
|
+
* @deprecated This is not the same as the current selection value. This is the set of manually togged off dates. It will be removed in a future update.
|
|
127
|
+
*/
|
|
125
128
|
readonly selectedDates$: Observable<Set<DateBlockIndex>>;
|
|
126
129
|
readonly isEnabledFilterDayFunction$: Observable<DecisionFunction<DateOrDateBlockIndex>>;
|
|
127
130
|
readonly isEnabledDayFunction$: Observable<DecisionFunction<DateOrDateBlockIndex>>;
|
|
@@ -134,9 +137,13 @@ export declare class DbxCalendarScheduleSelectionStore extends ComponentStore<Ca
|
|
|
134
137
|
readonly effectiveTimezone$: Observable<Maybe<TimezoneString>>;
|
|
135
138
|
readonly effectiveTimezoneNormal$: Observable<DateTimezoneUtcNormalInstance | undefined>;
|
|
136
139
|
readonly currentSelectionValue$: Observable<Maybe<CalendarScheduleSelectionValue>>;
|
|
140
|
+
readonly currentSelectionValueDateBlockDurationSpan$: Observable<DateBlockDurationSpan<DateBlock>[]>;
|
|
141
|
+
readonly selectionValueSelectedIndexes$: Observable<Set<DateBlockIndex>>;
|
|
142
|
+
readonly selectionValue$: Observable<CalendarScheduleSelectionValue>;
|
|
137
143
|
readonly currentSelectionValueWithTimezone$: Observable<Maybe<CalendarScheduleSelectionValue>>;
|
|
144
|
+
readonly selectionValueWithTimezone$: Observable<CalendarScheduleSelectionValue>;
|
|
145
|
+
readonly selectionValueWithTimezoneDateBlockDurationSpan$: Observable<DateBlockDurationSpan<DateBlock>[]>;
|
|
138
146
|
readonly nextToggleSelection$: Observable<Maybe<AllOrNoneSelection>>;
|
|
139
|
-
readonly selectionValue$: Observable<CalendarScheduleSelectionValue>;
|
|
140
147
|
readonly currentDateScheduleRangeValue$: Observable<Maybe<DateScheduleRange>>;
|
|
141
148
|
readonly dateScheduleRangeValue$: Observable<DateScheduleRange>;
|
|
142
149
|
readonly cellContentFactory$: Observable<CalendarScheduleSelectionCellContentFactory>;
|
|
@@ -152,6 +159,7 @@ export declare class DbxCalendarScheduleSelectionStore extends ComponentStore<Ca
|
|
|
152
159
|
readonly addSelectedDates: (observableOrValue: IterableOrValue<DateOrDateBlockIndex> | Observable<IterableOrValue<DateOrDateBlockIndex>>) => import("rxjs").Subscription;
|
|
153
160
|
readonly removeSelectedDates: (observableOrValue: IterableOrValue<DateOrDateBlockIndex> | Observable<IterableOrValue<DateOrDateBlockIndex>>) => import("rxjs").Subscription;
|
|
154
161
|
readonly setSelectedDates: (observableOrValue: IterableOrValue<DateOrDateBlockIndex> | Observable<IterableOrValue<DateOrDateBlockIndex>>) => import("rxjs").Subscription;
|
|
162
|
+
readonly setSelectedIndexes: (observableOrValue: IterableOrValue<DateOrDateBlockIndex> | Observable<IterableOrValue<DateOrDateBlockIndex>>) => import("rxjs").Subscription;
|
|
155
163
|
readonly selectAllDates: (observableOrValue: AllOrNoneSelection | Observable<AllOrNoneSelection>) => import("rxjs").Subscription;
|
|
156
164
|
readonly setInitialSelectionState: (() => void) | ((observableOrValue: Maybe<AllOrNoneSelection> | Observable<Maybe<AllOrNoneSelection>>) => import("rxjs").Subscription);
|
|
157
165
|
readonly setScheduleDays: (() => void) | ((observableOrValue: Maybe<Iterable<DateScheduleDayCode>> | Observable<Maybe<Iterable<DateScheduleDayCode>>>) => import("rxjs").Subscription);
|
|
@@ -176,6 +184,12 @@ export interface CalendarScheduleSelectionStateDatesChange {
|
|
|
176
184
|
remove?: IterableOrValue<DateOrDateBlockIndex>;
|
|
177
185
|
set?: IterableOrValue<DateOrDateBlockIndex>;
|
|
178
186
|
selectAll?: AllOrNoneSelection;
|
|
187
|
+
/**
|
|
188
|
+
* Inverts the set date changing behavior so that the set input is treated as items that should be retained instead of excluded.
|
|
189
|
+
*
|
|
190
|
+
* Ignored when set is not used. Ignored for selectAll.
|
|
191
|
+
*/
|
|
192
|
+
invertSetBehavior?: boolean;
|
|
179
193
|
}
|
|
180
194
|
export declare function updateStateWithChangedDates(state: CalendarScheduleSelectionState, change: CalendarScheduleSelectionStateDatesChange): CalendarScheduleSelectionState;
|
|
181
195
|
export declare function noSelectionCalendarScheduleSelectionState(state: CalendarScheduleSelectionState): CalendarScheduleSelectionState;
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { Component, EventEmitter, Output, Input } from '@angular/core';
|
|
2
|
-
import { map, shareReplay, first, throttleTime, BehaviorSubject, distinctUntilChanged } from 'rxjs';
|
|
2
|
+
import { map, shareReplay, first, throttleTime, BehaviorSubject, distinctUntilChanged, combineLatest, switchMap } from 'rxjs';
|
|
3
3
|
import { DbxCalendarStore, prepareAndSortCalendarEvents } from '@dereekb/dbx-web/calendar';
|
|
4
4
|
import { DbxCalendarScheduleSelectionStore } from './calendar.schedule.selection.store';
|
|
5
5
|
import { CalendarScheduleSelectionDayState } from './calendar.schedule.selection';
|
|
6
6
|
import { switchMapDbxInjectionComponentConfig } from '@dereekb/dbx-core';
|
|
7
|
+
import { asObservable } from '@dereekb/rxjs';
|
|
7
8
|
import { DbxScheduleSelectionCalendarDatePopoverButtonComponent } from './calendar.schedule.selection.popover.button.component';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@dereekb/dbx-web/calendar";
|
|
@@ -14,6 +15,46 @@ import * as i5 from "@dereekb/dbx-web";
|
|
|
14
15
|
import * as i6 from "angular-calendar";
|
|
15
16
|
import * as i7 from "./calendar.schedule.selection.cell.component";
|
|
16
17
|
import * as i8 from "./calendar.schedule.selection.toggle.button.component";
|
|
18
|
+
export function dbxScheduleSelectionCalendarBeforeMonthViewRenderFactory(inputModifyFn) {
|
|
19
|
+
const modifyFn = inputModifyFn || (() => { });
|
|
20
|
+
return (state$) => {
|
|
21
|
+
return (renderEvent) => {
|
|
22
|
+
const { body } = renderEvent;
|
|
23
|
+
// use latest/current state
|
|
24
|
+
state$.pipe(first()).subscribe((calendarScheduleState) => {
|
|
25
|
+
const { isEnabledDay, indexFactory, isEnabledFilterDay, allowedDaysOfWeek } = calendarScheduleState;
|
|
26
|
+
body.forEach((viewDay) => {
|
|
27
|
+
const { date } = viewDay;
|
|
28
|
+
const i = indexFactory(date);
|
|
29
|
+
const day = date.getDay();
|
|
30
|
+
let state;
|
|
31
|
+
if (!isEnabledFilterDay(i)) {
|
|
32
|
+
viewDay.cssClass = 'cal-day-not-applicable';
|
|
33
|
+
state = CalendarScheduleSelectionDayState.NOT_APPLICABLE;
|
|
34
|
+
}
|
|
35
|
+
else if (!allowedDaysOfWeek.has(day)) {
|
|
36
|
+
viewDay.cssClass = 'cal-day-disabled';
|
|
37
|
+
state = CalendarScheduleSelectionDayState.DISABLED;
|
|
38
|
+
}
|
|
39
|
+
else if (isEnabledDay(i)) {
|
|
40
|
+
viewDay.cssClass = 'cal-day-selected';
|
|
41
|
+
state = CalendarScheduleSelectionDayState.SELECTED;
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
viewDay.cssClass = 'cal-day-not-selected';
|
|
45
|
+
state = CalendarScheduleSelectionDayState.NOT_SELECTED;
|
|
46
|
+
}
|
|
47
|
+
const meta = {
|
|
48
|
+
state,
|
|
49
|
+
i
|
|
50
|
+
};
|
|
51
|
+
viewDay.meta = meta;
|
|
52
|
+
modifyFn(viewDay, calendarScheduleState);
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
}
|
|
17
58
|
export class DbxScheduleSelectionCalendarComponent {
|
|
18
59
|
constructor(calendarStore, dbxCalendarScheduleSelectionStore) {
|
|
19
60
|
this.calendarStore = calendarStore;
|
|
@@ -24,7 +65,17 @@ export class DbxScheduleSelectionCalendarComponent {
|
|
|
24
65
|
this.clickEvent = new EventEmitter();
|
|
25
66
|
// refresh any time the selected day function updates
|
|
26
67
|
this.state$ = this.dbxCalendarScheduleSelectionStore.state$;
|
|
27
|
-
this.
|
|
68
|
+
this.beforeMonthViewRender$ = this._config.pipe(switchMap((x) => {
|
|
69
|
+
let factory;
|
|
70
|
+
if (x.beforeMonthViewRenderFunctionFactory) {
|
|
71
|
+
factory = asObservable(x.beforeMonthViewRenderFunctionFactory);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
factory = asObservable(x.customizeDay).pipe(map((x) => dbxScheduleSelectionCalendarBeforeMonthViewRenderFactory(x)));
|
|
75
|
+
}
|
|
76
|
+
return factory.pipe(map((x) => x(this.state$)));
|
|
77
|
+
}), shareReplay(1));
|
|
78
|
+
this.refresh$ = combineLatest([this.state$, this.beforeMonthViewRender$]).pipe(throttleTime(100), map(() => undefined));
|
|
28
79
|
this.events$ = this.calendarStore.visibleEvents$.pipe(map(prepareAndSortCalendarEvents), shareReplay(1));
|
|
29
80
|
this.viewDate$ = this.calendarStore.date$;
|
|
30
81
|
}
|
|
@@ -40,7 +91,7 @@ export class DbxScheduleSelectionCalendarComponent {
|
|
|
40
91
|
return this._config.value;
|
|
41
92
|
}
|
|
42
93
|
set config(config) {
|
|
43
|
-
this._config.next(config);
|
|
94
|
+
this._config.next(config ?? {});
|
|
44
95
|
}
|
|
45
96
|
dayClicked({ date }) {
|
|
46
97
|
this.dbxCalendarScheduleSelectionStore.toggleSelectedDates(date);
|
|
@@ -49,34 +100,8 @@ export class DbxScheduleSelectionCalendarComponent {
|
|
|
49
100
|
this.clickEvent.emit({ action, event });
|
|
50
101
|
}
|
|
51
102
|
beforeMonthViewRender(renderEvent) {
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
body.forEach((viewDay) => {
|
|
55
|
-
const { date } = viewDay;
|
|
56
|
-
const i = indexFactory(date);
|
|
57
|
-
const day = date.getDay();
|
|
58
|
-
let state;
|
|
59
|
-
if (!isEnabledFilterDay(i)) {
|
|
60
|
-
viewDay.cssClass = 'cal-day-not-applicable';
|
|
61
|
-
state = CalendarScheduleSelectionDayState.NOT_APPLICABLE;
|
|
62
|
-
}
|
|
63
|
-
else if (!allowedDaysOfWeek.has(day)) {
|
|
64
|
-
viewDay.cssClass = 'cal-day-disabled';
|
|
65
|
-
state = CalendarScheduleSelectionDayState.DISABLED;
|
|
66
|
-
}
|
|
67
|
-
else if (isEnabledDay(i)) {
|
|
68
|
-
viewDay.cssClass = 'cal-day-selected';
|
|
69
|
-
state = CalendarScheduleSelectionDayState.SELECTED;
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
viewDay.cssClass = 'cal-day-not-selected';
|
|
73
|
-
state = CalendarScheduleSelectionDayState.NOT_SELECTED;
|
|
74
|
-
}
|
|
75
|
-
viewDay.meta = {
|
|
76
|
-
state,
|
|
77
|
-
i
|
|
78
|
-
};
|
|
79
|
-
});
|
|
103
|
+
this.beforeMonthViewRender$.pipe(first()).subscribe((x) => {
|
|
104
|
+
x(renderEvent);
|
|
80
105
|
});
|
|
81
106
|
}
|
|
82
107
|
}
|
|
@@ -90,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
90
115
|
}], config: [{
|
|
91
116
|
type: Input
|
|
92
117
|
}] } });
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.schedule.selection.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-form/calendar/src/lib/calendar.schedule.selection.component.ts","../../../../../../packages/dbx-form/calendar/src/lib/calendar.schedule.selection.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAa,KAAK,EAAU,MAAM,eAAe,CAAC;AAE1F,OAAO,EAAE,GAAG,EAAE,WAAW,EAAW,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,oBAAoB,EAAc,MAAM,MAAM,CAAC;AACzH,OAAO,EAAoB,gBAAgB,EAAE,4BAA4B,EAAE,MAAM,2BAA2B,CAAC;AAE7G,OAAO,EAAE,iCAAiC,EAAE,MAAM,qCAAqC,CAAC;AACxF,OAAO,EAAE,iCAAiC,EAAqC,MAAM,+BAA+B,CAAC;AACrH,OAAO,EAA+B,oCAAoC,EAAE,MAAM,mBAAmB,CAAC;AAEtG,OAAO,EAAE,sDAAsD,EAAE,MAAM,wDAAwD,CAAC;;;;;;;;;;AAkBhI,MAAM,OAAO,qCAAqC;IA2BhD,YAAqB,aAAkC,EAAW,iCAAoE;QAAjH,kBAAa,GAAb,aAAa,CAAqB;QAAW,sCAAiC,GAAjC,iCAAiC,CAAmC;QA1B9H,YAAO,GAAG,IAAI,eAAe,CAA8C,EAAE,CAAC,CAAC;QAE9E,8BAAyB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACpD,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,wBAAwB,IAAI,IAAI,CAAC,EACxD,oBAAoB,EAAE,CACvB,CAAC;QAEO,sCAAiC,GAAwD,IAAI,CAAC,OAAO,CAAC,IAAI,CACjH,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,qBAAqB,CAAC,EACnC,oCAAoC,CAAC,sDAAsD,CAAC,EAC5F,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAGF,eAAU,GAAG,IAAI,YAAY,EAAuB,CAAC;QAErD,qDAAqD;QAC5C,WAAM,GAAG,IAAI,CAAC,iCAAiC,CAAC,MAAM,CAAC;QACvD,aAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAClC,YAAY,CAAC,GAAG,CAAC,EACjB,GAAG,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CACC,CAAC;QAEf,YAAO,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,4BAA4B,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QACpG,cAAS,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;IAE2F,CAAC;IAE1I,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,iCAAiC,CAAC,gBAAgB,CAAC,CAAC,CAAC,qDAAqD;QAC1J,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAC9C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC1B,CAAC;IAED,IACI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IAC5B,CAAC;IAED,IAAI,MAAM,CAAC,MAAmD;QAC5D,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,UAAU,CAAC,EAAE,IAAI,EAAkB;QACjC,IAAI,CAAC,iCAAiC,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IACnE,CAAC;IAED,YAAY,CAAC,MAAc,EAAE,KAAuB;QAClD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IAC1C,CAAC;IAED,qBAAqB,CAAC,WAA+C;QACnE,MAAM,EAAE,IAAI,EAAE,GAAwE,WAAW,CAAC;QAClG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,YAAY,EAAE,YAAY,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,EAAE,EAAE;YAC5G,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;gBACvB,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;gBACzB,MAAM,CAAC,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;gBAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;gBAE1B,IAAI,KAAwC,CAAC;gBAE7C,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE;oBAC1B,OAAO,CAAC,QAAQ,GAAG,wBAAwB,CAAC;oBAC5C,KAAK,GAAG,iCAAiC,CAAC,cAAc,CAAC;iBAC1D;qBAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAgB,CAAC,EAAE;oBACnD,OAAO,CAAC,QAAQ,GAAG,kBAAkB,CAAC;oBACtC,KAAK,GAAG,iCAAiC,CAAC,QAAQ,CAAC;iBACpD;qBAAM,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE;oBAC1B,OAAO,CAAC,QAAQ,GAAG,kBAAkB,CAAC;oBACtC,KAAK,GAAG,iCAAiC,CAAC,QAAQ,CAAC;iBACpD;qBAAM;oBACL,OAAO,CAAC,QAAQ,GAAG,sBAAsB,CAAC;oBAC1C,KAAK,GAAG,iCAAiC,CAAC,YAAY,CAAC;iBACxD;gBAED,OAAO,CAAC,IAAI,GAAG;oBACb,KAAK;oBACL,CAAC;iBACF,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;;mIAtFU,qCAAqC;uHAArC,qCAAqC,+HAFrC,CAAC,gBAAgB,CAAC,0BCzB/B,szCAqBA;4FDMa,qCAAqC;kBALjD,SAAS;+BACE,iCAAiC,aAEhC,CAAC,gBAAgB,CAAC;uJAiB7B,UAAU;sBADT,MAAM;gBA0BH,MAAM;sBADT,KAAK","sourcesContent":["import { Component, EventEmitter, Output, OnDestroy, Input, OnInit } from '@angular/core';\nimport { CalendarEvent, CalendarMonthViewBeforeRenderEvent, CalendarMonthViewDay } from 'angular-calendar';\nimport { map, shareReplay, Subject, first, throttleTime, BehaviorSubject, distinctUntilChanged, Observable } from 'rxjs';\nimport { DbxCalendarEvent, DbxCalendarStore, prepareAndSortCalendarEvents } from '@dereekb/dbx-web/calendar';\nimport { DayOfWeek, Maybe } from '@dereekb/util';\nimport { DbxCalendarScheduleSelectionStore } from './calendar.schedule.selection.store';\nimport { CalendarScheduleSelectionDayState, CalendarScheduleSelectionMetadata } from './calendar.schedule.selection';\nimport { DbxInjectionComponentConfig, switchMapDbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { ObservableOrValueGetter } from '@dereekb/rxjs';\nimport { DbxScheduleSelectionCalendarDatePopoverButtonComponent } from './calendar.schedule.selection.popover.button.component';\n\nexport interface DbxScheduleSelectionCalendarComponentConfig {\n  /**\n   * Whether or not to show the clear selection button. Defaults to `true`.\n   */\n  readonly showClearSelectionButton?: boolean;\n  /**\n   * Configuration for displaying a custom selection button. When null/undefined/true is passed, will show the default DbxScheduleSelectionCalendarDatePopoverButtonComponent.\n   */\n  readonly buttonInjectionConfig?: Maybe<ObservableOrValueGetter<Maybe<DbxInjectionComponentConfig<any> | boolean>>>;\n}\n\n@Component({\n  selector: 'dbx-schedule-selection-calendar',\n  templateUrl: './calendar.schedule.selection.component.html',\n  providers: [DbxCalendarStore]\n})\nexport class DbxScheduleSelectionCalendarComponent<T> implements OnInit, OnDestroy {\n  private _config = new BehaviorSubject<DbxScheduleSelectionCalendarComponentConfig>({});\n\n  readonly showClearSelectionButton$ = this._config.pipe(\n    map((config) => config.showClearSelectionButton ?? true),\n    distinctUntilChanged()\n  );\n\n  readonly datePopoverButtonInjectionConfig$: Observable<Maybe<DbxInjectionComponentConfig<any>>> = this._config.pipe(\n    map((x) => x.buttonInjectionConfig),\n    switchMapDbxInjectionComponentConfig(DbxScheduleSelectionCalendarDatePopoverButtonComponent),\n    shareReplay(1)\n  );\n\n  @Output()\n  clickEvent = new EventEmitter<DbxCalendarEvent<T>>();\n\n  // refresh any time the selected day function updates\n  readonly state$ = this.dbxCalendarScheduleSelectionStore.state$;\n  readonly refresh$ = this.state$.pipe(\n    throttleTime(100),\n    map(() => undefined)\n  ) as Subject<undefined>;\n\n  readonly events$ = this.calendarStore.visibleEvents$.pipe(map(prepareAndSortCalendarEvents), shareReplay(1));\n  readonly viewDate$ = this.calendarStore.date$;\n\n  constructor(readonly calendarStore: DbxCalendarStore<T>, readonly dbxCalendarScheduleSelectionStore: DbxCalendarScheduleSelectionStore) {}\n\n  ngOnInit(): void {\n    this.calendarStore.setNavigationRangeLimit(this.dbxCalendarScheduleSelectionStore.minMaxDateRange$); // set navigation limit to the min/max allowed dates.\n    this.calendarStore.setShowPageButtons(true);\n  }\n\n  ngOnDestroy(): void {\n    this.clickEvent.complete();\n    this._config.complete();\n  }\n\n  @Input()\n  get config() {\n    return this._config.value;\n  }\n\n  set config(config: DbxScheduleSelectionCalendarComponentConfig) {\n    this._config.next(config);\n  }\n\n  dayClicked({ date }: { date: Date }): void {\n    this.dbxCalendarScheduleSelectionStore.toggleSelectedDates(date);\n  }\n\n  eventClicked(action: string, event: CalendarEvent<T>): void {\n    this.clickEvent.emit({ action, event });\n  }\n\n  beforeMonthViewRender(renderEvent: CalendarMonthViewBeforeRenderEvent): void {\n    const { body }: { body: CalendarMonthViewDay<CalendarScheduleSelectionMetadata>[] } = renderEvent;\n    this.state$.pipe(first()).subscribe(({ isEnabledDay, indexFactory, isEnabledFilterDay, allowedDaysOfWeek }) => {\n      body.forEach((viewDay) => {\n        const { date } = viewDay;\n        const i = indexFactory(date);\n        const day = date.getDay();\n\n        let state: CalendarScheduleSelectionDayState;\n\n        if (!isEnabledFilterDay(i)) {\n          viewDay.cssClass = 'cal-day-not-applicable';\n          state = CalendarScheduleSelectionDayState.NOT_APPLICABLE;\n        } else if (!allowedDaysOfWeek.has(day as DayOfWeek)) {\n          viewDay.cssClass = 'cal-day-disabled';\n          state = CalendarScheduleSelectionDayState.DISABLED;\n        } else if (isEnabledDay(i)) {\n          viewDay.cssClass = 'cal-day-selected';\n          state = CalendarScheduleSelectionDayState.SELECTED;\n        } else {\n          viewDay.cssClass = 'cal-day-not-selected';\n          state = CalendarScheduleSelectionDayState.NOT_SELECTED;\n        }\n\n        viewDay.meta = {\n          state,\n          i\n        };\n      });\n    });\n  }\n}\n","<dbx-calendar-base class=\"dbx-schedule-selection-calendar\">\n  <ng-container controls>\n    <ng-container *ngIf=\"showClearSelectionButton$ | async\">\n      <dbx-schedule-selection-calendar-selection-toggle-button></dbx-schedule-selection-calendar-selection-toggle-button>\n      <dbx-button-spacer></dbx-button-spacer>\n    </ng-container>\n    <dbx-injection [config]=\"datePopoverButtonInjectionConfig$ | async\"></dbx-injection>\n  </ng-container>\n  <div class=\"dbx-calendar-content dbx-calendar-content-month\">\n    <mwl-calendar-month-view [refresh]=\"refresh$\" [viewDate]=\"(viewDate$ | async)!\" [events]=\"(events$ | async)!\" (dayClicked)=\"dayClicked($event.day)\" (eventClicked)=\"eventClicked('Clicked', $event.event)\" (beforeViewRender)=\"beforeMonthViewRender($event)\" [cellTemplate]=\"monthDayCellTemplate\"></mwl-calendar-month-view>\n  </div>\n</dbx-calendar-base>\n\n<!-- Cell -->\n<ng-template #monthDayCellTemplate let-day=\"day\" let-locale=\"locale\">\n  <div class=\"cal-cell-top\">\n    <span class=\"cal-day-badge\" *ngIf=\"day.badgeTotal > 0\">{{ day.badgeTotal }}</span>\n    <span class=\"cal-day-number\">{{ day.date | calendarDate: 'monthViewDayNumber':locale }}</span>\n  </div>\n  <dbx-schedule-selection-calendar-cell [day]=\"day\"></dbx-schedule-selection-calendar-cell>\n</ng-template>\n"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.schedule.selection.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-form/calendar/src/lib/calendar.schedule.selection.component.ts","../../../../../../packages/dbx-form/calendar/src/lib/calendar.schedule.selection.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAa,KAAK,EAAU,MAAM,eAAe,CAAC;AAE1F,OAAO,EAAE,GAAG,EAAE,WAAW,EAAW,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,oBAAoB,EAAc,aAAa,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACnJ,OAAO,EAAoB,gBAAgB,EAAE,4BAA4B,EAAE,MAAM,2BAA2B,CAAC;AAE7G,OAAO,EAAkC,iCAAiC,EAAE,MAAM,qCAAqC,CAAC;AACxH,OAAO,EAAE,iCAAiC,EAAqC,MAAM,+BAA+B,CAAC;AACrH,OAAO,EAA+B,oCAAoC,EAAE,MAAM,mBAAmB,CAAC;AACtG,OAAO,EAA8C,YAAY,EAA0B,MAAM,eAAe,CAAC;AACjH,OAAO,EAAE,sDAAsD,EAAE,MAAM,wDAAwD,CAAC;;;;;;;;;;AA2BhI,MAAM,UAAU,wDAAwD,CAAC,aAAyF;IAChK,MAAM,QAAQ,GAAG,aAAa,IAAI,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IAE7C,OAAO,CAAC,MAAkD,EAAE,EAAE;QAC5D,OAAO,CAAC,WAA+C,EAAE,EAAE;YACzD,MAAM,EAAE,IAAI,EAAE,GAAwE,WAAW,CAAC;YAElG,2BAA2B;YAC3B,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,qBAAqD,EAAE,EAAE;gBACvF,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,GAAG,qBAAqB,CAAC;gBACpG,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;oBACvB,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;oBACzB,MAAM,CAAC,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;oBAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;oBAE1B,IAAI,KAAwC,CAAC;oBAE7C,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE;wBAC1B,OAAO,CAAC,QAAQ,GAAG,wBAAwB,CAAC;wBAC5C,KAAK,GAAG,iCAAiC,CAAC,cAAc,CAAC;qBAC1D;yBAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAgB,CAAC,EAAE;wBACnD,OAAO,CAAC,QAAQ,GAAG,kBAAkB,CAAC;wBACtC,KAAK,GAAG,iCAAiC,CAAC,QAAQ,CAAC;qBACpD;yBAAM,IAAI,YAAY,CAAC,CAAC,CAAC,EAAE;wBAC1B,OAAO,CAAC,QAAQ,GAAG,kBAAkB,CAAC;wBACtC,KAAK,GAAG,iCAAiC,CAAC,QAAQ,CAAC;qBACpD;yBAAM;wBACL,OAAO,CAAC,QAAQ,GAAG,sBAAsB,CAAC;wBAC1C,KAAK,GAAG,iCAAiC,CAAC,YAAY,CAAC;qBACxD;oBAED,MAAM,IAAI,GAAG;wBACX,KAAK;wBACL,CAAC;qBACF,CAAC;oBAEF,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;oBAEpB,QAAQ,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC;gBAC3C,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAOD,MAAM,OAAO,qCAAqC;IA2ChD,YAAqB,aAAkC,EAAW,iCAAoE;QAAjH,kBAAa,GAAb,aAAa,CAAqB;QAAW,sCAAiC,GAAjC,iCAAiC,CAAmC;QA1C9H,YAAO,GAAG,IAAI,eAAe,CAA8C,EAAE,CAAC,CAAC;QAE9E,8BAAyB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACpD,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,wBAAwB,IAAI,IAAI,CAAC,EACxD,oBAAoB,EAAE,CACvB,CAAC;QAEO,sCAAiC,GAAwD,IAAI,CAAC,OAAO,CAAC,IAAI,CACjH,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,qBAAqB,CAAC,EACnC,oCAAoC,CAAC,sDAAsD,CAAC,EAC5F,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAGF,eAAU,GAAG,IAAI,YAAY,EAAuB,CAAC;QAErD,qDAAqD;QAC5C,WAAM,GAAG,IAAI,CAAC,iCAAiC,CAAC,MAAM,CAAC;QAEvD,2BAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACjD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACd,IAAI,OAAqF,CAAC;YAE1F,IAAI,CAAC,CAAC,oCAAoC,EAAE;gBAC1C,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,oCAAoC,CAAC,CAAC;aAChE;iBAAM;gBACL,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,wDAAwD,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACtH;YAED,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAClD,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,aAAQ,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,IAAI,CAChF,YAAY,CAAC,GAAG,CAAC,EACjB,GAAG,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CACC,CAAC;QAEf,YAAO,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,4BAA4B,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QACpG,cAAS,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;IAE2F,CAAC;IAE1I,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,iCAAiC,CAAC,gBAAgB,CAAC,CAAC,CAAC,qDAAqD;QAC1J,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAC9C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC1B,CAAC;IAED,IACI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IAC5B,CAAC;IAED,IAAI,MAAM,CAAC,MAA0D;QACnE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,UAAU,CAAC,EAAE,IAAI,EAAkB;QACjC,IAAI,CAAC,iCAAiC,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IACnE,CAAC;IAED,YAAY,CAAC,MAAc,EAAE,KAAuB;QAClD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IAC1C,CAAC;IAED,qBAAqB,CAAC,WAA+C;QACnE,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACxD,CAAC,CAAC,WAAW,CAAC,CAAC;QACjB,CAAC,CAAC,CAAC;IACL,CAAC;;mIA5EU,qCAAqC;uHAArC,qCAAqC,+HAFrC,CAAC,gBAAgB,CAAC,0BCpF/B,szCAqBA;4FDiEa,qCAAqC;kBALjD,SAAS;+BACE,iCAAiC,aAEhC,CAAC,gBAAgB,CAAC;uJAiB7B,UAAU;sBADT,MAAM;gBA0CH,MAAM;sBADT,KAAK","sourcesContent":["import { Component, EventEmitter, Output, OnDestroy, Input, OnInit } from '@angular/core';\nimport { CalendarEvent, CalendarMonthViewBeforeRenderEvent, CalendarMonthViewDay } from 'angular-calendar';\nimport { map, shareReplay, Subject, first, throttleTime, BehaviorSubject, distinctUntilChanged, Observable, combineLatest, switchMap } from 'rxjs';\nimport { DbxCalendarEvent, DbxCalendarStore, prepareAndSortCalendarEvents } from '@dereekb/dbx-web/calendar';\nimport { DayOfWeek, Maybe } from '@dereekb/util';\nimport { CalendarScheduleSelectionState, DbxCalendarScheduleSelectionStore } from './calendar.schedule.selection.store';\nimport { CalendarScheduleSelectionDayState, CalendarScheduleSelectionMetadata } from './calendar.schedule.selection';\nimport { DbxInjectionComponentConfig, switchMapDbxInjectionComponentConfig } from '@dereekb/dbx-core';\nimport { ObservableOrValue, ObservableOrValueGetter, asObservable, asObservableFromGetter } from '@dereekb/rxjs';\nimport { DbxScheduleSelectionCalendarDatePopoverButtonComponent } from './calendar.schedule.selection.popover.button.component';\n\nexport interface DbxScheduleSelectionCalendarComponentConfig {\n  /**\n   * Whether or not to show the clear selection button. Defaults to `true`.\n   */\n  readonly showClearSelectionButton?: boolean;\n  /**\n   * Configuration for displaying a custom selection button. When null/undefined/true is passed, will show the default DbxScheduleSelectionCalendarDatePopoverButtonComponent.\n   */\n  readonly buttonInjectionConfig?: Maybe<ObservableOrValueGetter<Maybe<DbxInjectionComponentConfig<any> | boolean>>>;\n  /**\n   * Customize day function. When a new function is piped through the calendar is refreshed.\n   */\n  readonly customizeDay?: Maybe<ObservableOrValue<Maybe<DbxScheduleSelectionCalendarBeforeMonthViewRenderModifyDayFunction>>>;\n  /**\n   * Optional full control over the beforeMonthViewRender\n   */\n  readonly beforeMonthViewRenderFunctionFactory?: Maybe<ObservableOrValue<DbxScheduleSelectionCalendarBeforeMonthViewRenderFunctionFactory>>;\n}\n\nexport type DbxScheduleSelectionCalendarBeforeMonthViewRenderModifyDayFunction = (viewDay: CalendarMonthViewDay<CalendarScheduleSelectionMetadata>, state: CalendarScheduleSelectionState) => void;\n\nexport type DbxScheduleSelectionCalendarBeforeMonthViewRenderFunction = (renderEvent: CalendarMonthViewBeforeRenderEvent) => void;\n\nexport type DbxScheduleSelectionCalendarBeforeMonthViewRenderFunctionFactory = (state: Observable<CalendarScheduleSelectionState>) => DbxScheduleSelectionCalendarBeforeMonthViewRenderFunction;\n\nexport function dbxScheduleSelectionCalendarBeforeMonthViewRenderFactory(inputModifyFn?: Maybe<DbxScheduleSelectionCalendarBeforeMonthViewRenderModifyDayFunction>): DbxScheduleSelectionCalendarBeforeMonthViewRenderFunctionFactory {\n  const modifyFn = inputModifyFn || (() => {});\n\n  return (state$: Observable<CalendarScheduleSelectionState>) => {\n    return (renderEvent: CalendarMonthViewBeforeRenderEvent) => {\n      const { body }: { body: CalendarMonthViewDay<CalendarScheduleSelectionMetadata>[] } = renderEvent;\n\n      // use latest/current state\n      state$.pipe(first()).subscribe((calendarScheduleState: CalendarScheduleSelectionState) => {\n        const { isEnabledDay, indexFactory, isEnabledFilterDay, allowedDaysOfWeek } = calendarScheduleState;\n        body.forEach((viewDay) => {\n          const { date } = viewDay;\n          const i = indexFactory(date);\n          const day = date.getDay();\n\n          let state: CalendarScheduleSelectionDayState;\n\n          if (!isEnabledFilterDay(i)) {\n            viewDay.cssClass = 'cal-day-not-applicable';\n            state = CalendarScheduleSelectionDayState.NOT_APPLICABLE;\n          } else if (!allowedDaysOfWeek.has(day as DayOfWeek)) {\n            viewDay.cssClass = 'cal-day-disabled';\n            state = CalendarScheduleSelectionDayState.DISABLED;\n          } else if (isEnabledDay(i)) {\n            viewDay.cssClass = 'cal-day-selected';\n            state = CalendarScheduleSelectionDayState.SELECTED;\n          } else {\n            viewDay.cssClass = 'cal-day-not-selected';\n            state = CalendarScheduleSelectionDayState.NOT_SELECTED;\n          }\n\n          const meta = {\n            state,\n            i\n          };\n\n          viewDay.meta = meta;\n\n          modifyFn(viewDay, calendarScheduleState);\n        });\n      });\n    };\n  };\n}\n\n@Component({\n  selector: 'dbx-schedule-selection-calendar',\n  templateUrl: './calendar.schedule.selection.component.html',\n  providers: [DbxCalendarStore]\n})\nexport class DbxScheduleSelectionCalendarComponent<T> implements OnInit, OnDestroy {\n  private _config = new BehaviorSubject<DbxScheduleSelectionCalendarComponentConfig>({});\n\n  readonly showClearSelectionButton$ = this._config.pipe(\n    map((config) => config.showClearSelectionButton ?? true),\n    distinctUntilChanged()\n  );\n\n  readonly datePopoverButtonInjectionConfig$: Observable<Maybe<DbxInjectionComponentConfig<any>>> = this._config.pipe(\n    map((x) => x.buttonInjectionConfig),\n    switchMapDbxInjectionComponentConfig(DbxScheduleSelectionCalendarDatePopoverButtonComponent),\n    shareReplay(1)\n  );\n\n  @Output()\n  clickEvent = new EventEmitter<DbxCalendarEvent<T>>();\n\n  // refresh any time the selected day function updates\n  readonly state$ = this.dbxCalendarScheduleSelectionStore.state$;\n\n  readonly beforeMonthViewRender$ = this._config.pipe(\n    switchMap((x) => {\n      let factory: Observable<DbxScheduleSelectionCalendarBeforeMonthViewRenderFunctionFactory>;\n\n      if (x.beforeMonthViewRenderFunctionFactory) {\n        factory = asObservable(x.beforeMonthViewRenderFunctionFactory);\n      } else {\n        factory = asObservable(x.customizeDay).pipe(map((x) => dbxScheduleSelectionCalendarBeforeMonthViewRenderFactory(x)));\n      }\n\n      return factory.pipe(map((x) => x(this.state$)));\n    }),\n    shareReplay(1)\n  );\n\n  readonly refresh$ = combineLatest([this.state$, this.beforeMonthViewRender$]).pipe(\n    throttleTime(100),\n    map(() => undefined)\n  ) as Subject<undefined>;\n\n  readonly events$ = this.calendarStore.visibleEvents$.pipe(map(prepareAndSortCalendarEvents), shareReplay(1));\n  readonly viewDate$ = this.calendarStore.date$;\n\n  constructor(readonly calendarStore: DbxCalendarStore<T>, readonly dbxCalendarScheduleSelectionStore: DbxCalendarScheduleSelectionStore) {}\n\n  ngOnInit(): void {\n    this.calendarStore.setNavigationRangeLimit(this.dbxCalendarScheduleSelectionStore.minMaxDateRange$); // set navigation limit to the min/max allowed dates.\n    this.calendarStore.setShowPageButtons(true);\n  }\n\n  ngOnDestroy(): void {\n    this.clickEvent.complete();\n    this._config.complete();\n  }\n\n  @Input()\n  get config() {\n    return this._config.value;\n  }\n\n  set config(config: Maybe<DbxScheduleSelectionCalendarComponentConfig>) {\n    this._config.next(config ?? {});\n  }\n\n  dayClicked({ date }: { date: Date }): void {\n    this.dbxCalendarScheduleSelectionStore.toggleSelectedDates(date);\n  }\n\n  eventClicked(action: string, event: CalendarEvent<T>): void {\n    this.clickEvent.emit({ action, event });\n  }\n\n  beforeMonthViewRender(renderEvent: CalendarMonthViewBeforeRenderEvent): void {\n    this.beforeMonthViewRender$.pipe(first()).subscribe((x) => {\n      x(renderEvent);\n    });\n  }\n}\n","<dbx-calendar-base class=\"dbx-schedule-selection-calendar\">\n  <ng-container controls>\n    <ng-container *ngIf=\"showClearSelectionButton$ | async\">\n      <dbx-schedule-selection-calendar-selection-toggle-button></dbx-schedule-selection-calendar-selection-toggle-button>\n      <dbx-button-spacer></dbx-button-spacer>\n    </ng-container>\n    <dbx-injection [config]=\"datePopoverButtonInjectionConfig$ | async\"></dbx-injection>\n  </ng-container>\n  <div class=\"dbx-calendar-content dbx-calendar-content-month\">\n    <mwl-calendar-month-view [refresh]=\"refresh$\" [viewDate]=\"(viewDate$ | async)!\" [events]=\"(events$ | async)!\" (dayClicked)=\"dayClicked($event.day)\" (eventClicked)=\"eventClicked('Clicked', $event.event)\" (beforeViewRender)=\"beforeMonthViewRender($event)\" [cellTemplate]=\"monthDayCellTemplate\"></mwl-calendar-month-view>\n  </div>\n</dbx-calendar-base>\n\n<!-- Cell -->\n<ng-template #monthDayCellTemplate let-day=\"day\" let-locale=\"locale\">\n  <div class=\"cal-cell-top\">\n    <span class=\"cal-day-badge\" *ngIf=\"day.badgeTotal > 0\">{{ day.badgeTotal }}</span>\n    <span class=\"cal-day-number\">{{ day.date | calendarDate: 'monthViewDayNumber':locale }}</span>\n  </div>\n  <dbx-schedule-selection-calendar-cell [day]=\"day\"></dbx-schedule-selection-calendar-cell>\n</ng-template>\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Component, InjectionToken } from '@angular/core';
|
|
2
|
-
import { AbstractDialogDirective } from '@dereekb/dbx-web';
|
|
2
|
+
import { AbstractDialogDirective, sanitizeDbxDialogContentConfig } from '@dereekb/dbx-web';
|
|
3
3
|
import { KeyValueTypleValueFilter, mergeObjects } from '@dereekb/util';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@dereekb/dbx-web";
|
|
@@ -33,7 +33,7 @@ export class DbxScheduleSelectionCalendarDateDialogComponent extends AbstractDia
|
|
|
33
33
|
width: '80vw',
|
|
34
34
|
minHeight: 400,
|
|
35
35
|
minWidth: 360,
|
|
36
|
-
...contentConfig.dialogConfig,
|
|
36
|
+
...sanitizeDbxDialogContentConfig(contentConfig.dialogConfig),
|
|
37
37
|
injector,
|
|
38
38
|
data: {
|
|
39
39
|
config,
|
|
@@ -62,4 +62,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
62
62
|
`
|
|
63
63
|
}]
|
|
64
64
|
}] });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuc2NoZWR1bGUuc2VsZWN0aW9uLmRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9jYWxlbmRhci9zcmMvbGliL2NhbGVuZGFyLnNjaGVkdWxlLnNlbGVjdGlvbi5kaWFsb2cuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsY0FBYyxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBRXBFLE9BQU8sRUFBRSx1QkFBdUIsRUFBd0QsOEJBQThCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqSixPQUFPLEVBQUUsd0JBQXdCLEVBQXdCLFlBQVksRUFBNEIsTUFBTSxlQUFlLENBQUM7Ozs7QUFFdkg7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLHFFQUFxRSxHQUFHLElBQUksY0FBYyxDQUFDLGtEQUFrRCxDQUFDLENBQUM7QUFFNUo7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSx1RUFBdUUsR0FBRyxJQUFJLGNBQWMsQ0FBQyxvREFBb0QsQ0FBQyxDQUFDO0FBeUJoSyxNQUFNLE9BQU8sK0NBQWdELFNBQVEsdUJBQTBFO0lBQzdJLElBQUksYUFBYTtRQUNmLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDakMsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE9BQU8sSUFBSSxDQUFDLGFBQWEsRUFBRSxXQUFXLENBQUM7SUFDekMsQ0FBQztJQUVELE1BQU0sQ0FBQyxVQUFVLENBQUMsU0FBb0IsRUFBRSxNQUFtRDtRQUN6RixNQUFNLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxrQkFBa0IsRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsR0FBRyxNQUFNLENBQUM7UUFFOUYsTUFBTSxrQkFBa0IsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFzQyxxRUFBcUUsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUMxSixNQUFNLG9CQUFvQixHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQTRELHVFQUF1RSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBRXBMLE1BQU0sYUFBYSxHQUFHLFlBQVksQ0FBQyxDQUFDLG9CQUFvQixFQUFFLGtCQUFrQixDQUFDLEVBQUUsd0JBQXdCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUcsTUFBTSxXQUFXLEdBQUcsWUFBWSxDQUFDLENBQUMsa0JBQWtCLEVBQUUsYUFBYSxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsQ0FBQyxFQUFFLHdCQUF3QixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BJLGFBQWEsQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO1FBRXhDLE9BQU8sU0FBUyxDQUFDLElBQUksQ0FBQywrQ0FBK0MsRUFBRTtZQUNyRSxNQUFNLEVBQUUsMEJBQTBCO1lBQ2xDLEtBQUssRUFBRSxNQUFNO1lBQ2IsU0FBUyxFQUFFLEdBQUc7WUFDZCxRQUFRLEVBQUUsR0FBRztZQUNiLEdBQUcsOEJBQThCLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQztZQUM3RCxRQUFRO1lBQ1IsSUFBSSxFQUFFO2dCQUNKLE1BQU07Z0JBQ04sYUFBYTthQUNkO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7NklBL0JVLCtDQUErQztpSUFBL0MsK0NBQStDLDJFQVJoRDs7Ozs7O0dBTVQ7NEZBRVUsK0NBQStDO2tCQVQzRCxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRTs7Ozs7O0dBTVQ7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEluamVjdGlvblRva2VuLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlLCBEYnhEaWFsb2dDb250ZW50Q29uZmlnLCBEYnhEaWFsb2dDb250ZW50Rm9vdGVyQ29uZmlnLCBzYW5pdGl6ZURieERpYWxvZ0NvbnRlbnRDb25maWcgfSBmcm9tICdAZGVyZWVrYi9kYngtd2ViJztcbmltcG9ydCB7IEtleVZhbHVlVHlwbGVWYWx1ZUZpbHRlciwgTWF5YmUsIGNzc0NsYXNzZXNTZXQsIG1lcmdlT2JqZWN0cywgc3BhY2VTZXBhcmF0ZWRDc3NDbGFzc2VzIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5cbi8qKlxuICogVG9rZW4gdXNlZCB0byBjb25maWd1cmUgdGhlIGRlZmF1bHQgRGJ4RGlhbG9nQ29udGVudEZvb3RlckNvbmZpZyBmb3IgRGJ4U2NoZWR1bGVTZWxlY3Rpb25DYWxlbmRhckRhdGVEaWFsb2dDb21wb25lbnQuXG4gKlxuICogQGRlcHJlY2F0ZWQgdXNlIERFRkFVTFRfREJYX1NDSEVEVUxFX1NFTEVDVElPTl9DQUxFTkRBUl9EQVRFX1BPUFVQX0NPTlRFTlRfQ09ORklHX1RPS0VOIGluc3RlYWQuXG4gKi9cbmV4cG9ydCBjb25zdCBERUZBVUxUX0RCWF9TQ0hFRFVMRV9TRUxFQ1RJT05fQ0FMRU5EQVJfREFURV9QT1BVUF9DTE9TRV9DT05GSUdfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ0RieFNjaGVkdWxlU2VsZWN0aW9uQ2FsZW5kYXJEYXRlUG9wdXBDbG9zZUNvbmZpZycpO1xuXG4vKipcbiAqIFRva2VuIHVzZWQgdG8gY29uZmlndXJlIHRoZSBkZWZhdWx0IERieFNjaGVkdWxlU2VsZWN0aW9uQ2FsZW5kYXJEYXRlUG9wdXBDb25maWcgZm9yIERieFNjaGVkdWxlU2VsZWN0aW9uQ2FsZW5kYXJEYXRlRGlhbG9nQ29tcG9uZW50LlxuICovXG5leHBvcnQgY29uc3QgREVGQVVMVF9EQlhfU0NIRURVTEVfU0VMRUNUSU9OX0NBTEVOREFSX0RBVEVfUE9QVVBfQ09OVEVOVF9DT05GSUdfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ0RieFNjaGVkdWxlU2VsZWN0aW9uQ2FsZW5kYXJEYXRlUG9wdXBDb250ZW50Q29uZmlnJyk7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4U2NoZWR1bGVTZWxlY3Rpb25DYWxlbmRhckRhdGVQb3B1cENvbnRlbnRDb25maWcge1xuICBjbG9zZUNvbmZpZz86IERieERpYWxvZ0NvbnRlbnRGb290ZXJDb25maWc7XG4gIGRpYWxvZ0NvbmZpZz86IERieERpYWxvZ0NvbnRlbnRDb25maWc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4U2NoZWR1bGVTZWxlY3Rpb25DYWxlbmRhckRhdGVQb3B1cENvbmZpZyB7XG4gIGluamVjdG9yOiBJbmplY3RvcjtcbiAgY29udGVudENvbmZpZz86IE1heWJlPERieFNjaGVkdWxlU2VsZWN0aW9uQ2FsZW5kYXJEYXRlUG9wdXBDb250ZW50Q29uZmlnPjtcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHVzZSBjb250ZW50Q29uZmlnIGluc3RlYWQuXG4gICAqL1xuICBjbG9zZUNvbmZpZz86IE1heWJlPERieERpYWxvZ0NvbnRlbnRGb290ZXJDb25maWc+O1xufVxuXG5AQ29tcG9uZW50KHtcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGJ4LWRpYWxvZy1jb250ZW50IGNsYXNzPVwiZGJ4LXNjaGVkdWxlLXNlbGVjdGlvbi1jYWxlbmRhci1kYXRlLWRpYWxvZ1wiPlxuICAgICAgPGRieC1kaWFsb2ctY29udGVudC1jbG9zZSAoY2xvc2UpPVwiY2xvc2UoKVwiPjwvZGJ4LWRpYWxvZy1jb250ZW50LWNsb3NlPlxuICAgICAgPGRieC1zY2hlZHVsZS1zZWxlY3Rpb24tY2FsZW5kYXI+PC9kYngtc2NoZWR1bGUtc2VsZWN0aW9uLWNhbGVuZGFyPlxuICAgICAgPGRieC1kaWFsb2ctY29udGVudC1mb290ZXIgW2NvbmZpZ109XCJjbG9zZUNvbmZpZ1wiIChjbG9zZSk9XCJjbG9zZSgpXCI+PC9kYngtZGlhbG9nLWNvbnRlbnQtZm9vdGVyPlxuICAgIDwvZGJ4LWRpYWxvZy1jb250ZW50PlxuICBgXG59KVxuZXhwb3J0IGNsYXNzIERieFNjaGVkdWxlU2VsZWN0aW9uQ2FsZW5kYXJEYXRlRGlhbG9nQ29tcG9uZW50IGV4dGVuZHMgQWJzdHJhY3REaWFsb2dEaXJlY3RpdmU8dm9pZCwgRGJ4U2NoZWR1bGVTZWxlY3Rpb25DYWxlbmRhckRhdGVQb3B1cENvbmZpZz4ge1xuICBnZXQgY29udGVudENvbmZpZygpIHtcbiAgICByZXR1cm4gdGhpcy5kYXRhLmNvbnRlbnRDb25maWc7XG4gIH1cblxuICBnZXQgY2xvc2VDb25maWcoKSB7XG4gICAgcmV0dXJuIHRoaXMuY29udGVudENvbmZpZz8uY2xvc2VDb25maWc7XG4gIH1cblxuICBzdGF0aWMgb3BlbkRpYWxvZyhtYXREaWFsb2c6IE1hdERpYWxvZywgY29uZmlnOiBEYnhTY2hlZHVsZVNlbGVjdGlvbkNhbGVuZGFyRGF0ZVBvcHVwQ29uZmlnKSB7XG4gICAgY29uc3QgeyBpbmplY3RvciwgY29udGVudENvbmZpZzogaW5wdXRDb250ZW50Q29uZmlnLCBjbG9zZUNvbmZpZzogaW5wdXRDbG9zZUNvbmZpZyB9ID0gY29uZmlnO1xuXG4gICAgY29uc3QgZGVmYXVsdENsb3NlQ29uZmlnID0gaW5qZWN0b3IuZ2V0PE1heWJlPERieERpYWxvZ0NvbnRlbnRGb290ZXJDb25maWc+PihERUZBVUxUX0RCWF9TQ0hFRFVMRV9TRUxFQ1RJT05fQ0FMRU5EQVJfREFURV9QT1BVUF9DTE9TRV9DT05GSUdfVE9LRU4sIG51bGwpO1xuICAgIGNvbnN0IGRlZmF1bHRDb250ZW50Q29uZmlnID0gaW5qZWN0b3IuZ2V0PE1heWJlPERieFNjaGVkdWxlU2VsZWN0aW9uQ2FsZW5kYXJEYXRlUG9wdXBDb250ZW50Q29uZmlnPj4oREVGQVVMVF9EQlhfU0NIRURVTEVfU0VMRUNUSU9OX0NBTEVOREFSX0RBVEVfUE9QVVBfQ09OVEVOVF9DT05GSUdfVE9LRU4sIG51bGwpO1xuXG4gICAgY29uc3QgY29udGVudENvbmZpZyA9IG1lcmdlT2JqZWN0cyhbZGVmYXVsdENvbnRlbnRDb25maWcsIGlucHV0Q29udGVudENvbmZpZ10sIEtleVZhbHVlVHlwbGVWYWx1ZUZpbHRlci5OVUxMKTtcbiAgICBjb25zdCBjbG9zZUNvbmZpZyA9IG1lcmdlT2JqZWN0cyhbZGVmYXVsdENsb3NlQ29uZmlnLCBjb250ZW50Q29uZmlnPy5jbG9zZUNvbmZpZywgaW5wdXRDbG9zZUNvbmZpZ10sIEtleVZhbHVlVHlwbGVWYWx1ZUZpbHRlci5OVUxMKTtcbiAgICBjb250ZW50Q29uZmlnLmNsb3NlQ29uZmlnID0gY2xvc2VDb25maWc7XG5cbiAgICByZXR1cm4gbWF0RGlhbG9nLm9wZW4oRGJ4U2NoZWR1bGVTZWxlY3Rpb25DYWxlbmRhckRhdGVEaWFsb2dDb21wb25lbnQsIHtcbiAgICAgIGhlaWdodDogJ2NhbGModmFyKC0tdmgxMDApICogMC45KScsXG4gICAgICB3aWR0aDogJzgwdncnLFxuICAgICAgbWluSGVpZ2h0OiA0MDAsXG4gICAgICBtaW5XaWR0aDogMzYwLFxuICAgICAgLi4uc2FuaXRpemVEYnhEaWFsb2dDb250ZW50Q29uZmlnKGNvbnRlbnRDb25maWcuZGlhbG9nQ29uZmlnKSxcbiAgICAgIGluamVjdG9yLFxuICAgICAgZGF0YToge1xuICAgICAgICBjb25maWcsXG4gICAgICAgIGNvbnRlbnRDb25maWdcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxufVxuIl19
|