@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.
@@ -67,8 +67,8 @@ export class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
67
67
  get exclusions() {
68
68
  return this.props.exclusions;
69
69
  }
70
- get timezone() {
71
- return this.props.timezone;
70
+ get outputTimezone() {
71
+ return this.props.outputTimezone || this.props.timezone;
72
72
  }
73
73
  get initialSelectionState() {
74
74
  return this.props.initialSelectionState;
@@ -93,7 +93,7 @@ export class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
93
93
  this._valueSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateCellScheduleRangeValue$.subscribe((x) => {
94
94
  this.formControl.setValue(x);
95
95
  });
96
- const { timezone, minMaxDateRange, filter, exclusions, defaultScheduleDays } = this;
96
+ const { outputTimezone, minMaxDateRange, filter, exclusions, defaultScheduleDays } = this;
97
97
  if (filter != null) {
98
98
  this._filterSub.subscription = this.dbxCalendarScheduleSelectionStore.setFilter(asObservable(filter));
99
99
  }
@@ -106,8 +106,8 @@ export class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
106
106
  if (exclusions != null) {
107
107
  this._exclusionsSub.subscription = this.dbxCalendarScheduleSelectionStore.setExclusions(asObservable(exclusions));
108
108
  }
109
- if (timezone != null) {
110
- this.dbxCalendarScheduleSelectionStore.setTimezone(asObservable(this.timezone));
109
+ if (outputTimezone != null) {
110
+ this.dbxCalendarScheduleSelectionStore.setOutputTimezone(asObservable(this.outputTimezone));
111
111
  }
112
112
  if (this.initialSelectionState !== undefined) {
113
113
  this.dbxCalendarScheduleSelectionStore.setInitialSelectionState(this.initialSelectionState);
@@ -155,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
155
155
  }], ctorParameters: function () { return [{ type: i1.CompactContextStore, decorators: [{
156
156
  type: Optional
157
157
  }] }, { type: i2.DbxCalendarScheduleSelectionStore }, { type: i0.NgZone }]; } });
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.schedule.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/calendar/src/lib/field/schedule/calendar.schedule.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore } from '@dereekb/dbx-web';\nimport { Component, NgZone, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { ArrayOrValue, Maybe } from '@dereekb/util';\nimport { FieldType } from '@ngx-formly/material';\nimport { BehaviorSubject, distinctUntilChanged, map, shareReplay, startWith, Subscription, switchMap } from 'rxjs';\nimport { filterMaybe, ObservableOrValue, SubscriptionObject, asObservable } from '@dereekb/rxjs';\nimport { DateRange, TimezoneString, isSameDateCellScheduleDateRange, DateCellScheduleDateFilterConfig, DateCellScheduleDayCode, DateOrDateRangeOrDateCellIndexOrDateCellRange } from '@dereekb/date';\nimport { CalendarScheduleSelectionState, DbxCalendarScheduleSelectionStore } from '../../calendar.schedule.selection.store';\nimport { provideCalendarScheduleSelectionStoreIfParentIsUnavailable } from '../../calendar.schedule.selection.store.provide';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\nimport { DbxScheduleSelectionCalendarDatePopupContentConfig } from '../../calendar.schedule.selection.dialog.component';\nimport { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\n\nexport interface DbxFormCalendarDateCellScheduleRangeFieldProps extends Pick<FormlyFieldProps, 'label' | 'description' | 'readonly' | 'required'>, Pick<CalendarScheduleSelectionState, 'computeSelectionResultRelativeToFilter' | 'initialSelectionState'>, Partial<Pick<CalendarScheduleSelectionState, 'cellContentFactory'>> {\n  appearance?: MatFormFieldAppearance;\n  /**\n   * Whether or not to allow inputting custom text into the picker.\n   *\n   * If false, when the input text is picked the date picker will open.\n   *\n   * Is false by default.\n   */\n  allowTextInput?: boolean;\n  /**\n   * Whether or not to hide the customize button. Defaults to false.\n   */\n  hideCustomize?: boolean;\n  /**\n   * Whether or not to allow customizing before picking a date range to customize.\n   *\n   * Defaults to false.\n   */\n  allowCustomizeWithoutDateRange?: boolean;\n  /**\n   * (Optional) Timezone to use for the output start date.\n   */\n  timezone?: ObservableOrValue<Maybe<TimezoneString>>;\n  /**\n   * (Optional) Default schedule days to allow.\n   */\n  defaultScheduleDays?: ObservableOrValue<Maybe<Iterable<DateCellScheduleDayCode>>>;\n  /**\n   * Optional min/max date range to filter on. Works in conjuction with the filter.\n   */\n  minMaxDateRange?: ObservableOrValue<Maybe<Partial<DateRange>>>;\n  /**\n   * (Optional) Observable with a filter value to apply to the date range.\n   */\n  filter?: ObservableOrValue<Maybe<DateCellScheduleDateFilterConfig>>;\n  /**\n   * (Optional) Observable with days and values to exclude from the date range.\n   */\n  exclusions?: ObservableOrValue<Maybe<ArrayOrValue<DateOrDateRangeOrDateCellIndexOrDateCellRange>>>;\n  /**\n   * Custom dialog content config for the popup\n   */\n  dialogContentConfig?: Maybe<DbxScheduleSelectionCalendarDatePopupContentConfig>;\n  /**\n   * Custom details config for the date range\n   */\n  customDetailsConfig?: Maybe<DbxInjectionComponentConfig>;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-schedule-selection-field\">\n      <dbx-schedule-selection-calendar-date-range [openPickerOnTextClick]=\"openPickerOnTextClick\" [showCustomize]=\"showCustomize\" [required]=\"required\" [disabled]=\"isReadonlyOrDisabled\" [label]=\"label\" [hint]=\"description\">\n        <dbx-schedule-selection-calendar-date-dialog-button customizeButton [disabled]=\"disableCustomize$ | async\" [contentConfig]=\"dialogContentConfig\"></dbx-schedule-selection-calendar-date-dialog-button>\n        <dbx-injection [config]=\"customDetailsConfig\"></dbx-injection>\n      </dbx-schedule-selection-calendar-date-range>\n    </div>\n  `,\n  providers: [provideCalendarScheduleSelectionStoreIfParentIsUnavailable()]\n})\nexport class DbxFormCalendarDateScheduleRangeFieldComponent<T extends DbxFormCalendarDateCellScheduleRangeFieldProps = DbxFormCalendarDateCellScheduleRangeFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _syncSub = new SubscriptionObject();\n  private _valueSub = new SubscriptionObject();\n  private _timezoneSub = new SubscriptionObject();\n  private _minMaxDateRangeSub = new SubscriptionObject();\n  private _defaultWeekSub = new SubscriptionObject();\n  private _filterSub = new SubscriptionObject();\n  private _exclusionsSub = new SubscriptionObject();\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly disableCustomize$ = this.value$.pipe(\n    map((x) => (this.allowCustomizeWithoutDateRange ? false : !x)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  constructor(@Optional() readonly compact: CompactContextStore, readonly dbxCalendarScheduleSelectionStore: DbxCalendarScheduleSelectionStore, readonly ngZone: NgZone) {\n    super();\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  get openPickerOnTextClick() {\n    return this.props.allowTextInput !== true; // Opposite of allowTextInput\n  }\n\n  get allowCustomizeWithoutDateRange() {\n    return this.props.allowCustomizeWithoutDateRange ?? false;\n  }\n\n  get showCustomize() {\n    return !this.props.hideCustomize;\n  }\n\n  get defaultScheduleDays() {\n    return this.props.defaultScheduleDays;\n  }\n\n  get minMaxDateRange() {\n    return this.props.minMaxDateRange;\n  }\n\n  get filter() {\n    return this.props.filter;\n  }\n\n  get exclusions() {\n    return this.props.exclusions;\n  }\n\n  get timezone() {\n    return this.props.timezone;\n  }\n\n  get initialSelectionState() {\n    return this.props.initialSelectionState;\n  }\n\n  get computeSelectionResultRelativeToFilter() {\n    return this.props.computeSelectionResultRelativeToFilter;\n  }\n\n  get dialogContentConfig() {\n    return this.props.dialogContentConfig;\n  }\n\n  get customDetailsConfig() {\n    return this.props.customDetailsConfig;\n  }\n\n  get cellContentFactory() {\n    return this.props.cellContentFactory;\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    this._syncSub.subscription = this.value$.pipe(distinctUntilChanged(isSameDateCellScheduleDateRange)).subscribe((x) => {\n      this.dbxCalendarScheduleSelectionStore.setDateScheduleRangeValue(x);\n    });\n\n    this._valueSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateCellScheduleRangeValue$.subscribe((x) => {\n      this.formControl.setValue(x);\n    });\n\n    const { timezone, minMaxDateRange, filter, exclusions, defaultScheduleDays } = this;\n\n    if (filter != null) {\n      this._filterSub.subscription = this.dbxCalendarScheduleSelectionStore.setFilter(asObservable(filter)) as Subscription;\n    }\n\n    if (defaultScheduleDays != null) {\n      this._defaultWeekSub.subscription = this.dbxCalendarScheduleSelectionStore.setDefaultScheduleDays(asObservable(defaultScheduleDays)) as Subscription;\n    }\n\n    if (minMaxDateRange != null) {\n      this._minMaxDateRangeSub.subscription = this.dbxCalendarScheduleSelectionStore.setMinMaxDateRange(asObservable(minMaxDateRange)) as Subscription;\n    }\n\n    if (exclusions != null) {\n      this._exclusionsSub.subscription = this.dbxCalendarScheduleSelectionStore.setExclusions(asObservable(exclusions)) as Subscription;\n    }\n\n    if (timezone != null) {\n      this.dbxCalendarScheduleSelectionStore.setTimezone(asObservable(this.timezone));\n    }\n\n    if (this.initialSelectionState !== undefined) {\n      this.dbxCalendarScheduleSelectionStore.setInitialSelectionState(this.initialSelectionState);\n    }\n\n    if (this.computeSelectionResultRelativeToFilter != null) {\n      this.dbxCalendarScheduleSelectionStore.setComputeSelectionResultRelativeToFilter(this.computeSelectionResultRelativeToFilter);\n    }\n\n    if (this.cellContentFactory != null) {\n      this.dbxCalendarScheduleSelectionStore.setCellContentFactory(this.cellContentFactory);\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._syncSub.destroy();\n    this._valueSub.destroy();\n    this._filterSub.destroy();\n    this._timezoneSub.destroy();\n    this._minMaxDateRangeSub.destroy();\n    this._exclusionsSub.destroy();\n    this._formControlObs.complete();\n  }\n}\n"]}
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.schedule.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/calendar/src/lib/field/schedule/calendar.schedule.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore } from '@dereekb/dbx-web';\nimport { Component, NgZone, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { ArrayOrValue, Maybe } from '@dereekb/util';\nimport { FieldType } from '@ngx-formly/material';\nimport { BehaviorSubject, distinctUntilChanged, map, shareReplay, startWith, Subscription, switchMap } from 'rxjs';\nimport { filterMaybe, ObservableOrValue, SubscriptionObject, asObservable } from '@dereekb/rxjs';\nimport { DateRange, TimezoneString, isSameDateCellScheduleDateRange, DateCellScheduleDateFilterConfig, DateCellScheduleDayCode, DateOrDateRangeOrDateCellIndexOrDateCellRange } from '@dereekb/date';\nimport { CalendarScheduleSelectionState, DbxCalendarScheduleSelectionStore } from '../../calendar.schedule.selection.store';\nimport { provideCalendarScheduleSelectionStoreIfParentIsUnavailable } from '../../calendar.schedule.selection.store.provide';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\nimport { DbxScheduleSelectionCalendarDatePopupContentConfig } from '../../calendar.schedule.selection.dialog.component';\nimport { DbxInjectionComponentConfig } from '@dereekb/dbx-core';\n\nexport interface DbxFormCalendarDateCellScheduleRangeFieldProps extends Pick<FormlyFieldProps, 'label' | 'description' | 'readonly' | 'required'>, Pick<CalendarScheduleSelectionState, 'computeSelectionResultRelativeToFilter' | 'initialSelectionState'>, Partial<Pick<CalendarScheduleSelectionState, 'cellContentFactory'>> {\n  appearance?: MatFormFieldAppearance;\n  /**\n   * Whether or not to allow inputting custom text into the picker.\n   *\n   * If false, when the input text is picked the date picker will open.\n   *\n   * Is false by default.\n   */\n  allowTextInput?: boolean;\n  /**\n   * Whether or not to hide the customize button. Defaults to false.\n   */\n  hideCustomize?: boolean;\n  /**\n   * Whether or not to allow customizing before picking a date range to customize.\n   *\n   * Defaults to false.\n   */\n  allowCustomizeWithoutDateRange?: boolean;\n  /**\n   * (Optional) Timezone to use for the output start date.\n   *\n   * @deprecated use 'outputTimezone' instead.\n   */\n  timezone?: ObservableOrValue<Maybe<TimezoneString>>;\n  /**\n   * (Optional) Timezone to use for the output start date.\n   *\n   * If a filter is provided, this timezone overrides the filter's timezone output.\n   */\n  outputTimezone?: ObservableOrValue<Maybe<TimezoneString>>;\n  /**\n   * (Optional) Default schedule days to allow.\n   */\n  defaultScheduleDays?: ObservableOrValue<Maybe<Iterable<DateCellScheduleDayCode>>>;\n  /**\n   * Optional min/max date range to filter on. Works in conjuction with the filter.\n   */\n  minMaxDateRange?: ObservableOrValue<Maybe<Partial<DateRange>>>;\n  /**\n   * (Optional) Observable with a filter value to apply to the date range.\n   */\n  filter?: ObservableOrValue<Maybe<DateCellScheduleDateFilterConfig>>;\n  /**\n   * (Optional) Observable with days and values to exclude from the date range.\n   */\n  exclusions?: ObservableOrValue<Maybe<ArrayOrValue<DateOrDateRangeOrDateCellIndexOrDateCellRange>>>;\n  /**\n   * Custom dialog content config for the popup\n   */\n  dialogContentConfig?: Maybe<DbxScheduleSelectionCalendarDatePopupContentConfig>;\n  /**\n   * Custom details config for the date range\n   */\n  customDetailsConfig?: Maybe<DbxInjectionComponentConfig>;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-schedule-selection-field\">\n      <dbx-schedule-selection-calendar-date-range [openPickerOnTextClick]=\"openPickerOnTextClick\" [showCustomize]=\"showCustomize\" [required]=\"required\" [disabled]=\"isReadonlyOrDisabled\" [label]=\"label\" [hint]=\"description\">\n        <dbx-schedule-selection-calendar-date-dialog-button customizeButton [disabled]=\"disableCustomize$ | async\" [contentConfig]=\"dialogContentConfig\"></dbx-schedule-selection-calendar-date-dialog-button>\n        <dbx-injection [config]=\"customDetailsConfig\"></dbx-injection>\n      </dbx-schedule-selection-calendar-date-range>\n    </div>\n  `,\n  providers: [provideCalendarScheduleSelectionStoreIfParentIsUnavailable()]\n})\nexport class DbxFormCalendarDateScheduleRangeFieldComponent<T extends DbxFormCalendarDateCellScheduleRangeFieldProps = DbxFormCalendarDateCellScheduleRangeFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _syncSub = new SubscriptionObject();\n  private _valueSub = new SubscriptionObject();\n  private _timezoneSub = new SubscriptionObject();\n  private _minMaxDateRangeSub = new SubscriptionObject();\n  private _defaultWeekSub = new SubscriptionObject();\n  private _filterSub = new SubscriptionObject();\n  private _exclusionsSub = new SubscriptionObject();\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly disableCustomize$ = this.value$.pipe(\n    map((x) => (this.allowCustomizeWithoutDateRange ? false : !x)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  constructor(@Optional() readonly compact: CompactContextStore, readonly dbxCalendarScheduleSelectionStore: DbxCalendarScheduleSelectionStore, readonly ngZone: NgZone) {\n    super();\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  get openPickerOnTextClick() {\n    return this.props.allowTextInput !== true; // Opposite of allowTextInput\n  }\n\n  get allowCustomizeWithoutDateRange() {\n    return this.props.allowCustomizeWithoutDateRange ?? false;\n  }\n\n  get showCustomize() {\n    return !this.props.hideCustomize;\n  }\n\n  get defaultScheduleDays() {\n    return this.props.defaultScheduleDays;\n  }\n\n  get minMaxDateRange() {\n    return this.props.minMaxDateRange;\n  }\n\n  get filter() {\n    return this.props.filter;\n  }\n\n  get exclusions() {\n    return this.props.exclusions;\n  }\n\n  get outputTimezone() {\n    return this.props.outputTimezone || this.props.timezone;\n  }\n\n  get initialSelectionState() {\n    return this.props.initialSelectionState;\n  }\n\n  get computeSelectionResultRelativeToFilter() {\n    return this.props.computeSelectionResultRelativeToFilter;\n  }\n\n  get dialogContentConfig() {\n    return this.props.dialogContentConfig;\n  }\n\n  get customDetailsConfig() {\n    return this.props.customDetailsConfig;\n  }\n\n  get cellContentFactory() {\n    return this.props.cellContentFactory;\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    this._syncSub.subscription = this.value$.pipe(distinctUntilChanged(isSameDateCellScheduleDateRange)).subscribe((x) => {\n      this.dbxCalendarScheduleSelectionStore.setDateScheduleRangeValue(x);\n    });\n\n    this._valueSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateCellScheduleRangeValue$.subscribe((x) => {\n      this.formControl.setValue(x);\n    });\n\n    const { outputTimezone, minMaxDateRange, filter, exclusions, defaultScheduleDays } = this;\n\n    if (filter != null) {\n      this._filterSub.subscription = this.dbxCalendarScheduleSelectionStore.setFilter(asObservable(filter)) as Subscription;\n    }\n\n    if (defaultScheduleDays != null) {\n      this._defaultWeekSub.subscription = this.dbxCalendarScheduleSelectionStore.setDefaultScheduleDays(asObservable(defaultScheduleDays)) as Subscription;\n    }\n\n    if (minMaxDateRange != null) {\n      this._minMaxDateRangeSub.subscription = this.dbxCalendarScheduleSelectionStore.setMinMaxDateRange(asObservable(minMaxDateRange)) as Subscription;\n    }\n\n    if (exclusions != null) {\n      this._exclusionsSub.subscription = this.dbxCalendarScheduleSelectionStore.setExclusions(asObservable(exclusions)) as Subscription;\n    }\n\n    if (outputTimezone != null) {\n      this.dbxCalendarScheduleSelectionStore.setOutputTimezone(asObservable(this.outputTimezone));\n    }\n\n    if (this.initialSelectionState !== undefined) {\n      this.dbxCalendarScheduleSelectionStore.setInitialSelectionState(this.initialSelectionState);\n    }\n\n    if (this.computeSelectionResultRelativeToFilter != null) {\n      this.dbxCalendarScheduleSelectionStore.setComputeSelectionResultRelativeToFilter(this.computeSelectionResultRelativeToFilter);\n    }\n\n    if (this.cellContentFactory != null) {\n      this.dbxCalendarScheduleSelectionStore.setCellContentFactory(this.cellContentFactory);\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._syncSub.destroy();\n    this._valueSub.destroy();\n    this._filterSub.destroy();\n    this._timezoneSub.destroy();\n    this._minMaxDateRangeSub.destroy();\n    this._exclusionsSub.destroy();\n    this._formControlObs.complete();\n  }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { formlyField, propsAndConfigForFieldConfig } from '@dereekb/dbx-form';
2
2
  export function dateScheduleRangeField(config = {}) {
3
- const { key = 'schedule', appearance, hideCustomize, allowTextInput, filter, timezone, initialSelectionState, computeSelectionResultRelativeToFilter, exclusions, defaultScheduleDays, minMaxDateRange, cellContentFactory, dialogContentConfig, customDetailsConfig } = config;
3
+ const { key = 'schedule', appearance, hideCustomize, allowTextInput, filter, outputTimezone, timezone, initialSelectionState, computeSelectionResultRelativeToFilter, exclusions, defaultScheduleDays, minMaxDateRange, cellContentFactory, dialogContentConfig, customDetailsConfig } = config;
4
4
  const fieldConfig = {
5
5
  ...formlyField({
6
6
  key,
@@ -10,6 +10,7 @@ export function dateScheduleRangeField(config = {}) {
10
10
  allowTextInput,
11
11
  appearance,
12
12
  hideCustomize,
13
+ outputTimezone,
13
14
  timezone,
14
15
  defaultScheduleDays,
15
16
  minMaxDateRange,
@@ -25,4 +26,4 @@ export function dateScheduleRangeField(config = {}) {
25
26
  };
26
27
  return fieldConfig;
27
28
  }
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuc2NoZWR1bGUuZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9jYWxlbmRhci9zcmMvbGliL2ZpZWxkL3NjaGVkdWxlL2NhbGVuZGFyLnNjaGVkdWxlLmZpZWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBdUMsV0FBVyxFQUFzQiw0QkFBNEIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBTXZJLE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxTQUF1QyxFQUFFO0lBQzlFLE1BQU0sRUFBRSxHQUFHLEdBQUcsVUFBVSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsY0FBYyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUscUJBQXFCLEVBQUUsc0NBQXNDLEVBQUUsVUFBVSxFQUFFLG1CQUFtQixFQUFFLGVBQWUsRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxtQkFBbUIsRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUNoUixNQUFNLFdBQVcsR0FBc0I7UUFDckMsR0FBRyxXQUFXLENBQUM7WUFDYixHQUFHO1lBQ0gsSUFBSSxFQUFFLHFCQUFxQjtZQUMzQixHQUFHLDRCQUE0QixDQUFDLE1BQU0sRUFBRTtnQkFDdEMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxLQUFLLElBQUksVUFBVTtnQkFDakMsY0FBYztnQkFDZCxVQUFVO2dCQUNWLGFBQWE7Z0JBQ2IsUUFBUTtnQkFDUixtQkFBbUI7Z0JBQ25CLGVBQWU7Z0JBQ2YsTUFBTTtnQkFDTixVQUFVO2dCQUNWLG1CQUFtQjtnQkFDbkIsc0NBQXNDO2dCQUN0QyxxQkFBcUI7Z0JBQ3JCLGtCQUFrQjtnQkFDbEIsbUJBQW1CO2FBQ3BCLENBQUM7U0FDSCxDQUFDO0tBQ0gsQ0FBQztJQUVGLE9BQU8sV0FBVyxDQUFDO0FBQ3JCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZXNjcmlwdGlvbkZpZWxkQ29uZmlnLCBGaWVsZENvbmZpZywgZm9ybWx5RmllbGQsIExhYmVsZWRGaWVsZENvbmZpZywgcHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyB9IGZyb20gJ0BkZXJlZWtiL2RieC1mb3JtJztcbmltcG9ydCB7IEZvcm1seUZpZWxkQ29uZmlnIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBEYnhGb3JtQ2FsZW5kYXJEYXRlQ2VsbFNjaGVkdWxlUmFuZ2VGaWVsZFByb3BzIH0gZnJvbSAnLi9jYWxlbmRhci5zY2hlZHVsZS5maWVsZC5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERhdGVTY2hlZHVsZVJhbmdlRmllbGRDb25maWcgZXh0ZW5kcyBPbWl0PExhYmVsZWRGaWVsZENvbmZpZywgJ2tleScgfCAncGxhY2Vob2xkZXInPiwgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgUGFydGlhbDxGaWVsZENvbmZpZz4sIERieEZvcm1DYWxlbmRhckRhdGVDZWxsU2NoZWR1bGVSYW5nZUZpZWxkUHJvcHMge31cblxuZXhwb3J0IGZ1bmN0aW9uIGRhdGVTY2hlZHVsZVJhbmdlRmllbGQoY29uZmlnOiBEYXRlU2NoZWR1bGVSYW5nZUZpZWxkQ29uZmlnID0ge30pOiBGb3JtbHlGaWVsZENvbmZpZyB7XG4gIGNvbnN0IHsga2V5ID0gJ3NjaGVkdWxlJywgYXBwZWFyYW5jZSwgaGlkZUN1c3RvbWl6ZSwgYWxsb3dUZXh0SW5wdXQsIGZpbHRlciwgdGltZXpvbmUsIGluaXRpYWxTZWxlY3Rpb25TdGF0ZSwgY29tcHV0ZVNlbGVjdGlvblJlc3VsdFJlbGF0aXZlVG9GaWx0ZXIsIGV4Y2x1c2lvbnMsIGRlZmF1bHRTY2hlZHVsZURheXMsIG1pbk1heERhdGVSYW5nZSwgY2VsbENvbnRlbnRGYWN0b3J5LCBkaWFsb2dDb250ZW50Q29uZmlnLCBjdXN0b21EZXRhaWxzQ29uZmlnIH0gPSBjb25maWc7XG4gIGNvbnN0IGZpZWxkQ29uZmlnOiBGb3JtbHlGaWVsZENvbmZpZyA9IHtcbiAgICAuLi5mb3JtbHlGaWVsZCh7XG4gICAgICBrZXksXG4gICAgICB0eXBlOiAnZGF0ZS1zY2hlZHVsZS1yYW5nZScsXG4gICAgICAuLi5wcm9wc0FuZENvbmZpZ0ZvckZpZWxkQ29uZmlnKGNvbmZpZywge1xuICAgICAgICBsYWJlbDogY29uZmlnLmxhYmVsID8/ICdTY2hlZHVsZScsXG4gICAgICAgIGFsbG93VGV4dElucHV0LFxuICAgICAgICBhcHBlYXJhbmNlLFxuICAgICAgICBoaWRlQ3VzdG9taXplLFxuICAgICAgICB0aW1lem9uZSxcbiAgICAgICAgZGVmYXVsdFNjaGVkdWxlRGF5cyxcbiAgICAgICAgbWluTWF4RGF0ZVJhbmdlLFxuICAgICAgICBmaWx0ZXIsXG4gICAgICAgIGV4Y2x1c2lvbnMsXG4gICAgICAgIGRpYWxvZ0NvbnRlbnRDb25maWcsXG4gICAgICAgIGNvbXB1dGVTZWxlY3Rpb25SZXN1bHRSZWxhdGl2ZVRvRmlsdGVyLFxuICAgICAgICBpbml0aWFsU2VsZWN0aW9uU3RhdGUsXG4gICAgICAgIGNlbGxDb250ZW50RmFjdG9yeSxcbiAgICAgICAgY3VzdG9tRGV0YWlsc0NvbmZpZ1xuICAgICAgfSlcbiAgICB9KVxuICB9O1xuXG4gIHJldHVybiBmaWVsZENvbmZpZztcbn1cbiJdfQ==
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuc2NoZWR1bGUuZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9jYWxlbmRhci9zcmMvbGliL2ZpZWxkL3NjaGVkdWxlL2NhbGVuZGFyLnNjaGVkdWxlLmZpZWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBdUMsV0FBVyxFQUFzQiw0QkFBNEIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBTXZJLE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxTQUF1QyxFQUFFO0lBQzlFLE1BQU0sRUFBRSxHQUFHLEdBQUcsVUFBVSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsY0FBYyxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQUUsUUFBUSxFQUFFLHFCQUFxQixFQUFFLHNDQUFzQyxFQUFFLFVBQVUsRUFBRSxtQkFBbUIsRUFBRSxlQUFlLEVBQUUsa0JBQWtCLEVBQUUsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFDaFMsTUFBTSxXQUFXLEdBQXNCO1FBQ3JDLEdBQUcsV0FBVyxDQUFDO1lBQ2IsR0FBRztZQUNILElBQUksRUFBRSxxQkFBcUI7WUFDM0IsR0FBRyw0QkFBNEIsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3RDLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLFVBQVU7Z0JBQ2pDLGNBQWM7Z0JBQ2QsVUFBVTtnQkFDVixhQUFhO2dCQUNiLGNBQWM7Z0JBQ2QsUUFBUTtnQkFDUixtQkFBbUI7Z0JBQ25CLGVBQWU7Z0JBQ2YsTUFBTTtnQkFDTixVQUFVO2dCQUNWLG1CQUFtQjtnQkFDbkIsc0NBQXNDO2dCQUN0QyxxQkFBcUI7Z0JBQ3JCLGtCQUFrQjtnQkFDbEIsbUJBQW1CO2FBQ3BCLENBQUM7U0FDSCxDQUFDO0tBQ0gsQ0FBQztJQUVGLE9BQU8sV0FBVyxDQUFDO0FBQ3JCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZXNjcmlwdGlvbkZpZWxkQ29uZmlnLCBGaWVsZENvbmZpZywgZm9ybWx5RmllbGQsIExhYmVsZWRGaWVsZENvbmZpZywgcHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyB9IGZyb20gJ0BkZXJlZWtiL2RieC1mb3JtJztcbmltcG9ydCB7IEZvcm1seUZpZWxkQ29uZmlnIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBEYnhGb3JtQ2FsZW5kYXJEYXRlQ2VsbFNjaGVkdWxlUmFuZ2VGaWVsZFByb3BzIH0gZnJvbSAnLi9jYWxlbmRhci5zY2hlZHVsZS5maWVsZC5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERhdGVTY2hlZHVsZVJhbmdlRmllbGRDb25maWcgZXh0ZW5kcyBPbWl0PExhYmVsZWRGaWVsZENvbmZpZywgJ2tleScgfCAncGxhY2Vob2xkZXInPiwgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgUGFydGlhbDxGaWVsZENvbmZpZz4sIERieEZvcm1DYWxlbmRhckRhdGVDZWxsU2NoZWR1bGVSYW5nZUZpZWxkUHJvcHMge31cblxuZXhwb3J0IGZ1bmN0aW9uIGRhdGVTY2hlZHVsZVJhbmdlRmllbGQoY29uZmlnOiBEYXRlU2NoZWR1bGVSYW5nZUZpZWxkQ29uZmlnID0ge30pOiBGb3JtbHlGaWVsZENvbmZpZyB7XG4gIGNvbnN0IHsga2V5ID0gJ3NjaGVkdWxlJywgYXBwZWFyYW5jZSwgaGlkZUN1c3RvbWl6ZSwgYWxsb3dUZXh0SW5wdXQsIGZpbHRlciwgb3V0cHV0VGltZXpvbmUsIHRpbWV6b25lLCBpbml0aWFsU2VsZWN0aW9uU3RhdGUsIGNvbXB1dGVTZWxlY3Rpb25SZXN1bHRSZWxhdGl2ZVRvRmlsdGVyLCBleGNsdXNpb25zLCBkZWZhdWx0U2NoZWR1bGVEYXlzLCBtaW5NYXhEYXRlUmFuZ2UsIGNlbGxDb250ZW50RmFjdG9yeSwgZGlhbG9nQ29udGVudENvbmZpZywgY3VzdG9tRGV0YWlsc0NvbmZpZyB9ID0gY29uZmlnO1xuICBjb25zdCBmaWVsZENvbmZpZzogRm9ybWx5RmllbGRDb25maWcgPSB7XG4gICAgLi4uZm9ybWx5RmllbGQoe1xuICAgICAga2V5LFxuICAgICAgdHlwZTogJ2RhdGUtc2NoZWR1bGUtcmFuZ2UnLFxuICAgICAgLi4ucHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyhjb25maWcsIHtcbiAgICAgICAgbGFiZWw6IGNvbmZpZy5sYWJlbCA/PyAnU2NoZWR1bGUnLFxuICAgICAgICBhbGxvd1RleHRJbnB1dCxcbiAgICAgICAgYXBwZWFyYW5jZSxcbiAgICAgICAgaGlkZUN1c3RvbWl6ZSxcbiAgICAgICAgb3V0cHV0VGltZXpvbmUsXG4gICAgICAgIHRpbWV6b25lLFxuICAgICAgICBkZWZhdWx0U2NoZWR1bGVEYXlzLFxuICAgICAgICBtaW5NYXhEYXRlUmFuZ2UsXG4gICAgICAgIGZpbHRlcixcbiAgICAgICAgZXhjbHVzaW9ucyxcbiAgICAgICAgZGlhbG9nQ29udGVudENvbmZpZyxcbiAgICAgICAgY29tcHV0ZVNlbGVjdGlvblJlc3VsdFJlbGF0aXZlVG9GaWx0ZXIsXG4gICAgICAgIGluaXRpYWxTZWxlY3Rpb25TdGF0ZSxcbiAgICAgICAgY2VsbENvbnRlbnRGYWN0b3J5LFxuICAgICAgICBjdXN0b21EZXRhaWxzQ29uZmlnXG4gICAgICB9KVxuICAgIH0pXG4gIH07XG5cbiAgcmV0dXJuIGZpZWxkQ29uZmlnO1xufVxuIl19
@@ -3,9 +3,9 @@ import { formlyField, propsAndConfigForFieldConfig, flexLayoutWrapper, toggleFie
3
3
  import * as i0 from '@angular/core';
4
4
  import { Injectable, SkipSelf, Directive, Injector, Optional, Component, Inject, Input, ViewChild, ElementRef, ChangeDetectionStrategy, EventEmitter, Output, InjectionToken, NgModule } from '@angular/core';
5
5
  import { FieldType } from '@ngx-formly/material';
6
- import { switchMap, first, tap, map, distinctUntilChanged, shareReplay, of, combineLatestWith, BehaviorSubject, filter, combineLatest, startWith, throttleTime } from 'rxjs';
6
+ import { switchMap, first, tap, map, distinctUntilChanged, shareReplay, of, combineLatestWith, BehaviorSubject, filter, combineLatest, EMPTY, startWith, throttleTime } from 'rxjs';
7
7
  import { filterMaybe, distinctUntilHasDifferentValues, SubscriptionObject, asObservableFromGetter, asObservable } from '@dereekb/rxjs';
8
- import { DateCellScheduleDayCode, expandDateCellScheduleDayCodesToDayOfWeekSet, dateCellTimingStartsAtForStartOfDay, dateCellTimingRelativeIndexFactory, dateCellDayOfWeekFactory, findMaxDate, findMinDate, isSameDateRange, isSameDateDay, isSameDate, dateCellTimingDateFactory, expandDateCellScheduleRange, formatToISO8601DayString, isSameDateCellScheduleDateRange, dateCellTimingRelativeIndexArrayFactory, isInfiniteDateRange, copyDateCellScheduleDateFilterConfig, dateCellScheduleDateFilter, dateTimezoneUtcNormal, fullDateCellScheduleRange, expandDateCellScheduleDayCodes, fullWeekDateCellScheduleDayCodes, dateCellScheduleDayCodesAreSetsEquivalent, simplifyDateCellScheduleDayCodes, isDateInDateRangeFunction, isDateWithinDateCellRangeFunction, copyHoursAndMinutesFromDate, dateCellScheduleEncodedWeek, dateCellTimingStartDateFactory, enabledDaysFromDateCellScheduleDayCodes, dateCellScheduleDayCodesFromEnabledDays, formatToMonthDayString, dateRange, DateRangeType } from '@dereekb/date';
8
+ import { DateCellScheduleDayCode, expandDateCellScheduleDayCodesToDayOfWeekSet, dateCellTimingStartsAtForStartOfDay, dateCellTimingRelativeIndexFactory, dateCellDayOfWeekFactory, findMaxDate, findMinDate, isSameDateRange, isSameDateDay, isSameDate, dateCellTimingDateFactory, expandDateCellScheduleRange, formatToISO8601DayString, changeDateCellScheduleDateRangeToTimezone, isSameDateCellScheduleDateRange, dateCellTimingRelativeIndexArrayFactory, isInfiniteDateRange, copyDateCellScheduleDateFilterConfig, dateTimezoneUtcNormal, dateCellScheduleDateFilter, fullDateCellScheduleRange, dateCellTimingTimezoneNormalInstance, expandDateCellScheduleDayCodes, fullWeekDateCellScheduleDayCodes, dateCellScheduleDayCodesAreSetsEquivalent, simplifyDateCellScheduleDayCodes, isDateInDateRangeFunction, isDateWithinDateCellRangeFunction, dateCellScheduleEncodedWeek, dateCellTimingStartDateFactory, enabledDaysFromDateCellScheduleDayCodes, dateCellScheduleDayCodesFromEnabledDays, formatToMonthDayString, dateRange, DateRangeType } from '@dereekb/date';
9
9
  import { isInAllowedDaysOfWeekSet, mapValuesToSet, unique, mergeArrays, iterableToArray, range, toggleInSet, removeFromSet, addToSet, isIndexNumberInIndexRangeFunction, minAndMaxNumber, getDaysOfWeekNames, reduceBooleansWithAnd, mergeObjects, KeyValueTypleValueFilter } from '@dereekb/util';
10
10
  import { ComponentStore } from '@ngrx/component-store';
11
11
  import { startOfDay, endOfDay, isBefore, endOfWeek } from 'date-fns';
@@ -38,12 +38,13 @@ import { FlexLayoutModule } from '@angular/flex-layout';
38
38
 
39
39
  function dateScheduleRangeField(config = {}) {
40
40
  var _a;
41
- const { key = 'schedule', appearance, hideCustomize, allowTextInput, filter, timezone, initialSelectionState, computeSelectionResultRelativeToFilter, exclusions, defaultScheduleDays, minMaxDateRange, cellContentFactory, dialogContentConfig, customDetailsConfig } = config;
41
+ const { key = 'schedule', appearance, hideCustomize, allowTextInput, filter, outputTimezone, timezone, initialSelectionState, computeSelectionResultRelativeToFilter, exclusions, defaultScheduleDays, minMaxDateRange, cellContentFactory, dialogContentConfig, customDetailsConfig } = config;
42
42
  const fieldConfig = Object.assign({}, formlyField(Object.assign({ key, type: 'date-schedule-range' }, propsAndConfigForFieldConfig(config, {
43
43
  label: (_a = config.label) !== null && _a !== void 0 ? _a : 'Schedule',
44
44
  allowTextInput,
45
45
  appearance,
46
46
  hideCustomize,
47
+ outputTimezone,
47
48
  timezone,
48
49
  defaultScheduleDays,
49
50
  minMaxDateRange,
@@ -127,7 +128,7 @@ function calendarScheduleMinAndMaxDateRange(x) {
127
128
  }
128
129
  function calendarScheduleStartBeingUsedFromFilter(x) {
129
130
  var _a;
130
- return x.computeSelectionResultRelativeToFilter && ((_a = x.filter) === null || _a === void 0 ? void 0 : _a.start) != null;
131
+ return x.computeSelectionResultRelativeToFilter && ((_a = x.filter) === null || _a === void 0 ? void 0 : _a.start) != null; // may be using either
131
132
  }
132
133
  class DbxCalendarScheduleSelectionStore extends ComponentStore {
133
134
  constructor() {
@@ -146,7 +147,7 @@ class DbxCalendarScheduleSelectionStore extends ComponentStore {
146
147
  this.hasConfiguredMinMaxRange$ = this.minMaxDateRange$.pipe(map((x) => x != null && x.start != null && x.end != null), distinctUntilChanged(), shareReplay(1));
147
148
  this.inputStart$ = this.state$.pipe(map((x) => x.inputStart), distinctUntilChanged(isSameDate), shareReplay(1));
148
149
  this.inputEnd$ = this.state$.pipe(map((x) => x.inputEnd), distinctUntilChanged(isSameDate), shareReplay(1));
149
- this.currentInputRange$ = this.state$.pipe(map(({ inputStart, inputEnd }) => ({ inputStart, inputEnd })), distinctUntilChanged((a, b) => isSameDate(a.inputStart, b.inputStart) && isSameDate(a.inputEnd, b.inputEnd)), map((x) => {
150
+ this.currentInputRange$ = this.state$.pipe(map(({ inputStart, inputEnd }) => ({ start: inputStart, end: inputEnd })), distinctUntilChanged((a, b) => isSameDateRange(a, b)), map((x) => ({ inputStart: x.start, inputEnd: x.end })), map((x) => {
150
151
  if (x.inputStart && x.inputEnd) {
151
152
  return x;
152
153
  }
@@ -171,9 +172,19 @@ class DbxCalendarScheduleSelectionStore extends ComponentStore {
171
172
  this.isInAllowedDaysOfWeekFunction$ = this.allowedDaysOfWeek$.pipe(map((x) => isInAllowedDaysOfWeekSet(x)), shareReplay(1));
172
173
  this.scheduleDays$ = this.state$.pipe(map((x) => x.effectiveScheduleDays), distinctUntilHasDifferentValues(), shareReplay(1));
173
174
  this.outputTimezone$ = this.state$.pipe(map((x) => x.outputTimezone), distinctUntilChanged(), shareReplay(1));
174
- this.effectiveOutputTimezone$ = this.state$.pipe(map((x) => (!calendarScheduleStartBeingUsedFromFilter(x) && x.outputTimezone ? x.outputTimezone : undefined)), distinctUntilChanged(), shareReplay(1));
175
- this.effectiveOutputTimezoneNormal$ = this.state$.pipe(map((x) => (!calendarScheduleStartBeingUsedFromFilter(x) && x.outputTimezoneNormal ? x.outputTimezoneNormal : undefined)), distinctUntilChanged(), shareReplay(1));
176
- this.currentSelectionValue$ = this.state$.pipe(map((x) => x.currentSelectionValue), shareReplay(1));
175
+ /**
176
+ * The timezone of the output values.
177
+ *
178
+ * If an outputTimezone is not specified, this defaults to the system timezone.
179
+ */
180
+ this.effectiveOutputTimezone$ = this.state$.pipe(map((x) => x.outputTimezone || x.systemTimezone), distinctUntilChanged(), shareReplay(1));
181
+ /**
182
+ * An outputTimezoneNormal to use.
183
+ *
184
+ * If an outputTimezone is not specified, this is undefined.
185
+ */
186
+ this.effectiveOutputTimezoneNormal$ = this.state$.pipe(map((x) => (x.outputTimezoneNormal ? x.outputTimezoneNormal : undefined)), distinctUntilChanged(), shareReplay(1));
187
+ this.currentSelectionValue$ = this.state$.pipe(map((x) => x.currentSelectionValue), distinctUntilChanged(), shareReplay(1));
177
188
  this.currentSelectionValueStart$ = this.currentSelectionValue$.pipe(map((x) => x === null || x === void 0 ? void 0 : x.dateScheduleRange.start), distinctUntilChanged(isSameDate), shareReplay(1));
178
189
  this.currentSelectionValueDateCellTimingDateFactory$ = this.currentSelectionValue$.pipe(map((x) => (x ? dateCellTimingDateFactory({ startsAt: x.dateScheduleRange.start, timezone: x.dateScheduleRange.timezone }) : undefined)), shareReplay(1));
179
190
  this.currentSelectionValueDateCellDurationSpanExpansion$ = this.currentSelectionValue$.pipe(map((x) => (x ? expandDateCellScheduleRange({ dateCellScheduleRange: x.dateScheduleRange }) : [])), shareReplay(1));
@@ -183,12 +194,14 @@ class DbxCalendarScheduleSelectionStore extends ComponentStore {
183
194
  }), shareReplay(1));
184
195
  this.selectionValue$ = this.currentSelectionValue$.pipe(filterMaybe(), shareReplay(1));
185
196
  this.currentSelectionValueWithTimezone$ = this.currentSelectionValue$.pipe(combineLatestWith(this.effectiveOutputTimezoneNormal$), map(([x, timezoneNormal]) => {
197
+ let currentValueWithTimezone = x;
186
198
  if (x && timezoneNormal) {
187
- x = {
188
- dateScheduleRange: Object.assign(Object.assign({}, x.dateScheduleRange), { start: timezoneNormal.targetDateToSystemDate(x.dateScheduleRange.start), end: timezoneNormal.targetDateToSystemDate(x.dateScheduleRange.end) })
199
+ currentValueWithTimezone = {
200
+ dateScheduleRange: changeDateCellScheduleDateRangeToTimezone(x.dateScheduleRange, timezoneNormal),
201
+ minMaxRange: x.minMaxRange
189
202
  };
190
203
  }
191
- return x;
204
+ return currentValueWithTimezone;
192
205
  }), distinctUntilChanged(), shareReplay(1));
193
206
  this.selectionValueWithTimezone$ = this.currentSelectionValueWithTimezone$.pipe(filterMaybe(), shareReplay(1));
194
207
  this.selectionValueWithTimezoneDateCellDurationSpanExpansion$ = this.selectionValueWithTimezone$.pipe(map((x) => expandDateCellScheduleRange({ dateCellScheduleRange: x.dateScheduleRange })), shareReplay(1));
@@ -215,6 +228,9 @@ class DbxCalendarScheduleSelectionStore extends ComponentStore {
215
228
  this.setComputeSelectionResultRelativeToFilter = this.updater(updateStateWithComputeSelectionResultRelativeToFilter);
216
229
  this.clearFilter = this.updater((state) => updateStateWithFilter(state, undefined));
217
230
  this.setOutputTimezone = this.updater(updateStateWithTimezoneValue);
231
+ /**
232
+ * Sets the "input" date range. This is the range that gets displayed on the date range picker.
233
+ */
218
234
  this.setInputRange = this.updater(updateStateWithChangedRange);
219
235
  // NOTE: Selected dates are NOT selected indexes. They are the internal selected dates that are excluded from the selection.
220
236
  this.toggleSelectedDates = this.updater((state, toggle) => updateStateWithChangedDates(state, { toggle }));
@@ -313,8 +329,25 @@ function updateStateWithFilter(state, inputFilter) {
313
329
  // create the filter using inputFilter, exclusions, and minMaxDateRange
314
330
  if (inputFilter || (exclusions === null || exclusions === void 0 ? void 0 : exclusions.length) || minMaxDateRange) {
315
331
  let enabledFilter;
332
+ let filterStart = null; // the start date that will be used/set on the filter.
316
333
  if (inputFilter) {
317
334
  filter = copyDateCellScheduleDateFilterConfig(inputFilter); // copy filter
335
+ // configure filter start
336
+ if (inputFilter.start) {
337
+ filterStart = inputFilter.start;
338
+ }
339
+ else if (inputFilter.startsAt) {
340
+ if (inputFilter.timezone) {
341
+ const timezoneNormal = dateTimezoneUtcNormal(inputFilter.timezone);
342
+ filterStart = timezoneNormal.startOfDayInTargetTimezone(inputFilter.startsAt);
343
+ }
344
+ else {
345
+ filterStart = inputFilter.startsAt;
346
+ filter.timezone = systemTimezone;
347
+ }
348
+ }
349
+ filter.start = filterStart !== null && filterStart !== void 0 ? filterStart : undefined;
350
+ // configure exclusions
318
351
  if (exclusions === null || exclusions === void 0 ? void 0 : exclusions.length) {
319
352
  enabledFilter = Object.assign(Object.assign({}, filter), { ex: unique(mergeArrays([filter.ex, exclusions])) });
320
353
  }
@@ -330,13 +363,13 @@ function updateStateWithFilter(state, inputFilter) {
330
363
  }
331
364
  if (minMaxDateRange) {
332
365
  enabledFilter.minMaxDateRange = minMaxDateRange;
333
- enabledFilter.setStartAsMinDate = (filter === null || filter === void 0 ? void 0 : filter.start) ? true : false; // If a start date is set, then it becomes the floor.
366
+ enabledFilter.setStartAsMinDate = filterStart ? true : false; // If a start date is set, then it becomes the floor.
334
367
  }
335
368
  /**
336
369
  * If the input filter has a start date, use that as the relative start to ensure indexes are compared the same,
337
370
  * otherwise use the state's start. This is important for the index calculations.
338
371
  */
339
- enabledFilter.start = (_a = inputFilter === null || inputFilter === void 0 ? void 0 : inputFilter.start) !== null && _a !== void 0 ? _a : state.start;
372
+ enabledFilter.start = (_a = filter === null || filter === void 0 ? void 0 : filter.start) !== null && _a !== void 0 ? _a : state.start;
340
373
  // create the filter
341
374
  isEnabledFilterDay = dateCellScheduleDateFilter(enabledFilter);
342
375
  }
@@ -376,24 +409,28 @@ function updateStateWithTimezoneValue(state, timezone) {
376
409
  }
377
410
  }
378
411
  function updateStateWithDateCellScheduleRangeValue(state, inputChange) {
379
- const { outputTimezoneNormal: timezoneNormal, currentSelectionValue } = state;
412
+ var _a;
413
+ const { currentSelectionValue, systemTimezone } = state;
380
414
  const currentDateCellScheduleRange = currentSelectionValue === null || currentSelectionValue === void 0 ? void 0 : currentSelectionValue.dateScheduleRange; // current range is always in system time
381
415
  let change;
382
- if (!calendarScheduleStartBeingUsedFromFilter(state) && timezoneNormal) {
383
- // When using timezones, always return from the start of the day. Inputs are converted to the system time and used as the start of the day.
384
- // Outputs remain accurate.
385
- if (inputChange) {
386
- // calculate the schedule range
387
- const fullChange = fullDateCellScheduleRange({ dateCellScheduleRange: inputChange });
388
- // convert the start/end to system time
389
- change = {
390
- start: startOfDay(timezoneNormal.systemDateToTargetDate(fullChange.start)),
391
- end: startOfDay(timezoneNormal.systemDateToTargetDate(fullChange.end)),
392
- w: fullChange.w,
393
- ex: fullChange.ex,
394
- timezone: fullChange.timezone
395
- };
396
- }
416
+ // When using timezones, always return from the start of the day. Inputs are converted to the system time and used as the start of the day.
417
+ // Outputs remain accurate.
418
+ if (inputChange) {
419
+ // make sure a timezone is set. Input may not have a timezone attached. Default to system time.
420
+ const inputChangeWithTimezoneSet = Object.assign(Object.assign({}, inputChange), { timezone: (_a = inputChange.timezone) !== null && _a !== void 0 ? _a : systemTimezone });
421
+ // calculate the schedule range
422
+ const fullChange = fullDateCellScheduleRange({ dateCellScheduleRange: inputChangeWithTimezoneSet });
423
+ const inputNormal = dateCellTimingTimezoneNormalInstance(fullChange);
424
+ const startInSystemTz = inputNormal.systemDateToTargetDate(fullChange.start);
425
+ const endInSystemTz = startOfDay(inputNormal.systemDateToTargetDate(fullChange.end));
426
+ // convert the start/end to system time
427
+ change = {
428
+ start: startInSystemTz,
429
+ end: endInSystemTz,
430
+ w: fullChange.w,
431
+ ex: fullChange.ex,
432
+ timezone: fullChange.timezone
433
+ };
397
434
  }
398
435
  const isSameValue = isSameDateCellScheduleDateRange(currentDateCellScheduleRange, change);
399
436
  if (isSameValue) {
@@ -548,7 +585,7 @@ function updateStateWithChangedRange(state, change) {
548
585
  const { inputStart: currentInputStart, inputEnd: currentInputEnd, indexFactory, minMaxDateRange } = state;
549
586
  const { start: minDate, end: maxDate } = minMaxDateRange !== null && minMaxDateRange !== void 0 ? minMaxDateRange : {};
550
587
  const inputStart = startOfDay(change.inputStart);
551
- const inputEnd = endOfDay(change.inputEnd);
588
+ const inputEnd = startOfDay(change.inputEnd); // midnight of the last day
552
589
  const isValidRange = minDate != null || maxDate != null ? isDateInDateRangeFunction({ start: minDate !== null && minDate !== void 0 ? minDate : undefined, end: maxDate !== null && maxDate !== void 0 ? maxDate : undefined }) : () => true;
553
590
  if (!isValidRange(inputStart) || !isValidRange(inputEnd) || (isSameDateDay(inputStart, currentInputStart) && isSameDateDay(inputEnd, currentInputEnd))) {
554
591
  return state; // if no change, return the current state.
@@ -589,6 +626,7 @@ function isEnabledDayInCalendarScheduleSelectionState(state) {
589
626
  }
590
627
  function computeScheduleSelectionValue(state) {
591
628
  const { indexFactory, allowedDaysOfWeek, effectiveScheduleDays, indexDayOfWeek, computeSelectionResultRelativeToFilter, filter, systemTimezone } = state;
629
+ let timezone = systemTimezone;
592
630
  const rangeAndExclusion = computeScheduleSelectionRangeAndExclusion(state);
593
631
  if (rangeAndExclusion == null) {
594
632
  return null;
@@ -600,9 +638,11 @@ function computeScheduleSelectionValue(state) {
600
638
  let end = rangeEnd;
601
639
  // If computeSelectionResultRelativeToFilter is true, then we need to offset the values to be relative to that start.
602
640
  if (computeSelectionResultRelativeToFilter && (filter === null || filter === void 0 ? void 0 : filter.start)) {
603
- start = filter.start;
604
- if (filter === null || filter === void 0 ? void 0 : filter.end) {
605
- end = copyHoursAndMinutesFromDate(end, filter.end);
641
+ start = filter.start; // always start at the filter's start date
642
+ if (filter.timezone) {
643
+ timezone = filter.timezone;
644
+ const filterNormal = dateTimezoneUtcNormal(timezone);
645
+ end = filterNormal.startOfDayInTargetTimezone(end);
606
646
  }
607
647
  const filterStartIndexOffset = indexFactory(rangeStart) - indexFactory(start);
608
648
  filterOffsetExcludedRange = range(0, filterStartIndexOffset);
@@ -623,7 +663,7 @@ function computeScheduleSelectionValue(state) {
623
663
  end = start; // end is start
624
664
  }
625
665
  const dateScheduleRange = {
626
- timezone: systemTimezone,
666
+ timezone,
627
667
  start,
628
668
  end,
629
669
  w,
@@ -764,7 +804,7 @@ class DbxScheduleSelectionCalendarDateRangeComponent {
764
804
  this.matFormFieldDefaultOptions = matFormFieldDefaultOptions;
765
805
  this._required = new BehaviorSubject(false);
766
806
  this.required$ = this._required.asObservable();
767
- this.timezone$ = this.dbxCalendarScheduleSelectionStore.currentTimezone$;
807
+ this.timezone$ = this.dbxCalendarScheduleSelectionStore.effectiveOutputTimezone$;
768
808
  this.openPickerOnTextClick = true;
769
809
  this.label = 'Enter a date range';
770
810
  this.showCustomize = false;
@@ -851,7 +891,7 @@ class DbxScheduleSelectionCalendarDateRangeComponent {
851
891
  .pipe(distinctUntilChanged(), switchMap((opened) => {
852
892
  let obs;
853
893
  if (opened) {
854
- obs = of({});
894
+ obs = EMPTY;
855
895
  }
856
896
  else {
857
897
  obs = this.range.valueChanges.pipe(startWith(this.range.value));
@@ -1244,10 +1284,11 @@ class DbxScheduleSelectionCalendarComponent {
1244
1284
  this._inputReadonly = new BehaviorSubject(undefined);
1245
1285
  this._config = new BehaviorSubject({});
1246
1286
  this._centerRangeSub = new SubscriptionObject();
1247
- this.readonly$ = this._config.pipe(switchMap((x) => (x.readonly != null ? asObservableFromGetter(x.readonly) : of(undefined))), combineLatestWith(this._inputReadonly), map(([configReadonly, inputReadonly]) => {
1287
+ this.config$ = this._config.pipe(distinctUntilChanged(), shareReplay(1));
1288
+ this.readonly$ = this.config$.pipe(switchMap((x) => (x.readonly != null ? asObservableFromGetter(x.readonly) : of(undefined))), combineLatestWith(this._inputReadonly), map(([configReadonly, inputReadonly]) => {
1248
1289
  return (configReadonly !== null && configReadonly !== void 0 ? configReadonly : false) || (inputReadonly !== null && inputReadonly !== void 0 ? inputReadonly : false);
1249
1290
  }), shareReplay(1));
1250
- this.showButtonsOnReadonly$ = this._config.pipe(map((x) => { var _a; return (_a = x.showButtonsOnReadonly) !== null && _a !== void 0 ? _a : false; }), distinctUntilChanged(), shareReplay(1));
1291
+ this.showButtonsOnReadonly$ = this.config$.pipe(map((x) => { var _a; return (_a = x.showButtonsOnReadonly) !== null && _a !== void 0 ? _a : false; }), distinctUntilChanged(), shareReplay(1));
1251
1292
  this.showButtons$ = this.showButtonsOnReadonly$.pipe(switchMap((x) => {
1252
1293
  if (x) {
1253
1294
  return of(true);
@@ -1256,12 +1297,12 @@ class DbxScheduleSelectionCalendarComponent {
1256
1297
  return this.readonly$.pipe(map((x) => !x));
1257
1298
  }
1258
1299
  }), distinctUntilChanged(), shareReplay(1));
1259
- this.showClearSelectionButton$ = this._config.pipe(map((config) => { var _a; return (_a = config.showClearSelectionButton) !== null && _a !== void 0 ? _a : true; }), combineLatestWith(this.showButtons$), map((x) => reduceBooleansWithAnd(x)), distinctUntilChanged(), shareReplay(1));
1260
- this.datePopoverButtonInjectionConfig$ = this._config.pipe(map((x) => x.buttonInjectionConfig), switchMapDbxInjectionComponentConfig(DbxScheduleSelectionCalendarDatePopoverButtonComponent), combineLatestWith(this.showButtons$), map(([config, showButton]) => (showButton ? config : undefined)), shareReplay(1));
1300
+ this.showClearSelectionButton$ = this.config$.pipe(map((config) => { var _a; return (_a = config.showClearSelectionButton) !== null && _a !== void 0 ? _a : true; }), combineLatestWith(this.showButtons$), map((x) => reduceBooleansWithAnd(x)), distinctUntilChanged(), shareReplay(1));
1301
+ this.datePopoverButtonInjectionConfig$ = this.config$.pipe(map((x) => x.buttonInjectionConfig), switchMapDbxInjectionComponentConfig(DbxScheduleSelectionCalendarDatePopoverButtonComponent), combineLatestWith(this.showButtons$), map(([config, showButton]) => (showButton ? config : undefined)), shareReplay(1));
1261
1302
  this.clickEvent = new EventEmitter();
1262
1303
  // refresh any time the selected day function updates
1263
1304
  this.state$ = this.dbxCalendarScheduleSelectionStore.state$;
1264
- this.beforeMonthViewRender$ = this._config.pipe(switchMap((x) => {
1305
+ this.beforeMonthViewRender$ = this.config$.pipe(switchMap((x) => {
1265
1306
  let factory;
1266
1307
  if (x.beforeMonthViewRenderFunctionFactory) {
1267
1308
  factory = asObservable(x.beforeMonthViewRenderFunctionFactory);
@@ -1491,8 +1532,8 @@ class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
1491
1532
  get exclusions() {
1492
1533
  return this.props.exclusions;
1493
1534
  }
1494
- get timezone() {
1495
- return this.props.timezone;
1535
+ get outputTimezone() {
1536
+ return this.props.outputTimezone || this.props.timezone;
1496
1537
  }
1497
1538
  get initialSelectionState() {
1498
1539
  return this.props.initialSelectionState;
@@ -1517,7 +1558,7 @@ class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
1517
1558
  this._valueSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateCellScheduleRangeValue$.subscribe((x) => {
1518
1559
  this.formControl.setValue(x);
1519
1560
  });
1520
- const { timezone, minMaxDateRange, filter, exclusions, defaultScheduleDays } = this;
1561
+ const { outputTimezone, minMaxDateRange, filter, exclusions, defaultScheduleDays } = this;
1521
1562
  if (filter != null) {
1522
1563
  this._filterSub.subscription = this.dbxCalendarScheduleSelectionStore.setFilter(asObservable(filter));
1523
1564
  }
@@ -1530,8 +1571,8 @@ class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
1530
1571
  if (exclusions != null) {
1531
1572
  this._exclusionsSub.subscription = this.dbxCalendarScheduleSelectionStore.setExclusions(asObservable(exclusions));
1532
1573
  }
1533
- if (timezone != null) {
1534
- this.dbxCalendarScheduleSelectionStore.setTimezone(asObservable(this.timezone));
1574
+ if (outputTimezone != null) {
1575
+ this.dbxCalendarScheduleSelectionStore.setOutputTimezone(asObservable(this.outputTimezone));
1535
1576
  }
1536
1577
  if (this.initialSelectionState !== undefined) {
1537
1578
  this.dbxCalendarScheduleSelectionStore.setInitialSelectionState(this.initialSelectionState);