@progressio_resources/gravity-design-system 2.6.21 → 2.6.23
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/esm2022/lib/components/gravity-calendar-v2/datepicker/base/bs-datepicker-container.mjs +66 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-datepicker-inline.component.mjs +129 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-datepicker-inline.config.mjs +14 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-datepicker.callbacks.mjs +13 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-datepicker.component.mjs +210 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-datepicker.config.mjs +46 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker-inline.component.mjs +130 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker-inline.config.mjs +18 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker.component.mjs +218 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker.config.mjs +18 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-datepicker-container.component.mjs +134 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-datepicker-inline-container.component.mjs +33 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-datepicker-navigation-view/bs-datepicker-navigation-view.component.mjs +44 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-daterangepicker-container.component.mjs +190 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-daterangepicker-inline-container.component.mjs +33 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-days-calendar-view/bs-datepicker-day-decorator.directive.mjs +30 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-days-calendar-view/bs-days-calendar-view.component.mjs +54 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-months-calendar-view/bs-months-calendar-view.component.mjs +49 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/components/bs-years-calendar-view/bs-years-calendar-view.component.mjs +50 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/datepicker-animations.mjs +16 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/engine/calc-days-calendar.mjs +16 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/engine/flag-days-calendar.mjs +53 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/engine/flag-months-calendar.mjs +39 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/engine/flag-years-calendar.mjs +36 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/engine/format-days-calendar.mjs +23 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/engine/format-months-calendar.mjs +23 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/engine/format-years-calendar.mjs +43 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/engine/view-mode.mjs +4 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/models/index.mjs +7 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/reducer/_defaults.mjs +6 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.actions.mjs +64 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.effects.mjs +128 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.reducer.mjs +301 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.state.mjs +16 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.store.mjs +20 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/utils/bs-calendar-utils.mjs +74 -0
- package/esm2022/lib/components/gravity-calendar-v2/datepicker/utils/matrix-utils.mjs +14 -0
- package/esm2022/lib/components/gravity-calendar-v2/gravity-calendar-v2.component.mjs +227 -0
- package/esm2022/lib/gravity-design-system.module.mjs +47 -3
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/progressio_resources-gravity-design-system.mjs +2458 -33
- package/fesm2022/progressio_resources-gravity-design-system.mjs.map +1 -1
- package/lib/components/gravity-calendar-v2/datepicker/base/bs-datepicker-container.d.ts +41 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-datepicker-inline.component.d.ts +40 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-datepicker-inline.config.d.ts +6 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-datepicker.callbacks.d.ts +6 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-datepicker.component.d.ts +64 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-datepicker.config.d.ts +53 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker-inline.component.d.ts +37 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker-inline.config.d.ts +7 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker.component.d.ts +61 -0
- package/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker.config.d.ts +7 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-datepicker-container.component.d.ts +34 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-datepicker-inline-container.component.d.ts +14 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-datepicker-navigation-view/bs-datepicker-navigation-view.component.d.ts +16 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-daterangepicker-container.component.d.ts +40 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-daterangepicker-inline-container.component.d.ts +14 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-days-calendar-view/bs-datepicker-day-decorator.directive.d.ts +7 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-days-calendar-view/bs-days-calendar-view.component.d.ts +23 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-months-calendar-view/bs-months-calendar-view.component.d.ts +19 -0
- package/lib/components/gravity-calendar-v2/datepicker/components/bs-years-calendar-view/bs-years-calendar-view.component.d.ts +19 -0
- package/lib/components/gravity-calendar-v2/datepicker/datepicker-animations.d.ts +3 -0
- package/lib/components/gravity-calendar-v2/datepicker/engine/calc-days-calendar.d.ts +2 -0
- package/lib/components/gravity-calendar-v2/datepicker/engine/flag-days-calendar.d.ts +12 -0
- package/lib/components/gravity-calendar-v2/datepicker/engine/flag-months-calendar.d.ts +12 -0
- package/lib/components/gravity-calendar-v2/datepicker/engine/flag-years-calendar.d.ts +13 -0
- package/lib/components/gravity-calendar-v2/datepicker/engine/format-days-calendar.d.ts +2 -0
- package/lib/components/gravity-calendar-v2/datepicker/engine/format-months-calendar.d.ts +2 -0
- package/lib/components/gravity-calendar-v2/datepicker/engine/format-years-calendar.d.ts +4 -0
- package/lib/components/gravity-calendar-v2/datepicker/engine/view-mode.d.ts +2 -0
- package/lib/components/gravity-calendar-v2/datepicker/models/index.d.ts +86 -0
- package/lib/components/gravity-calendar-v2/datepicker/reducer/_defaults.d.ts +3 -0
- package/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.actions.d.ts +34 -0
- package/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.effects.d.ts +34 -0
- package/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.reducer.d.ts +3 -0
- package/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.state.d.ts +34 -0
- package/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.store.d.ts +8 -0
- package/lib/components/gravity-calendar-v2/datepicker/utils/bs-calendar-utils.d.ts +13 -0
- package/lib/components/gravity-calendar-v2/datepicker/utils/matrix-utils.d.ts +9 -0
- package/lib/components/gravity-calendar-v2/gravity-calendar-v2.component.d.ts +49 -0
- package/lib/gravity-design-system.module.d.ts +43 -29
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/src/lib/styles/components/_datepicker-v2.scss +9 -0
- package/src/lib/styles/gravity-design-system.scss +1 -0
package/esm2022/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.effects.mjs
ADDED
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { combineLatest } from 'rxjs';
|
|
3
|
+
import { filter, map } from 'rxjs/operators';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./bs-datepicker.actions";
|
|
6
|
+
export class BsDatepickerEffects {
|
|
7
|
+
constructor(_actions) {
|
|
8
|
+
this._actions = _actions;
|
|
9
|
+
this._subs = [];
|
|
10
|
+
}
|
|
11
|
+
init(_bsDatepickerStore) {
|
|
12
|
+
this._store = _bsDatepickerStore;
|
|
13
|
+
return this;
|
|
14
|
+
}
|
|
15
|
+
/** setters */
|
|
16
|
+
setValue(value) {
|
|
17
|
+
this._store?.dispatch(this._actions.select(value));
|
|
18
|
+
}
|
|
19
|
+
setRangeValue(value) {
|
|
20
|
+
this._store?.dispatch(this._actions.selectRange(value));
|
|
21
|
+
}
|
|
22
|
+
setMinDate(value) {
|
|
23
|
+
this._store?.dispatch(this._actions.minDate(value));
|
|
24
|
+
return this;
|
|
25
|
+
}
|
|
26
|
+
setMaxDate(value) {
|
|
27
|
+
this._store?.dispatch(this._actions.maxDate(value));
|
|
28
|
+
return this;
|
|
29
|
+
}
|
|
30
|
+
setDisabled(value) {
|
|
31
|
+
this._store?.dispatch(this._actions.isDisabled(value));
|
|
32
|
+
return this;
|
|
33
|
+
}
|
|
34
|
+
/* Set rendering options */
|
|
35
|
+
setOptions(_config) {
|
|
36
|
+
const _options = Object.assign({ locale: 'en' }, _config);
|
|
37
|
+
this._store?.dispatch(this._actions.setOptions(_options));
|
|
38
|
+
return this;
|
|
39
|
+
}
|
|
40
|
+
/** view to mode bindings */
|
|
41
|
+
setBindings(container) {
|
|
42
|
+
if (!this._store)
|
|
43
|
+
return this;
|
|
44
|
+
container.daysCalendar$ = this._store.select(state => state.flaggedMonths).pipe(filter(months => !!months));
|
|
45
|
+
container.monthsCalendar = this._store.select(state => state.flaggedMonthsCalendar).pipe(filter(months => !!months));
|
|
46
|
+
container.yearsCalendar = this._store.select(state => state.yearsCalendarFlagged).pipe(filter(years => !!years));
|
|
47
|
+
container.viewMode = this._store.select(state => state.view?.mode);
|
|
48
|
+
container.options$ = combineLatest([this._store.select(state => state.displayMonths)]).pipe(map((latest) => ({ displayMonths: latest[0] })));
|
|
49
|
+
return this;
|
|
50
|
+
}
|
|
51
|
+
/** event handlers */
|
|
52
|
+
setEventHandlers(container) {
|
|
53
|
+
container.setViewMode = (event) => {
|
|
54
|
+
this._store?.dispatch(this._actions.changeViewMode(event));
|
|
55
|
+
};
|
|
56
|
+
container.navigateTo = (event) => {
|
|
57
|
+
this._store?.dispatch(this._actions.navigateStep(event.step));
|
|
58
|
+
};
|
|
59
|
+
container.dayHoverHandler = (event) => {
|
|
60
|
+
const _cell = event.cell;
|
|
61
|
+
if (_cell.isOtherMonth || _cell.isDisabled)
|
|
62
|
+
return;
|
|
63
|
+
this._store?.dispatch(this._actions.hoverDay(event));
|
|
64
|
+
_cell.isHovered = event.isHovered;
|
|
65
|
+
};
|
|
66
|
+
container.monthHoverHandler = (event) => {
|
|
67
|
+
event.cell.isHovered = event.isHovered;
|
|
68
|
+
};
|
|
69
|
+
container.yearHoverHandler = (event) => {
|
|
70
|
+
event.cell.isHovered = event.isHovered;
|
|
71
|
+
};
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
registerDatepickerSideEffects() {
|
|
75
|
+
if (!this._store)
|
|
76
|
+
return this;
|
|
77
|
+
this._subs.push(this._store.select(state => state.view).subscribe(() => {
|
|
78
|
+
this._store?.dispatch(this._actions.calculate());
|
|
79
|
+
}));
|
|
80
|
+
// format calendar values on month model change
|
|
81
|
+
this._subs.push(this._store
|
|
82
|
+
.select(state => state.monthsModel)
|
|
83
|
+
.pipe(filter(monthModel => !!monthModel))
|
|
84
|
+
.subscribe(() => this._store?.dispatch(this._actions.format())));
|
|
85
|
+
// flag day values
|
|
86
|
+
this._subs.push(this._store
|
|
87
|
+
.select(state => state.formattedMonths)
|
|
88
|
+
.pipe(filter(month => !!month))
|
|
89
|
+
.subscribe(() => this._store?.dispatch(this._actions.flag())));
|
|
90
|
+
// flag day values
|
|
91
|
+
this._subs.push(this._store
|
|
92
|
+
.select(state => state.selectedDate)
|
|
93
|
+
.pipe(filter(selectedDate => !!selectedDate))
|
|
94
|
+
.subscribe(() => this._store?.dispatch(this._actions.flag())));
|
|
95
|
+
// flag for date range picker
|
|
96
|
+
this._subs.push(this._store
|
|
97
|
+
.select(state => state.selectedRange)
|
|
98
|
+
.pipe(filter(selectedRange => !!selectedRange))
|
|
99
|
+
.subscribe(() => this._store?.dispatch(this._actions.flag())));
|
|
100
|
+
// monthsCalendar
|
|
101
|
+
this._subs.push(this._store
|
|
102
|
+
.select(state => state.monthsCalendar)
|
|
103
|
+
.subscribe(() => this._store?.dispatch(this._actions.flag())));
|
|
104
|
+
// years calendar
|
|
105
|
+
this._subs.push(this._store
|
|
106
|
+
.select(state => state.yearsCalendarModel)
|
|
107
|
+
.pipe(filter(state => !!state))
|
|
108
|
+
.subscribe(() => this._store?.dispatch(this._actions.flag())));
|
|
109
|
+
// on hover
|
|
110
|
+
this._subs.push(this._store
|
|
111
|
+
.select(state => state.hoveredDate)
|
|
112
|
+
.pipe(filter(hoveredDate => !!hoveredDate))
|
|
113
|
+
.subscribe(() => this._store?.dispatch(this._actions.flag())));
|
|
114
|
+
return this;
|
|
115
|
+
}
|
|
116
|
+
destroy() {
|
|
117
|
+
for (const sub of this._subs) {
|
|
118
|
+
sub.unsubscribe();
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDatepickerEffects, deps: [{ token: i1.BsDatepickerActions }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
122
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDatepickerEffects, providedIn: 'platform' }); }
|
|
123
|
+
}
|
|
124
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDatepickerEffects, decorators: [{
|
|
125
|
+
type: Injectable,
|
|
126
|
+
args: [{ providedIn: 'platform' }]
|
|
127
|
+
}], ctorParameters: function () { return [{ type: i1.BsDatepickerActions }]; } });
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-datepicker.effects.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.effects.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\n\nimport {combineLatest, Observable, Subscription} from 'rxjs';\nimport {filter, map} from 'rxjs/operators';\n\nimport {BsDatepickerAbstractComponent} from '../base/bs-datepicker-container';\nimport {BsDatepickerConfig} from '../bs-datepicker.config';\n\nimport {\n  BsDatepickerViewMode,\n  BsNavigationEvent,\n  CellHoverEvent,\n  DatepickerRenderOptions,\n  DaysCalendarViewModel,\n  DayViewModel,\n  MonthsCalendarViewModel,\n  YearsCalendarViewModel\n} from '../models';\nimport {BsDatepickerActions} from './bs-datepicker.actions';\nimport {BsDatepickerStore} from './bs-datepicker.store';\n\n\n@Injectable({providedIn: 'platform'})\nexport class BsDatepickerEffects {\n  viewMode?: Observable<BsDatepickerViewMode>;\n  daysCalendar?: Observable<DaysCalendarViewModel[]>;\n  monthsCalendar?: Observable<MonthsCalendarViewModel[]>;\n  yearsCalendar?: Observable<YearsCalendarViewModel[]>;\n  options?: Observable<DatepickerRenderOptions>;\n\n  private _store?: BsDatepickerStore;\n  private _subs: Subscription[] = [];\n\n  constructor(private _actions: BsDatepickerActions) {\n  }\n\n  init(_bsDatepickerStore: BsDatepickerStore): BsDatepickerEffects {\n    this._store = _bsDatepickerStore;\n    return this;\n  }\n\n  /** setters */\n\n  setValue(value?: Date): void {\n    this._store?.dispatch(this._actions.select(value));\n  }\n\n  setRangeValue(value?: (Date | undefined)[] | undefined): void {\n    this._store?.dispatch(this._actions.selectRange(value));\n  }\n\n  setMinDate(value?: Date): BsDatepickerEffects {\n    this._store?.dispatch(this._actions.minDate(value));\n    return this;\n  }\n\n  setMaxDate(value?: Date): BsDatepickerEffects {\n    this._store?.dispatch(this._actions.maxDate(value));\n    return this;\n  }\n\n  setDisabled(value?: boolean): BsDatepickerEffects {\n    this._store?.dispatch(this._actions.isDisabled(value));\n    return this;\n  }\n\n  /* Set rendering options */\n  setOptions(_config: BsDatepickerConfig): BsDatepickerEffects {\n    const _options = Object.assign({locale: 'en'}, _config);\n    this._store?.dispatch(this._actions.setOptions(_options));\n    return this;\n  }\n\n  /** view to mode bindings */\n  setBindings(container: BsDatepickerAbstractComponent): BsDatepickerEffects {\n    if (!this._store) return this;\n\n    container.daysCalendar$ = this._store.select(state => state.flaggedMonths).pipe(filter(months => !!months));\n    container.monthsCalendar = this._store.select(state => state.flaggedMonthsCalendar).pipe(filter(months => !!months));\n    container.yearsCalendar = this._store.select(state => state.yearsCalendarFlagged).pipe(filter(years => !!years));\n    container.viewMode = this._store.select(state => state.view?.mode);\n    container.options$ = combineLatest([this._store.select(state => state.displayMonths)]).pipe(map((latest) => ({displayMonths: latest[0]})));\n\n    return this;\n  }\n\n  /** event handlers */\n  setEventHandlers(container: BsDatepickerAbstractComponent): BsDatepickerEffects {\n    container.setViewMode = (event: BsDatepickerViewMode): void => {\n      this._store?.dispatch(this._actions.changeViewMode(event));\n    };\n\n    container.navigateTo = (event: BsNavigationEvent): void => {\n      this._store?.dispatch(this._actions.navigateStep(event.step));\n    };\n\n    container.dayHoverHandler = (event: CellHoverEvent): void => {\n      const _cell = event.cell as DayViewModel;\n\n      if (_cell.isOtherMonth || _cell.isDisabled) return;\n\n      this._store?.dispatch(this._actions.hoverDay(event));\n      _cell.isHovered = event.isHovered;\n    };\n\n    container.monthHoverHandler = (event: CellHoverEvent): void => {\n      event.cell.isHovered = event.isHovered;\n    };\n\n    container.yearHoverHandler = (event: CellHoverEvent): void => {\n      event.cell.isHovered = event.isHovered;\n    };\n\n    return this;\n  }\n\n  registerDatepickerSideEffects(): BsDatepickerEffects {\n    if (!this._store) return this;\n\n    this._subs.push(\n      this._store.select(state => state.view).subscribe(() => {\n        this._store?.dispatch(this._actions.calculate());\n      })\n    );\n\n    // format calendar values on month model change\n    this._subs.push(\n      this._store\n        .select(state => state.monthsModel)\n        .pipe(filter(monthModel => !!monthModel))\n        .subscribe(() => this._store?.dispatch(this._actions.format()))\n    );\n\n    // flag day values\n    this._subs.push(\n      this._store\n        .select(state => state.formattedMonths)\n        .pipe(filter(month => !!month))\n        .subscribe(() => this._store?.dispatch(this._actions.flag()))\n    );\n\n    // flag day values\n    this._subs.push(\n      this._store\n        .select(state => state.selectedDate)\n        .pipe(filter(selectedDate => !!selectedDate))\n        .subscribe(() => this._store?.dispatch(this._actions.flag()))\n    );\n\n    // flag for date range picker\n    this._subs.push(\n      this._store\n        .select(state => state.selectedRange)\n        .pipe(filter(selectedRange => !!selectedRange))\n        .subscribe(() => this._store?.dispatch(this._actions.flag()))\n    );\n\n    // monthsCalendar\n    this._subs.push(\n      this._store\n        .select(state => state.monthsCalendar)\n        .subscribe(() => this._store?.dispatch(this._actions.flag()))\n    );\n\n    // years calendar\n    this._subs.push(\n      this._store\n        .select(state => state.yearsCalendarModel)\n        .pipe(filter(state => !!state))\n        .subscribe(() => this._store?.dispatch(this._actions.flag()))\n    );\n\n    // on hover\n    this._subs.push(\n      this._store\n        .select(state => state.hoveredDate)\n        .pipe(filter(hoveredDate => !!hoveredDate))\n        .subscribe(() => this._store?.dispatch(this._actions.flag()))\n    );\n\n    return this;\n  }\n\n  destroy(): void {\n    for (const sub of this._subs) {\n      sub.unsubscribe();\n    }\n  }\n}\n"]}
|
package/esm2022/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.reducer.mjs
ADDED
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
import { initialDatepickerState } from './bs-datepicker.state';
|
|
2
|
+
import { BsDatepickerActions } from './bs-datepicker.actions';
|
|
3
|
+
import { calcDaysCalendar } from '../engine/calc-days-calendar';
|
|
4
|
+
import { formatDaysCalendar } from '../engine/format-days-calendar';
|
|
5
|
+
import { flagDaysCalendar } from '../engine/flag-days-calendar';
|
|
6
|
+
import { getLocale, isAfter, isArray, isBefore, isDateValid, isSame, setFullDate, shiftDate, startOf } from 'ngx-bootstrap/chronos';
|
|
7
|
+
import { canSwitchMode } from '../engine/view-mode';
|
|
8
|
+
import { formatMonthsCalendar } from '../engine/format-months-calendar';
|
|
9
|
+
import { flagMonthsCalendar } from '../engine/flag-months-calendar';
|
|
10
|
+
import { formatYearsCalendar, initialYearShift, yearsPerCalendar } from '../engine/format-years-calendar';
|
|
11
|
+
import { flagYearsCalendar } from '../engine/flag-years-calendar';
|
|
12
|
+
import { getYearsCalendarInitialDate } from '../utils/bs-calendar-utils';
|
|
13
|
+
export function bsDatepickerReducer(state = initialDatepickerState, action) {
|
|
14
|
+
switch (action.type) {
|
|
15
|
+
case BsDatepickerActions.CALCULATE: {
|
|
16
|
+
return calculateReducer(state);
|
|
17
|
+
}
|
|
18
|
+
case BsDatepickerActions.FORMAT: {
|
|
19
|
+
return formatReducer(state);
|
|
20
|
+
}
|
|
21
|
+
case BsDatepickerActions.FLAG: {
|
|
22
|
+
return flagReducer(state);
|
|
23
|
+
}
|
|
24
|
+
case BsDatepickerActions.NAVIGATE_OFFSET: {
|
|
25
|
+
return navigateOffsetReducer(state, action);
|
|
26
|
+
}
|
|
27
|
+
case BsDatepickerActions.NAVIGATE_TO: {
|
|
28
|
+
const payload = action.payload;
|
|
29
|
+
if (!state.view || !payload.unit)
|
|
30
|
+
return state;
|
|
31
|
+
const date = setFullDate(state.view.date, payload.unit);
|
|
32
|
+
let newState;
|
|
33
|
+
let mode;
|
|
34
|
+
if (canSwitchMode(payload.viewMode, state.minMode)) {
|
|
35
|
+
mode = payload.viewMode;
|
|
36
|
+
newState = { view: { date, mode } };
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
mode = state.view.mode;
|
|
40
|
+
newState = { selectedDate: date, view: { date, mode } };
|
|
41
|
+
}
|
|
42
|
+
return Object.assign({}, state, newState);
|
|
43
|
+
}
|
|
44
|
+
case BsDatepickerActions.CHANGE_VIEWMODE: {
|
|
45
|
+
if (!canSwitchMode(action.payload, state.minMode) || !state.view)
|
|
46
|
+
return state;
|
|
47
|
+
const date = state.view.date;
|
|
48
|
+
const mode = action.payload;
|
|
49
|
+
const newState = { view: { date, mode } };
|
|
50
|
+
return Object.assign({}, state, newState);
|
|
51
|
+
}
|
|
52
|
+
case BsDatepickerActions.HOVER: {
|
|
53
|
+
return Object.assign({}, state, { hoveredDate: action.payload });
|
|
54
|
+
}
|
|
55
|
+
case BsDatepickerActions.SELECT: {
|
|
56
|
+
if (!state.view)
|
|
57
|
+
return state;
|
|
58
|
+
const newState = {
|
|
59
|
+
selectedDate: action.payload,
|
|
60
|
+
view: state.view
|
|
61
|
+
};
|
|
62
|
+
const mode = state.view.mode;
|
|
63
|
+
const _date = action.payload || state.view.date;
|
|
64
|
+
const date = getViewDate(_date, state.minDate, state.maxDate);
|
|
65
|
+
newState.view = { mode, date };
|
|
66
|
+
return Object.assign({}, state, newState);
|
|
67
|
+
}
|
|
68
|
+
case BsDatepickerActions.SET_OPTIONS: {
|
|
69
|
+
if (!state.view)
|
|
70
|
+
return state;
|
|
71
|
+
const newState = action.payload;
|
|
72
|
+
// preserve view mode
|
|
73
|
+
const mode = newState.minMode ? newState.minMode : state.view.mode;
|
|
74
|
+
const _viewDate = isDateValid(newState.value) && newState.value || isArray(newState.value) && isDateValid(newState.value[0]) && newState.value[0] || state.view.date;
|
|
75
|
+
const date = getViewDate(_viewDate, newState.minDate, newState.maxDate);
|
|
76
|
+
newState.view = { mode, date };
|
|
77
|
+
// update selected value
|
|
78
|
+
if (newState.value) {
|
|
79
|
+
// if new value is array we work with date range
|
|
80
|
+
if (isArray(newState.value)) {
|
|
81
|
+
newState.selectedRange = newState.value;
|
|
82
|
+
}
|
|
83
|
+
// if new value is a date -> datepicker
|
|
84
|
+
if (newState.value instanceof Date) {
|
|
85
|
+
newState.selectedDate = newState.value;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return Object.assign({}, state, newState);
|
|
89
|
+
}
|
|
90
|
+
// date range picker
|
|
91
|
+
case BsDatepickerActions.SELECT_RANGE: {
|
|
92
|
+
if (!state.view)
|
|
93
|
+
return state;
|
|
94
|
+
const newState = {
|
|
95
|
+
selectedRange: action.payload,
|
|
96
|
+
view: state.view
|
|
97
|
+
};
|
|
98
|
+
const mode = state.view.mode;
|
|
99
|
+
const _date = action.payload && action.payload[0] || state.view.date;
|
|
100
|
+
const date = getViewDate(_date, state.minDate, state.maxDate);
|
|
101
|
+
newState.view = { mode, date };
|
|
102
|
+
return Object.assign({}, state, newState);
|
|
103
|
+
}
|
|
104
|
+
case BsDatepickerActions.SET_MIN_DATE: {
|
|
105
|
+
return Object.assign({}, state, {
|
|
106
|
+
minDate: action.payload
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
case BsDatepickerActions.SET_MAX_DATE: {
|
|
110
|
+
return Object.assign({}, state, {
|
|
111
|
+
maxDate: action.payload
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
case BsDatepickerActions.SET_IS_DISABLED: {
|
|
115
|
+
return Object.assign({}, state, {
|
|
116
|
+
isDisabled: action.payload
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
default:
|
|
120
|
+
return state;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
function calculateReducer(state) {
|
|
124
|
+
if (!state.view)
|
|
125
|
+
return state;
|
|
126
|
+
// how many calendars
|
|
127
|
+
let displayMonths = state.displayMonths;
|
|
128
|
+
// use selected date on initial rendering if set
|
|
129
|
+
let viewDate = state.view.date;
|
|
130
|
+
if (state.view.mode === 'day' && state.monthViewOptions) {
|
|
131
|
+
state.monthViewOptions.firstDayOfWeek = getLocale(state.locale).firstDayOfWeek();
|
|
132
|
+
let monthsModel = new Array(displayMonths);
|
|
133
|
+
for (let monthIndex = 0; monthIndex < displayMonths; monthIndex++) {
|
|
134
|
+
monthsModel[monthIndex] = calcDaysCalendar(viewDate, state.monthViewOptions);
|
|
135
|
+
viewDate = shiftDate(viewDate, { month: 1 });
|
|
136
|
+
}
|
|
137
|
+
// Check if parameter enabled and check if it's not months navigation event
|
|
138
|
+
if (state.preventChangeToNextMonth && state.flaggedMonths && state.hoveredDate) {
|
|
139
|
+
const viewMonth = calcDaysCalendar(state.view.date, state.monthViewOptions);
|
|
140
|
+
// Check if viewed right month same as in flaggedMonths state, then override months model with flaggedMonths
|
|
141
|
+
if (state.flaggedMonths.length >= 2) {
|
|
142
|
+
if (state.flaggedMonths[1].month.getMonth() === viewMonth.month.getMonth()) {
|
|
143
|
+
monthsModel = state.flaggedMonths.map((item) => {
|
|
144
|
+
return state.monthViewOptions ? calcDaysCalendar(item.month, state.monthViewOptions) : null;
|
|
145
|
+
}).filter(item => item !== null);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
monthsModel = state.flaggedMonths.map((item) => {
|
|
150
|
+
return state.monthViewOptions ? calcDaysCalendar(item.month, state.monthViewOptions) : null;
|
|
151
|
+
}).filter(item => item !== null);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
return Object.assign({}, state, { monthsModel });
|
|
155
|
+
}
|
|
156
|
+
if (state.view.mode === 'month') {
|
|
157
|
+
const monthsCalendar = new Array(displayMonths);
|
|
158
|
+
for (let calendarIndex = 0; calendarIndex < displayMonths; calendarIndex++) {
|
|
159
|
+
monthsCalendar[calendarIndex] = formatMonthsCalendar(viewDate, getFormatOptions(state));
|
|
160
|
+
viewDate = shiftDate(viewDate, { year: 1 });
|
|
161
|
+
}
|
|
162
|
+
return Object.assign({}, state, { monthsCalendar });
|
|
163
|
+
}
|
|
164
|
+
if (state.view.mode === 'year') {
|
|
165
|
+
const yearsCalendarModel = new Array(displayMonths);
|
|
166
|
+
for (let calendarIndex = 0; calendarIndex < displayMonths; calendarIndex++) {
|
|
167
|
+
yearsCalendarModel[calendarIndex] = formatYearsCalendar(viewDate, getFormatOptions(state), state.minMode === 'year' ? getYearsCalendarInitialDate(state, calendarIndex) : undefined, state.selectedDate ? state.selectedDate : new Date());
|
|
168
|
+
viewDate = shiftDate(viewDate, { year: yearsPerCalendar });
|
|
169
|
+
}
|
|
170
|
+
return Object.assign({}, state, { yearsCalendarModel });
|
|
171
|
+
}
|
|
172
|
+
return state;
|
|
173
|
+
}
|
|
174
|
+
function formatReducer(state) {
|
|
175
|
+
if (!state.view)
|
|
176
|
+
return state;
|
|
177
|
+
if (state.view.mode === 'day' && state.monthsModel) {
|
|
178
|
+
const formattedMonths = state.monthsModel.map((month, monthIndex) => formatDaysCalendar(month, getFormatOptions(state), monthIndex));
|
|
179
|
+
return Object.assign({}, state, { formattedMonths });
|
|
180
|
+
}
|
|
181
|
+
// how many calendars
|
|
182
|
+
const displayMonths = state.displayMonths || 1;
|
|
183
|
+
// check initial rendering
|
|
184
|
+
// use selected date on initial rendering if set
|
|
185
|
+
let viewDate = state.view.date;
|
|
186
|
+
if (state.view.mode === 'month') {
|
|
187
|
+
const monthsCalendar = new Array(displayMonths);
|
|
188
|
+
for (let calendarIndex = 0; calendarIndex < displayMonths; calendarIndex++) {
|
|
189
|
+
monthsCalendar[calendarIndex] = formatMonthsCalendar(viewDate, getFormatOptions(state));
|
|
190
|
+
viewDate = shiftDate(viewDate, { year: 1 });
|
|
191
|
+
}
|
|
192
|
+
return Object.assign({}, state, { monthsCalendar });
|
|
193
|
+
}
|
|
194
|
+
if (state.view.mode === 'year') {
|
|
195
|
+
const yearsCalendarModel = new Array(displayMonths);
|
|
196
|
+
for (let calendarIndex = 0; calendarIndex < displayMonths; calendarIndex++) {
|
|
197
|
+
yearsCalendarModel[calendarIndex] = formatYearsCalendar(viewDate, getFormatOptions(state), undefined, state.selectedDate ? state.selectedDate : new Date());
|
|
198
|
+
viewDate = shiftDate(viewDate, { year: 16 });
|
|
199
|
+
}
|
|
200
|
+
return Object.assign({}, state, { yearsCalendarModel });
|
|
201
|
+
}
|
|
202
|
+
return state;
|
|
203
|
+
}
|
|
204
|
+
function flagReducer(state) {
|
|
205
|
+
if (!state.view)
|
|
206
|
+
return state;
|
|
207
|
+
const displayMonths = isDisplayOneMonth(state.view.date, state.minDate, state.maxDate) ? 1 : state.displayMonths;
|
|
208
|
+
if (state.formattedMonths && state.view.mode === 'day') {
|
|
209
|
+
const flaggedMonths = state.formattedMonths.map((formattedMonth, monthIndex) => flagDaysCalendar(formattedMonth, {
|
|
210
|
+
isDisabled: state.isDisabled,
|
|
211
|
+
minDate: state.minDate,
|
|
212
|
+
maxDate: state.maxDate,
|
|
213
|
+
hoveredDate: state.hoveredDate,
|
|
214
|
+
selectedDate: state.selectedDate,
|
|
215
|
+
selectedRange: state.selectedRange,
|
|
216
|
+
displayMonths,
|
|
217
|
+
monthIndex
|
|
218
|
+
}));
|
|
219
|
+
return Object.assign({}, state, { flaggedMonths });
|
|
220
|
+
}
|
|
221
|
+
if (state.view.mode === 'month' && state.monthsCalendar) {
|
|
222
|
+
const flaggedMonthsCalendar = state.monthsCalendar.map((formattedMonth, monthIndex) => flagMonthsCalendar(formattedMonth, {
|
|
223
|
+
isDisabled: state.isDisabled,
|
|
224
|
+
minDate: state.minDate,
|
|
225
|
+
maxDate: state.maxDate,
|
|
226
|
+
hoveredMonth: state.hoveredMonth,
|
|
227
|
+
selectedDate: state.selectedDate,
|
|
228
|
+
selectedRange: state.selectedRange,
|
|
229
|
+
displayMonths,
|
|
230
|
+
monthIndex
|
|
231
|
+
}));
|
|
232
|
+
return Object.assign({}, state, { flaggedMonthsCalendar });
|
|
233
|
+
}
|
|
234
|
+
if (state.view.mode === 'year' && state.yearsCalendarModel) {
|
|
235
|
+
const yearsCalendarFlagged = state.yearsCalendarModel.map((formattedMonth, yearIndex) => flagYearsCalendar(formattedMonth, {
|
|
236
|
+
isDisabled: state.isDisabled,
|
|
237
|
+
minDate: state.minDate,
|
|
238
|
+
maxDate: state.maxDate,
|
|
239
|
+
hoveredYear: state.hoveredYear,
|
|
240
|
+
selectedDate: state.selectedDate,
|
|
241
|
+
selectedRange: state.selectedRange,
|
|
242
|
+
displayMonths,
|
|
243
|
+
yearIndex
|
|
244
|
+
}));
|
|
245
|
+
return Object.assign({}, state, { yearsCalendarFlagged });
|
|
246
|
+
}
|
|
247
|
+
return state;
|
|
248
|
+
}
|
|
249
|
+
function navigateOffsetReducer(state, action) {
|
|
250
|
+
if (!state.view)
|
|
251
|
+
return state;
|
|
252
|
+
const date = shiftViewDate(state, action);
|
|
253
|
+
if (!date)
|
|
254
|
+
return state;
|
|
255
|
+
const newState = {
|
|
256
|
+
view: { mode: state.view.mode, date }
|
|
257
|
+
};
|
|
258
|
+
return Object.assign({}, state, newState);
|
|
259
|
+
}
|
|
260
|
+
function shiftViewDate(state, action) {
|
|
261
|
+
if (!state.view)
|
|
262
|
+
return undefined;
|
|
263
|
+
if (state.view.mode === 'year' && state.minMode === 'year') {
|
|
264
|
+
const initialDate = getYearsCalendarInitialDate(state, 0);
|
|
265
|
+
if (initialDate) {
|
|
266
|
+
const middleDate = shiftDate(initialDate, { year: -initialYearShift });
|
|
267
|
+
return shiftDate(middleDate, action.payload);
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
return shiftDate(startOf(state.view.date, 'month'), action.payload);
|
|
271
|
+
}
|
|
272
|
+
function getFormatOptions(state) {
|
|
273
|
+
return {
|
|
274
|
+
locale: state.locale,
|
|
275
|
+
monthTitle: state.monthTitle,
|
|
276
|
+
yearTitle: state.yearTitle,
|
|
277
|
+
dayLabel: state.dayLabel,
|
|
278
|
+
monthLabel: state.monthLabel,
|
|
279
|
+
yearLabel: state.yearLabel
|
|
280
|
+
};
|
|
281
|
+
}
|
|
282
|
+
/**
|
|
283
|
+
* if view date is provided (bsValue|ngModel) it should be shown
|
|
284
|
+
* if view date is not provider:
|
|
285
|
+
* if minDate>currentDate (default view value), show minDate
|
|
286
|
+
* if maxDate<currentDate(default view value) show maxDate
|
|
287
|
+
*/
|
|
288
|
+
function getViewDate(viewDate, minDate, maxDate) {
|
|
289
|
+
const _date = Array.isArray(viewDate) ? viewDate[0] : viewDate;
|
|
290
|
+
if (minDate && isAfter(minDate, _date, 'day'))
|
|
291
|
+
return minDate;
|
|
292
|
+
if (maxDate && isBefore(maxDate, _date, 'day'))
|
|
293
|
+
return maxDate;
|
|
294
|
+
return _date;
|
|
295
|
+
}
|
|
296
|
+
function isDisplayOneMonth(viewDate, minDate, maxDate) {
|
|
297
|
+
if (maxDate && isSame(maxDate, viewDate, 'day'))
|
|
298
|
+
return true;
|
|
299
|
+
return minDate && maxDate && minDate.getMonth() === maxDate.getMonth();
|
|
300
|
+
}
|
|
301
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-datepicker.reducer.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-v2/datepicker/reducer/bs-datepicker.reducer.ts"],"names":[],"mappings":"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","sourcesContent":["import {BsDatepickerState, BsDatepickerViewState, initialDatepickerState} from './bs-datepicker.state';\nimport {Action} from 'ngx-bootstrap/mini-ngrx';\nimport {BsDatepickerActions} from './bs-datepicker.actions';\nimport {calcDaysCalendar} from '../engine/calc-days-calendar';\nimport {formatDaysCalendar} from '../engine/format-days-calendar';\nimport {flagDaysCalendar} from '../engine/flag-days-calendar';\nimport {\n  getLocale,\n  isAfter,\n  isArray,\n  isBefore,\n  isDateValid,\n  isSame,\n  setFullDate,\n  shiftDate,\n  startOf\n} from 'ngx-bootstrap/chronos';\nimport {canSwitchMode} from '../engine/view-mode';\nimport {formatMonthsCalendar} from '../engine/format-months-calendar';\nimport {flagMonthsCalendar} from '../engine/flag-months-calendar';\nimport {formatYearsCalendar, initialYearShift, yearsPerCalendar} from '../engine/format-years-calendar';\nimport {flagYearsCalendar} from '../engine/flag-years-calendar';\nimport {\n  BsDatepickerViewMode,\n  BsViewNavigationEvent,\n  DatepickerFormatOptions,\n  DaysCalendarModel,\n  DaysCalendarViewModel,\n  MonthsCalendarViewModel,\n  YearsCalendarViewModel\n} from '../models';\nimport {getYearsCalendarInitialDate} from '../utils/bs-calendar-utils';\n\n\nexport function bsDatepickerReducer(state: BsDatepickerState = initialDatepickerState, action: Action): BsDatepickerState {\n  switch (action.type) {\n    case BsDatepickerActions.CALCULATE: {\n      return calculateReducer(state);\n    }\n\n    case BsDatepickerActions.FORMAT: {\n      return formatReducer(state);\n    }\n\n    case BsDatepickerActions.FLAG: {\n      return flagReducer(state);\n    }\n\n    case BsDatepickerActions.NAVIGATE_OFFSET: {\n      return navigateOffsetReducer(state, action);\n    }\n\n    case BsDatepickerActions.NAVIGATE_TO: {\n      const payload: BsViewNavigationEvent = action.payload;\n\n      if (!state.view || !payload.unit) return state;\n\n      const date: Date = setFullDate(state.view.date, payload.unit);\n\n      let newState;\n      let mode: BsDatepickerViewMode;\n\n      if (canSwitchMode(payload.viewMode, state.minMode)) {\n        mode = payload.viewMode;\n        newState = {view: {date, mode}};\n      } else {\n        mode = state.view.mode;\n        newState = {selectedDate: date, view: {date, mode}};\n      }\n\n      return Object.assign({}, state, newState);\n    }\n\n    case BsDatepickerActions.CHANGE_VIEWMODE: {\n      if (!canSwitchMode(action.payload, state.minMode) || !state.view) return state;\n\n      const date: Date = state.view.date;\n      const mode = action.payload;\n      const newState = {view: {date, mode}};\n\n      return Object.assign({}, state, newState);\n    }\n\n    case BsDatepickerActions.HOVER: {\n      return Object.assign({}, state, {hoveredDate: action.payload});\n    }\n\n    case BsDatepickerActions.SELECT: {\n      if (!state.view) return state;\n\n      const newState = {\n        selectedDate: action.payload,\n        view: state.view\n      };\n\n      const mode = state.view.mode;\n      const _date = action.payload || state.view.date;\n      const date: Date = getViewDate(_date, state.minDate, state.maxDate);\n      newState.view = {mode, date};\n\n      return Object.assign({}, state, newState);\n    }\n\n    case BsDatepickerActions.SET_OPTIONS: {\n      if (!state.view) return state;\n\n      const newState = action.payload;\n      // preserve view mode\n      const mode = newState.minMode ? newState.minMode : state.view.mode;\n      const _viewDate = isDateValid(newState.value) && newState.value || isArray(newState.value) && isDateValid(newState.value[0]) && newState.value[0] || state.view.date;\n      const date: Date = getViewDate(_viewDate, newState.minDate, newState.maxDate);\n      newState.view = {mode, date};\n\n      // update selected value\n      if (newState.value) {\n        // if new value is array we work with date range\n        if (isArray(newState.value)) {\n          newState.selectedRange = newState.value;\n        }\n\n        // if new value is a date -> datepicker\n        if (newState.value instanceof Date) {\n          newState.selectedDate = newState.value;\n        }\n      }\n\n      return Object.assign({}, state, newState);\n    }\n\n    // date range picker\n    case BsDatepickerActions.SELECT_RANGE: {\n      if (!state.view) return state;\n\n      const newState = {\n        selectedRange: action.payload,\n        view: state.view\n      };\n\n      const mode = state.view.mode;\n      const _date = action.payload && action.payload[0] || state.view.date;\n      const date: Date = getViewDate(_date, state.minDate, state.maxDate);\n      newState.view = {mode, date};\n\n      return Object.assign({}, state, newState);\n    }\n\n    case BsDatepickerActions.SET_MIN_DATE: {\n      return Object.assign({}, state, {\n        minDate: action.payload\n      });\n    }\n\n    case BsDatepickerActions.SET_MAX_DATE: {\n      return Object.assign({}, state, {\n        maxDate: action.payload\n      });\n    }\n\n    case BsDatepickerActions.SET_IS_DISABLED: {\n      return Object.assign({}, state, {\n        isDisabled: action.payload\n      });\n    }\n\n    default:\n      return state;\n  }\n}\n\nfunction calculateReducer(state: BsDatepickerState): BsDatepickerState {\n  if (!state.view) return state;\n\n  // how many calendars\n  let displayMonths: number = state.displayMonths;\n\n  // use selected date on initial rendering if set\n  let viewDate: Date = state.view.date;\n\n  if (state.view.mode === 'day' && state.monthViewOptions) {\n    state.monthViewOptions.firstDayOfWeek = getLocale(state.locale).firstDayOfWeek();\n\n    let monthsModel = new Array(displayMonths);\n    for (let monthIndex: number = 0; monthIndex < displayMonths; monthIndex++) {\n      monthsModel[monthIndex] = calcDaysCalendar(viewDate, state.monthViewOptions);\n      viewDate = shiftDate(viewDate, {month: 1});\n    }\n\n    // Check if parameter enabled and check if it's not months navigation event\n    if (state.preventChangeToNextMonth && state.flaggedMonths && state.hoveredDate) {\n      const viewMonth: DaysCalendarModel = calcDaysCalendar(state.view.date, state.monthViewOptions);\n\n      // Check if viewed right month same as in flaggedMonths state, then override months model with flaggedMonths\n      if (state.flaggedMonths.length >= 2) {\n        if (state.flaggedMonths[1].month.getMonth() === viewMonth.month.getMonth()) {\n          monthsModel = state.flaggedMonths.map((item: DaysCalendarViewModel) => {\n            return state.monthViewOptions ? calcDaysCalendar(item.month, state.monthViewOptions) : null;\n          }).filter(item => item !== null);\n        }\n      } else {\n        monthsModel = state.flaggedMonths.map((item: DaysCalendarViewModel) => {\n          return state.monthViewOptions ? calcDaysCalendar(item.month, state.monthViewOptions) : null;\n        }).filter(item => item !== null);\n      }\n    }\n\n    return Object.assign({}, state, {monthsModel});\n  }\n\n  if (state.view.mode === 'month') {\n    const monthsCalendar = new Array(displayMonths);\n\n    for (let calendarIndex: number = 0; calendarIndex < displayMonths; calendarIndex++) {\n      monthsCalendar[calendarIndex] = formatMonthsCalendar(viewDate, getFormatOptions(state));\n      viewDate = shiftDate(viewDate, {year: 1});\n    }\n\n    return Object.assign({}, state, {monthsCalendar});\n  }\n\n  if (state.view.mode === 'year') {\n    const yearsCalendarModel = new Array(displayMonths);\n\n    for (let calendarIndex: number = 0; calendarIndex < displayMonths; calendarIndex++) {\n      yearsCalendarModel[calendarIndex] = formatYearsCalendar(viewDate, getFormatOptions(state), state.minMode === 'year' ? getYearsCalendarInitialDate(state, calendarIndex) : undefined, state.selectedDate ? state.selectedDate : new Date());\n      viewDate = shiftDate(viewDate, {year: yearsPerCalendar});\n    }\n\n    return Object.assign({}, state, {yearsCalendarModel});\n  }\n\n  return state;\n}\n\nfunction formatReducer(state: BsDatepickerState): BsDatepickerState {\n  if (!state.view) return state;\n\n  if (state.view.mode === 'day' && state.monthsModel) {\n    const formattedMonths: DaysCalendarViewModel[] = state.monthsModel.map((month: DaysCalendarModel, monthIndex: number) => formatDaysCalendar(month, getFormatOptions(state), monthIndex));\n\n    return Object.assign({}, state, {formattedMonths});\n  }\n\n  // how many calendars\n  const displayMonths: number = state.displayMonths || 1;\n\n  // check initial rendering\n  // use selected date on initial rendering if set\n  let viewDate: Date = state.view.date;\n\n  if (state.view.mode === 'month') {\n    const monthsCalendar = new Array(displayMonths);\n    for (let calendarIndex: number = 0; calendarIndex < displayMonths; calendarIndex++) {\n      monthsCalendar[calendarIndex] = formatMonthsCalendar(viewDate, getFormatOptions(state));\n      viewDate = shiftDate(viewDate, {year: 1});\n    }\n\n    return Object.assign({}, state, {monthsCalendar});\n  }\n\n  if (state.view.mode === 'year') {\n    const yearsCalendarModel = new Array(displayMonths);\n\n    for (let calendarIndex: number = 0; calendarIndex < displayMonths; calendarIndex++) {\n      yearsCalendarModel[calendarIndex] = formatYearsCalendar(viewDate, getFormatOptions(state), undefined, state.selectedDate ? state.selectedDate : new Date());\n      viewDate = shiftDate(viewDate, {year: 16});\n    }\n\n    return Object.assign({}, state, {yearsCalendarModel});\n  }\n\n  return state;\n}\n\nfunction flagReducer(state: BsDatepickerState): BsDatepickerState {\n  if (!state.view) return state;\n\n  const displayMonths: number = isDisplayOneMonth(state.view.date, state.minDate, state.maxDate) ? 1 : state.displayMonths;\n  if (state.formattedMonths && state.view.mode === 'day') {\n    const flaggedMonths: DaysCalendarViewModel[] = state.formattedMonths.map((formattedMonth: DaysCalendarViewModel, monthIndex: number) =>\n      flagDaysCalendar(formattedMonth, {\n        isDisabled: state.isDisabled,\n        minDate: state.minDate,\n        maxDate: state.maxDate,\n        hoveredDate: state.hoveredDate,\n        selectedDate: state.selectedDate,\n        selectedRange: state.selectedRange,\n        displayMonths,\n        monthIndex\n      }));\n\n    return Object.assign({}, state, {flaggedMonths});\n  }\n\n  if (state.view.mode === 'month' && state.monthsCalendar) {\n    const flaggedMonthsCalendar: MonthsCalendarViewModel[] = state.monthsCalendar.map((formattedMonth: MonthsCalendarViewModel, monthIndex: number) =>\n      flagMonthsCalendar(formattedMonth, {\n        isDisabled: state.isDisabled,\n        minDate: state.minDate,\n        maxDate: state.maxDate,\n        hoveredMonth: state.hoveredMonth,\n        selectedDate: state.selectedDate,\n        selectedRange: state.selectedRange,\n        displayMonths,\n        monthIndex\n      }));\n\n    return Object.assign({}, state, {flaggedMonthsCalendar});\n  }\n\n  if (state.view.mode === 'year' && state.yearsCalendarModel) {\n    const yearsCalendarFlagged: YearsCalendarViewModel[] = state.yearsCalendarModel.map((formattedMonth: YearsCalendarViewModel, yearIndex: number) =>\n      flagYearsCalendar(formattedMonth, {\n        isDisabled: state.isDisabled,\n        minDate: state.minDate,\n        maxDate: state.maxDate,\n        hoveredYear: state.hoveredYear,\n        selectedDate: state.selectedDate,\n        selectedRange: state.selectedRange,\n        displayMonths,\n        yearIndex\n      })\n    );\n\n    return Object.assign({}, state, {yearsCalendarFlagged});\n  }\n\n  return state;\n}\n\nfunction navigateOffsetReducer(state: BsDatepickerState, action: Action): BsDatepickerState {\n  if (!state.view) return state;\n\n  const date: Date | undefined = shiftViewDate(state, action);\n  if (!date) return state;\n\n  const newState: { view: BsDatepickerViewState } = {\n    view: {mode: state.view.mode, date}\n  };\n\n  return Object.assign({}, state, newState);\n}\n\nfunction shiftViewDate(state: BsDatepickerState, action: Action): Date | undefined {\n  if (!state.view) return undefined;\n\n  if (state.view.mode === 'year' && state.minMode === 'year') {\n    const initialDate: Date | undefined = getYearsCalendarInitialDate(state, 0);\n\n    if (initialDate) {\n      const middleDate = shiftDate(initialDate, {year: -initialYearShift});\n      return shiftDate(middleDate, action.payload);\n    }\n  }\n\n  return shiftDate(startOf(state.view.date, 'month'), action.payload);\n}\n\nfunction getFormatOptions(state: BsDatepickerState): DatepickerFormatOptions {\n  return {\n    locale: state.locale,\n\n    monthTitle: state.monthTitle,\n    yearTitle: state.yearTitle,\n\n    dayLabel: state.dayLabel,\n    monthLabel: state.monthLabel,\n    yearLabel: state.yearLabel\n  };\n}\n\n/**\n * if view date is provided (bsValue|ngModel) it should be shown\n * if view date is not provider:\n * if minDate>currentDate (default view value), show minDate\n * if maxDate<currentDate(default view value) show maxDate\n */\nfunction getViewDate(viewDate: Date | Date[], minDate?: Date, maxDate?: Date): Date {\n  const _date: Date = Array.isArray(viewDate) ? viewDate[0] : viewDate;\n\n  if (minDate && isAfter(minDate, _date, 'day')) return minDate;\n  if (maxDate && isBefore(maxDate, _date, 'day')) return maxDate;\n\n  return _date;\n}\n\nfunction isDisplayOneMonth(viewDate: Date, minDate?: Date, maxDate?: Date): boolean | undefined {\n  if (maxDate && isSame(maxDate, viewDate, 'day')) return true;\n\n  return minDate && maxDate && minDate.getMonth() === maxDate.getMonth();\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { defaultMonthOptions } from './_defaults';
|
|
2
|
+
import { BsDatepickerConfig } from '../bs-datepicker.config';
|
|
3
|
+
export class BsDatepickerState {
|
|
4
|
+
constructor() {
|
|
5
|
+
// DatepickerRenderOptions
|
|
6
|
+
this.displayMonths = 1;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
const _initialView = { date: new Date(), mode: 'day' };
|
|
10
|
+
export const initialDatepickerState = Object.assign(new BsDatepickerConfig(), {
|
|
11
|
+
locale: 'en',
|
|
12
|
+
view: _initialView,
|
|
13
|
+
selectedRange: [],
|
|
14
|
+
monthViewOptions: defaultMonthOptions
|
|
15
|
+
});
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnMtZGF0ZXBpY2tlci5zdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dyYXZpdHktZGVzaWduLXN5c3RlbS9zcmMvbGliL2NvbXBvbmVudHMvZ3Jhdml0eS1jYWxlbmRhci12Mi9kYXRlcGlja2VyL3JlZHVjZXIvYnMtZGF0ZXBpY2tlci5zdGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVQSxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxhQUFhLENBQUM7QUFDaEQsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFPM0QsTUFBTSxPQUFPLGlCQUFpQjtJQUE5QjtRQW9DRSwwQkFBMEI7UUFDMUIsa0JBQWEsR0FBVyxDQUFDLENBQUM7SUFXNUIsQ0FBQztDQUFBO0FBRUQsTUFBTSxZQUFZLEdBQTBCLEVBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBQyxDQUFDO0FBRTVFLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFzQixNQUFNLENBQUMsTUFBTSxDQUNwRSxJQUFJLGtCQUFrQixFQUFFLEVBQ3hCO0lBQ0UsTUFBTSxFQUFFLElBQUk7SUFDWixJQUFJLEVBQUUsWUFBWTtJQUNsQixhQUFhLEVBQUUsRUFBRTtJQUNqQixnQkFBZ0IsRUFBRSxtQkFBbUI7Q0FDdEMsQ0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQnNEYXRlcGlja2VyVmlld01vZGUsXG4gIERhdGVwaWNrZXJGb3JtYXRPcHRpb25zLFxuICBEYXRlcGlja2VyUmVuZGVyT3B0aW9ucyxcbiAgRGF5c0NhbGVuZGFyTW9kZWwsXG4gIERheXNDYWxlbmRhclZpZXdNb2RlbCxcbiAgTW9udGhzQ2FsZW5kYXJWaWV3TW9kZWwsXG4gIE1vbnRoVmlld09wdGlvbnMsXG4gIFllYXJzQ2FsZW5kYXJWaWV3TW9kZWxcbn0gZnJvbSAnLi4vbW9kZWxzJztcbmltcG9ydCB7ZGVmYXVsdE1vbnRoT3B0aW9uc30gZnJvbSAnLi9fZGVmYXVsdHMnO1xuaW1wb3J0IHtCc0RhdGVwaWNrZXJDb25maWd9IGZyb20gJy4uL2JzLWRhdGVwaWNrZXIuY29uZmlnJztcblxuZXhwb3J0IGludGVyZmFjZSBCc0RhdGVwaWNrZXJWaWV3U3RhdGUge1xuICBkYXRlOiBEYXRlO1xuICBtb2RlOiBCc0RhdGVwaWNrZXJWaWV3TW9kZTtcbn1cblxuZXhwb3J0IGNsYXNzIEJzRGF0ZXBpY2tlclN0YXRlIGltcGxlbWVudHMgRGF0ZXBpY2tlclJlbmRlck9wdGlvbnMsIERhdGVwaWNrZXJGb3JtYXRPcHRpb25zIHtcbiAgLy8gZGF0ZSBwaWNrZXJcbiAgc2VsZWN0ZWREYXRlPzogRGF0ZTtcbiAgLy8gZGF0ZXJhbmdlIHBpY2tlclxuICBzZWxlY3RlZFJhbmdlPzogRGF0ZVtdO1xuXG4gIC8vIGluaXRpYWwgZGF0ZSBvZiBjYWxlbmRhciwgdG9kYXkgYnkgZGVmYXVsdFxuICB2aWV3PzogQnNEYXRlcGlja2VyVmlld1N0YXRlO1xuXG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICAvLyBib3VuZHNcbiAgbWluRGF0ZT86IERhdGU7XG4gIG1heERhdGU/OiBEYXRlO1xuICBtaW5Nb2RlPzogQnNEYXRlcGlja2VyVmlld01vZGU7XG5cbiAgaG92ZXJlZERhdGU/OiBEYXRlO1xuICBob3ZlcmVkTW9udGg/OiBEYXRlO1xuICBob3ZlcmVkWWVhcj86IERhdGU7XG5cbiAgLy8gZGF5cyBjYWxlbmRhclxuICBtb250aHNNb2RlbD86IERheXNDYWxlbmRhck1vZGVsW107XG4gIGZvcm1hdHRlZE1vbnRocz86IERheXNDYWxlbmRhclZpZXdNb2RlbFtdO1xuICBmbGFnZ2VkTW9udGhzPzogRGF5c0NhbGVuZGFyVmlld01vZGVsW107XG4gIHByZXZlbnRDaGFuZ2VUb05leHRNb250aD86IGJvb2xlYW47IC8vIGRhdGVSYW5nZVBpY2tlciBvbmx5O1xuXG4gIC8vIG1vbnRocyBjYWxlbmRhclxuICBtb250aHNDYWxlbmRhcj86IE1vbnRoc0NhbGVuZGFyVmlld01vZGVsW107XG4gIGZsYWdnZWRNb250aHNDYWxlbmRhcj86IE1vbnRoc0NhbGVuZGFyVmlld01vZGVsW107XG5cbiAgLy8geWVhcnMgY2FsZW5kYXJcbiAgeWVhcnNDYWxlbmRhck1vZGVsPzogWWVhcnNDYWxlbmRhclZpZXdNb2RlbFtdO1xuICB5ZWFyc0NhbGVuZGFyRmxhZ2dlZD86IFllYXJzQ2FsZW5kYXJWaWV3TW9kZWxbXTtcblxuICAvLyBvcHRpb25zXG4gIG1vbnRoVmlld09wdGlvbnM/OiBNb250aFZpZXdPcHRpb25zO1xuXG4gIC8vIERhdGVwaWNrZXJSZW5kZXJPcHRpb25zXG4gIGRpc3BsYXlNb250aHM6IG51bWJlciA9IDE7XG5cbiAgLy8gRGF0ZXBpY2tlckZvcm1hdE9wdGlvbnNcbiAgbG9jYWxlPzogc3RyaW5nO1xuXG4gIG1vbnRoVGl0bGU/OiBzdHJpbmc7XG4gIHllYXJUaXRsZT86IHN0cmluZztcblxuICBkYXlMYWJlbD86IHN0cmluZztcbiAgbW9udGhMYWJlbD86IHN0cmluZztcbiAgeWVhckxhYmVsPzogc3RyaW5nO1xufVxuXG5jb25zdCBfaW5pdGlhbFZpZXc6IEJzRGF0ZXBpY2tlclZpZXdTdGF0ZSA9IHtkYXRlOiBuZXcgRGF0ZSgpLCBtb2RlOiAnZGF5J307XG5cbmV4cG9ydCBjb25zdCBpbml0aWFsRGF0ZXBpY2tlclN0YXRlOiBCc0RhdGVwaWNrZXJTdGF0ZSA9IE9iamVjdC5hc3NpZ24oXG4gIG5ldyBCc0RhdGVwaWNrZXJDb25maWcoKSxcbiAge1xuICAgIGxvY2FsZTogJ2VuJyxcbiAgICB2aWV3OiBfaW5pdGlhbFZpZXcsXG4gICAgc2VsZWN0ZWRSYW5nZTogW10sXG4gICAgbW9udGhWaWV3T3B0aW9uczogZGVmYXVsdE1vbnRoT3B0aW9uc1xuICB9XG4pO1xuIl19
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { MiniState, MiniStore } from 'ngx-bootstrap/mini-ngrx';
|
|
3
|
+
import { initialDatepickerState } from './bs-datepicker.state';
|
|
4
|
+
import { BehaviorSubject } from 'rxjs';
|
|
5
|
+
import { bsDatepickerReducer } from './bs-datepicker.reducer';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class BsDatepickerStore extends MiniStore {
|
|
8
|
+
constructor() {
|
|
9
|
+
const _dispatcher = new BehaviorSubject({ type: '[datepicker] dispatcher init' });
|
|
10
|
+
const state = new MiniState(initialDatepickerState, _dispatcher, bsDatepickerReducer);
|
|
11
|
+
super(_dispatcher, bsDatepickerReducer, state);
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDatepickerStore, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
14
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDatepickerStore, providedIn: 'platform' }); }
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDatepickerStore, decorators: [{
|
|
17
|
+
type: Injectable,
|
|
18
|
+
args: [{ providedIn: 'platform' }]
|
|
19
|
+
}], ctorParameters: function () { return []; } });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnMtZGF0ZXBpY2tlci5zdG9yZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dyYXZpdHktZGVzaWduLXN5c3RlbS9zcmMvbGliL2NvbXBvbmVudHMvZ3Jhdml0eS1jYWxlbmRhci12Mi9kYXRlcGlja2VyL3JlZHVjZXIvYnMtZGF0ZXBpY2tlci5zdG9yZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBUyxTQUFTLEVBQUUsU0FBUyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDckUsT0FBTyxFQUFvQixzQkFBc0IsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQ2hGLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDckMsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0seUJBQXlCLENBQUM7O0FBRzVELE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxTQUE0QjtJQUVqRTtRQUNFLE1BQU0sV0FBVyxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUMsSUFBSSxFQUFFLDhCQUE4QixFQUFDLENBQUMsQ0FBQztRQUN4RixNQUFNLEtBQUssR0FBRyxJQUFJLFNBQVMsQ0FBb0Isc0JBQXNCLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixDQUFDLENBQUM7UUFDekcsS0FBSyxDQUFDLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNqRCxDQUFDOytHQU5VLGlCQUFpQjttSEFBakIsaUJBQWlCLGNBREwsVUFBVTs7NEZBQ3RCLGlCQUFpQjtrQkFEN0IsVUFBVTttQkFBQyxFQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtBY3Rpb24sIE1pbmlTdGF0ZSwgTWluaVN0b3JlfSBmcm9tICduZ3gtYm9vdHN0cmFwL21pbmktbmdyeCc7XG5pbXBvcnQge0JzRGF0ZXBpY2tlclN0YXRlLCBpbml0aWFsRGF0ZXBpY2tlclN0YXRlfSBmcm9tICcuL2JzLWRhdGVwaWNrZXIuc3RhdGUnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtic0RhdGVwaWNrZXJSZWR1Y2VyfSBmcm9tICcuL2JzLWRhdGVwaWNrZXIucmVkdWNlcic7XG5cbkBJbmplY3RhYmxlKHtwcm92aWRlZEluOiAncGxhdGZvcm0nfSlcbmV4cG9ydCBjbGFzcyBCc0RhdGVwaWNrZXJTdG9yZSBleHRlbmRzIE1pbmlTdG9yZTxCc0RhdGVwaWNrZXJTdGF0ZT4ge1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGNvbnN0IF9kaXNwYXRjaGVyID0gbmV3IEJlaGF2aW9yU3ViamVjdDxBY3Rpb24+KHt0eXBlOiAnW2RhdGVwaWNrZXJdIGRpc3BhdGNoZXIgaW5pdCd9KTtcbiAgICBjb25zdCBzdGF0ZSA9IG5ldyBNaW5pU3RhdGU8QnNEYXRlcGlja2VyU3RhdGU+KGluaXRpYWxEYXRlcGlja2VyU3RhdGUsIF9kaXNwYXRjaGVyLCBic0RhdGVwaWNrZXJSZWR1Y2VyKTtcbiAgICBzdXBlcihfZGlzcGF0Y2hlciwgYnNEYXRlcGlja2VyUmVkdWNlciwgc3RhdGUpO1xuICB9XG59XG4iXX0=
|