@dereekb/dbx-form 9.25.2 → 9.25.4
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/calendar/lib/calendar.schedule.selection.component.d.ts +1 -0
- package/calendar/lib/calendar.schedule.selection.range.component.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.store.d.ts +28 -4
- package/calendar/lib/field/schedule/calendar.schedule.field.component.d.ts +9 -1
- package/esm2020/calendar/lib/calendar.schedule.selection.component.mjs +7 -6
- package/esm2020/calendar/lib/calendar.schedule.selection.range.component.mjs +4 -4
- package/esm2020/calendar/lib/calendar.schedule.selection.store.mjs +74 -37
- package/esm2020/calendar/lib/field/schedule/calendar.schedule.field.component.mjs +6 -6
- package/esm2020/calendar/lib/field/schedule/calendar.schedule.field.mjs +3 -2
- package/fesm2015/dereekb-dbx-form-calendar.mjs +87 -46
- package/fesm2015/dereekb-dbx-form-calendar.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-form-calendar.mjs +89 -50
- package/fesm2020/dereekb-dbx-form-calendar.mjs.map +1 -1
- package/mapbox/package.json +4 -4
- package/package.json +4 -4
|
@@ -44,6 +44,7 @@ export declare class DbxScheduleSelectionCalendarComponent<T> implements OnInit,
|
|
|
44
44
|
private _inputReadonly;
|
|
45
45
|
private _config;
|
|
46
46
|
private _centerRangeSub;
|
|
47
|
+
readonly config$: Observable<DbxScheduleSelectionCalendarComponentConfig>;
|
|
47
48
|
readonly readonly$: Observable<boolean>;
|
|
48
49
|
readonly showButtonsOnReadonly$: Observable<boolean>;
|
|
49
50
|
readonly showButtons$: Observable<boolean>;
|
|
@@ -14,7 +14,7 @@ export declare class DbxScheduleSelectionCalendarDateRangeComponent implements O
|
|
|
14
14
|
readonly matFormFieldDefaultOptions: MatFormFieldDefaultOptions;
|
|
15
15
|
private _required;
|
|
16
16
|
readonly required$: Observable<boolean>;
|
|
17
|
-
readonly timezone$: Observable<
|
|
17
|
+
readonly timezone$: Observable<string>;
|
|
18
18
|
openPickerOnTextClick: boolean;
|
|
19
19
|
picker: MatDateRangePicker<Date>;
|
|
20
20
|
label?: Maybe<string>;
|
|
@@ -29,7 +29,9 @@ export interface CalendarScheduleSelectionState extends PartialCalendarScheduleS
|
|
|
29
29
|
/**
|
|
30
30
|
* Filters the days of the schedule to only allow selecting days in the schedule.
|
|
31
31
|
*
|
|
32
|
-
*
|
|
32
|
+
* The output will be relative to this filter, and in it's timezone unless computeSelectionResultRelativeToFilter is false.
|
|
33
|
+
*
|
|
34
|
+
* This is a copy of any set/configured input filter and will have a start date set from start or startsAt.
|
|
33
35
|
*/
|
|
34
36
|
filter?: Maybe<DateCellScheduleDateFilterConfig>;
|
|
35
37
|
/**
|
|
@@ -157,8 +159,18 @@ export declare class DbxCalendarScheduleSelectionStore extends ComponentStore<Ca
|
|
|
157
159
|
}>;
|
|
158
160
|
readonly scheduleDays$: Observable<Set<DateCellScheduleDayCode>>;
|
|
159
161
|
readonly outputTimezone$: Observable<Maybe<TimezoneString>>;
|
|
160
|
-
|
|
161
|
-
|
|
162
|
+
/**
|
|
163
|
+
* The timezone of the output values.
|
|
164
|
+
*
|
|
165
|
+
* If an outputTimezone is not specified, this defaults to the system timezone.
|
|
166
|
+
*/
|
|
167
|
+
readonly effectiveOutputTimezone$: Observable<TimezoneString>;
|
|
168
|
+
/**
|
|
169
|
+
* An outputTimezoneNormal to use.
|
|
170
|
+
*
|
|
171
|
+
* If an outputTimezone is not specified, this is undefined.
|
|
172
|
+
*/
|
|
173
|
+
readonly effectiveOutputTimezoneNormal$: Observable<Maybe<DateTimezoneUtcNormalInstance>>;
|
|
162
174
|
readonly currentSelectionValue$: Observable<Maybe<CalendarScheduleSelectionValue>>;
|
|
163
175
|
readonly currentSelectionValueStart$: Observable<Maybe<Date>>;
|
|
164
176
|
readonly currentSelectionValueDateCellTimingDateFactory$: Observable<import("@dereekb/date").DateCellTimingDateFactory<{
|
|
@@ -185,6 +197,9 @@ export declare class DbxCalendarScheduleSelectionStore extends ComponentStore<Ca
|
|
|
185
197
|
readonly setComputeSelectionResultRelativeToFilter: (() => void) | ((observableOrValue: Maybe<boolean> | Observable<Maybe<boolean>>) => import("rxjs").Subscription);
|
|
186
198
|
readonly clearFilter: () => void;
|
|
187
199
|
readonly setOutputTimezone: (() => void) | ((observableOrValue: Maybe<string> | Observable<Maybe<string>>) => import("rxjs").Subscription);
|
|
200
|
+
/**
|
|
201
|
+
* Sets the "input" date range. This is the range that gets displayed on the date range picker.
|
|
202
|
+
*/
|
|
188
203
|
readonly setInputRange: (observableOrValue: CalendarScheduleSelectionInputDateRange | Observable<CalendarScheduleSelectionInputDateRange>) => import("rxjs").Subscription;
|
|
189
204
|
readonly toggleSelectedDates: (observableOrValue: IterableOrValue<DateCellTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateCellTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
|
|
190
205
|
readonly addSelectedDates: (observableOrValue: IterableOrValue<DateCellTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateCellTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
|
|
@@ -219,7 +234,7 @@ export declare class DbxCalendarScheduleSelectionStore extends ComponentStore<Ca
|
|
|
219
234
|
/**
|
|
220
235
|
* @deprecated use effectiveOuputTimezoneNormal$
|
|
221
236
|
*/
|
|
222
|
-
readonly effectiveTimezoneNormal$: Observable<DateTimezoneUtcNormalInstance
|
|
237
|
+
readonly effectiveTimezoneNormal$: Observable<Maybe<DateTimezoneUtcNormalInstance>>;
|
|
223
238
|
/**
|
|
224
239
|
* @deprecated use currentSelectionValueDateCellDurationSpanExpansion$
|
|
225
240
|
*/
|
|
@@ -261,8 +276,17 @@ export declare function updateStateWithChangedRange(state: CalendarScheduleSelec
|
|
|
261
276
|
export declare function finalizeNewCalendarScheduleSelectionState(nextState: CalendarScheduleSelectionState): CalendarScheduleSelectionState;
|
|
262
277
|
export declare function isEnabledDayInCalendarScheduleSelectionState(state: CalendarScheduleSelectionState): DecisionFunction<DateCellTimingRelativeIndexFactoryInput>;
|
|
263
278
|
export declare function computeScheduleSelectionValue(state: CalendarScheduleSelectionState): Maybe<CalendarScheduleSelectionValue>;
|
|
279
|
+
/**
|
|
280
|
+
* The selected date range and the corresponding cell range.
|
|
281
|
+
*/
|
|
264
282
|
export interface CalendarScheduleSelectionRangeAndExclusion extends DateRange {
|
|
283
|
+
/**
|
|
284
|
+
* Corresponds to the start and end indexes in the date range.
|
|
285
|
+
*/
|
|
265
286
|
dateCellRange: DateCellRangeWithRange;
|
|
287
|
+
/**
|
|
288
|
+
* All excluded indexes.
|
|
289
|
+
*/
|
|
266
290
|
excluded: DateCellIndex[];
|
|
267
291
|
}
|
|
268
292
|
export declare function computeScheduleSelectionRangeAndExclusion(state: CalendarScheduleSelectionState): Maybe<CalendarScheduleSelectionRangeAndExclusion>;
|
|
@@ -33,8 +33,16 @@ export interface DbxFormCalendarDateCellScheduleRangeFieldProps extends Pick<For
|
|
|
33
33
|
allowCustomizeWithoutDateRange?: boolean;
|
|
34
34
|
/**
|
|
35
35
|
* (Optional) Timezone to use for the output start date.
|
|
36
|
+
*
|
|
37
|
+
* @deprecated use 'outputTimezone' instead.
|
|
36
38
|
*/
|
|
37
39
|
timezone?: ObservableOrValue<Maybe<TimezoneString>>;
|
|
40
|
+
/**
|
|
41
|
+
* (Optional) Timezone to use for the output start date.
|
|
42
|
+
*
|
|
43
|
+
* If a filter is provided, this timezone overrides the filter's timezone output.
|
|
44
|
+
*/
|
|
45
|
+
outputTimezone?: ObservableOrValue<Maybe<TimezoneString>>;
|
|
38
46
|
/**
|
|
39
47
|
* (Optional) Default schedule days to allow.
|
|
40
48
|
*/
|
|
@@ -88,7 +96,7 @@ export declare class DbxFormCalendarDateScheduleRangeFieldComponent<T extends Db
|
|
|
88
96
|
get minMaxDateRange(): ObservableOrValue<Maybe<Partial<DateRange>>>;
|
|
89
97
|
get filter(): ObservableOrValue<Maybe<DateCellScheduleDateFilterConfig>>;
|
|
90
98
|
get exclusions(): ObservableOrValue<Maybe<ArrayOrValue<DateOrDateRangeOrDateCellIndexOrDateCellRange>>>;
|
|
91
|
-
get
|
|
99
|
+
get outputTimezone(): ObservableOrValue<Maybe<string>>;
|
|
92
100
|
get initialSelectionState(): Maybe<import("@dereekb/util").AllOrNoneSelection>;
|
|
93
101
|
get computeSelectionResultRelativeToFilter(): Maybe<boolean>;
|
|
94
102
|
get dialogContentConfig(): Maybe<DbxScheduleSelectionCalendarDatePopupContentConfig>;
|
|
@@ -66,10 +66,11 @@ export class DbxScheduleSelectionCalendarComponent {
|
|
|
66
66
|
this._inputReadonly = new BehaviorSubject(undefined);
|
|
67
67
|
this._config = new BehaviorSubject({});
|
|
68
68
|
this._centerRangeSub = new SubscriptionObject();
|
|
69
|
-
this.
|
|
69
|
+
this.config$ = this._config.pipe(distinctUntilChanged(), shareReplay(1));
|
|
70
|
+
this.readonly$ = this.config$.pipe(switchMap((x) => (x.readonly != null ? asObservableFromGetter(x.readonly) : of(undefined))), combineLatestWith(this._inputReadonly), map(([configReadonly, inputReadonly]) => {
|
|
70
71
|
return (configReadonly ?? false) || (inputReadonly ?? false);
|
|
71
72
|
}), shareReplay(1));
|
|
72
|
-
this.showButtonsOnReadonly$ = this.
|
|
73
|
+
this.showButtonsOnReadonly$ = this.config$.pipe(map((x) => x.showButtonsOnReadonly ?? false), distinctUntilChanged(), shareReplay(1));
|
|
73
74
|
this.showButtons$ = this.showButtonsOnReadonly$.pipe(switchMap((x) => {
|
|
74
75
|
if (x) {
|
|
75
76
|
return of(true);
|
|
@@ -78,12 +79,12 @@ export class DbxScheduleSelectionCalendarComponent {
|
|
|
78
79
|
return this.readonly$.pipe(map((x) => !x));
|
|
79
80
|
}
|
|
80
81
|
}), distinctUntilChanged(), shareReplay(1));
|
|
81
|
-
this.showClearSelectionButton$ = this.
|
|
82
|
-
this.datePopoverButtonInjectionConfig$ = this.
|
|
82
|
+
this.showClearSelectionButton$ = this.config$.pipe(map((config) => config.showClearSelectionButton ?? true), combineLatestWith(this.showButtons$), map((x) => reduceBooleansWithAnd(x)), distinctUntilChanged(), shareReplay(1));
|
|
83
|
+
this.datePopoverButtonInjectionConfig$ = this.config$.pipe(map((x) => x.buttonInjectionConfig), switchMapDbxInjectionComponentConfig(DbxScheduleSelectionCalendarDatePopoverButtonComponent), combineLatestWith(this.showButtons$), map(([config, showButton]) => (showButton ? config : undefined)), shareReplay(1));
|
|
83
84
|
this.clickEvent = new EventEmitter();
|
|
84
85
|
// refresh any time the selected day function updates
|
|
85
86
|
this.state$ = this.dbxCalendarScheduleSelectionStore.state$;
|
|
86
|
-
this.beforeMonthViewRender$ = this.
|
|
87
|
+
this.beforeMonthViewRender$ = this.config$.pipe(switchMap((x) => {
|
|
87
88
|
let factory;
|
|
88
89
|
if (x.beforeMonthViewRenderFunctionFactory) {
|
|
89
90
|
factory = asObservable(x.beforeMonthViewRenderFunctionFactory);
|
|
@@ -172,4 +173,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
172
173
|
}], readonly: [{
|
|
173
174
|
type: Input
|
|
174
175
|
}] } });
|
|
175
|
-
//# 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":"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","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, of, combineLatestWith, share } from 'rxjs';\nimport { DbxCalendarEvent, DbxCalendarStore, prepareAndSortCalendarEvents } from '@dereekb/dbx-web/calendar';\nimport { DayOfWeek, Maybe, reduceBooleansWithAnd } 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, SubscriptionObject, asObservable, asObservableFromGetter } from '@dereekb/rxjs';\nimport { DbxScheduleSelectionCalendarDatePopoverButtonComponent } from './calendar.schedule.selection.popover.button.component';\nimport { DateRangeType, dateRange, isSameDate } from '@dereekb/date';\nimport { endOfWeek } from 'date-fns';\n\nexport interface DbxScheduleSelectionCalendarComponentConfig {\n  /**\n   * Whether or not the selection calendar is readonly. Defaults to 'false'.\n   */\n  readonly readonly?: Maybe<ObservableOrValueGetter<Maybe<boolean>>>;\n  /**\n   * Whether or not to show the configured buttons when readonly is true. Defaults to false.\n   */\n  readonly showButtonsOnReadonly?: boolean;\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          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 _inputReadonly = new BehaviorSubject<Maybe<boolean>>(undefined);\n  private _config = new BehaviorSubject<DbxScheduleSelectionCalendarComponentConfig>({});\n  private _centerRangeSub = new SubscriptionObject();\n\n  readonly readonly$: Observable<boolean> = this._config.pipe(\n    switchMap((x) => (x.readonly != null ? asObservableFromGetter(x.readonly) : of(undefined))),\n    combineLatestWith(this._inputReadonly),\n    map(([configReadonly, inputReadonly]) => {\n      return (configReadonly ?? false) || (inputReadonly ?? false);\n    }),\n    shareReplay(1)\n  );\n\n  readonly showButtonsOnReadonly$: Observable<boolean> = this._config.pipe(\n    map((x) => x.showButtonsOnReadonly ?? false),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly showButtons$ = this.showButtonsOnReadonly$.pipe(\n    switchMap((x) => {\n      if (x) {\n        return of(true);\n      } else {\n        return this.readonly$.pipe(map((x) => !x));\n      }\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly showClearSelectionButton$ = this._config.pipe(\n    map((config) => config.showClearSelectionButton ?? true),\n    combineLatestWith(this.showButtons$),\n    map((x) => reduceBooleansWithAnd(x)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly datePopoverButtonInjectionConfig$: Observable<Maybe<DbxInjectionComponentConfig<any>>> = this._config.pipe(\n    map((x) => x.buttonInjectionConfig),\n    switchMapDbxInjectionComponentConfig(DbxScheduleSelectionCalendarDatePopoverButtonComponent),\n    combineLatestWith(this.showButtons$),\n    map(([config, showButton]) => (showButton ? config : undefined)),\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(20, undefined, { leading: true, trailing: true }),\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.dbxCalendarScheduleSelectionStore.setViewReadonlyState(this.readonly$); // sync the readonly state\n\n    this.calendarStore.setNavigationRangeLimit(this.dbxCalendarScheduleSelectionStore.minMaxDateRange$); // set navigation limit to the min/max allowed dates.\n    this.calendarStore.setShowPageButtons(true);\n\n    // when a new filter is set, if the first two pages of selectable indexes fit within the calendar month, focus on that calendar month.\n    this._centerRangeSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateRange$\n      .pipe(\n        first(),\n        switchMap((x) => {\n          let result: Observable<[typeof x, boolean]> = x\n            ? of([x, true])\n            : this.dbxCalendarScheduleSelectionStore.minMaxDateRange$.pipe(\n                first(),\n                map((y) => [y, false] as [typeof x, boolean])\n              );\n          return result;\n        })\n      )\n      .subscribe(([x, isFromSelectedDateRange]) => {\n        if (x?.start) {\n          let tapDay: Maybe<Date>;\n          const startMonth = dateRange({ date: x.start, type: DateRangeType.CALENDAR_MONTH });\n          const monthToFocus = endOfWeek(startMonth.start);\n\n          if (x.end != null) {\n            const endMonth = dateRange({ date: x.end, type: DateRangeType.CALENDAR_MONTH });\n\n            if (isSameDate(startMonth.start, endMonth.start)) {\n              tapDay = monthToFocus;\n            }\n          }\n\n          if (!tapDay && isFromSelectedDateRange) {\n            tapDay = monthToFocus;\n          }\n\n          if (tapDay) {\n            this.calendarStore.tapDay(tapDay);\n          }\n        }\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.clickEvent.complete();\n    this._inputReadonly.complete();\n    this._config.complete();\n    this._centerRangeSub.destroy();\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  @Input()\n  set readonly(readonly: Maybe<boolean>) {\n    this._inputReadonly.next(readonly);\n  }\n\n  dayClicked({ date }: { date: Date }): void {\n    this.readonly$.pipe(first()).subscribe((readonly) => {\n      if (!readonly) {\n        this.dbxCalendarScheduleSelectionStore.toggleSelectedDates(date);\n      }\n    });\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\" [ngClass]=\"(readonly$ | async) ? 'dbx-schedule-selection-calendar-readonly' : ''\">\n  <ng-container controls>\n    <ng-container *ngIf=\"showClearSelectionButton$ | async\">\n      <dbx-schedule-selection-calendar-selection-toggle-button [disabled]=\"readonly$ | async\"></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"]}
|
|
176
|
+
//# 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,EAAE,EAAE,iBAAiB,EAAS,MAAM,MAAM,CAAC;AACjL,OAAO,EAAoB,gBAAgB,EAAE,4BAA4B,EAAE,MAAM,2BAA2B,CAAC;AAC7G,OAAO,EAAoB,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACxE,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,kBAAkB,EAAE,YAAY,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AACrI,OAAO,EAAE,sDAAsD,EAAE,MAAM,wDAAwD,CAAC;AAChI,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACrE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;;;;;;;;;;;AAmCrC,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;oBACpB,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;IA+EhD,YAAqB,aAAkC,EAAW,iCAAoE;QAAjH,kBAAa,GAAb,aAAa,CAAqB;QAAW,sCAAiC,GAAjC,iCAAiC,CAAmC;QA9E9H,mBAAc,GAAG,IAAI,eAAe,CAAiB,SAAS,CAAC,CAAC;QAChE,YAAO,GAAG,IAAI,eAAe,CAA8C,EAAE,CAAC,CAAC;QAC/E,oBAAe,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAE1C,YAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAEpE,cAAS,GAAwB,IAAI,CAAC,OAAO,CAAC,IAAI,CACzD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAC3F,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC,EACtC,GAAG,CAAC,CAAC,CAAC,cAAc,EAAE,aAAa,CAAC,EAAE,EAAE;YACtC,OAAO,CAAC,cAAc,IAAI,KAAK,CAAC,IAAI,CAAC,aAAa,IAAI,KAAK,CAAC,CAAC;QAC/D,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,2BAAsB,GAAwB,IAAI,CAAC,OAAO,CAAC,IAAI,CACtE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,qBAAqB,IAAI,KAAK,CAAC,EAC5C,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,iBAAY,GAAG,IAAI,CAAC,sBAAsB,CAAC,IAAI,CACtD,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACd,IAAI,CAAC,EAAE;gBACL,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;aACjB;iBAAM;gBACL,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aAC5C;QACH,CAAC,CAAC,EACF,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,8BAAyB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CACpD,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,wBAAwB,IAAI,IAAI,CAAC,EACxD,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,EACpC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,EACpC,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,CACf,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,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,EACpC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAChE,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,EAAE,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,EAC9D,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,iCAAiC,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,0BAA0B;QAEvG,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;QAE5C,sIAAsI;QACtI,IAAI,CAAC,eAAe,CAAC,YAAY,GAAG,IAAI,CAAC,iCAAiC,CAAC,iBAAiB;aACzF,IAAI,CACH,KAAK,EAAE,EACP,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACd,IAAI,MAAM,GAAoC,CAAC;gBAC7C,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;gBACf,CAAC,CAAC,IAAI,CAAC,iCAAiC,CAAC,gBAAgB,CAAC,IAAI,CAC1D,KAAK,EAAE,EACP,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,CAAwB,CAAC,CAC9C,CAAC;YACN,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH;aACA,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,uBAAuB,CAAC,EAAE,EAAE;YAC1C,IAAI,CAAC,EAAE,KAAK,EAAE;gBACZ,IAAI,MAAmB,CAAC;gBACxB,MAAM,UAAU,GAAG,SAAS,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,aAAa,CAAC,cAAc,EAAE,CAAC,CAAC;gBACpF,MAAM,YAAY,GAAG,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;gBAEjD,IAAI,CAAC,CAAC,GAAG,IAAI,IAAI,EAAE;oBACjB,MAAM,QAAQ,GAAG,SAAS,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,aAAa,CAAC,cAAc,EAAE,CAAC,CAAC;oBAEhF,IAAI,UAAU,CAAC,UAAU,CAAC,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC,EAAE;wBAChD,MAAM,GAAG,YAAY,CAAC;qBACvB;iBACF;gBAED,IAAI,CAAC,MAAM,IAAI,uBAAuB,EAAE;oBACtC,MAAM,GAAG,YAAY,CAAC;iBACvB;gBAED,IAAI,MAAM,EAAE;oBACV,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;iBACnC;aACF;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;QAC/B,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QACxB,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;IACjC,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,IACI,QAAQ,CAAC,QAAwB;QACnC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED,UAAU,CAAC,EAAE,IAAI,EAAkB;QACjC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YAClD,IAAI,CAAC,QAAQ,EAAE;gBACb,IAAI,CAAC,iCAAiC,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;aAClE;QACH,CAAC,CAAC,CAAC;IACL,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;;mIAnKU,qCAAqC;uHAArC,qCAAqC,qJAFrC,CAAC,gBAAgB,CAAC,0BC7F/B,26CAqBA;4FD0Ea,qCAAqC;kBALjD,SAAS;+BACE,iCAAiC,aAEhC,CAAC,gBAAgB,CAAC;uJAqD7B,UAAU;sBADT,MAAM;gBAoFH,MAAM;sBADT,KAAK;gBAUF,QAAQ;sBADX,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, of, combineLatestWith, share } from 'rxjs';\nimport { DbxCalendarEvent, DbxCalendarStore, prepareAndSortCalendarEvents } from '@dereekb/dbx-web/calendar';\nimport { DayOfWeek, Maybe, reduceBooleansWithAnd } 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, SubscriptionObject, asObservable, asObservableFromGetter } from '@dereekb/rxjs';\nimport { DbxScheduleSelectionCalendarDatePopoverButtonComponent } from './calendar.schedule.selection.popover.button.component';\nimport { DateRangeType, dateRange, isSameDate } from '@dereekb/date';\nimport { endOfWeek } from 'date-fns';\n\nexport interface DbxScheduleSelectionCalendarComponentConfig {\n  /**\n   * Whether or not the selection calendar is readonly. Defaults to 'false'.\n   */\n  readonly readonly?: Maybe<ObservableOrValueGetter<Maybe<boolean>>>;\n  /**\n   * Whether or not to show the configured buttons when readonly is true. Defaults to false.\n   */\n  readonly showButtonsOnReadonly?: boolean;\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          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 _inputReadonly = new BehaviorSubject<Maybe<boolean>>(undefined);\n  private _config = new BehaviorSubject<DbxScheduleSelectionCalendarComponentConfig>({});\n  private _centerRangeSub = new SubscriptionObject();\n\n  readonly config$ = this._config.pipe(distinctUntilChanged(), shareReplay(1));\n\n  readonly readonly$: Observable<boolean> = this.config$.pipe(\n    switchMap((x) => (x.readonly != null ? asObservableFromGetter(x.readonly) : of(undefined))),\n    combineLatestWith(this._inputReadonly),\n    map(([configReadonly, inputReadonly]) => {\n      return (configReadonly ?? false) || (inputReadonly ?? false);\n    }),\n    shareReplay(1)\n  );\n\n  readonly showButtonsOnReadonly$: Observable<boolean> = this.config$.pipe(\n    map((x) => x.showButtonsOnReadonly ?? false),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly showButtons$ = this.showButtonsOnReadonly$.pipe(\n    switchMap((x) => {\n      if (x) {\n        return of(true);\n      } else {\n        return this.readonly$.pipe(map((x) => !x));\n      }\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly showClearSelectionButton$ = this.config$.pipe(\n    map((config) => config.showClearSelectionButton ?? true),\n    combineLatestWith(this.showButtons$),\n    map((x) => reduceBooleansWithAnd(x)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly datePopoverButtonInjectionConfig$: Observable<Maybe<DbxInjectionComponentConfig<any>>> = this.config$.pipe(\n    map((x) => x.buttonInjectionConfig),\n    switchMapDbxInjectionComponentConfig(DbxScheduleSelectionCalendarDatePopoverButtonComponent),\n    combineLatestWith(this.showButtons$),\n    map(([config, showButton]) => (showButton ? config : undefined)),\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(20, undefined, { leading: true, trailing: true }),\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.dbxCalendarScheduleSelectionStore.setViewReadonlyState(this.readonly$); // sync the readonly state\n\n    this.calendarStore.setNavigationRangeLimit(this.dbxCalendarScheduleSelectionStore.minMaxDateRange$); // set navigation limit to the min/max allowed dates.\n    this.calendarStore.setShowPageButtons(true);\n\n    // when a new filter is set, if the first two pages of selectable indexes fit within the calendar month, focus on that calendar month.\n    this._centerRangeSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateRange$\n      .pipe(\n        first(),\n        switchMap((x) => {\n          let result: Observable<[typeof x, boolean]> = x\n            ? of([x, true])\n            : this.dbxCalendarScheduleSelectionStore.minMaxDateRange$.pipe(\n                first(),\n                map((y) => [y, false] as [typeof x, boolean])\n              );\n          return result;\n        })\n      )\n      .subscribe(([x, isFromSelectedDateRange]) => {\n        if (x?.start) {\n          let tapDay: Maybe<Date>;\n          const startMonth = dateRange({ date: x.start, type: DateRangeType.CALENDAR_MONTH });\n          const monthToFocus = endOfWeek(startMonth.start);\n\n          if (x.end != null) {\n            const endMonth = dateRange({ date: x.end, type: DateRangeType.CALENDAR_MONTH });\n\n            if (isSameDate(startMonth.start, endMonth.start)) {\n              tapDay = monthToFocus;\n            }\n          }\n\n          if (!tapDay && isFromSelectedDateRange) {\n            tapDay = monthToFocus;\n          }\n\n          if (tapDay) {\n            this.calendarStore.tapDay(tapDay);\n          }\n        }\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.clickEvent.complete();\n    this._inputReadonly.complete();\n    this._config.complete();\n    this._centerRangeSub.destroy();\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  @Input()\n  set readonly(readonly: Maybe<boolean>) {\n    this._inputReadonly.next(readonly);\n  }\n\n  dayClicked({ date }: { date: Date }): void {\n    this.readonly$.pipe(first()).subscribe((readonly) => {\n      if (!readonly) {\n        this.dbxCalendarScheduleSelectionStore.toggleSelectedDates(date);\n      }\n    });\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\" [ngClass]=\"(readonly$ | async) ? 'dbx-schedule-selection-calendar-readonly' : ''\">\n  <ng-container controls>\n    <ng-container *ngIf=\"showClearSelectionButton$ | async\">\n      <dbx-schedule-selection-calendar-selection-toggle-button [disabled]=\"readonly$ | async\"></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"]}
|
|
@@ -3,7 +3,7 @@ import { Component, Inject, Input, ViewChild } from '@angular/core';
|
|
|
3
3
|
import { DbxCalendarScheduleSelectionStore } from './calendar.schedule.selection.store';
|
|
4
4
|
import { DbxCalendarStore } from '@dereekb/dbx-web/calendar';
|
|
5
5
|
import { FormGroup, FormControl } from '@angular/forms';
|
|
6
|
-
import { switchMap, throttleTime, distinctUntilChanged, filter, BehaviorSubject, startWith,
|
|
6
|
+
import { switchMap, throttleTime, distinctUntilChanged, filter, BehaviorSubject, startWith, map, shareReplay, combineLatest, EMPTY } from 'rxjs';
|
|
7
7
|
import { isSameDateDay } from '@dereekb/date';
|
|
8
8
|
import { MAT_FORM_FIELD_DEFAULT_OPTIONS } from '@angular/material/form-field';
|
|
9
9
|
import { MatDateRangePicker } from '@angular/material/datepicker';
|
|
@@ -23,7 +23,7 @@ export class DbxScheduleSelectionCalendarDateRangeComponent {
|
|
|
23
23
|
this.matFormFieldDefaultOptions = matFormFieldDefaultOptions;
|
|
24
24
|
this._required = new BehaviorSubject(false);
|
|
25
25
|
this.required$ = this._required.asObservable();
|
|
26
|
-
this.timezone$ = this.dbxCalendarScheduleSelectionStore.
|
|
26
|
+
this.timezone$ = this.dbxCalendarScheduleSelectionStore.effectiveOutputTimezone$;
|
|
27
27
|
this.openPickerOnTextClick = true;
|
|
28
28
|
this.label = 'Enter a date range';
|
|
29
29
|
this.showCustomize = false;
|
|
@@ -108,7 +108,7 @@ export class DbxScheduleSelectionCalendarDateRangeComponent {
|
|
|
108
108
|
.pipe(distinctUntilChanged(), switchMap((opened) => {
|
|
109
109
|
let obs;
|
|
110
110
|
if (opened) {
|
|
111
|
-
obs =
|
|
111
|
+
obs = EMPTY;
|
|
112
112
|
}
|
|
113
113
|
else {
|
|
114
114
|
obs = this.range.valueChanges.pipe(startWith(this.range.value));
|
|
@@ -185,4 +185,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
185
185
|
}], required: [{
|
|
186
186
|
type: Input
|
|
187
187
|
}] } });
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.schedule.selection.range.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-form/calendar/src/lib/calendar.schedule.selection.range.component.ts","../../../../../../packages/dbx-form/calendar/src/lib/calendar.schedule.selection.range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SubscriptionObject } from '@dereekb/rxjs';\nimport { Component, Inject, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { DbxCalendarScheduleSelectionStore } from './calendar.schedule.selection.store';\nimport { DbxCalendarStore } from '@dereekb/dbx-web/calendar';\nimport { FormGroup, FormControl, AbstractControl } from '@angular/forms';\nimport { Maybe } from '@dereekb/util';\nimport { switchMap, throttleTime, distinctUntilChanged, filter, BehaviorSubject, startWith, Observable, of, map, shareReplay, combineLatest } from 'rxjs';\nimport { isSameDateDay } from '@dereekb/date';\nimport { MatFormFieldDefaultOptions, MAT_FORM_FIELD_DEFAULT_OPTIONS } from '@angular/material/form-field';\nimport { ErrorStateMatcher } from '@angular/material/core';\nimport { DateFilterFn, MatDateRangePicker } from '@angular/material/datepicker';\n\ninterface RangeValue {\n  start?: Maybe<Date>;\n  end?: Maybe<Date>;\n}\n\n@Component({\n  selector: 'dbx-schedule-selection-calendar-date-range',\n  templateUrl: './calendar.schedule.selection.range.component.html'\n})\nexport class DbxScheduleSelectionCalendarDateRangeComponent implements OnInit, OnDestroy {\n  private _required = new BehaviorSubject<boolean>(false);\n\n  readonly required$ = this._required.asObservable();\n  readonly timezone$ = this.dbxCalendarScheduleSelectionStore.currentTimezone$;\n\n  @Input()\n  openPickerOnTextClick: boolean = true;\n\n  @ViewChild('picker')\n  picker!: MatDateRangePicker<Date>;\n\n  @Input()\n  label?: Maybe<string> = 'Enter a date range';\n\n  @Input()\n  hint?: Maybe<string>;\n\n  @Input()\n  set disabled(disabled: Maybe<boolean>) {\n    if (disabled) {\n      this.range.disable();\n    } else {\n      this.range.enable();\n    }\n  }\n\n  @Input()\n  showCustomize = false;\n\n  private _pickerOpened = new BehaviorSubject<boolean>(false);\n\n  private _requiredSub = new SubscriptionObject();\n  private _syncSub = new SubscriptionObject();\n  private _valueSub = new SubscriptionObject();\n\n  readonly range = new FormGroup({\n    start: new FormControl<Maybe<Date>>(null),\n    end: new FormControl<Maybe<Date>>(null)\n  });\n\n  readonly errorStateMatcher: ErrorStateMatcher = {\n    isErrorState: (control: AbstractControl | null, form) => {\n      if (control) {\n        return (control.invalid && (control.dirty || control.touched)) || (control.touched && this.range.invalid);\n      } else {\n        return false;\n      }\n    }\n  };\n\n  readonly minDate$ = this.dbxCalendarScheduleSelectionStore.minDate$;\n  readonly maxDate$ = this.dbxCalendarScheduleSelectionStore.maxDate$;\n  readonly timezoneReleventDate$ = this.dbxCalendarScheduleSelectionStore.currentDateRange$.pipe(\n    map((currentDateRange) => {\n      return currentDateRange ? currentDateRange.start ?? currentDateRange.end : undefined ?? new Date();\n    }),\n    shareReplay(1)\n  );\n\n  readonly isCustomized$ = this.dbxCalendarScheduleSelectionStore.isCustomized$;\n  readonly currentErrorMessage$ = this.range.statusChanges.pipe(\n    filter((x) => x === 'INVALID' || x === 'VALID'),\n    map((x) => {\n      let currentErrorMessage: string | undefined;\n\n      if (x === 'INVALID') {\n        const { start, end } = this.range.controls;\n\n        if (this.range.hasError('required')) {\n          currentErrorMessage = 'Date range is required';\n        } else if (start.hasError('matStartDateInvalid')) {\n          currentErrorMessage = 'Invalid start date';\n        } else if (start.hasError('matDatepickerMin')) {\n          currentErrorMessage = 'Start date is too early';\n        } else if (start.hasError('matDatepickerMax')) {\n          currentErrorMessage = 'Start date is too late';\n        } else if (end.hasError('matStartDateInvalid')) {\n          currentErrorMessage = 'Invalid end date';\n        } else if (end.hasError('matDatepickerMin')) {\n          currentErrorMessage = 'End date is too early';\n        } else if (end.hasError('matDatepickerMax')) {\n          currentErrorMessage = 'End date is too late';\n        }\n      }\n\n      return currentErrorMessage;\n    }),\n    shareReplay(1)\n  );\n\n  readonly pickerOpened$ = this._pickerOpened.asObservable();\n\n  readonly defaultDatePickerFilter: DateFilterFn<Date> = () => true;\n  readonly datePickerFilter$: Observable<DateFilterFn<Date>> = combineLatest([this.dbxCalendarScheduleSelectionStore.isEnabledFilterDayFunction$, this.dbxCalendarScheduleSelectionStore.isInAllowedDaysOfWeekFunction$]).pipe(\n    map(([isEnabled, isAllowedDayOfWeek]) => {\n      const fn = (date: Date | null) => {\n        const result = date ? isAllowedDayOfWeek(date) && isEnabled(date) : true;\n        return result;\n      };\n      return fn;\n    }),\n    shareReplay(1)\n  );\n\n  constructor(readonly dbxCalendarStore: DbxCalendarStore, readonly dbxCalendarScheduleSelectionStore: DbxCalendarScheduleSelectionStore, @Inject(MAT_FORM_FIELD_DEFAULT_OPTIONS) readonly matFormFieldDefaultOptions: MatFormFieldDefaultOptions) {}\n\n  ngOnInit(): void {\n    this._syncSub.subscription = this.dbxCalendarScheduleSelectionStore.currentInputRange$.subscribe((x) => {\n      this.range.setValue({\n        start: x?.inputStart ?? null,\n        end: x?.inputEnd ?? null\n      });\n    });\n\n    this._valueSub.subscription = this._pickerOpened\n      .pipe(\n        distinctUntilChanged(),\n        switchMap((opened) => {\n          let obs: Observable<RangeValue>;\n\n          if (opened) {\n            obs = of({});\n          } else {\n            obs = this.range.valueChanges.pipe(startWith(this.range.value));\n          }\n\n          return obs;\n        }),\n        filter((x) => Boolean(x.start && x.end)),\n        distinctUntilChanged((a, b) => isSameDateDay(a.start, b.start) && isSameDateDay(a.end, b.end)),\n        throttleTime(100, undefined, { trailing: true })\n      )\n      .subscribe((x) => {\n        if (x.start && x.end) {\n          this.dbxCalendarScheduleSelectionStore.setInputRange({ inputStart: x.start, inputEnd: x.end });\n        }\n      });\n\n    // add a required validator when needed\n    this._requiredSub.subscription = this._required.subscribe((x) => {\n      const validators = x\n        ? [\n            (control: AbstractControl) => {\n              const range = control.value;\n\n              if (!range || !range.start || !range.end) {\n                return { required: true };\n              }\n\n              return null;\n            }\n          ]\n        : [];\n\n      this.range.setValidators(validators);\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._required.complete();\n    this._pickerOpened.complete();\n    this._requiredSub.destroy();\n    this._syncSub.destroy();\n    this._valueSub.destroy();\n  }\n\n  @Input()\n  get required() {\n    return this._required.value;\n  }\n\n  set required(required: boolean) {\n    this._required.next(required);\n  }\n\n  clickedDateRangeInput() {\n    if (this.openPickerOnTextClick) {\n      this.picker.open();\n    }\n  }\n\n  pickerOpened() {\n    this._pickerOpened.next(true);\n  }\n\n  pickerClosed() {\n    this._pickerOpened.next(false);\n  }\n}\n","<mat-form-field class=\"dbx-schedule-selection-calendar-date-range-field\">\n  <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n  <div class=\"dbx-schedule-selection-calendar-date-range-field-content\">\n    <!-- Primary Content -->\n    <div class=\"dbx-flex\">\n      <div *ngIf=\"showCustomize && (isCustomized$ | async)\" class=\"date-range-field-customized\">\n        <span class=\"dbx-accent-bg date-range-field-customized-text\">Custom</span>\n      </div>\n      <dbx-button-spacer></dbx-button-spacer>\n      <mat-datepicker-toggle class=\"mat-datepicker-button-highlight\" matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n      <dbx-button-spacer></dbx-button-spacer>\n      <mat-date-range-input (click)=\"clickedDateRangeInput()\" [required]=\"required$ | async\" [dateFilter]=\"(datePickerFilter$ | async) ?? defaultDatePickerFilter\" [formGroup]=\"range\" [rangePicker]=\"picker\">\n        <input [errorStateMatcher]=\"errorStateMatcher\" matStartDate formControlName=\"start\" placeholder=\"Start date\" />\n        <input [errorStateMatcher]=\"errorStateMatcher\" matEndDate formControlName=\"end\" placeholder=\"End date\" />\n      </mat-date-range-input>\n      <span *ngIf=\"timezone$ | async\" class=\"dbx-flex-bar dbx-faint dbx-nowrap dbx-icon-spacer\">{{ timezone$ | async | timezoneAbbreviation: (timezoneReleventDate$ | async) }}</span>\n      <div *ngIf=\"showCustomize\">\n        <dbx-button-spacer></dbx-button-spacer>\n        <ng-content select=\"[customizeButton]\"></ng-content>\n      </div>\n      <mat-date-range-picker #picker (opened)=\"pickerOpened()\" (closed)=\"pickerClosed()\"></mat-date-range-picker>\n    </div>\n    <!-- Custom Content -->\n    <div>\n      <ng-content></ng-content>\n    </div>\n  </div>\n  <mat-error *ngIf=\"currentErrorMessage$ | async\">{{ currentErrorMessage$ | async }}</mat-error>\n  <mat-hint>{{ hint }}</mat-hint>\n</mat-form-field>\n"]}
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.schedule.selection.range.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-form/calendar/src/lib/calendar.schedule.selection.range.component.ts","../../../../../../packages/dbx-form/calendar/src/lib/calendar.schedule.selection.range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SubscriptionObject } from '@dereekb/rxjs';\nimport { Component, Inject, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { DbxCalendarScheduleSelectionStore } from './calendar.schedule.selection.store';\nimport { DbxCalendarStore } from '@dereekb/dbx-web/calendar';\nimport { FormGroup, FormControl, AbstractControl } from '@angular/forms';\nimport { Maybe } from '@dereekb/util';\nimport { switchMap, throttleTime, distinctUntilChanged, filter, BehaviorSubject, startWith, Observable, of, map, shareReplay, combineLatest, EMPTY } from 'rxjs';\nimport { isSameDateDay } from '@dereekb/date';\nimport { MatFormFieldDefaultOptions, MAT_FORM_FIELD_DEFAULT_OPTIONS } from '@angular/material/form-field';\nimport { ErrorStateMatcher } from '@angular/material/core';\nimport { DateFilterFn, MatDateRangePicker } from '@angular/material/datepicker';\n\ninterface RangeValue {\n  start?: Maybe<Date>;\n  end?: Maybe<Date>;\n}\n\n@Component({\n  selector: 'dbx-schedule-selection-calendar-date-range',\n  templateUrl: './calendar.schedule.selection.range.component.html'\n})\nexport class DbxScheduleSelectionCalendarDateRangeComponent implements OnInit, OnDestroy {\n  private _required = new BehaviorSubject<boolean>(false);\n\n  readonly required$ = this._required.asObservable();\n  readonly timezone$ = this.dbxCalendarScheduleSelectionStore.effectiveOutputTimezone$;\n\n  @Input()\n  openPickerOnTextClick: boolean = true;\n\n  @ViewChild('picker')\n  picker!: MatDateRangePicker<Date>;\n\n  @Input()\n  label?: Maybe<string> = 'Enter a date range';\n\n  @Input()\n  hint?: Maybe<string>;\n\n  @Input()\n  set disabled(disabled: Maybe<boolean>) {\n    if (disabled) {\n      this.range.disable();\n    } else {\n      this.range.enable();\n    }\n  }\n\n  @Input()\n  showCustomize = false;\n\n  private _pickerOpened = new BehaviorSubject<boolean>(false);\n\n  private _requiredSub = new SubscriptionObject();\n  private _syncSub = new SubscriptionObject();\n  private _valueSub = new SubscriptionObject();\n\n  readonly range = new FormGroup({\n    start: new FormControl<Maybe<Date>>(null),\n    end: new FormControl<Maybe<Date>>(null)\n  });\n\n  readonly errorStateMatcher: ErrorStateMatcher = {\n    isErrorState: (control: AbstractControl | null, form) => {\n      if (control) {\n        return (control.invalid && (control.dirty || control.touched)) || (control.touched && this.range.invalid);\n      } else {\n        return false;\n      }\n    }\n  };\n\n  readonly minDate$ = this.dbxCalendarScheduleSelectionStore.minDate$;\n  readonly maxDate$ = this.dbxCalendarScheduleSelectionStore.maxDate$;\n  readonly timezoneReleventDate$ = this.dbxCalendarScheduleSelectionStore.currentDateRange$.pipe(\n    map((currentDateRange) => {\n      return currentDateRange ? currentDateRange.start ?? currentDateRange.end : undefined ?? new Date();\n    }),\n    shareReplay(1)\n  );\n\n  readonly isCustomized$ = this.dbxCalendarScheduleSelectionStore.isCustomized$;\n  readonly currentErrorMessage$ = this.range.statusChanges.pipe(\n    filter((x) => x === 'INVALID' || x === 'VALID'),\n    map((x) => {\n      let currentErrorMessage: string | undefined;\n\n      if (x === 'INVALID') {\n        const { start, end } = this.range.controls;\n\n        if (this.range.hasError('required')) {\n          currentErrorMessage = 'Date range is required';\n        } else if (start.hasError('matStartDateInvalid')) {\n          currentErrorMessage = 'Invalid start date';\n        } else if (start.hasError('matDatepickerMin')) {\n          currentErrorMessage = 'Start date is too early';\n        } else if (start.hasError('matDatepickerMax')) {\n          currentErrorMessage = 'Start date is too late';\n        } else if (end.hasError('matStartDateInvalid')) {\n          currentErrorMessage = 'Invalid end date';\n        } else if (end.hasError('matDatepickerMin')) {\n          currentErrorMessage = 'End date is too early';\n        } else if (end.hasError('matDatepickerMax')) {\n          currentErrorMessage = 'End date is too late';\n        }\n      }\n\n      return currentErrorMessage;\n    }),\n    shareReplay(1)\n  );\n\n  readonly pickerOpened$ = this._pickerOpened.asObservable();\n\n  readonly defaultDatePickerFilter: DateFilterFn<Date> = () => true;\n  readonly datePickerFilter$: Observable<DateFilterFn<Date>> = combineLatest([this.dbxCalendarScheduleSelectionStore.isEnabledFilterDayFunction$, this.dbxCalendarScheduleSelectionStore.isInAllowedDaysOfWeekFunction$]).pipe(\n    map(([isEnabled, isAllowedDayOfWeek]) => {\n      const fn = (date: Date | null) => {\n        const result = date ? isAllowedDayOfWeek(date) && isEnabled(date) : true;\n        return result;\n      };\n      return fn;\n    }),\n    shareReplay(1)\n  );\n\n  constructor(readonly dbxCalendarStore: DbxCalendarStore, readonly dbxCalendarScheduleSelectionStore: DbxCalendarScheduleSelectionStore, @Inject(MAT_FORM_FIELD_DEFAULT_OPTIONS) readonly matFormFieldDefaultOptions: MatFormFieldDefaultOptions) {}\n\n  ngOnInit(): void {\n    this._syncSub.subscription = this.dbxCalendarScheduleSelectionStore.currentInputRange$.subscribe((x) => {\n      this.range.setValue({\n        start: x?.inputStart ?? null,\n        end: x?.inputEnd ?? null\n      });\n    });\n\n    this._valueSub.subscription = this._pickerOpened\n      .pipe(\n        distinctUntilChanged(),\n        switchMap((opened) => {\n          let obs: Observable<RangeValue>;\n\n          if (opened) {\n            obs = EMPTY;\n          } else {\n            obs = this.range.valueChanges.pipe(startWith(this.range.value));\n          }\n\n          return obs;\n        }),\n        filter((x) => Boolean(x.start && x.end)),\n        distinctUntilChanged((a, b) => isSameDateDay(a.start, b.start) && isSameDateDay(a.end, b.end)),\n        throttleTime(100, undefined, { trailing: true })\n      )\n      .subscribe((x) => {\n        if (x.start && x.end) {\n          this.dbxCalendarScheduleSelectionStore.setInputRange({ inputStart: x.start, inputEnd: x.end });\n        }\n      });\n\n    // add a required validator when needed\n    this._requiredSub.subscription = this._required.subscribe((x) => {\n      const validators = x\n        ? [\n            (control: AbstractControl) => {\n              const range = control.value;\n\n              if (!range || !range.start || !range.end) {\n                return { required: true };\n              }\n\n              return null;\n            }\n          ]\n        : [];\n\n      this.range.setValidators(validators);\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._required.complete();\n    this._pickerOpened.complete();\n    this._requiredSub.destroy();\n    this._syncSub.destroy();\n    this._valueSub.destroy();\n  }\n\n  @Input()\n  get required() {\n    return this._required.value;\n  }\n\n  set required(required: boolean) {\n    this._required.next(required);\n  }\n\n  clickedDateRangeInput() {\n    if (this.openPickerOnTextClick) {\n      this.picker.open();\n    }\n  }\n\n  pickerOpened() {\n    this._pickerOpened.next(true);\n  }\n\n  pickerClosed() {\n    this._pickerOpened.next(false);\n  }\n}\n","<mat-form-field class=\"dbx-schedule-selection-calendar-date-range-field\">\n  <mat-label *ngIf=\"label\">{{ label }}</mat-label>\n  <div class=\"dbx-schedule-selection-calendar-date-range-field-content\">\n    <!-- Primary Content -->\n    <div class=\"dbx-flex\">\n      <div *ngIf=\"showCustomize && (isCustomized$ | async)\" class=\"date-range-field-customized\">\n        <span class=\"dbx-accent-bg date-range-field-customized-text\">Custom</span>\n      </div>\n      <dbx-button-spacer></dbx-button-spacer>\n      <mat-datepicker-toggle class=\"mat-datepicker-button-highlight\" matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n      <dbx-button-spacer></dbx-button-spacer>\n      <mat-date-range-input (click)=\"clickedDateRangeInput()\" [required]=\"required$ | async\" [dateFilter]=\"(datePickerFilter$ | async) ?? defaultDatePickerFilter\" [formGroup]=\"range\" [rangePicker]=\"picker\">\n        <input [errorStateMatcher]=\"errorStateMatcher\" matStartDate formControlName=\"start\" placeholder=\"Start date\" />\n        <input [errorStateMatcher]=\"errorStateMatcher\" matEndDate formControlName=\"end\" placeholder=\"End date\" />\n      </mat-date-range-input>\n      <span *ngIf=\"timezone$ | async\" class=\"dbx-flex-bar dbx-faint dbx-nowrap dbx-icon-spacer\">{{ timezone$ | async | timezoneAbbreviation: (timezoneReleventDate$ | async) }}</span>\n      <div *ngIf=\"showCustomize\">\n        <dbx-button-spacer></dbx-button-spacer>\n        <ng-content select=\"[customizeButton]\"></ng-content>\n      </div>\n      <mat-date-range-picker #picker (opened)=\"pickerOpened()\" (closed)=\"pickerClosed()\"></mat-date-range-picker>\n    </div>\n    <!-- Custom Content -->\n    <div>\n      <ng-content></ng-content>\n    </div>\n  </div>\n  <mat-error *ngIf=\"currentErrorMessage$ | async\">{{ currentErrorMessage$ | async }}</mat-error>\n  <mat-hint>{{ hint }}</mat-hint>\n</mat-form-field>\n"]}
|