@dereekb/dbx-form 9.23.9 → 9.23.11
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.store.d.ts +36 -4
- package/calendar/lib/field/schedule/calendar.schedule.field.component.d.ts +9 -4
- package/esm2020/calendar/lib/calendar.schedule.selection.store.mjs +133 -37
- package/esm2020/calendar/lib/field/schedule/calendar.schedule.field.component.mjs +24 -3
- package/esm2020/calendar/lib/field/schedule/calendar.schedule.field.mjs +6 -3
- package/fesm2015/dereekb-dbx-form-calendar.mjs +161 -41
- package/fesm2015/dereekb-dbx-form-calendar.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-form-calendar.mjs +161 -41
- package/fesm2020/dereekb-dbx-form-calendar.mjs.map +1 -1
- package/lib/extension/calendar/_calendar.scss +2 -0
- package/mapbox/package.json +4 -4
- package/package.json +4 -4
|
@@ -20,6 +20,7 @@ export class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
|
|
|
20
20
|
this._syncSub = new SubscriptionObject();
|
|
21
21
|
this._valueSub = new SubscriptionObject();
|
|
22
22
|
this._filterSub = new SubscriptionObject();
|
|
23
|
+
this._exclusionsSub = new SubscriptionObject();
|
|
23
24
|
this._formControlObs = new BehaviorSubject(undefined);
|
|
24
25
|
this.formControl$ = this._formControlObs.pipe(filterMaybe());
|
|
25
26
|
this.value$ = this.formControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value))), shareReplay(1));
|
|
@@ -45,6 +46,15 @@ export class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
|
|
|
45
46
|
get filter() {
|
|
46
47
|
return this.props.filter;
|
|
47
48
|
}
|
|
49
|
+
get exclusions() {
|
|
50
|
+
return this.props.exclusions;
|
|
51
|
+
}
|
|
52
|
+
get initialSelectionState() {
|
|
53
|
+
return this.props.initialSelectionState;
|
|
54
|
+
}
|
|
55
|
+
get computeSelectionResultRelativeToFilter() {
|
|
56
|
+
return this.props.computeSelectionResultRelativeToFilter;
|
|
57
|
+
}
|
|
48
58
|
ngOnInit() {
|
|
49
59
|
this._formControlObs.next(this.formControl);
|
|
50
60
|
this._syncSub.subscription = this.value$.pipe(distinctUntilChanged(isSameDateScheduleRange)).subscribe((x) => {
|
|
@@ -53,17 +63,28 @@ export class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
|
|
|
53
63
|
this._valueSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateScheduleRangeValue$.subscribe((x) => {
|
|
54
64
|
this.formControl.setValue(x);
|
|
55
65
|
});
|
|
56
|
-
const filter = this
|
|
66
|
+
const { filter, exclusions } = this;
|
|
57
67
|
if (filter != null) {
|
|
58
68
|
this._filterSub.subscription = this.dbxCalendarScheduleSelectionStore.setFilter(asObservable(filter));
|
|
59
69
|
}
|
|
70
|
+
if (exclusions != null) {
|
|
71
|
+
this._exclusionsSub.subscription = this.dbxCalendarScheduleSelectionStore.setExclusions(asObservable(exclusions));
|
|
72
|
+
}
|
|
73
|
+
if (this.initialSelectionState !== undefined) {
|
|
74
|
+
this.dbxCalendarScheduleSelectionStore.setInitialSelectionState(this.initialSelectionState);
|
|
75
|
+
}
|
|
76
|
+
if (this.computeSelectionResultRelativeToFilter != null) {
|
|
77
|
+
this.dbxCalendarScheduleSelectionStore.setComputeSelectionResultRelativeToFilter(this.computeSelectionResultRelativeToFilter);
|
|
78
|
+
}
|
|
79
|
+
// TODO: Also add ability to set min/max dates independent of the filter
|
|
60
80
|
}
|
|
61
81
|
ngOnDestroy() {
|
|
62
82
|
super.ngOnDestroy();
|
|
63
83
|
this._syncSub.destroy();
|
|
64
84
|
this._valueSub.destroy();
|
|
65
|
-
this._formControlObs.complete();
|
|
66
85
|
this._filterSub.destroy();
|
|
86
|
+
this._exclusionsSub.destroy();
|
|
87
|
+
this._formControlObs.complete();
|
|
67
88
|
}
|
|
68
89
|
}
|
|
69
90
|
DbxFormCalendarDateScheduleRangeFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormCalendarDateScheduleRangeFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.DbxCalendarScheduleSelectionStore }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -89,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
89
110
|
}], ctorParameters: function () { return [{ type: i1.CompactContextStore, decorators: [{
|
|
90
111
|
type: Optional
|
|
91
112
|
}] }, { type: i2.DbxCalendarScheduleSelectionStore }, { type: i0.NgZone }]; } });
|
|
92
|
-
//# 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 { Maybe } from '@dereekb/util';\nimport { FieldType } from '@ngx-formly/material';\nimport { BehaviorSubject, distinctUntilChanged, shareReplay, startWith, Subscription, switchMap } from 'rxjs';\nimport { filterMaybe, ObservableOrValue, SubscriptionObject, asObservable } from '@dereekb/rxjs';\nimport { DateScheduleDateFilterConfig, isSameDateScheduleRange } from '@dereekb/date';\nimport { DbxCalendarScheduleSelectionStore } from '../../calendar.schedule.selection.store';\nimport { provideCalendarScheduleSelectionStoreIfParentIsUnavailable } from '../../calendar.schedule.selection.store.provide';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\n\nexport interface DbxFormCalendarDateScheduleRangeFieldProps extends Pick<FormlyFieldProps, 'label' | 'description' | 'readonly' | 'required'> {\n  appearance?: MatFormFieldAppearance;\n  hideCustomize?: boolean;\n  filter?: ObservableOrValue<Maybe<DateScheduleDateFilterConfig>>;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-schedule-selection-field\">\n      <dbx-schedule-selection-calendar-date-range [showCustomize]=\"showCustomize\" [required]=\"required\" [disabled]=\"isReadonlyOrDisabled\" [label]=\"label\" [hint]=\"description\">\n        <dbx-schedule-selection-calendar-date-dialog-button customizeButton></dbx-schedule-selection-calendar-date-dialog-button>\n      </dbx-schedule-selection-calendar-date-range>\n    </div>\n  `,\n  providers: [provideCalendarScheduleSelectionStoreIfParentIsUnavailable()]\n})\nexport class DbxFormCalendarDateScheduleRangeFieldComponent<T extends DbxFormCalendarDateScheduleRangeFieldProps = DbxFormCalendarDateScheduleRangeFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _syncSub = new SubscriptionObject();\n  private _valueSub = new SubscriptionObject();\n  private _filterSub = 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  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 showCustomize() {\n    return !this.props.hideCustomize;\n  }\n\n  get filter() {\n    return this.props.filter;\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    this._syncSub.subscription = this.value$.pipe(distinctUntilChanged(isSameDateScheduleRange)).subscribe((x) => {\n      this.dbxCalendarScheduleSelectionStore.setDateScheduleRangeValue(x);\n    });\n\n    this._valueSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateScheduleRangeValue$.subscribe((x) => {\n      this.formControl.setValue(x);\n    });\n\n    const filter = this.filter;\n\n    if (filter != null) {\n      this._filterSub.subscription = this.dbxCalendarScheduleSelectionStore.setFilter(asObservable(filter)) as Subscription;\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._syncSub.destroy();\n    this._valueSub.destroy();\n    this._formControlObs.complete();\n    this._filterSub.destroy();\n  }\n}\n"]}
|
|
113
|
+
//# 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":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,EAAqB,QAAQ,EAAE,MAAM,eAAe,CAAC;AAG/E,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,oBAAoB,EAAE,WAAW,EAAE,SAAS,EAAgB,SAAS,EAAE,MAAM,MAAM,CAAC;AAC9G,OAAO,EAAE,WAAW,EAAqB,kBAAkB,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AACjG,OAAO,EAAiG,uBAAuB,EAAE,MAAM,eAAe,CAAC;AACvJ,OAAO,EAAkC,iCAAiC,EAAE,MAAM,yCAAyC,CAAC;AAC5H,OAAO,EAAE,0DAA0D,EAAE,MAAM,iDAAiD,CAAC;;;;;;AAoB7H,MAAM,OAAO,8CAAkJ,SAAQ,SAA6B;IAclM,YAAiC,OAA4B,EAAW,iCAAoE,EAAW,MAAc;QACnK,KAAK,EAAE,CAAC;QADuB,YAAO,GAAP,OAAO,CAAqB;QAAW,sCAAiC,GAAjC,iCAAiC,CAAmC;QAAW,WAAM,GAAN,MAAM,CAAQ;QAb7J,aAAQ,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACpC,cAAS,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACrC,eAAU,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACtC,mBAAc,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAE1C,oBAAe,GAAG,IAAI,eAAe,CAAyB,SAAS,CAAC,CAAC;QACxE,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAExD,WAAM,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CACtC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAC3E,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;IAIF,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,GAAa,CAAC;IAClC,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,IAAiB,CAAC;IAChC,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC;IACjC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;IAChC,CAAC;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC;IAC9C,CAAC;IAED,IAAI,aAAa;QACf,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;IACnC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC3B,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC;IAC/B,CAAC;IAED,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC;IAC1C,CAAC;IAED,IAAI,sCAAsC;QACxC,OAAO,IAAI,CAAC,KAAK,CAAC,sCAAsC,CAAC;IAC3D,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAE5C,IAAI,CAAC,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC3G,IAAI,CAAC,iCAAiC,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,iCAAiC,CAAC,8BAA8B,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAClH,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEH,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;QAEpC,IAAI,MAAM,IAAI,IAAI,EAAE;YAClB,IAAI,CAAC,UAAU,CAAC,YAAY,GAAG,IAAI,CAAC,iCAAiC,CAAC,SAAS,CAAC,YAAY,CAAC,MAAM,CAAC,CAAiB,CAAC;SACvH;QAED,IAAI,UAAU,IAAI,IAAI,EAAE;YACtB,IAAI,CAAC,cAAc,CAAC,YAAY,GAAG,IAAI,CAAC,iCAAiC,CAAC,aAAa,CAAC,YAAY,CAAC,UAAU,CAAC,CAAiB,CAAC;SACnI;QAED,IAAI,IAAI,CAAC,qBAAqB,KAAK,SAAS,EAAE;YAC5C,IAAI,CAAC,iCAAiC,CAAC,wBAAwB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;SAC7F;QAED,IAAI,IAAI,CAAC,sCAAsC,IAAI,IAAI,EAAE;YACvD,IAAI,CAAC,iCAAiC,CAAC,yCAAyC,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;SAC/H;QAED,wEAAwE;IAC1E,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QACxB,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;QACzB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;QAC1B,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;QAC9B,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;;4IAjGU,8CAA8C;gIAA9C,8CAA8C,uCAF9C,CAAC,0DAA0D,EAAE,CAAC,iDAP/D;;;;;;GAMT;4FAGU,8CAA8C;kBAV1D,SAAS;mBAAC;oBACT,QAAQ,EAAE;;;;;;GAMT;oBACD,SAAS,EAAE,CAAC,0DAA0D,EAAE,CAAC;iBAC1E;;0BAec,QAAQ","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 { AllOrNoneSelection, ArrayOrValue, Maybe } from '@dereekb/util';\nimport { FieldType } from '@ngx-formly/material';\nimport { BehaviorSubject, distinctUntilChanged, shareReplay, startWith, Subscription, switchMap } from 'rxjs';\nimport { filterMaybe, ObservableOrValue, SubscriptionObject, asObservable } from '@dereekb/rxjs';\nimport { DateBlockIndex, DateOrDateRangeOrDateBlockIndexOrDateBlockRange, DateScheduleDateFilterConfig, isSameDateScheduleRange } 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';\n\nexport interface DbxFormCalendarDateScheduleRangeFieldProps extends Pick<FormlyFieldProps, 'label' | 'description' | 'readonly' | 'required'>, Pick<CalendarScheduleSelectionState, 'computeSelectionResultRelativeToFilter' | 'initialSelectionState'> {\n  appearance?: MatFormFieldAppearance;\n  hideCustomize?: boolean;\n  filter?: ObservableOrValue<Maybe<DateScheduleDateFilterConfig>>;\n  exclusions?: ObservableOrValue<Maybe<ArrayOrValue<DateOrDateRangeOrDateBlockIndexOrDateBlockRange>>>;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-schedule-selection-field\">\n      <dbx-schedule-selection-calendar-date-range [showCustomize]=\"showCustomize\" [required]=\"required\" [disabled]=\"isReadonlyOrDisabled\" [label]=\"label\" [hint]=\"description\">\n        <dbx-schedule-selection-calendar-date-dialog-button customizeButton></dbx-schedule-selection-calendar-date-dialog-button>\n      </dbx-schedule-selection-calendar-date-range>\n    </div>\n  `,\n  providers: [provideCalendarScheduleSelectionStoreIfParentIsUnavailable()]\n})\nexport class DbxFormCalendarDateScheduleRangeFieldComponent<T extends DbxFormCalendarDateScheduleRangeFieldProps = DbxFormCalendarDateScheduleRangeFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _syncSub = new SubscriptionObject();\n  private _valueSub = 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  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 showCustomize() {\n    return !this.props.hideCustomize;\n  }\n\n  get filter() {\n    return this.props.filter;\n  }\n\n  get exclusions() {\n    return this.props.exclusions;\n  }\n\n  get initialSelectionState() {\n    return this.props.initialSelectionState;\n  }\n\n  get computeSelectionResultRelativeToFilter() {\n    return this.props.computeSelectionResultRelativeToFilter;\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    this._syncSub.subscription = this.value$.pipe(distinctUntilChanged(isSameDateScheduleRange)).subscribe((x) => {\n      this.dbxCalendarScheduleSelectionStore.setDateScheduleRangeValue(x);\n    });\n\n    this._valueSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateScheduleRangeValue$.subscribe((x) => {\n      this.formControl.setValue(x);\n    });\n\n    const { filter, exclusions } = this;\n\n    if (filter != null) {\n      this._filterSub.subscription = this.dbxCalendarScheduleSelectionStore.setFilter(asObservable(filter)) as Subscription;\n    }\n\n    if (exclusions != null) {\n      this._exclusionsSub.subscription = this.dbxCalendarScheduleSelectionStore.setExclusions(asObservable(exclusions)) as Subscription;\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    // TODO: Also add ability to set min/max dates independent of the filter\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._syncSub.destroy();\n    this._valueSub.destroy();\n    this._filterSub.destroy();\n    this._exclusionsSub.destroy();\n    this._formControlObs.complete();\n  }\n}\n"]}
|
|
@@ -1,16 +1,19 @@
|
|
|
1
1
|
import { formlyField, propsAndConfigForFieldConfig } from '@dereekb/dbx-form';
|
|
2
2
|
export function dateScheduleRangeField(config = {}) {
|
|
3
|
-
const { key = 'schedule', filter } = config;
|
|
3
|
+
const { key = 'schedule', filter, initialSelectionState, computeSelectionResultRelativeToFilter, exclusions } = config;
|
|
4
4
|
const fieldConfig = {
|
|
5
5
|
...formlyField({
|
|
6
6
|
key,
|
|
7
7
|
type: 'date-schedule-range',
|
|
8
8
|
...propsAndConfigForFieldConfig(config, {
|
|
9
9
|
label: config.label ?? 'Schedule',
|
|
10
|
-
filter
|
|
10
|
+
filter,
|
|
11
|
+
computeSelectionResultRelativeToFilter,
|
|
12
|
+
initialSelectionState,
|
|
13
|
+
exclusions
|
|
11
14
|
})
|
|
12
15
|
})
|
|
13
16
|
};
|
|
14
17
|
return fieldConfig;
|
|
15
18
|
}
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuc2NoZWR1bGUuZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9jYWxlbmRhci9zcmMvbGliL2ZpZWxkL3NjaGVkdWxlL2NhbGVuZGFyLnNjaGVkdWxlLmZpZWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBdUMsV0FBVyxFQUFzQiw0QkFBNEIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBTXZJLE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxTQUF1QyxFQUFFO0lBQzlFLE1BQU0sRUFBRSxHQUFHLEdBQUcsVUFBVSxFQUFFLE1BQU0sRUFBRSxxQkFBcUIsRUFBRSxzQ0FBc0MsRUFBRSxVQUFVLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFDdkgsTUFBTSxXQUFXLEdBQXNCO1FBQ3JDLEdBQUcsV0FBVyxDQUFDO1lBQ2IsR0FBRztZQUNILElBQUksRUFBRSxxQkFBcUI7WUFDM0IsR0FBRyw0QkFBNEIsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3RDLEtBQUssRUFBRSxNQUFNLENBQUMsS0FBSyxJQUFJLFVBQVU7Z0JBQ2pDLE1BQU07Z0JBQ04sc0NBQXNDO2dCQUN0QyxxQkFBcUI7Z0JBQ3JCLFVBQVU7YUFDWCxDQUFDO1NBQ0gsQ0FBQztLQUNILENBQUM7SUFFRixPQUFPLFdBQVcsQ0FBQztBQUNyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgRmllbGRDb25maWcsIGZvcm1seUZpZWxkLCBMYWJlbGVkRmllbGRDb25maWcsIHByb3BzQW5kQ29uZmlnRm9yRmllbGRDb25maWcgfSBmcm9tICdAZGVyZWVrYi9kYngtZm9ybSc7XG5pbXBvcnQgeyBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgRGJ4Rm9ybUNhbGVuZGFyRGF0ZVNjaGVkdWxlUmFuZ2VGaWVsZFByb3BzIH0gZnJvbSAnLi9jYWxlbmRhci5zY2hlZHVsZS5maWVsZC5jb21wb25lbnQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERhdGVTY2hlZHVsZVJhbmdlRmllbGRDb25maWcgZXh0ZW5kcyBPbWl0PExhYmVsZWRGaWVsZENvbmZpZywgJ2tleScgfCAncGxhY2Vob2xkZXInPiwgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgUGFydGlhbDxGaWVsZENvbmZpZz4sIERieEZvcm1DYWxlbmRhckRhdGVTY2hlZHVsZVJhbmdlRmllbGRQcm9wcyB7fVxuXG5leHBvcnQgZnVuY3Rpb24gZGF0ZVNjaGVkdWxlUmFuZ2VGaWVsZChjb25maWc6IERhdGVTY2hlZHVsZVJhbmdlRmllbGRDb25maWcgPSB7fSk6IEZvcm1seUZpZWxkQ29uZmlnIHtcbiAgY29uc3QgeyBrZXkgPSAnc2NoZWR1bGUnLCBmaWx0ZXIsIGluaXRpYWxTZWxlY3Rpb25TdGF0ZSwgY29tcHV0ZVNlbGVjdGlvblJlc3VsdFJlbGF0aXZlVG9GaWx0ZXIsIGV4Y2x1c2lvbnMgfSA9IGNvbmZpZztcbiAgY29uc3QgZmllbGRDb25maWc6IEZvcm1seUZpZWxkQ29uZmlnID0ge1xuICAgIC4uLmZvcm1seUZpZWxkKHtcbiAgICAgIGtleSxcbiAgICAgIHR5cGU6ICdkYXRlLXNjaGVkdWxlLXJhbmdlJyxcbiAgICAgIC4uLnByb3BzQW5kQ29uZmlnRm9yRmllbGRDb25maWcoY29uZmlnLCB7XG4gICAgICAgIGxhYmVsOiBjb25maWcubGFiZWwgPz8gJ1NjaGVkdWxlJyxcbiAgICAgICAgZmlsdGVyLFxuICAgICAgICBjb21wdXRlU2VsZWN0aW9uUmVzdWx0UmVsYXRpdmVUb0ZpbHRlcixcbiAgICAgICAgaW5pdGlhbFNlbGVjdGlvblN0YXRlLFxuICAgICAgICBleGNsdXNpb25zXG4gICAgICB9KVxuICAgIH0pXG4gIH07XG5cbiAgcmV0dXJuIGZpZWxkQ29uZmlnO1xufVxuIl19
|
|
@@ -5,10 +5,10 @@ import { Injectable, SkipSelf, Directive, Injector, Optional, Component, Inject,
|
|
|
5
5
|
import { FieldType } from '@ngx-formly/material';
|
|
6
6
|
import { map, distinctUntilChanged, shareReplay, BehaviorSubject, switchMap, of, startWith, filter, throttleTime, first } from 'rxjs';
|
|
7
7
|
import { filterMaybe, SubscriptionObject, asObservable } from '@dereekb/rxjs';
|
|
8
|
-
import { DateScheduleDayCode, expandDateScheduleDayCodesToDayOfWeekSet, dateTimingRelativeIndexFactory, dateBlockDayOfWeekFactory, isSameDate, isSameDateRange, isSameDateScheduleRange,
|
|
9
|
-
import { setsAreEquivalent, iterableToArray, toggleInSet, addToSet, isIndexNumberInIndexRangeFunction,
|
|
8
|
+
import { DateScheduleDayCode, expandDateScheduleDayCodesToDayOfWeekSet, dateTimingRelativeIndexFactory, dateBlockDayOfWeekFactory, findMaxDate, findMinDate, isSameDate, isSameDateRange, isSameDateScheduleRange, isSameDateDay, dateTimingRelativeIndexArrayFactory, copyDateScheduleDateFilterConfig, dateScheduleDateFilter, expandDateScheduleDayCodes, isDateInDateRangeFunction, isDateWithinDateBlockRangeFunction, dateScheduleEncodedWeek, dateBlockTimingDateFactory, enabledDaysFromDateScheduleDayCodes, dateScheduleDayCodesFromEnabledDays, formatToMonthDayString } from '@dereekb/date';
|
|
9
|
+
import { setsAreEquivalent, unique, mergeArrays, range, iterableToArray, toggleInSet, addToSet, isIndexNumberInIndexRangeFunction, minAndMaxNumber, randomNumberFactory, getDaysOfWeekNames } from '@dereekb/util';
|
|
10
10
|
import { ComponentStore } from '@ngrx/component-store';
|
|
11
|
-
import { startOfDay
|
|
11
|
+
import { startOfDay } from 'date-fns';
|
|
12
12
|
import * as i1$1 from '@dereekb/dbx-web';
|
|
13
13
|
import { AbstractPopoverDirective, AbstractDialogDirective, DbxActionModule, DbxButtonModule, DbxDialogInteractionModule, DbxPopoverInteractionModule, DbxTextModule } from '@dereekb/dbx-web';
|
|
14
14
|
import * as i3 from '@angular/forms';
|
|
@@ -37,10 +37,13 @@ import { FlexLayoutModule } from '@angular/flex-layout';
|
|
|
37
37
|
|
|
38
38
|
function dateScheduleRangeField(config = {}) {
|
|
39
39
|
var _a;
|
|
40
|
-
const { key = 'schedule', filter } = config;
|
|
40
|
+
const { key = 'schedule', filter, initialSelectionState, computeSelectionResultRelativeToFilter, exclusions } = config;
|
|
41
41
|
const fieldConfig = Object.assign({}, formlyField(Object.assign({ key, type: 'date-schedule-range' }, propsAndConfigForFieldConfig(config, {
|
|
42
42
|
label: (_a = config.label) !== null && _a !== void 0 ? _a : 'Schedule',
|
|
43
|
-
filter
|
|
43
|
+
filter,
|
|
44
|
+
computeSelectionResultRelativeToFilter,
|
|
45
|
+
initialSelectionState,
|
|
46
|
+
exclusions
|
|
44
47
|
}))));
|
|
45
48
|
return fieldConfig;
|
|
46
49
|
}
|
|
@@ -91,11 +94,26 @@ function initialCalendarScheduleSelectionState() {
|
|
|
91
94
|
indexDayOfWeek,
|
|
92
95
|
isEnabledFilterDay: () => true,
|
|
93
96
|
isEnabledDay: () => false,
|
|
94
|
-
minDate:
|
|
95
|
-
maxDate:
|
|
97
|
+
minDate: null,
|
|
98
|
+
maxDate: null,
|
|
99
|
+
computeSelectionResultRelativeToFilter: true,
|
|
96
100
|
cellContentFactory: defaultCalendarScheduleSelectionCellContentFactory
|
|
97
101
|
};
|
|
98
102
|
}
|
|
103
|
+
function calendarScheduleMinDate(x) {
|
|
104
|
+
var _a;
|
|
105
|
+
return findMaxDate([(_a = x.filter) === null || _a === void 0 ? void 0 : _a.start, x.minDate]);
|
|
106
|
+
}
|
|
107
|
+
function calendarScheduleMaxDate(x) {
|
|
108
|
+
var _a;
|
|
109
|
+
return findMinDate([(_a = x.filter) === null || _a === void 0 ? void 0 : _a.end, x.maxDate]);
|
|
110
|
+
}
|
|
111
|
+
function calendarScheduleMinAndMaxDate(x) {
|
|
112
|
+
return {
|
|
113
|
+
minDate: calendarScheduleMinDate(x),
|
|
114
|
+
maxDate: calendarScheduleMaxDate(x)
|
|
115
|
+
};
|
|
116
|
+
}
|
|
99
117
|
class DbxCalendarScheduleSelectionStore extends ComponentStore {
|
|
100
118
|
constructor() {
|
|
101
119
|
super(initialCalendarScheduleSelectionState());
|
|
@@ -116,18 +134,22 @@ class DbxCalendarScheduleSelectionStore extends ComponentStore {
|
|
|
116
134
|
this.isEnabledFilterDayFunction$ = this.state$.pipe(map((x) => x.isEnabledFilterDay), shareReplay(1));
|
|
117
135
|
this.isEnabledDayFunction$ = this.state$.pipe(map((x) => x.isEnabledDay), shareReplay(1));
|
|
118
136
|
this.currentDateRange$ = this.state$.pipe(map(computeCalendarScheduleSelectionRange), distinctUntilChanged((a, b) => isSameDateRange(a, b)), shareReplay(1));
|
|
137
|
+
this.computeSelectionResultRelativeToFilter$ = this.state$.pipe(map((x) => x.computeSelectionResultRelativeToFilter), shareReplay(1));
|
|
138
|
+
this.startBeingUsedFromFilter$ = this.state$.pipe(map((x) => { var _a; return x.computeSelectionResultRelativeToFilter && ((_a = x.filter) === null || _a === void 0 ? void 0 : _a.start) != null; }), shareReplay(1));
|
|
119
139
|
this.dateRange$ = this.currentDateRange$.pipe(filterMaybe(), shareReplay(1));
|
|
120
140
|
this.scheduleDays$ = this.state$.pipe(map((x) => x.scheduleDays), distinctUntilChanged(setsAreEquivalent), shareReplay(1));
|
|
121
141
|
this.currentSelectionValue$ = this.state$.pipe(map((x) => x.currentSelectionValue), shareReplay(1));
|
|
122
142
|
this.selectionValue$ = this.currentSelectionValue$.pipe(filterMaybe(), shareReplay(1));
|
|
123
143
|
this.currentDateScheduleRangeValue$ = this.currentSelectionValue$.pipe(map((x) => x === null || x === void 0 ? void 0 : x.dateScheduleRange), distinctUntilChanged(isSameDateScheduleRange), shareReplay(1));
|
|
124
144
|
this.dateScheduleRangeValue$ = this.currentDateScheduleRangeValue$.pipe(filterMaybe(), shareReplay(1));
|
|
125
|
-
this.minDate$ = this.state$.pipe(map(
|
|
126
|
-
this.maxDate$ = this.state$.pipe(map(
|
|
145
|
+
this.minDate$ = this.state$.pipe(map(calendarScheduleMinDate), distinctUntilChanged(isSameDateDay), shareReplay(1));
|
|
146
|
+
this.maxDate$ = this.state$.pipe(map(calendarScheduleMaxDate), distinctUntilChanged(isSameDateDay), shareReplay(1));
|
|
127
147
|
this.cellContentFactory$ = this.state$.pipe(map((x) => x.cellContentFactory), distinctUntilChanged(), shareReplay(1));
|
|
128
148
|
this.isCustomized$ = this.state$.pipe(map((x) => x.selectedIndexes.size > 0), distinctUntilChanged(), shareReplay(1));
|
|
129
149
|
// MARK: State Changes
|
|
130
150
|
this.setFilter = this.updater((state, filter) => updateStateWithFilter(state, filter));
|
|
151
|
+
this.setExclusions = this.updater((state, exclusions) => updateStateWithExclusions(state, exclusions));
|
|
152
|
+
this.setComputeSelectionResultRelativeToFilter = this.updater((state, computeSelectionResultRelativeToFilter) => updateStateWithComputeSelectionResultRelativeToFilter(state, computeSelectionResultRelativeToFilter));
|
|
131
153
|
this.clearFilter = this.updater((state) => updateStateWithFilter(state, undefined));
|
|
132
154
|
this.setTimezone = this.updater((state, timezone) => (Object.assign(Object.assign({}, state), { timezone })));
|
|
133
155
|
this.setInputRange = this.updater((state, range) => updateStateWithChangedRange(state, range));
|
|
@@ -135,6 +157,8 @@ class DbxCalendarScheduleSelectionStore extends ComponentStore {
|
|
|
135
157
|
this.addSelectedDates = this.updater((state, add) => updateStateWithChangedDates(state, { add }));
|
|
136
158
|
this.removeSelectedDates = this.updater((state, remove) => updateStateWithChangedDates(state, { remove }));
|
|
137
159
|
this.setSelectedDates = this.updater((state, set) => updateStateWithChangedDates(state, { set }));
|
|
160
|
+
this.selectAllDates = this.updater((state, selectAll = 'all') => updateStateWithChangedDates(state, { selectAll }));
|
|
161
|
+
this.setInitialSelectionState = this.updater((state, initialSelectionState) => updateStateWithInitialSelectionState(state, initialSelectionState));
|
|
138
162
|
this.setScheduleDays = this.updater((state, scheduleDays) => updateStateWithChangedScheduleDays(state, scheduleDays));
|
|
139
163
|
this.setAllowAllScheduleDays = this.updater((state) => updateStateWithChangedScheduleDays(state, null));
|
|
140
164
|
this.setDateScheduleRangeValue = this.updater((state, value) => updateStateWithDateScheduleRangeValue(state, value));
|
|
@@ -146,12 +170,64 @@ DbxCalendarScheduleSelectionStore.ɵprov = i0.ɵɵngDeclareInjectable({ minVersi
|
|
|
146
170
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxCalendarScheduleSelectionStore, decorators: [{
|
|
147
171
|
type: Injectable
|
|
148
172
|
}], ctorParameters: function () { return []; } });
|
|
149
|
-
function
|
|
173
|
+
function updateStateWithInitialSelectionState(state, initialSelectionState) {
|
|
174
|
+
const { selectedIndexes } = state;
|
|
175
|
+
if (selectedIndexes.size === 0 && initialSelectionState === 'all') {
|
|
176
|
+
state = updateStateWithChangedDates(state, { selectAll: initialSelectionState });
|
|
177
|
+
}
|
|
178
|
+
return Object.assign(Object.assign({}, state), { initialSelectionState });
|
|
179
|
+
}
|
|
180
|
+
function updateStateWithComputeSelectionResultRelativeToFilter(currentState, computeSelectionResultRelativeToFilter) {
|
|
181
|
+
let state = Object.assign(Object.assign({}, currentState), { computeSelectionResultRelativeToFilter });
|
|
182
|
+
if (Boolean(currentState.computeSelectionResultRelativeToFilter) !== Boolean(computeSelectionResultRelativeToFilter)) {
|
|
183
|
+
state = updateStateWithChangedDates(state, {}); // recalculate if change occurs as it will affect the output value
|
|
184
|
+
}
|
|
185
|
+
return state;
|
|
186
|
+
}
|
|
187
|
+
function updateStateWithExclusions(state, inputExclusions) {
|
|
188
|
+
let computedExclusions;
|
|
189
|
+
if (inputExclusions) {
|
|
190
|
+
const { indexFactory } = state;
|
|
191
|
+
const indexArrayFactory = dateTimingRelativeIndexArrayFactory(indexFactory);
|
|
192
|
+
computedExclusions = indexArrayFactory(inputExclusions);
|
|
193
|
+
}
|
|
194
|
+
state = Object.assign(Object.assign({}, state), { inputExclusions, computedExclusions });
|
|
195
|
+
return updateStateWithFilter(state, state.filter);
|
|
196
|
+
}
|
|
197
|
+
function updateStateWithFilter(state, inputFilter) {
|
|
198
|
+
const { computedExclusions: exclusions } = state;
|
|
150
199
|
let isEnabledFilterDay = () => true;
|
|
151
|
-
|
|
152
|
-
|
|
200
|
+
let filter = null;
|
|
201
|
+
if (inputFilter || (exclusions === null || exclusions === void 0 ? void 0 : exclusions.length)) {
|
|
202
|
+
let enabledFilter;
|
|
203
|
+
if (inputFilter) {
|
|
204
|
+
filter = copyDateScheduleDateFilterConfig(inputFilter); // copy filter
|
|
205
|
+
if (exclusions === null || exclusions === void 0 ? void 0 : exclusions.length) {
|
|
206
|
+
enabledFilter = Object.assign(Object.assign({}, filter), { ex: unique(mergeArrays([filter.ex, exclusions])) });
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
enabledFilter = filter;
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
else {
|
|
213
|
+
enabledFilter = {
|
|
214
|
+
w: '89',
|
|
215
|
+
ex: exclusions
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
isEnabledFilterDay = dateScheduleDateFilter(enabledFilter);
|
|
153
219
|
}
|
|
154
|
-
|
|
220
|
+
state = Object.assign(Object.assign({}, state), { filter, isEnabledFilterDay });
|
|
221
|
+
// attempt to re-apply the initial selection state once filter is applied
|
|
222
|
+
if (state.initialSelectionState) {
|
|
223
|
+
state = updateStateWithInitialSelectionState(state, state.initialSelectionState);
|
|
224
|
+
}
|
|
225
|
+
// re-calculate the selection given the filter
|
|
226
|
+
const { inputStart, inputEnd } = state;
|
|
227
|
+
if (inputStart && inputEnd) {
|
|
228
|
+
state = updateStateWithChangedRange(state, { inputStart, inputEnd });
|
|
229
|
+
}
|
|
230
|
+
return state;
|
|
155
231
|
}
|
|
156
232
|
function updateStateWithDateScheduleRangeValue(state, change) {
|
|
157
233
|
var _a;
|
|
@@ -162,7 +238,7 @@ function updateStateWithDateScheduleRangeValue(state, change) {
|
|
|
162
238
|
else {
|
|
163
239
|
if (change != null) {
|
|
164
240
|
const nextState = Object.assign(Object.assign({}, state), { inputStart: change.start, inputEnd: change.end, selectedIndexes: new Set(change.ex) });
|
|
165
|
-
return updateStateWithChangedScheduleDays(finalizeNewCalendarScheduleSelectionState(nextState),
|
|
241
|
+
return updateStateWithChangedScheduleDays(finalizeNewCalendarScheduleSelectionState(nextState), expandDateScheduleDayCodes(change.w));
|
|
166
242
|
}
|
|
167
243
|
else {
|
|
168
244
|
return noSelectionCalendarScheduleSelectionState(state); // clear selection, retain disabled days
|
|
@@ -182,10 +258,26 @@ function updateStateWithChangedScheduleDays(state, change) {
|
|
|
182
258
|
}
|
|
183
259
|
}
|
|
184
260
|
function updateStateWithChangedDates(state, change) {
|
|
261
|
+
var _a;
|
|
185
262
|
const { indexFactory, allowedDaysOfWeek, indexDayOfWeek } = state;
|
|
263
|
+
const { minDate, maxDate } = calendarScheduleMinAndMaxDate(state);
|
|
186
264
|
let selectedIndexes;
|
|
187
|
-
if (change.set) {
|
|
188
|
-
|
|
265
|
+
if (change.reset || change.selectAll != null || change.set) {
|
|
266
|
+
let set = (_a = change.set) !== null && _a !== void 0 ? _a : [];
|
|
267
|
+
let selectAll = change.reset === true ? state.initialSelectionState : change.selectAll;
|
|
268
|
+
switch (selectAll) {
|
|
269
|
+
case 'all':
|
|
270
|
+
if (minDate != null && maxDate != null) {
|
|
271
|
+
const minIndex = indexFactory(minDate);
|
|
272
|
+
const maxIndex = indexFactory(maxDate);
|
|
273
|
+
set = range(minIndex, maxIndex);
|
|
274
|
+
}
|
|
275
|
+
break;
|
|
276
|
+
case 'none':
|
|
277
|
+
set = [];
|
|
278
|
+
break;
|
|
279
|
+
}
|
|
280
|
+
selectedIndexes = new Set(iterableToArray(set).map(indexFactory));
|
|
189
281
|
}
|
|
190
282
|
else {
|
|
191
283
|
selectedIndexes = new Set(state.selectedIndexes);
|
|
@@ -211,22 +303,22 @@ function updateStateWithChangedDates(state, change) {
|
|
|
211
303
|
}
|
|
212
304
|
else {
|
|
213
305
|
// no selected days
|
|
214
|
-
return noSelectionCalendarScheduleSelectionState(
|
|
306
|
+
return noSelectionCalendarScheduleSelectionState(nextState);
|
|
215
307
|
}
|
|
216
308
|
}
|
|
217
309
|
function noSelectionCalendarScheduleSelectionState(state) {
|
|
218
310
|
return finalizeNewCalendarScheduleSelectionState(Object.assign(Object.assign({}, state), { selectedIndexes: new Set(), inputStart: null, inputEnd: null }));
|
|
219
311
|
}
|
|
220
312
|
function updateStateWithChangedRange(state, change) {
|
|
221
|
-
const { inputStart: currentInputStart, inputEnd: currentInputEnd, indexFactory, minDate, maxDate } = state;
|
|
222
|
-
|
|
223
|
-
|
|
313
|
+
const { inputStart: currentInputStart, inputEnd: currentInputEnd, indexFactory, minDate, maxDate, filter, computeSelectionResultRelativeToFilter } = state;
|
|
314
|
+
let inputStart = startOfDay(change.inputStart);
|
|
315
|
+
let inputEnd = startOfDay(change.inputEnd);
|
|
224
316
|
const isValidRange = minDate != null || maxDate != null ? isDateInDateRangeFunction({ start: minDate !== null && minDate !== void 0 ? minDate : undefined, end: maxDate !== null && maxDate !== void 0 ? maxDate : undefined }) : () => true;
|
|
225
317
|
if (!isValidRange(inputStart) || !isValidRange(inputEnd) || (isSameDateDay(inputStart, currentInputStart) && isSameDateDay(inputEnd, currentInputEnd))) {
|
|
226
318
|
return state; // if no change, return the current state.
|
|
227
319
|
}
|
|
228
320
|
// retain all indexes that are within the new range
|
|
229
|
-
const minIndex = indexFactory(inputStart);
|
|
321
|
+
const minIndex = computeSelectionResultRelativeToFilter && (filter === null || filter === void 0 ? void 0 : filter.start) ? indexFactory(filter === null || filter === void 0 ? void 0 : filter.start) : indexFactory(inputStart);
|
|
230
322
|
const maxIndex = indexFactory(inputEnd) + 1;
|
|
231
323
|
const currentIndexes = Array.from(state.selectedIndexes);
|
|
232
324
|
const isInCurrentRange = isIndexNumberInIndexRangeFunction({ minIndex, maxIndex });
|
|
@@ -259,19 +351,30 @@ function isEnabledDayInCalendarScheduleSelectionState(state) {
|
|
|
259
351
|
};
|
|
260
352
|
}
|
|
261
353
|
function computeScheduleSelectionValue(state) {
|
|
262
|
-
const { scheduleDays, allowedDaysOfWeek, indexDayOfWeek } = state;
|
|
354
|
+
const { indexFactory, scheduleDays, allowedDaysOfWeek, indexDayOfWeek, computeSelectionResultRelativeToFilter, filter } = state;
|
|
263
355
|
const rangeAndExclusion = computeScheduleSelectionRangeAndExclusion(state);
|
|
264
356
|
if (rangeAndExclusion == null) {
|
|
265
357
|
return null;
|
|
266
358
|
}
|
|
267
|
-
const { start, end, excluded, dateBlockRange } = rangeAndExclusion;
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
359
|
+
const { start: rangeStart, end, excluded: allExcluded, dateBlockRange } = rangeAndExclusion;
|
|
360
|
+
let filterOffsetExcludedRange = [];
|
|
361
|
+
let indexOffset = dateBlockRange.i;
|
|
362
|
+
let start = rangeStart;
|
|
363
|
+
// If computeSelectionResultRelativeToFilter is true, then we need to offset the values to be relative to that start.
|
|
364
|
+
if (computeSelectionResultRelativeToFilter && (filter === null || filter === void 0 ? void 0 : filter.start)) {
|
|
365
|
+
start = filter.start;
|
|
366
|
+
const filterStartIndexOffset = indexFactory(rangeStart) - indexFactory(start);
|
|
367
|
+
filterOffsetExcludedRange = range(0, filterStartIndexOffset);
|
|
368
|
+
indexOffset = indexOffset - filterStartIndexOffset;
|
|
369
|
+
}
|
|
370
|
+
const excluded = computeSelectionResultRelativeToFilter
|
|
371
|
+
? allExcluded.filter((x) => {
|
|
372
|
+
const isExcludedIndex = allowedDaysOfWeek.has(indexDayOfWeek(x)); // ???
|
|
373
|
+
return isExcludedIndex;
|
|
374
|
+
})
|
|
375
|
+
: allExcluded;
|
|
376
|
+
const offsetExcluded = excluded.map((x) => x - indexOffset); // set to the proper offset
|
|
377
|
+
const ex = [...filterOffsetExcludedRange, ...offsetExcluded];
|
|
275
378
|
const w = dateScheduleEncodedWeek(scheduleDays);
|
|
276
379
|
const d = []; // "included" blocks are never used/calculated.
|
|
277
380
|
const dateScheduleRange = {
|
|
@@ -287,7 +390,7 @@ function computeScheduleSelectionValue(state) {
|
|
|
287
390
|
};
|
|
288
391
|
}
|
|
289
392
|
function computeScheduleSelectionRangeAndExclusion(state) {
|
|
290
|
-
const { isEnabledDay } = state;
|
|
393
|
+
const { isEnabledDay, isEnabledFilterDay } = state;
|
|
291
394
|
const dateFactory = dateBlockTimingDateFactory(state);
|
|
292
395
|
const dateBlockRange = computeCalendarScheduleSelectionDateBlockRange(state);
|
|
293
396
|
if (dateBlockRange == null) {
|
|
@@ -296,7 +399,7 @@ function computeScheduleSelectionRangeAndExclusion(state) {
|
|
|
296
399
|
const start = dateFactory(dateBlockRange.i);
|
|
297
400
|
const end = dateFactory(dateBlockRange.to);
|
|
298
401
|
const excluded = range(dateBlockRange.i, dateBlockRange.to + 1).filter((x) => {
|
|
299
|
-
const isExcludedIndex = !isEnabledDay(x);
|
|
402
|
+
const isExcludedIndex = !isEnabledDay(x) || !isEnabledFilterDay(x);
|
|
300
403
|
return isExcludedIndex;
|
|
301
404
|
});
|
|
302
405
|
const result = {
|
|
@@ -310,12 +413,8 @@ function computeScheduleSelectionRangeAndExclusion(state) {
|
|
|
310
413
|
function computeCalendarScheduleSelectionRange(state) {
|
|
311
414
|
const dateFactory = dateBlockTimingDateFactory(state);
|
|
312
415
|
const dateBlockRange = computeCalendarScheduleSelectionDateBlockRange(state);
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
}
|
|
316
|
-
else {
|
|
317
|
-
return undefined;
|
|
318
|
-
}
|
|
416
|
+
const dateRange = dateBlockRange != null ? { start: dateFactory(dateBlockRange.i), end: dateFactory(dateBlockRange.to) } : undefined;
|
|
417
|
+
return dateRange;
|
|
319
418
|
}
|
|
320
419
|
function computeCalendarScheduleSelectionDateBlockRange(state) {
|
|
321
420
|
const { indexFactory, inputStart, inputEnd, allowedDaysOfWeek, indexDayOfWeek, isEnabledDay, isEnabledFilterDay } = state;
|
|
@@ -823,6 +922,7 @@ class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
|
|
|
823
922
|
this._syncSub = new SubscriptionObject();
|
|
824
923
|
this._valueSub = new SubscriptionObject();
|
|
825
924
|
this._filterSub = new SubscriptionObject();
|
|
925
|
+
this._exclusionsSub = new SubscriptionObject();
|
|
826
926
|
this._formControlObs = new BehaviorSubject(undefined);
|
|
827
927
|
this.formControl$ = this._formControlObs.pipe(filterMaybe());
|
|
828
928
|
this.value$ = this.formControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value))), shareReplay(1));
|
|
@@ -849,6 +949,15 @@ class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
|
|
|
849
949
|
get filter() {
|
|
850
950
|
return this.props.filter;
|
|
851
951
|
}
|
|
952
|
+
get exclusions() {
|
|
953
|
+
return this.props.exclusions;
|
|
954
|
+
}
|
|
955
|
+
get initialSelectionState() {
|
|
956
|
+
return this.props.initialSelectionState;
|
|
957
|
+
}
|
|
958
|
+
get computeSelectionResultRelativeToFilter() {
|
|
959
|
+
return this.props.computeSelectionResultRelativeToFilter;
|
|
960
|
+
}
|
|
852
961
|
ngOnInit() {
|
|
853
962
|
this._formControlObs.next(this.formControl);
|
|
854
963
|
this._syncSub.subscription = this.value$.pipe(distinctUntilChanged(isSameDateScheduleRange)).subscribe((x) => {
|
|
@@ -857,17 +966,28 @@ class DbxFormCalendarDateScheduleRangeFieldComponent extends FieldType {
|
|
|
857
966
|
this._valueSub.subscription = this.dbxCalendarScheduleSelectionStore.currentDateScheduleRangeValue$.subscribe((x) => {
|
|
858
967
|
this.formControl.setValue(x);
|
|
859
968
|
});
|
|
860
|
-
const filter = this
|
|
969
|
+
const { filter, exclusions } = this;
|
|
861
970
|
if (filter != null) {
|
|
862
971
|
this._filterSub.subscription = this.dbxCalendarScheduleSelectionStore.setFilter(asObservable(filter));
|
|
863
972
|
}
|
|
973
|
+
if (exclusions != null) {
|
|
974
|
+
this._exclusionsSub.subscription = this.dbxCalendarScheduleSelectionStore.setExclusions(asObservable(exclusions));
|
|
975
|
+
}
|
|
976
|
+
if (this.initialSelectionState !== undefined) {
|
|
977
|
+
this.dbxCalendarScheduleSelectionStore.setInitialSelectionState(this.initialSelectionState);
|
|
978
|
+
}
|
|
979
|
+
if (this.computeSelectionResultRelativeToFilter != null) {
|
|
980
|
+
this.dbxCalendarScheduleSelectionStore.setComputeSelectionResultRelativeToFilter(this.computeSelectionResultRelativeToFilter);
|
|
981
|
+
}
|
|
982
|
+
// TODO: Also add ability to set min/max dates independent of the filter
|
|
864
983
|
}
|
|
865
984
|
ngOnDestroy() {
|
|
866
985
|
super.ngOnDestroy();
|
|
867
986
|
this._syncSub.destroy();
|
|
868
987
|
this._valueSub.destroy();
|
|
869
|
-
this._formControlObs.complete();
|
|
870
988
|
this._filterSub.destroy();
|
|
989
|
+
this._exclusionsSub.destroy();
|
|
990
|
+
this._formControlObs.complete();
|
|
871
991
|
}
|
|
872
992
|
}
|
|
873
993
|
DbxFormCalendarDateScheduleRangeFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormCalendarDateScheduleRangeFieldComponent, deps: [{ token: i1$1.CompactContextStore, optional: true }, { token: DbxCalendarScheduleSelectionStore }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -1061,5 +1181,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
1061
1181
|
* Generated bundle index. Do not edit.
|
|
1062
1182
|
*/
|
|
1063
1183
|
|
|
1064
|
-
export { CalendarScheduleSelectionDayState, DEFAULT_SCHEDULE_SELECTION_CALENDAR_DATE_POPOVER_KEY, DbxCalendarScheduleSelectionStore, DbxCalendarScheduleSelectionStoreInjectionBlockDirective, DbxCalendarScheduleSelectionStoreProviderBlock, DbxFormCalendarDateScheduleRangeFieldComponent, DbxFormCalendarModule, DbxFormDateScheduleRangeFieldModule, DbxScheduleSelectionCalendarCellComponent, DbxScheduleSelectionCalendarComponent, DbxScheduleSelectionCalendarDateDaysComponent, DbxScheduleSelectionCalendarDateDaysFormComponent, DbxScheduleSelectionCalendarDateDialogButtonComponent, DbxScheduleSelectionCalendarDateDialogComponent, DbxScheduleSelectionCalendarDatePopoverButtonComponent, DbxScheduleSelectionCalendarDatePopoverComponent, DbxScheduleSelectionCalendarDatePopoverContentComponent, DbxScheduleSelectionCalendarDateRangeComponent, computeCalendarScheduleSelectionDateBlockRange, computeCalendarScheduleSelectionRange, computeScheduleSelectionRangeAndExclusion, computeScheduleSelectionValue, dateScheduleRangeField, dbxScheduleSelectionCalendarDateDaysFormDayFields, dbxScheduleSelectionCalendarDateDaysFormFields, defaultCalendarScheduleSelectionCellContentFactory, finalizeNewCalendarScheduleSelectionState, initialCalendarScheduleSelectionState, isEnabledDayInCalendarScheduleSelectionState, noSelectionCalendarScheduleSelectionState, provideCalendarScheduleSelectionStoreIfParentIsUnavailable, updateStateWithChangedDates, updateStateWithChangedRange, updateStateWithChangedScheduleDays, updateStateWithDateScheduleRangeValue, updateStateWithFilter };
|
|
1184
|
+
export { CalendarScheduleSelectionDayState, DEFAULT_SCHEDULE_SELECTION_CALENDAR_DATE_POPOVER_KEY, DbxCalendarScheduleSelectionStore, DbxCalendarScheduleSelectionStoreInjectionBlockDirective, DbxCalendarScheduleSelectionStoreProviderBlock, DbxFormCalendarDateScheduleRangeFieldComponent, DbxFormCalendarModule, DbxFormDateScheduleRangeFieldModule, DbxScheduleSelectionCalendarCellComponent, DbxScheduleSelectionCalendarComponent, DbxScheduleSelectionCalendarDateDaysComponent, DbxScheduleSelectionCalendarDateDaysFormComponent, DbxScheduleSelectionCalendarDateDialogButtonComponent, DbxScheduleSelectionCalendarDateDialogComponent, DbxScheduleSelectionCalendarDatePopoverButtonComponent, DbxScheduleSelectionCalendarDatePopoverComponent, DbxScheduleSelectionCalendarDatePopoverContentComponent, DbxScheduleSelectionCalendarDateRangeComponent, calendarScheduleMaxDate, calendarScheduleMinAndMaxDate, calendarScheduleMinDate, computeCalendarScheduleSelectionDateBlockRange, computeCalendarScheduleSelectionRange, computeScheduleSelectionRangeAndExclusion, computeScheduleSelectionValue, dateScheduleRangeField, dbxScheduleSelectionCalendarDateDaysFormDayFields, dbxScheduleSelectionCalendarDateDaysFormFields, defaultCalendarScheduleSelectionCellContentFactory, finalizeNewCalendarScheduleSelectionState, initialCalendarScheduleSelectionState, isEnabledDayInCalendarScheduleSelectionState, noSelectionCalendarScheduleSelectionState, provideCalendarScheduleSelectionStoreIfParentIsUnavailable, updateStateWithChangedDates, updateStateWithChangedRange, updateStateWithChangedScheduleDays, updateStateWithComputeSelectionResultRelativeToFilter, updateStateWithDateScheduleRangeValue, updateStateWithExclusions, updateStateWithFilter, updateStateWithInitialSelectionState };
|
|
1065
1185
|
//# sourceMappingURL=dereekb-dbx-form-calendar.mjs.map
|