@dereekb/dbx-form 9.24.37 → 9.24.39

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.
@@ -1,4 +1,4 @@
1
- import { DateBlockDayOfWeekFactory, DateBlockIndex, DateBlockRangeWithRange, DateRange, DateScheduleDateFilterConfig, DateScheduleDayCode, DateScheduleRange, DateTimingRelativeIndexFactory, DateOrDateRangeOrDateBlockIndexOrDateBlockRange, DateTimezoneUtcNormalInstance, DateBlock, DateBlockDurationSpan, DateTimingRelativeIndexFactoryInput, DateBlockTimingStart } from '@dereekb/date';
1
+ import { DateBlockDayOfWeekFactory, DateBlockIndex, DateBlockRangeWithRange, DateRange, DateScheduleDateFilterConfig, DateScheduleDayCode, DateScheduleRange, DateBlockTimingRelativeIndexFactory, DateOrDateRangeOrDateBlockIndexOrDateBlockRange, DateTimezoneUtcNormalInstance, DateBlock, DateBlockDurationSpan, DateBlockTimingRelativeIndexFactoryInput, DateBlockTimingStart } from '@dereekb/date';
2
2
  import { Maybe, TimezoneString, DecisionFunction, IterableOrValue, MaybeMap, DayOfWeek, AllOrNoneSelection, ArrayOrValue, ISO8601DayString } from '@dereekb/util';
3
3
  import { ComponentStore } from '@ngrx/component-store';
4
4
  import { Observable } from 'rxjs';
@@ -59,9 +59,9 @@ export interface CalendarScheduleSelectionState extends PartialCalendarScheduleS
59
59
  */
60
60
  timezoneNormal?: Maybe<DateTimezoneUtcNormalInstance>;
61
61
  /**
62
- * DateTimingRelativeIndexFactory
62
+ * DateBlockTimingRelativeIndexFactory
63
63
  */
64
- indexFactory: DateTimingRelativeIndexFactory;
64
+ indexFactory: DateBlockTimingRelativeIndexFactory;
65
65
  /**
66
66
  * Array of manually selected dates within the picked range. This is NOT the set of all selected indexes in terms of output.
67
67
  *
@@ -93,13 +93,13 @@ export interface CalendarScheduleSelectionState extends PartialCalendarScheduleS
93
93
  /**
94
94
  * Decision function that returns true if a value is enabled given the current filter.
95
95
  */
96
- isEnabledFilterDay: DecisionFunction<DateTimingRelativeIndexFactoryInput>;
96
+ isEnabledFilterDay: DecisionFunction<DateBlockTimingRelativeIndexFactoryInput>;
97
97
  /**
98
98
  * Decision function that returns true if a value is enabled.
99
99
  *
100
100
  * This function does not take the current filter into account.
101
101
  */
102
- isEnabledDay: DecisionFunction<DateTimingRelativeIndexFactoryInput>;
102
+ isEnabledDay: DecisionFunction<DateBlockTimingRelativeIndexFactoryInput>;
103
103
  /**
104
104
  * CalendarScheduleSelectionCellContentFactory for the view.
105
105
  */
@@ -140,13 +140,17 @@ export declare class DbxCalendarScheduleSelectionStore extends ComponentStore<Ca
140
140
  * @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.
141
141
  */
142
142
  readonly selectedDates$: Observable<Set<DateBlockIndex>>;
143
- readonly isEnabledFilterDayFunction$: Observable<DecisionFunction<DateTimingRelativeIndexFactoryInput>>;
144
- readonly isEnabledDayFunction$: Observable<DecisionFunction<DateTimingRelativeIndexFactoryInput>>;
143
+ readonly isEnabledFilterDayFunction$: Observable<DecisionFunction<DateBlockTimingRelativeIndexFactoryInput>>;
144
+ readonly isEnabledDayFunction$: Observable<DecisionFunction<DateBlockTimingRelativeIndexFactoryInput>>;
145
145
  readonly currentDateRange$: Observable<Maybe<DateRange>>;
146
146
  readonly computeSelectionResultRelativeToFilter$: Observable<Maybe<boolean>>;
147
147
  readonly startBeingUsedFromFilter$: Observable<Maybe<boolean>>;
148
148
  readonly dateRange$: Observable<DateRange>;
149
149
  readonly allowedDaysOfWeek$: Observable<Set<DayOfWeek>>;
150
+ readonly isInAllowedDaysOfWeekFunction$: Observable<DecisionFunction<Date | DayOfWeek> & {
151
+ readonly _readValue: (input: Date | DayOfWeek) => DayOfWeek;
152
+ readonly _set: Set<DayOfWeek>;
153
+ }>;
150
154
  readonly scheduleDays$: Observable<Set<DateScheduleDayCode>>;
151
155
  readonly currentTimezone$: Observable<Maybe<TimezoneString>>;
152
156
  readonly effectiveTimezone$: Observable<Maybe<TimezoneString>>;
@@ -177,11 +181,11 @@ export declare class DbxCalendarScheduleSelectionStore extends ComponentStore<Ca
177
181
  readonly clearFilter: () => void;
178
182
  readonly setTimezone: (() => void) | ((observableOrValue: Maybe<string> | Observable<Maybe<string>>) => import("rxjs").Subscription);
179
183
  readonly setInputRange: (observableOrValue: CalendarScheduleSelectionInputDateRange | Observable<CalendarScheduleSelectionInputDateRange>) => import("rxjs").Subscription;
180
- readonly toggleSelectedDates: (observableOrValue: IterableOrValue<DateTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
181
- readonly addSelectedDates: (observableOrValue: IterableOrValue<DateTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
182
- readonly removeSelectedDates: (observableOrValue: IterableOrValue<DateTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
183
- readonly setSelectedDates: (observableOrValue: IterableOrValue<DateTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
184
- readonly setSelectedIndexes: (observableOrValue: IterableOrValue<DateTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
184
+ readonly toggleSelectedDates: (observableOrValue: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
185
+ readonly addSelectedDates: (observableOrValue: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
186
+ readonly removeSelectedDates: (observableOrValue: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
187
+ readonly setSelectedDates: (observableOrValue: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
188
+ readonly setSelectedIndexes: (observableOrValue: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput> | Observable<IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>>) => import("rxjs").Subscription;
185
189
  readonly selectAllDates: (observableOrValue: AllOrNoneSelection | Observable<AllOrNoneSelection>) => import("rxjs").Subscription;
186
190
  readonly setInitialSelectionState: (() => void) | ((observableOrValue: Maybe<AllOrNoneSelection> | Observable<Maybe<AllOrNoneSelection>>) => import("rxjs").Subscription);
187
191
  readonly setDefaultScheduleDays: (() => void) | ((observableOrValue: Maybe<Iterable<DateScheduleDayCode>> | Observable<Maybe<Iterable<DateScheduleDayCode>>>) => import("rxjs").Subscription);
@@ -210,10 +214,10 @@ export declare function updateStateWithChangedScheduleDays(state: CalendarSchedu
210
214
  export declare function finalizeUpdateStateWithChangedScheduleDays(previousState: CalendarScheduleSelectionState, nextState: CalendarScheduleSelectionState): CalendarScheduleSelectionState;
211
215
  export interface CalendarScheduleSelectionStateDatesChange {
212
216
  reset?: true;
213
- toggle?: IterableOrValue<DateTimingRelativeIndexFactoryInput>;
214
- add?: IterableOrValue<DateTimingRelativeIndexFactoryInput>;
215
- remove?: IterableOrValue<DateTimingRelativeIndexFactoryInput>;
216
- set?: IterableOrValue<DateTimingRelativeIndexFactoryInput>;
217
+ toggle?: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>;
218
+ add?: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>;
219
+ remove?: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>;
220
+ set?: IterableOrValue<DateBlockTimingRelativeIndexFactoryInput>;
217
221
  selectAll?: AllOrNoneSelection;
218
222
  /**
219
223
  * Inverts the set date changing behavior so that the set input is treated as items that should be retained instead of excluded.
@@ -226,7 +230,7 @@ export declare function updateStateWithChangedDates(state: CalendarScheduleSelec
226
230
  export declare function noSelectionCalendarScheduleSelectionState(state: CalendarScheduleSelectionState): CalendarScheduleSelectionState;
227
231
  export declare function updateStateWithChangedRange(state: CalendarScheduleSelectionState, change: CalendarScheduleSelectionInputDateRange): CalendarScheduleSelectionState;
228
232
  export declare function finalizeNewCalendarScheduleSelectionState(nextState: CalendarScheduleSelectionState): CalendarScheduleSelectionState;
229
- export declare function isEnabledDayInCalendarScheduleSelectionState(state: CalendarScheduleSelectionState): DecisionFunction<DateTimingRelativeIndexFactoryInput>;
233
+ export declare function isEnabledDayInCalendarScheduleSelectionState(state: CalendarScheduleSelectionState): DecisionFunction<DateBlockTimingRelativeIndexFactoryInput>;
230
234
  export declare function computeScheduleSelectionValue(state: CalendarScheduleSelectionState): Maybe<CalendarScheduleSelectionValue>;
231
235
  export interface CalendarScheduleSelectionRangeAndExclusion extends DateRange {
232
236
  dateBlockRange: DateBlockRangeWithRange;
@@ -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, of, map, shareReplay } from 'rxjs';
6
+ import { switchMap, throttleTime, distinctUntilChanged, filter, BehaviorSubject, startWith, of, map, shareReplay, combineLatest } 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';
@@ -81,9 +81,9 @@ export class DbxScheduleSelectionCalendarDateRangeComponent {
81
81
  }), shareReplay(1));
82
82
  this.pickerOpened$ = this._pickerOpened.asObservable();
83
83
  this.defaultDatePickerFilter = () => true;
84
- this.datePickerFilter$ = this.dbxCalendarScheduleSelectionStore.isEnabledFilterDayFunction$.pipe(map((isEnabled) => {
84
+ this.datePickerFilter$ = combineLatest([this.dbxCalendarScheduleSelectionStore.isEnabledFilterDayFunction$, this.dbxCalendarScheduleSelectionStore.isInAllowedDaysOfWeekFunction$]).pipe(map(([isEnabled, isAllowedDayOfWeek]) => {
85
85
  const fn = (date) => {
86
- const result = date ? isEnabled(date) : true;
86
+ const result = date ? isAllowedDayOfWeek(date) && isEnabled(date) : true;
87
87
  return result;
88
88
  };
89
89
  return fn;
@@ -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 } 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>> = this.dbxCalendarScheduleSelectionStore.isEnabledFilterDayFunction$.pipe(\n    map((isEnabled) => {\n      const fn = (date: Date | null) => {\n        const result = date ? isEnabled(date) : true;\n\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":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AACvF,OAAO,EAAE,iCAAiC,EAAE,MAAM,qCAAqC,CAAC;AACxF,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,WAAW,EAAmB,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,EAAE,eAAe,EAAE,SAAS,EAAc,EAAE,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AAC1J,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAA8B,8BAA8B,EAAE,MAAM,8BAA8B,CAAC;AAE1G,OAAO,EAAgB,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;;;;;;;;;;AAWhF,MAAM,OAAO,8CAA8C;IAyGzD,YAAqB,gBAAkC,EAAW,iCAAoE,EAAmD,0BAAsD;QAA1N,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAW,sCAAiC,GAAjC,iCAAiC,CAAmC;QAAmD,+BAA0B,GAA1B,0BAA0B,CAA4B;QAxGvO,cAAS,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAE/C,cAAS,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;QAC1C,cAAS,GAAG,IAAI,CAAC,iCAAiC,CAAC,gBAAgB,CAAC;QAG7E,0BAAqB,GAAY,IAAI,CAAC;QAMtC,UAAK,GAAmB,oBAAoB,CAAC;QAe7C,kBAAa,GAAG,KAAK,CAAC;QAEd,kBAAa,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAEpD,iBAAY,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACxC,aAAQ,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACpC,cAAS,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAEpC,UAAK,GAAG,IAAI,SAAS,CAAC;YAC7B,KAAK,EAAE,IAAI,WAAW,CAAc,IAAI,CAAC;YACzC,GAAG,EAAE,IAAI,WAAW,CAAc,IAAI,CAAC;SACxC,CAAC,CAAC;QAEM,sBAAiB,GAAsB;YAC9C,YAAY,EAAE,CAAC,OAA+B,EAAE,IAAI,EAAE,EAAE;gBACtD,IAAI,OAAO,EAAE;oBACX,OAAO,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;iBAC3G;qBAAM;oBACL,OAAO,KAAK,CAAC;iBACd;YACH,CAAC;SACF,CAAC;QAEO,aAAQ,GAAG,IAAI,CAAC,iCAAiC,CAAC,QAAQ,CAAC;QAC3D,aAAQ,GAAG,IAAI,CAAC,iCAAiC,CAAC,QAAQ,CAAC;QAC3D,0BAAqB,GAAG,IAAI,CAAC,iCAAiC,CAAC,iBAAiB,CAAC,IAAI,CAC5F,GAAG,CAAC,CAAC,gBAAgB,EAAE,EAAE;YACvB,OAAO,gBAAgB,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,IAAI,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,IAAI,IAAI,IAAI,EAAE,CAAC;QACrG,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,kBAAa,GAAG,IAAI,CAAC,iCAAiC,CAAC,aAAa,CAAC;QACrE,yBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,CAC3D,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,IAAI,CAAC,KAAK,OAAO,CAAC,EAC/C,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACR,IAAI,mBAAuC,CAAC;YAE5C,IAAI,CAAC,KAAK,SAAS,EAAE;gBACnB,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAE3C,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE;oBACnC,mBAAmB,GAAG,wBAAwB,CAAC;iBAChD;qBAAM,IAAI,KAAK,CAAC,QAAQ,CAAC,qBAAqB,CAAC,EAAE;oBAChD,mBAAmB,GAAG,oBAAoB,CAAC;iBAC5C;qBAAM,IAAI,KAAK,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE;oBAC7C,mBAAmB,GAAG,yBAAyB,CAAC;iBACjD;qBAAM,IAAI,KAAK,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE;oBAC7C,mBAAmB,GAAG,wBAAwB,CAAC;iBAChD;qBAAM,IAAI,GAAG,CAAC,QAAQ,CAAC,qBAAqB,CAAC,EAAE;oBAC9C,mBAAmB,GAAG,kBAAkB,CAAC;iBAC1C;qBAAM,IAAI,GAAG,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE;oBAC3C,mBAAmB,GAAG,uBAAuB,CAAC;iBAC/C;qBAAM,IAAI,GAAG,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE;oBAC3C,mBAAmB,GAAG,sBAAsB,CAAC;iBAC9C;aACF;YAED,OAAO,mBAAmB,CAAC;QAC7B,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,kBAAa,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;QAElD,4BAAuB,GAAuB,GAAG,EAAE,CAAC,IAAI,CAAC;QACzD,sBAAiB,GAAmC,aAAa,CAAC,CAAC,IAAI,CAAC,iCAAiC,CAAC,2BAA2B,EAAE,IAAI,CAAC,iCAAiC,CAAC,8BAA8B,CAAC,CAAC,CAAC,IAAI,CAC1N,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,kBAAkB,CAAC,EAAE,EAAE;YACtC,MAAM,EAAE,GAAG,CAAC,IAAiB,EAAE,EAAE;gBAC/B,MAAM,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;gBACzE,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC;YACF,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;IAEgP,CAAC;IAvFnP,IACI,QAAQ,CAAC,QAAwB;QACnC,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;SACtB;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;SACrB;IACH,CAAC;IAkFD,QAAQ;QACN,IAAI,CAAC,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,iCAAiC,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACrG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAClB,KAAK,EAAE,CAAC,EAAE,UAAU,IAAI,IAAI;gBAC5B,GAAG,EAAE,CAAC,EAAE,QAAQ,IAAI,IAAI;aACzB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa;aAC7C,IAAI,CACH,oBAAoB,EAAE,EACtB,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACnB,IAAI,GAA2B,CAAC;YAEhC,IAAI,MAAM,EAAE;gBACV,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;aACd;iBAAM;gBACL,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;aACjE;YAED,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,EACF,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EACxC,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,aAAa,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAC9F,YAAY,CAAC,GAAG,EAAE,SAAS,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CACjD;aACA,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACf,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,EAAE;gBACpB,IAAI,CAAC,iCAAiC,CAAC,aAAa,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;aAChG;QACH,CAAC,CAAC,CAAC;QAEL,uCAAuC;QACvC,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC9D,MAAM,UAAU,GAAG,CAAC;gBAClB,CAAC,CAAC;oBACE,CAAC,OAAwB,EAAE,EAAE;wBAC3B,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;wBAE5B,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE;4BACxC,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;yBAC3B;wBAED,OAAO,IAAI,CAAC;oBACd,CAAC;iBACF;gBACH,CAAC,CAAC,EAAE,CAAC;YAEP,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QACxB,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAED,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;IAC9B,CAAC;IAED,IAAI,QAAQ,CAAC,QAAiB;QAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAChC,CAAC;IAED,qBAAqB;QACnB,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;SACpB;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,YAAY;QACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;;4IA5LU,8CAA8C,mGAyGuF,8BAA8B;gIAzGnK,8CAA8C,0VCrB3D,k4DA8BA;4FDTa,8CAA8C;kBAJ1D,SAAS;+BACE,4CAA4C;;0BA4GmF,MAAM;2BAAC,8BAA8B;4CAlG9K,qBAAqB;sBADpB,KAAK;gBAIN,MAAM;sBADL,SAAS;uBAAC,QAAQ;gBAInB,KAAK;sBADJ,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIF,QAAQ;sBADX,KAAK;gBAUN,aAAa;sBADZ,KAAK;gBA6IF,QAAQ;sBADX,KAAK","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"]}