@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
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { Directive, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { filter } from 'rxjs/operators';
|
|
3
|
+
import { BsDatepickerConfig } from './bs-datepicker.config';
|
|
4
|
+
import { BsDaterangepickerInlineContainerComponent } from './components/bs-daterangepicker-inline-container.component';
|
|
5
|
+
import { checkBsValue, checkRangesWithMaxDate } from './utils/bs-calendar-utils';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "./bs-daterangepicker-inline.config";
|
|
8
|
+
import * as i2 from "ngx-bootstrap/component-loader";
|
|
9
|
+
export class BsDaterangepickerInlineDirective {
|
|
10
|
+
/** Initial value of datepicker */
|
|
11
|
+
set bsValue(value) {
|
|
12
|
+
if (this._bsValue === value)
|
|
13
|
+
return;
|
|
14
|
+
this._bsValue = value;
|
|
15
|
+
this.bsValueChange.emit(value);
|
|
16
|
+
}
|
|
17
|
+
constructor(_config, _elementRef, _renderer, _viewContainerRef, cis) {
|
|
18
|
+
this._config = _config;
|
|
19
|
+
this._elementRef = _elementRef;
|
|
20
|
+
/** Indicates whether datepicker is enabled or not */
|
|
21
|
+
this.isDisabled = false;
|
|
22
|
+
this.isMobile = false;
|
|
23
|
+
/** Emits when daterangepicker value has been changed */
|
|
24
|
+
this.bsValueChange = new EventEmitter();
|
|
25
|
+
this.onApplyEmit = new EventEmitter();
|
|
26
|
+
this._subs = [];
|
|
27
|
+
Object.assign(this, this._config);
|
|
28
|
+
this._datepicker = cis.createLoader(_elementRef, _viewContainerRef, _renderer);
|
|
29
|
+
}
|
|
30
|
+
ngOnInit() {
|
|
31
|
+
this.setConfig();
|
|
32
|
+
this.initSubscribes();
|
|
33
|
+
}
|
|
34
|
+
ngOnChanges(changes) {
|
|
35
|
+
if (!this._datepickerRef || !this._datepickerRef.instance)
|
|
36
|
+
return;
|
|
37
|
+
if (changes["minDate"]) {
|
|
38
|
+
this._datepickerRef.instance.minDate = this.minDate;
|
|
39
|
+
}
|
|
40
|
+
if (changes["maxDate"]) {
|
|
41
|
+
this._datepickerRef.instance.maxDate = this.maxDate;
|
|
42
|
+
}
|
|
43
|
+
if (changes["isDisabled"]) {
|
|
44
|
+
this._datepickerRef.instance.isDisabled = this.isDisabled;
|
|
45
|
+
}
|
|
46
|
+
this.setConfig();
|
|
47
|
+
}
|
|
48
|
+
initSubscribes() {
|
|
49
|
+
this.unsubscribeSubscriptions();
|
|
50
|
+
// if date changes from external source (model -> view)
|
|
51
|
+
this._subs.push(this.bsValueChange.subscribe((value) => {
|
|
52
|
+
if (this._datepickerRef) {
|
|
53
|
+
this._datepickerRef.instance.value = value;
|
|
54
|
+
}
|
|
55
|
+
}));
|
|
56
|
+
// if date changes from picker (view -> model)
|
|
57
|
+
if (this._datepickerRef) {
|
|
58
|
+
this._subs.push(this._datepickerRef.instance.valueChange
|
|
59
|
+
.pipe(filter((range) => {
|
|
60
|
+
if (range?.length == 0)
|
|
61
|
+
return true;
|
|
62
|
+
if (range?.length == 2)
|
|
63
|
+
return range && range[0] && !!range[1];
|
|
64
|
+
}))
|
|
65
|
+
.subscribe((value) => {
|
|
66
|
+
this.bsValue = value;
|
|
67
|
+
}));
|
|
68
|
+
this._subs.push(this._datepickerRef.instance.onApplyChange.subscribe(() => {
|
|
69
|
+
this.onApplyEmit.emit();
|
|
70
|
+
}));
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
unsubscribeSubscriptions() {
|
|
74
|
+
if (this._subs?.length) {
|
|
75
|
+
this._subs.map((sub) => sub.unsubscribe());
|
|
76
|
+
this._subs.length = 0;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
/** Set config for datepicker */
|
|
80
|
+
setConfig() {
|
|
81
|
+
if (this._datepicker) {
|
|
82
|
+
this._datepicker.hide();
|
|
83
|
+
}
|
|
84
|
+
this._config = Object.assign({}, this._config, this.bsConfig, {
|
|
85
|
+
value: checkBsValue(this._bsValue, this.maxDate || this.bsConfig && this.bsConfig.maxDate),
|
|
86
|
+
isDisabled: this.isDisabled,
|
|
87
|
+
isMobile: this.isMobile || this.bsConfig && this.bsConfig.isMobile,
|
|
88
|
+
minDate: this.minDate || this.bsConfig && this.bsConfig.minDate,
|
|
89
|
+
maxDate: this.maxDate || this.bsConfig && this.bsConfig.maxDate,
|
|
90
|
+
ranges: checkRangesWithMaxDate(this.bsConfig && this.bsConfig.ranges, this.maxDate || this.bsConfig && this.bsConfig.maxDate),
|
|
91
|
+
maxDateRange: this.bsConfig && this.bsConfig.maxDateRange
|
|
92
|
+
});
|
|
93
|
+
this._datepickerRef = this._datepicker
|
|
94
|
+
.provide({ provide: BsDatepickerConfig, useValue: this._config })
|
|
95
|
+
.attach(BsDaterangepickerInlineContainerComponent)
|
|
96
|
+
.to(this._elementRef)
|
|
97
|
+
.show();
|
|
98
|
+
this.initSubscribes();
|
|
99
|
+
}
|
|
100
|
+
ngOnDestroy() {
|
|
101
|
+
this._datepicker.dispose();
|
|
102
|
+
this.unsubscribeSubscriptions();
|
|
103
|
+
}
|
|
104
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerInlineDirective, deps: [{ token: i1.BsDaterangepickerInlineConfig }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ViewContainerRef }, { token: i2.ComponentLoaderFactory }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
105
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: BsDaterangepickerInlineDirective, selector: "[gravityRangePickerInline]", inputs: { bsConfig: "bsConfig", isDisabled: "isDisabled", isMobile: "isMobile", maxDate: "maxDate", minDate: "minDate", bsValue: "bsValue" }, outputs: { bsValueChange: "bsValueChange", onApplyEmit: "onApplyEmit" }, exportAs: ["gravityRangePickerInline"], usesOnChanges: true, ngImport: i0 }); }
|
|
106
|
+
}
|
|
107
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerInlineDirective, decorators: [{
|
|
108
|
+
type: Directive,
|
|
109
|
+
args: [{
|
|
110
|
+
selector: '[gravityRangePickerInline]',
|
|
111
|
+
exportAs: 'gravityRangePickerInline'
|
|
112
|
+
}]
|
|
113
|
+
}], ctorParameters: function () { return [{ type: i1.BsDaterangepickerInlineConfig }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i2.ComponentLoaderFactory }]; }, propDecorators: { bsConfig: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], isDisabled: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], isMobile: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], maxDate: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], minDate: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], bsValueChange: [{
|
|
124
|
+
type: Output
|
|
125
|
+
}], onApplyEmit: [{
|
|
126
|
+
type: Output
|
|
127
|
+
}], bsValue: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}] } });
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-daterangepicker-inline.component.js","sourceRoot":"","sources":["../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker-inline.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  ViewContainerRef\n} from '@angular/core';\n\nimport {ComponentLoader, ComponentLoaderFactory} from 'ngx-bootstrap/component-loader';\n\nimport {Subscription} from 'rxjs';\nimport {filter} from 'rxjs/operators';\n\nimport {BsDatepickerConfig} from './bs-datepicker.config';\nimport {BsDaterangepickerInlineConfig} from './bs-daterangepicker-inline.config';\nimport {BsDaterangepickerInlineContainerComponent} from './components/bs-daterangepicker-inline-container.component';\nimport {checkBsValue, checkRangesWithMaxDate} from './utils/bs-calendar-utils';\n\n@Directive({\n  selector: '[gravityRangePickerInline]',\n  exportAs: 'gravityRangePickerInline'\n})\nexport class BsDaterangepickerInlineDirective implements OnInit, OnDestroy, OnChanges {\n  /** Config object for datepicker */\n  @Input() bsConfig?: Partial<BsDaterangepickerInlineConfig>;\n\n  /** Indicates whether datepicker is enabled or not */\n  @Input() isDisabled: boolean = false;\n  @Input() isMobile: boolean = false;\n\n  /** Maximum date which is available for selection */\n  @Input() maxDate?: Date;\n\n  /** Minimum date which is available for selection */\n  @Input() minDate?: Date;\n\n  /** Emits when daterangepicker value has been changed */\n  @Output() bsValueChange: EventEmitter<(Date | undefined)[] | undefined> = new EventEmitter();\n  @Output() onApplyEmit: EventEmitter<void> = new EventEmitter<void>();\n\n  private _bsValue?: (Date | undefined)[] | undefined;\n\n  /** Initial value of datepicker */\n  @Input() set bsValue(value: (Date | undefined)[] | undefined) {\n    if (this._bsValue === value) return;\n\n    this._bsValue = value;\n    this.bsValueChange.emit(value);\n  }\n\n  protected _subs: Subscription[] = [];\n  private _datepickerRef?: ComponentRef<BsDaterangepickerInlineContainerComponent>;\n  private readonly _datepicker: ComponentLoader<BsDaterangepickerInlineContainerComponent>;\n\n  constructor(public _config: BsDaterangepickerInlineConfig, private _elementRef: ElementRef, _renderer: Renderer2, _viewContainerRef: ViewContainerRef, cis: ComponentLoaderFactory) {\n    Object.assign(this, this._config);\n\n    this._datepicker = cis.createLoader<BsDaterangepickerInlineContainerComponent>(_elementRef, _viewContainerRef, _renderer);\n  }\n\n  ngOnInit(): void {\n    this.setConfig();\n    this.initSubscribes();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!this._datepickerRef || !this._datepickerRef.instance) return;\n\n    if (changes[\"minDate\"]) {\n      this._datepickerRef.instance.minDate = this.minDate;\n    }\n\n    if (changes[\"maxDate\"]) {\n      this._datepickerRef.instance.maxDate = this.maxDate;\n    }\n\n    if (changes[\"isDisabled\"]) {\n      this._datepickerRef.instance.isDisabled = this.isDisabled;\n    }\n\n    this.setConfig();\n  }\n\n  private initSubscribes(): void {\n    this.unsubscribeSubscriptions();\n\n    // if date changes from external source (model -> view)\n    this._subs.push(\n      this.bsValueChange.subscribe((value: Date[]) => {\n        if (this._datepickerRef) {\n          this._datepickerRef.instance.value = value;\n        }\n      })\n    );\n\n    // if date changes from picker (view -> model)\n    if (this._datepickerRef) {\n      this._subs.push(\n        this._datepickerRef.instance.valueChange\n          .pipe(filter((range: Date[]) => {\n            if (range?.length == 0) return true;\n            if (range?.length == 2) return range && range[0] && !!range[1];\n          }))\n          .subscribe((value: Date[]) => {\n            this.bsValue = value;\n          })\n      );\n\n      this._subs.push(\n        this._datepickerRef.instance.onApplyChange.subscribe(() => {\n          this.onApplyEmit.emit();\n        })\n      );\n    }\n  }\n\n  private unsubscribeSubscriptions(): void {\n    if (this._subs?.length) {\n      this._subs.map((sub: Subscription) => sub.unsubscribe());\n      this._subs.length = 0;\n    }\n  }\n\n  /** Set config for datepicker */\n  private setConfig(): void {\n    if (this._datepicker) {\n      this._datepicker.hide();\n    }\n\n    this._config = Object.assign({}, this._config, this.bsConfig, {\n      value: checkBsValue(this._bsValue, this.maxDate || this.bsConfig && this.bsConfig.maxDate),\n      isDisabled: this.isDisabled,\n      isMobile: this.isMobile || this.bsConfig && this.bsConfig.isMobile,\n      minDate: this.minDate || this.bsConfig && this.bsConfig.minDate,\n      maxDate: this.maxDate || this.bsConfig && this.bsConfig.maxDate,\n      ranges: checkRangesWithMaxDate(this.bsConfig && this.bsConfig.ranges, this.maxDate || this.bsConfig && this.bsConfig.maxDate),\n      maxDateRange: this.bsConfig && this.bsConfig.maxDateRange\n    });\n\n    this._datepickerRef = this._datepicker\n      .provide({provide: BsDatepickerConfig, useValue: this._config})\n      .attach(BsDaterangepickerInlineContainerComponent)\n      .to(this._elementRef)\n      .show();\n\n    this.initSubscribes();\n  }\n\n  ngOnDestroy(): void {\n    this._datepicker.dispose();\n    this.unsubscribeSubscriptions();\n  }\n}\n"]}
|
package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker-inline.config.mjs
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BsDatepickerConfig } from './bs-datepicker.config';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class BsDaterangepickerInlineConfig extends BsDatepickerConfig {
|
|
5
|
+
constructor() {
|
|
6
|
+
super(...arguments);
|
|
7
|
+
this.displayMonths = 2;
|
|
8
|
+
}
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerInlineConfig, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
10
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerInlineConfig, providedIn: 'root' }); }
|
|
11
|
+
}
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerInlineConfig, decorators: [{
|
|
13
|
+
type: Injectable,
|
|
14
|
+
args: [{
|
|
15
|
+
providedIn: 'root'
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnMtZGF0ZXJhbmdlcGlja2VyLWlubGluZS5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktY2FsZW5kYXItdjIvZGF0ZXBpY2tlci9icy1kYXRlcmFuZ2VwaWNrZXItaW5saW5lLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHdCQUF3QixDQUFDOztBQUsxRCxNQUFNLE9BQU8sNkJBQThCLFNBQVEsa0JBQWtCO0lBSHJFOztRQUlXLGtCQUFhLEdBQVcsQ0FBQyxDQUFDO0tBQ3BDOytHQUZZLDZCQUE2QjttSEFBN0IsNkJBQTZCLGNBRjVCLE1BQU07OzRGQUVQLDZCQUE2QjtrQkFIekMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtCc0RhdGVwaWNrZXJDb25maWd9IGZyb20gJy4vYnMtZGF0ZXBpY2tlci5jb25maWcnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBCc0RhdGVyYW5nZXBpY2tlcklubGluZUNvbmZpZyBleHRlbmRzIEJzRGF0ZXBpY2tlckNvbmZpZyB7XG4gIG92ZXJyaWRlIGRpc3BsYXlNb250aHM6IG51bWJlciA9IDI7XG59XG4iXX0=
|
package/esm2022/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker.component.mjs
ADDED
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
import { Directive, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { BsDaterangepickerContainerComponent } from './components/bs-daterangepicker-container.component';
|
|
3
|
+
import { BehaviorSubject, Subject } from 'rxjs';
|
|
4
|
+
import { filter, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { BsDatepickerConfig } from './bs-datepicker.config';
|
|
6
|
+
import { checkBsValue, checkRangesWithMaxDate } from './utils/bs-calendar-utils';
|
|
7
|
+
import { BsDatepickerCallbacks } from "./bs-datepicker.callbacks";
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "./bs-daterangepicker.config";
|
|
10
|
+
import * as i2 from "ngx-bootstrap/component-loader";
|
|
11
|
+
export let previousDate;
|
|
12
|
+
export class BsDaterangepickerDirective {
|
|
13
|
+
/** Returns whether or not the daterangepicker is currently being shown */
|
|
14
|
+
get isOpen() {
|
|
15
|
+
return this._datepicker.isShown;
|
|
16
|
+
}
|
|
17
|
+
set isOpen(value) {
|
|
18
|
+
this.isOpen$.next(value);
|
|
19
|
+
}
|
|
20
|
+
/** Initial value of daterangepicker */
|
|
21
|
+
set bsValue(value) {
|
|
22
|
+
if (this._bsValue === value)
|
|
23
|
+
return;
|
|
24
|
+
this.initPreviousValue();
|
|
25
|
+
this._bsValue = value;
|
|
26
|
+
this.bsValueChange.emit(value);
|
|
27
|
+
}
|
|
28
|
+
constructor(_config, _elementRef, _renderer, _viewContainerRef, cis) {
|
|
29
|
+
this._config = _config;
|
|
30
|
+
this._elementRef = _elementRef;
|
|
31
|
+
this._renderer = _renderer;
|
|
32
|
+
/** A selector specifying the element the daterangepicker should be appended to. */
|
|
33
|
+
this.container = 'body';
|
|
34
|
+
/** Indicates whether daterangepicker's content is enabled or not */
|
|
35
|
+
this.isDisabled = false;
|
|
36
|
+
this.isMobile = false;
|
|
37
|
+
/** Emits when daterangepicker value has been changed */
|
|
38
|
+
this.bsValueChange = new EventEmitter();
|
|
39
|
+
this.onApplyEmit = new EventEmitter();
|
|
40
|
+
this._subs = [];
|
|
41
|
+
this.isDestroy$ = new Subject();
|
|
42
|
+
this._rangeInputFormat$ = new Subject();
|
|
43
|
+
Object.assign(this, _config);
|
|
44
|
+
this._datepicker = cis.createLoader(_elementRef, _viewContainerRef, _renderer);
|
|
45
|
+
this.isOpen$ = new BehaviorSubject(this.isOpen);
|
|
46
|
+
this.onHidden = this._datepicker.onHidden;
|
|
47
|
+
this.onShown = this._datepicker.onShown;
|
|
48
|
+
}
|
|
49
|
+
ngOnInit() {
|
|
50
|
+
this._datepicker.listen({
|
|
51
|
+
outsideClick: true,
|
|
52
|
+
outsideEsc: true,
|
|
53
|
+
triggers: 'click',
|
|
54
|
+
show: () => this.show()
|
|
55
|
+
});
|
|
56
|
+
this.initPreviousValue();
|
|
57
|
+
this.setConfig();
|
|
58
|
+
}
|
|
59
|
+
initPreviousValue() {
|
|
60
|
+
previousDate = this._bsValue;
|
|
61
|
+
}
|
|
62
|
+
ngOnChanges(changes) {
|
|
63
|
+
if (changes["bsConfig"]) {
|
|
64
|
+
this.setConfig();
|
|
65
|
+
this._rangeInputFormat$.next('L');
|
|
66
|
+
}
|
|
67
|
+
if (!this._datepickerRef || !this._datepickerRef.instance)
|
|
68
|
+
return;
|
|
69
|
+
if (changes["minDate"]) {
|
|
70
|
+
this._datepickerRef.instance.minDate = this.minDate;
|
|
71
|
+
}
|
|
72
|
+
if (changes["maxDate"]) {
|
|
73
|
+
this._datepickerRef.instance.maxDate = this.maxDate;
|
|
74
|
+
}
|
|
75
|
+
if (changes["isDisabled"]) {
|
|
76
|
+
this._datepickerRef.instance.isDisabled = this.isDisabled;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
ngAfterViewInit() {
|
|
80
|
+
this.isOpen$.pipe(filter(isOpen => isOpen !== this.isOpen), takeUntil(this.isDestroy$)).subscribe(() => this.toggle());
|
|
81
|
+
}
|
|
82
|
+
initSubscribes() {
|
|
83
|
+
// if date changes from external source (model -> view)
|
|
84
|
+
this._subs.push(this.bsValueChange.subscribe((value) => {
|
|
85
|
+
if (this._datepickerRef) {
|
|
86
|
+
this._datepickerRef.instance.value = value;
|
|
87
|
+
}
|
|
88
|
+
}));
|
|
89
|
+
// if date changes from picker (view -> model)
|
|
90
|
+
if (this._datepickerRef) {
|
|
91
|
+
this._subs.push(this._datepickerRef.instance.valueChange
|
|
92
|
+
.pipe(filter((range) => {
|
|
93
|
+
if (range.length == 0)
|
|
94
|
+
return true;
|
|
95
|
+
if (range.length == 2)
|
|
96
|
+
return range && range[0] && !!range[1];
|
|
97
|
+
}))
|
|
98
|
+
.subscribe((value) => {
|
|
99
|
+
this.initPreviousValue();
|
|
100
|
+
this.bsValue = value;
|
|
101
|
+
// TODO ebiazzetti keep modal open after select the dates
|
|
102
|
+
if (this.keepDatepickerModalOpened())
|
|
103
|
+
return;
|
|
104
|
+
this.hide();
|
|
105
|
+
}));
|
|
106
|
+
this._subs.push(this._datepickerRef.instance.onApplyChange.subscribe(() => {
|
|
107
|
+
this.onApplyEmit.emit();
|
|
108
|
+
}));
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
keepDatepickerModalOpened() {
|
|
112
|
+
if (!previousDate || !this.bsConfig?.keepDatepickerOpened)
|
|
113
|
+
return false;
|
|
114
|
+
return this.isDateSame();
|
|
115
|
+
}
|
|
116
|
+
isDateSame() {
|
|
117
|
+
return ((this._bsValue?.[0]?.getDate() === previousDate?.[0]?.getDate())
|
|
118
|
+
&& (this._bsValue?.[0]?.getMonth() === previousDate?.[0]?.getMonth())
|
|
119
|
+
&& (this._bsValue?.[0]?.getFullYear() === previousDate?.[0]?.getFullYear())
|
|
120
|
+
&& (this._bsValue?.[1]?.getDate() === previousDate?.[1]?.getDate())
|
|
121
|
+
&& (this._bsValue?.[1]?.getMonth() === previousDate?.[1]?.getMonth())
|
|
122
|
+
&& (this._bsValue?.[1]?.getFullYear() === previousDate?.[1]?.getFullYear()));
|
|
123
|
+
}
|
|
124
|
+
/** Opens an element’s datepicker. This is considered a “manual” triggering of the datepicker */
|
|
125
|
+
show() {
|
|
126
|
+
if (this._datepicker.isShown)
|
|
127
|
+
return;
|
|
128
|
+
this.setConfig();
|
|
129
|
+
const callbacks = new BsDatepickerCallbacks();
|
|
130
|
+
callbacks.hide = this.hide.bind(this);
|
|
131
|
+
this._datepickerRef = this._datepicker
|
|
132
|
+
.provide({ provide: BsDatepickerConfig, useValue: this._config })
|
|
133
|
+
.provide({ provide: BsDatepickerCallbacks, useValue: callbacks })
|
|
134
|
+
.attach(BsDaterangepickerContainerComponent)
|
|
135
|
+
.to(this.container)
|
|
136
|
+
.position({ attachment: 'bottom' })
|
|
137
|
+
.show({ placement: 'bottom' });
|
|
138
|
+
this.initSubscribes();
|
|
139
|
+
}
|
|
140
|
+
/** Closes an element’s datepicker. This is considered a “manual” triggering of the datepicker. */
|
|
141
|
+
hide() {
|
|
142
|
+
if (this.isOpen) {
|
|
143
|
+
this._datepicker.hide();
|
|
144
|
+
}
|
|
145
|
+
for (const sub of this._subs) {
|
|
146
|
+
sub.unsubscribe();
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
/** Toggles an element’s datepicker. This is considered a “manual” triggering of the datepicker. */
|
|
150
|
+
toggle() {
|
|
151
|
+
if (this.isOpen) {
|
|
152
|
+
return this.hide();
|
|
153
|
+
}
|
|
154
|
+
this.show();
|
|
155
|
+
}
|
|
156
|
+
/** Set config for daterangepicker */
|
|
157
|
+
setConfig() {
|
|
158
|
+
this._config = Object.assign({}, this._config, this.bsConfig, {
|
|
159
|
+
value: checkBsValue(this._bsValue, this.maxDate || this.bsConfig && this.bsConfig.maxDate),
|
|
160
|
+
isDisabled: this.isDisabled,
|
|
161
|
+
isMobile: this.isMobile || this.bsConfig && this.bsConfig.isMobile,
|
|
162
|
+
minDate: this.minDate || this.bsConfig && this.bsConfig.minDate,
|
|
163
|
+
maxDate: this.maxDate || this.bsConfig && this.bsConfig.maxDate,
|
|
164
|
+
ranges: checkRangesWithMaxDate(this.bsConfig && this.bsConfig.ranges, this.maxDate || this.bsConfig && this.bsConfig.maxDate),
|
|
165
|
+
maxDateRange: this.bsConfig && this.bsConfig.maxDateRange,
|
|
166
|
+
keepDatepickerOpened: this.bsConfig?.keepDatepickerOpened
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
unsubscribeSubscriptions() {
|
|
170
|
+
if (this._subs?.length) {
|
|
171
|
+
this._subs.map((sub) => sub.unsubscribe());
|
|
172
|
+
this._subs.length = 0;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
ngOnDestroy() {
|
|
176
|
+
this._datepicker.dispose();
|
|
177
|
+
this.isOpen$.next(false);
|
|
178
|
+
if (this.isDestroy$) {
|
|
179
|
+
this.isDestroy$.next(null);
|
|
180
|
+
this.isDestroy$.complete();
|
|
181
|
+
}
|
|
182
|
+
this.unsubscribeSubscriptions();
|
|
183
|
+
}
|
|
184
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerDirective, deps: [{ token: i1.BsDaterangepickerConfig }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ViewContainerRef }, { token: i2.ComponentLoaderFactory }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
185
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: BsDaterangepickerDirective, selector: "[gravityRangePicker]", inputs: { bsConfig: "bsConfig", container: "container", isDisabled: "isDisabled", isMobile: "isMobile", maxDate: "maxDate", minDate: "minDate", isOpen: "isOpen", bsValue: "bsValue" }, outputs: { bsValueChange: "bsValueChange", onApplyEmit: "onApplyEmit", onHidden: "onHidden", onShown: "onShown" }, exportAs: ["gravityRangePicker"], usesOnChanges: true, ngImport: i0 }); }
|
|
186
|
+
}
|
|
187
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerDirective, decorators: [{
|
|
188
|
+
type: Directive,
|
|
189
|
+
args: [{
|
|
190
|
+
selector: '[gravityRangePicker]',
|
|
191
|
+
exportAs: 'gravityRangePicker'
|
|
192
|
+
}]
|
|
193
|
+
}], ctorParameters: function () { return [{ type: i1.BsDaterangepickerConfig }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i2.ComponentLoaderFactory }]; }, propDecorators: { bsConfig: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], container: [{
|
|
196
|
+
type: Input
|
|
197
|
+
}], isDisabled: [{
|
|
198
|
+
type: Input
|
|
199
|
+
}], isMobile: [{
|
|
200
|
+
type: Input
|
|
201
|
+
}], maxDate: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], minDate: [{
|
|
204
|
+
type: Input
|
|
205
|
+
}], bsValueChange: [{
|
|
206
|
+
type: Output
|
|
207
|
+
}], onApplyEmit: [{
|
|
208
|
+
type: Output
|
|
209
|
+
}], onHidden: [{
|
|
210
|
+
type: Output
|
|
211
|
+
}], onShown: [{
|
|
212
|
+
type: Output
|
|
213
|
+
}], isOpen: [{
|
|
214
|
+
type: Input
|
|
215
|
+
}], bsValue: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}] } });
|
|
218
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-daterangepicker.component.js","sourceRoot":"","sources":["../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-v2/datepicker/bs-daterangepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  ViewContainerRef\n} from '@angular/core';\nimport {BsDaterangepickerConfig} from './bs-daterangepicker.config';\nimport {BsDaterangepickerContainerComponent} from './components/bs-daterangepicker-container.component';\nimport {BehaviorSubject, Subject, Subscription} from 'rxjs';\nimport {filter, takeUntil} from 'rxjs/operators';\nimport {ComponentLoader, ComponentLoaderFactory} from 'ngx-bootstrap/component-loader';\nimport {BsDatepickerConfig} from './bs-datepicker.config';\nimport {checkBsValue, checkRangesWithMaxDate} from './utils/bs-calendar-utils';\nimport {BsDatepickerCallbacks} from \"./bs-datepicker.callbacks\";\n\nexport let previousDate: (Date | undefined)[] | undefined;\n\n@Directive({\n  selector: '[gravityRangePicker]',\n  exportAs: 'gravityRangePicker'\n})\nexport class BsDaterangepickerDirective implements OnInit, OnDestroy, OnChanges, AfterViewInit {\n  /** Config object for daterangepicker */\n  @Input() bsConfig?: Partial<BsDaterangepickerConfig>;\n\n  /** A selector specifying the element the daterangepicker should be appended to. */\n  @Input() container: string = 'body';\n\n  /** Indicates whether daterangepicker's content is enabled or not */\n  @Input() isDisabled: boolean = false;\n  @Input() isMobile: boolean = false;\n\n  /** Maximum date which is available for selection */\n  @Input() maxDate?: Date;\n\n  /** Minimum date which is available for selection */\n  @Input() minDate?: Date;\n\n  /** Emits when daterangepicker value has been changed */\n  @Output() bsValueChange: EventEmitter<((Date | undefined)[] | undefined)> = new EventEmitter<((Date | undefined)[] | undefined)>();\n  @Output() onApplyEmit: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Emits an event when the daterangepicker is hidden */\n  @Output() onHidden: EventEmitter<unknown>;\n\n  /** Emits an event when the daterangepicker is shown */\n  @Output() onShown: EventEmitter<unknown>;\n\n  private isOpen$: BehaviorSubject<boolean>;\n\n  /** Returns whether or not the daterangepicker is currently being shown */\n  @Input() get isOpen(): boolean {\n    return this._datepicker.isShown;\n  }\n\n  set isOpen(value: boolean) {\n    this.isOpen$.next(value);\n  }\n\n  public _bsValue?: (Date | undefined)[];\n\n  /** Initial value of daterangepicker */\n  @Input() set bsValue(value: (Date | undefined)[] | undefined) {\n    if (this._bsValue === value) return;\n\n    this.initPreviousValue();\n    this._bsValue = value;\n    this.bsValueChange.emit(value);\n  }\n\n  protected _subs: Subscription[] = [];\n  private _datepicker: ComponentLoader<BsDaterangepickerContainerComponent>;\n  private _datepickerRef?: ComponentRef<BsDaterangepickerContainerComponent>;\n  private isDestroy$: Subject<unknown> = new Subject();\n  private readonly _rangeInputFormat$ = new Subject<string>();\n\n  constructor(public _config: BsDaterangepickerConfig, private _elementRef: ElementRef, private _renderer: Renderer2, _viewContainerRef: ViewContainerRef, cis: ComponentLoaderFactory) {\n    Object.assign(this, _config);\n\n    this._datepicker = cis.createLoader<BsDaterangepickerContainerComponent>(_elementRef, _viewContainerRef, _renderer);\n\n    this.isOpen$ = new BehaviorSubject(this.isOpen);\n    this.onHidden = this._datepicker.onHidden;\n    this.onShown = this._datepicker.onShown;\n  }\n\n  ngOnInit(): void {\n    this._datepicker.listen({\n      outsideClick: true,\n      outsideEsc: true,\n      triggers: 'click',\n      show: () => this.show()\n    });\n\n    this.initPreviousValue();\n    this.setConfig();\n  }\n\n  private initPreviousValue(): void {\n    previousDate = this._bsValue;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes[\"bsConfig\"]) {\n      this.setConfig();\n      this._rangeInputFormat$.next('L');\n    }\n\n    if (!this._datepickerRef || !this._datepickerRef.instance) return;\n\n    if (changes[\"minDate\"]) {\n      this._datepickerRef.instance.minDate = this.minDate;\n    }\n\n    if (changes[\"maxDate\"]) {\n      this._datepickerRef.instance.maxDate = this.maxDate;\n    }\n\n    if (changes[\"isDisabled\"]) {\n      this._datepickerRef.instance.isDisabled = this.isDisabled;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.isOpen$.pipe(filter(isOpen => isOpen !== this.isOpen), takeUntil(this.isDestroy$)).subscribe(() => this.toggle());\n  }\n\n  private initSubscribes(): void {\n    // if date changes from external source (model -> view)\n    this._subs.push(\n      this.bsValueChange.subscribe((value: Date[]) => {\n        if (this._datepickerRef) {\n          this._datepickerRef.instance.value = value;\n        }\n      })\n    );\n\n    // if date changes from picker (view -> model)\n    if (this._datepickerRef) {\n      this._subs.push(\n        this._datepickerRef.instance.valueChange\n          .pipe(filter((range: Date[]) => {\n            if (range.length == 0) return true;\n            if (range.length == 2) return range && range[0] && !!range[1];\n          }))\n          .subscribe((value: Date[]) => {\n            this.initPreviousValue();\n            this.bsValue = value;\n\n            // TODO ebiazzetti keep modal open after select the dates\n            if (this.keepDatepickerModalOpened()) return;\n\n            this.hide();\n          })\n      );\n\n      this._subs.push(\n        this._datepickerRef.instance.onApplyChange.subscribe(() => {\n          this.onApplyEmit.emit();\n        })\n      );\n    }\n  }\n\n  private keepDatepickerModalOpened(): boolean {\n    if (!previousDate || !this.bsConfig?.keepDatepickerOpened) return false;\n    return this.isDateSame();\n  }\n\n  private isDateSame(): boolean {\n    return ((this._bsValue?.[0]?.getDate() === previousDate?.[0]?.getDate())\n      && (this._bsValue?.[0]?.getMonth() === previousDate?.[0]?.getMonth())\n      && (this._bsValue?.[0]?.getFullYear() === previousDate?.[0]?.getFullYear())\n      && (this._bsValue?.[1]?.getDate() === previousDate?.[1]?.getDate())\n      && (this._bsValue?.[1]?.getMonth() === previousDate?.[1]?.getMonth())\n      && (this._bsValue?.[1]?.getFullYear() === previousDate?.[1]?.getFullYear())\n    );\n  }\n\n  /** Opens an element’s datepicker. This is considered a “manual” triggering of the datepicker */\n  private show(): void {\n    if (this._datepicker.isShown) return;\n\n    this.setConfig();\n\n    const callbacks: BsDatepickerCallbacks = new BsDatepickerCallbacks();\n    callbacks.hide = this.hide.bind(this);\n\n    this._datepickerRef = this._datepicker\n      .provide({provide: BsDatepickerConfig, useValue: this._config})\n      .provide({provide: BsDatepickerCallbacks, useValue: callbacks})\n      .attach(BsDaterangepickerContainerComponent)\n      .to(this.container)\n      .position({attachment: 'bottom'})\n      .show({placement: 'bottom'});\n\n    this.initSubscribes();\n  }\n\n  /** Closes an element’s datepicker. This is considered a “manual” triggering of the datepicker. */\n  public hide(): void {\n    if (this.isOpen) {\n      this._datepicker.hide();\n    }\n\n    for (const sub of this._subs) {\n      sub.unsubscribe();\n    }\n  }\n\n  /** Toggles an element’s datepicker. This is considered a “manual” triggering of the datepicker. */\n  private toggle(): void {\n    if (this.isOpen) {\n      return this.hide();\n    }\n\n    this.show();\n  }\n\n  /** Set config for daterangepicker */\n  private setConfig(): void {\n    this._config = Object.assign({}, this._config, this.bsConfig, {\n      value: checkBsValue(this._bsValue, this.maxDate || this.bsConfig && this.bsConfig.maxDate),\n      isDisabled: this.isDisabled,\n      isMobile: this.isMobile || this.bsConfig && this.bsConfig.isMobile,\n      minDate: this.minDate || this.bsConfig && this.bsConfig.minDate,\n      maxDate: this.maxDate || this.bsConfig && this.bsConfig.maxDate,\n      ranges: checkRangesWithMaxDate(this.bsConfig && this.bsConfig.ranges, this.maxDate || this.bsConfig && this.bsConfig.maxDate),\n      maxDateRange: this.bsConfig && this.bsConfig.maxDateRange,\n      keepDatepickerOpened: this.bsConfig?.keepDatepickerOpened\n    });\n  }\n\n  private unsubscribeSubscriptions(): void {\n    if (this._subs?.length) {\n      this._subs.map((sub: Subscription) => sub.unsubscribe());\n      this._subs.length = 0;\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._datepicker.dispose();\n    this.isOpen$.next(false);\n\n    if (this.isDestroy$) {\n      this.isDestroy$.next(null);\n      this.isDestroy$.complete();\n    }\n\n    this.unsubscribeSubscriptions();\n  }\n}\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BsDatepickerConfig } from './bs-datepicker.config';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class BsDaterangepickerConfig extends BsDatepickerConfig {
|
|
5
|
+
constructor() {
|
|
6
|
+
super(...arguments);
|
|
7
|
+
this.displayMonths = 2;
|
|
8
|
+
}
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerConfig, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
10
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerConfig, providedIn: 'root' }); }
|
|
11
|
+
}
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BsDaterangepickerConfig, decorators: [{
|
|
13
|
+
type: Injectable,
|
|
14
|
+
args: [{
|
|
15
|
+
providedIn: 'root'
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnMtZGF0ZXJhbmdlcGlja2VyLmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dyYXZpdHktZGVzaWduLXN5c3RlbS9zcmMvbGliL2NvbXBvbmVudHMvZ3Jhdml0eS1jYWxlbmRhci12Mi9kYXRlcGlja2VyL2JzLWRhdGVyYW5nZXBpY2tlci5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQzs7QUFLMUQsTUFBTSxPQUFPLHVCQUF3QixTQUFRLGtCQUFrQjtJQUgvRDs7UUFJVyxrQkFBYSxHQUFXLENBQUMsQ0FBQztLQUNwQzsrR0FGWSx1QkFBdUI7bUhBQXZCLHVCQUF1QixjQUZ0QixNQUFNOzs0RkFFUCx1QkFBdUI7a0JBSG5DLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7QnNEYXRlcGlja2VyQ29uZmlnfSBmcm9tICcuL2JzLWRhdGVwaWNrZXIuY29uZmlnJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQnNEYXRlcmFuZ2VwaWNrZXJDb25maWcgZXh0ZW5kcyBCc0RhdGVwaWNrZXJDb25maWcge1xuICBvdmVycmlkZSBkaXNwbGF5TW9udGhzOiBudW1iZXIgPSAyO1xufVxuIl19
|