ontimize-web-ngx 15.3.4 → 15.4.0

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.
Files changed (54) hide show
  1. package/esm2020/lib/components/grid/o-grid.component.mjs +2 -1
  2. package/esm2020/lib/components/input/date-range/o-daterange-input.component.mjs +240 -218
  3. package/esm2020/lib/components/input/date-range/o-daterange-input.module.mjs +3 -5
  4. package/esm2020/lib/components/input/date-range-legacy/o-daterange-input.component.mjs +353 -0
  5. package/esm2020/lib/components/input/date-range-legacy/o-daterange-input.directive.mjs +381 -0
  6. package/esm2020/lib/components/input/date-range-legacy/o-daterange-input.module.mjs +21 -0
  7. package/esm2020/lib/components/input/date-range-legacy/o-daterange-picker.component.mjs +1009 -0
  8. package/esm2020/lib/components/input/date-range-legacy/o-daterange-picker.config.mjs +2 -0
  9. package/esm2020/lib/components/input/index.mjs +7 -5
  10. package/esm2020/lib/components/list/o-list.component.mjs +2 -1
  11. package/esm2020/lib/components/o-service-base-component.class.mjs +24 -9
  12. package/esm2020/lib/components/o-service-component.class.mjs +2 -1
  13. package/esm2020/lib/components/table/o-table.component.mjs +17 -7
  14. package/esm2020/lib/config/o-modules.mjs +5 -3
  15. package/esm2020/lib/i18n/i18n.mjs +9 -3
  16. package/esm2020/lib/interfaces/form-layout-manager.interface.mjs +2 -0
  17. package/esm2020/lib/interfaces/index.mjs +3 -1
  18. package/esm2020/lib/interfaces/pagination-context.interface.mjs +2 -0
  19. package/esm2020/lib/layouts/form-layout/o-form-layout-manager-base.class.mjs +1 -1
  20. package/esm2020/lib/layouts/form-layout/o-form-layout-manager.component.mjs +1 -1
  21. package/esm2020/lib/ontimize-web-ngx.module.mjs +7 -6
  22. package/esm2020/lib/services/base-service.class.mjs +12 -1
  23. package/esm2020/lib/services/index.mjs +2 -1
  24. package/esm2020/lib/services/pagination-context.service.mjs +25 -0
  25. package/fesm2015/ontimize-web-ngx.mjs +477 -43
  26. package/fesm2015/ontimize-web-ngx.mjs.map +1 -1
  27. package/fesm2020/ontimize-web-ngx.mjs +466 -43
  28. package/fesm2020/ontimize-web-ngx.mjs.map +1 -1
  29. package/lib/components/input/date-range/o-daterange-input.component.d.ts +47 -33
  30. package/lib/components/input/date-range/o-daterange-input.module.d.ts +4 -6
  31. package/lib/components/input/date-range-legacy/o-daterange-input.component.d.ts +70 -0
  32. package/lib/components/input/date-range-legacy/o-daterange-input.module.d.ts +11 -0
  33. package/lib/components/input/index.d.ts +6 -4
  34. package/lib/components/o-service-base-component.class.d.ts +1 -0
  35. package/lib/components/table/extensions/header/o-table-header-components.d.ts +2 -2
  36. package/lib/components/table/o-table.component.d.ts +2 -0
  37. package/lib/i18n/i18n.d.ts +6 -0
  38. package/lib/interfaces/form-layout-manager.interface.d.ts +43 -0
  39. package/lib/interfaces/index.d.ts +2 -0
  40. package/lib/interfaces/pagination-context.interface.d.ts +6 -0
  41. package/lib/layouts/form-layout/o-form-layout-manager-base.class.d.ts +30 -12
  42. package/lib/layouts/form-layout/o-form-layout-manager.component.d.ts +2 -1
  43. package/lib/ontimize-web-ngx.module.d.ts +5 -4
  44. package/lib/services/base-service.class.d.ts +6 -0
  45. package/lib/services/index.d.ts +1 -0
  46. package/lib/services/pagination-context.service.d.ts +11 -0
  47. package/package.json +1 -1
  48. package/theme.scss +2 -2
  49. package/esm2020/lib/components/input/date-range/o-daterange-input.directive.mjs +0 -381
  50. package/esm2020/lib/components/input/date-range/o-daterange-picker.component.mjs +0 -1009
  51. package/esm2020/lib/components/input/date-range/o-daterange-picker.config.mjs +0 -2
  52. /package/lib/components/input/{date-range → date-range-legacy}/o-daterange-input.directive.d.ts +0 -0
  53. /package/lib/components/input/{date-range → date-range-legacy}/o-daterange-picker.component.d.ts +0 -0
  54. /package/lib/components/input/{date-range → date-range-legacy}/o-daterange-picker.config.d.ts +0 -0
@@ -1,381 +0,0 @@
1
- import { ESCAPE, UP_ARROW } from '@angular/cdk/keycodes';
2
- import { Overlay, OverlayConfig, ScrollStrategyOptions } from '@angular/cdk/overlay';
3
- import { ComponentPortal } from '@angular/cdk/portal';
4
- import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, forwardRef, Input, KeyValueDiffers, NgZone, Output, ViewContainerRef } from '@angular/core';
5
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
6
- import { MatDialog } from '@angular/material/dialog';
7
- import moment from 'moment';
8
- import { merge } from 'rxjs';
9
- import { filter, take } from 'rxjs/operators';
10
- import { DaterangepickerComponent } from './o-daterange-picker.component';
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "@angular/material/dialog";
13
- import * as i2 from "@angular/cdk/overlay";
14
- export class ODaterangepickerDirective {
15
- set separator(value) {
16
- if (value !== null) {
17
- this._separator = value;
18
- if (this._locale) {
19
- this._locale.separator = value;
20
- }
21
- }
22
- }
23
- set locale(value) {
24
- if (value !== null) {
25
- this._locale = value;
26
- if (this._separator) {
27
- this._locale.separator = this._separator;
28
- }
29
- }
30
- }
31
- get locale() {
32
- return this._locale;
33
- }
34
- set startKey(value) {
35
- if (value && value !== null) {
36
- this._startKey = value;
37
- }
38
- else {
39
- this._startKey = 'startDate';
40
- }
41
- }
42
- get startKey() {
43
- return this._startKey;
44
- }
45
- set endKey(value) {
46
- if (value && value !== null) {
47
- this._endKey = value;
48
- }
49
- else {
50
- this._endKey = 'endDate';
51
- }
52
- }
53
- get endKey() {
54
- return this._endKey;
55
- }
56
- get value() {
57
- return this._value || null;
58
- }
59
- set value(val) {
60
- this._value = val;
61
- this._onChange(val);
62
- this._changeDetectorRef.markForCheck();
63
- }
64
- constructor(_dialog, _ngZone, _overlay, _viewContainerRef, _changeDetectorRef, _el, differs, scrollStrategy) {
65
- this._dialog = _dialog;
66
- this._ngZone = _ngZone;
67
- this._overlay = _overlay;
68
- this._viewContainerRef = _viewContainerRef;
69
- this._changeDetectorRef = _changeDetectorRef;
70
- this._el = _el;
71
- this.differs = differs;
72
- this.scrollStrategy = scrollStrategy;
73
- this._onChange = Function.prototype;
74
- this._onTouched = Function.prototype;
75
- this._validatorChange = Function.prototype;
76
- this.minDate = null;
77
- this.maxDate = null;
78
- this.dateLimit = null;
79
- this.showCancel = false;
80
- this.timePicker = false;
81
- this.showRanges = false;
82
- this.timePicker24Hour = false;
83
- this.timePickerIncrement = 1;
84
- this.timePickerSeconds = false;
85
- this._endKey = 'endDate';
86
- this._startKey = 'startDate';
87
- this.ranges = {
88
- 'DATERANGE.today': [moment(), moment()],
89
- 'DATERANGE.yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')],
90
- 'DATERANGE.last_7days': [moment().subtract(6, 'days'), moment()],
91
- 'DATERANGE.last_30days': [moment().subtract(29, 'days'), moment()],
92
- 'DATERANGE.this_month': [moment().startOf('month'), moment().endOf('month')],
93
- 'DATERANGE.last_month': [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')],
94
- 'DATERANGE.this_year': [moment().startOf('year'), moment().endOf('year')]
95
- };
96
- this.oTouchUi = false;
97
- this.notForChangesProperty = [
98
- 'locale',
99
- 'endKey',
100
- 'startKey'
101
- ];
102
- this.onChange = new EventEmitter();
103
- this.rangeClicked = new EventEmitter();
104
- this.datesUpdated = new EventEmitter();
105
- this.drops = 'down';
106
- this.opens = 'right';
107
- }
108
- initializeListeners(instance) {
109
- instance.rangeClicked.asObservable().subscribe((range) => {
110
- this.rangeClicked.emit(range);
111
- });
112
- instance.datesUpdated.asObservable().subscribe((range) => {
113
- this.datesUpdated.emit(range);
114
- });
115
- instance.choosedDate.asObservable().subscribe((change) => {
116
- if (change) {
117
- const value = {};
118
- value[this._startKey] = change.startDate;
119
- value[this._endKey] = change.endDate;
120
- this.value = value;
121
- this.onChange.emit(value);
122
- if (typeof change.chosenLabel === 'string') {
123
- this._el.nativeElement.value = change.chosenLabel;
124
- }
125
- }
126
- });
127
- instance.firstMonthDayClass = this.firstMonthDayClass;
128
- instance.lastMonthDayClass = this.lastMonthDayClass;
129
- instance.emptyWeekRowClass = this.emptyWeekRowClass;
130
- instance.firstDayOfNextMonthClass = this.firstDayOfNextMonthClass;
131
- instance.lastDayOfPreviousMonthClass = this.lastDayOfPreviousMonthClass;
132
- instance.drops = this.drops;
133
- instance.opens = this.opens;
134
- instance.minDate = this.minDate;
135
- instance.maxDate = this.maxDate;
136
- instance.locale = this.locale;
137
- instance.showWeekNumbers = this.showWeekNumbers;
138
- instance.singleDatePicker = this.singleDatePicker;
139
- if (this.showRanges) {
140
- instance.ranges = this.ranges;
141
- instance.keepCalendarOpeningWithRange = true;
142
- instance.alwaysShowCalendars = true;
143
- }
144
- this.localeDiffer = this.differs.find(this.locale).create();
145
- }
146
- onBlur() {
147
- this._onTouched();
148
- }
149
- open() {
150
- if (!this.oTouchUi) {
151
- this.openAsPopup();
152
- }
153
- else {
154
- this.openAsDialog();
155
- }
156
- }
157
- ngOnDestroy() {
158
- this.close();
159
- if (this._popupRef) {
160
- this._popupRef.dispose();
161
- this._popupComponentRef = null;
162
- }
163
- }
164
- clear() {
165
- this._popupComponentRef.instance.clear();
166
- }
167
- writeValue(value) {
168
- this.setValue(value);
169
- }
170
- registerOnChange(fn) {
171
- this._onChange = fn;
172
- }
173
- registerOnTouched(fn) {
174
- this._onTouched = fn;
175
- }
176
- setValueInDateComponent(instance, val) {
177
- if (val) {
178
- if (val[this._startKey]) {
179
- instance.setStartDate(val[this._startKey]);
180
- }
181
- if (val[this._endKey]) {
182
- instance.setEndDate(val[this._endKey]);
183
- }
184
- instance.calculateChosenLabel();
185
- if (instance.chosenLabel) {
186
- this._el.nativeElement.value = instance.chosenLabel;
187
- }
188
- }
189
- else {
190
- instance.clear();
191
- }
192
- }
193
- setValue(val) {
194
- if (val) {
195
- this.value = val;
196
- }
197
- }
198
- openAsPopup() {
199
- if (!this._calendarPortal) {
200
- this._calendarPortal = new ComponentPortal(DaterangepickerComponent, this._viewContainerRef);
201
- }
202
- if (!this._popupRef) {
203
- this._createPopup();
204
- }
205
- if (!this._popupRef.hasAttached()) {
206
- this._popupComponentRef = this._popupRef.attach(this._calendarPortal);
207
- this.initializeListeners(this._popupComponentRef.instance);
208
- if (this.value) {
209
- this.setValueInDateComponent(this._popupComponentRef.instance, this.value);
210
- }
211
- this._ngZone.onStable.asObservable().pipe(take(1)).subscribe(() => {
212
- this._popupRef.updatePosition();
213
- });
214
- }
215
- }
216
- _createPopup() {
217
- const overlayConfig = new OverlayConfig({
218
- positionStrategy: this._createPopupPositionStrategy(),
219
- hasBackdrop: true,
220
- backdropClass: 'mat-overlay-transparent-backdrop',
221
- direction: 'ltr',
222
- panelClass: 'o-daterangepicker-popup',
223
- scrollStrategy: this.scrollStrategy.close()
224
- });
225
- this._popupRef = this._overlay.create(overlayConfig);
226
- this._popupRef.overlayElement.setAttribute('role', 'dialog');
227
- merge(this._popupRef.backdropClick(), this._popupRef.detachments(), this._popupRef.keydownEvents().pipe(filter(event => {
228
- return event.keyCode === ESCAPE ||
229
- (this._el && event.altKey && event.keyCode === UP_ARROW);
230
- }))).subscribe(() => this.close());
231
- }
232
- _createPopupPositionStrategy() {
233
- return this._overlay.position()
234
- .flexibleConnectedTo(this._el)
235
- .withViewportMargin(8)
236
- .withPositions([
237
- {
238
- originX: 'start',
239
- originY: 'bottom',
240
- overlayX: 'start',
241
- overlayY: 'top'
242
- },
243
- {
244
- originX: 'start',
245
- originY: 'top',
246
- overlayX: 'start',
247
- overlayY: 'bottom'
248
- },
249
- {
250
- originX: 'end',
251
- originY: 'bottom',
252
- overlayX: 'end',
253
- overlayY: 'top'
254
- },
255
- {
256
- originX: 'end',
257
- originY: 'top',
258
- overlayX: 'end',
259
- overlayY: 'bottom'
260
- }
261
- ]);
262
- }
263
- openAsDialog() {
264
- if (this._dialogRef) {
265
- this._dialogRef.close();
266
- }
267
- this._dialogRef = this._dialog.open(DaterangepickerComponent, {
268
- direction: 'ltr',
269
- viewContainerRef: this._viewContainerRef,
270
- panelClass: 'mat-datepicker-dialog',
271
- });
272
- this.initializeListeners(this._dialogRef.componentInstance);
273
- if (this.value) {
274
- this.setValueInDateComponent(this._dialogRef.componentInstance, this.value);
275
- }
276
- this._dialogRef.afterClosed().subscribe(() => this.close());
277
- }
278
- close() {
279
- if (this._popupRef && this._popupRef.hasAttached()) {
280
- this._popupRef.detach();
281
- }
282
- if (this._dialogRef) {
283
- this._dialogRef.close();
284
- }
285
- if (this._calendarPortal && this._calendarPortal.isAttached) {
286
- this._calendarPortal.detach();
287
- }
288
- }
289
- }
290
- ODaterangepickerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ODaterangepickerDirective, deps: [{ token: i1.MatDialog }, { token: i0.NgZone }, { token: i2.Overlay }, { token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.KeyValueDiffers }, { token: i2.ScrollStrategyOptions }], target: i0.ɵɵFactoryTarget.Directive });
291
- ODaterangepickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: ODaterangepickerDirective, selector: "input[o-daterange-input]", inputs: { minDate: "minDate", maxDate: "maxDate", showCustomRangeLabel: "showCustomRangeLabel", linkedCalendars: "linkedCalendars", dateLimit: "dateLimit", singleDatePicker: "singleDatePicker", showWeekNumbers: "showWeekNumbers", showISOWeekNumbers: "showISOWeekNumbers", showDropdowns: "showDropdowns", isInvalidDate: "isInvalidDate", isCustomDate: "isCustomDate", opens: "opens", drops: "drops", lastMonthDayClass: "lastMonthDayClass", emptyWeekRowClass: "emptyWeekRowClass", firstDayOfNextMonthClass: "firstDayOfNextMonthClass", lastDayOfPreviousMonthClass: "lastDayOfPreviousMonthClass", keepCalendarOpeningWithRange: "keepCalendarOpeningWithRange", showRangeLabelOnInput: "showRangeLabelOnInput", showCancel: "showCancel", timePicker: "timePicker", showRanges: "showRanges", timePicker24Hour: "timePicker24Hour", timePickerIncrement: "timePickerIncrement", timePickerSeconds: "timePickerSeconds", separator: "separator", locale: "locale", _endKey: "_endKey", oTouchUi: "oTouchUi", startKey: "startKey", endKey: "endKey" }, outputs: { onChange: "onChange", rangeClicked: "rangeClicked", datesUpdated: "datesUpdated" }, host: { listeners: { "keyup.esc": "close()", "blur": "onBlur()" } }, providers: [
292
- {
293
- provide: NG_VALUE_ACCESSOR,
294
- useExisting: forwardRef(() => ODaterangepickerDirective), multi: true
295
- }
296
- ], ngImport: i0 });
297
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ODaterangepickerDirective, decorators: [{
298
- type: Directive,
299
- args: [{
300
- selector: 'input[o-daterange-input]',
301
- host: {
302
- '(keyup.esc)': 'close()',
303
- '(blur)': 'onBlur()'
304
- },
305
- providers: [
306
- {
307
- provide: NG_VALUE_ACCESSOR,
308
- useExisting: forwardRef(() => ODaterangepickerDirective), multi: true
309
- }
310
- ]
311
- }]
312
- }], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i0.NgZone }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.KeyValueDiffers }, { type: i2.ScrollStrategyOptions }]; }, propDecorators: { minDate: [{
313
- type: Input
314
- }], maxDate: [{
315
- type: Input
316
- }], showCustomRangeLabel: [{
317
- type: Input
318
- }], linkedCalendars: [{
319
- type: Input
320
- }], dateLimit: [{
321
- type: Input
322
- }], singleDatePicker: [{
323
- type: Input
324
- }], showWeekNumbers: [{
325
- type: Input
326
- }], showISOWeekNumbers: [{
327
- type: Input
328
- }], showDropdowns: [{
329
- type: Input
330
- }], isInvalidDate: [{
331
- type: Input
332
- }], isCustomDate: [{
333
- type: Input
334
- }], opens: [{
335
- type: Input
336
- }], drops: [{
337
- type: Input
338
- }], lastMonthDayClass: [{
339
- type: Input
340
- }], emptyWeekRowClass: [{
341
- type: Input
342
- }], firstDayOfNextMonthClass: [{
343
- type: Input
344
- }], lastDayOfPreviousMonthClass: [{
345
- type: Input
346
- }], keepCalendarOpeningWithRange: [{
347
- type: Input
348
- }], showRangeLabelOnInput: [{
349
- type: Input
350
- }], showCancel: [{
351
- type: Input
352
- }], timePicker: [{
353
- type: Input
354
- }], showRanges: [{
355
- type: Input
356
- }], timePicker24Hour: [{
357
- type: Input
358
- }], timePickerIncrement: [{
359
- type: Input
360
- }], timePickerSeconds: [{
361
- type: Input
362
- }], separator: [{
363
- type: Input
364
- }], locale: [{
365
- type: Input
366
- }], _endKey: [{
367
- type: Input
368
- }], oTouchUi: [{
369
- type: Input
370
- }], startKey: [{
371
- type: Input
372
- }], endKey: [{
373
- type: Input
374
- }], onChange: [{
375
- type: Output
376
- }], rangeClicked: [{
377
- type: Output
378
- }], datesUpdated: [{
379
- type: Output
380
- }] } });
381
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-daterange-input.directive.js","sourceRoot":"","sources":["../../../../../../projects/ontimize-web-ngx/src/lib/components/input/date-range/o-daterange-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ESCAPE, UP_ARROW } from '@angular/cdk/keycodes';\nimport { Overlay, OverlayConfig, OverlayRef, PositionStrategy, ScrollStrategyOptions } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ChangeDetectorRef, ComponentRef, Directive, ElementRef, EventEmitter, forwardRef, Input, KeyValueDiffer, KeyValueDiffers, NgZone, Output, ViewContainerRef, OnDestroy } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\nimport moment from 'moment'\nimport { merge } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DaterangepickerComponent } from './o-daterange-picker.component';\n\n@Directive({\n  selector: 'input[o-daterange-input]',\n  host: {\n    '(keyup.esc)': 'close()',\n    '(blur)': 'onBlur()'\n  },\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ODaterangepickerDirective), multi: true\n    }\n  ]\n})\nexport class ODaterangepickerDirective implements OnDestroy {\n\n  private _onChange = Function.prototype;\n  private _onTouched = Function.prototype;\n  public _validatorChange = Function.prototype;\n  private _value: any;\n\n  public localeDiffer: KeyValueDiffer<string, any>;\n\n  @Input()\n  minDate: moment.Moment = null;\n  @Input()\n  maxDate: moment.Moment = null;\n  @Input()\n  showCustomRangeLabel: boolean;\n  @Input()\n  linkedCalendars: boolean;\n  @Input()\n  dateLimit: number = null;\n  @Input()\n  singleDatePicker: boolean;\n  @Input()\n  showWeekNumbers: boolean;\n  @Input()\n  showISOWeekNumbers: boolean;\n  @Input()\n  showDropdowns: boolean;\n  @Input()\n  isInvalidDate: () => boolean;\n  @Input()\n  isCustomDate: () => boolean;\n  // @Input()\n  // showClearButton: boolean;\n\n\n  @Input()\n  opens: string;\n  @Input()\n  drops: string;\n  firstMonthDayClass: string;\n  @Input()\n  lastMonthDayClass: string;\n  @Input()\n  emptyWeekRowClass: string;\n  @Input()\n  firstDayOfNextMonthClass: string;\n  @Input()\n  lastDayOfPreviousMonthClass: string;\n  @Input()\n  keepCalendarOpeningWithRange: boolean;\n  @Input()\n  showRangeLabelOnInput: boolean;\n  @Input()\n  showCancel: boolean = false;\n  // timepicker variables\n  @Input()\n  timePicker: boolean = false;\n  @Input()\n  showRanges: boolean = false;\n  @Input()\n  timePicker24Hour: boolean = false;\n  @Input()\n  timePickerIncrement: number = 1;\n  @Input()\n  timePickerSeconds: boolean = false;\n  _locale: any;\n  _separator: string;\n\n  @Input() set separator(value) {\n    if (value !== null) {\n      this._separator = value;\n      if (this._locale) {\n        this._locale.separator = value;\n      }\n    }\n  }\n\n  @Input() set locale(value) {\n    if (value !== null) {\n      this._locale = value;\n      if (this._separator) {\n        this._locale.separator = this._separator;\n      }\n    }\n  }\n  get locale(): any {\n    return this._locale;\n  }\n\n  @Input()\n  private _endKey: string = 'endDate';\n  private _startKey: string = 'startDate';\n\n  public ranges: any = {\n    'DATERANGE.today': [moment(), moment()],\n    'DATERANGE.yesterday': [moment().subtract(1, 'days'), moment().subtract(1, 'days')],\n    'DATERANGE.last_7days': [moment().subtract(6, 'days'), moment()],\n    'DATERANGE.last_30days': [moment().subtract(29, 'days'), moment()],\n    'DATERANGE.this_month': [moment().startOf('month'), moment().endOf('month')],\n    'DATERANGE.last_month': [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')],\n    'DATERANGE.this_year': [moment().startOf('year'), moment().endOf('year')]\n  };\n\n  @Input()\n  oTouchUi: boolean = false;\n\n  @Input() set startKey(value) {\n    if (value && value !== null) {\n      this._startKey = value;\n    } else {\n      this._startKey = 'startDate';\n    }\n  }\n  get startKey(): string {\n    return this._startKey;\n  }\n  @Input() set endKey(value) {\n    if (value && value !== null) {\n      this._endKey = value;\n    } else {\n      this._endKey = 'endDate';\n    }\n  }\n  get endKey(): string {\n    return this._endKey;\n  }\n  notForChangesProperty: Array<string> = [\n    'locale',\n    'endKey',\n    'startKey'\n  ];\n\n  get value() {\n    return this._value || null;\n  }\n  set value(val) {\n    this._value = val;\n    this._onChange(val);\n    this._changeDetectorRef.markForCheck();\n  }\n  @Output() onChange: EventEmitter<object> = new EventEmitter();\n  @Output() rangeClicked: EventEmitter<object> = new EventEmitter();\n  @Output() datesUpdated: EventEmitter<object> = new EventEmitter();\n\n  private _popupComponentRef: ComponentRef<DaterangepickerComponent> | null;\n  private _calendarPortal: ComponentPortal<DaterangepickerComponent>;\n  _popupRef: OverlayRef;\n  private _dialogRef: MatDialogRef<DaterangepickerComponent> | null;\n\n  constructor(\n    private _dialog: MatDialog,\n    private _ngZone: NgZone,\n    private _overlay: Overlay,\n    public _viewContainerRef: ViewContainerRef,\n    public _changeDetectorRef: ChangeDetectorRef,\n    public _el: ElementRef,\n    private differs: KeyValueDiffers,\n    private scrollStrategy: ScrollStrategyOptions\n  ) {\n    this.drops = 'down';\n    this.opens = 'right';\n  }\n\n  initializeListeners(instance) {\n    instance.rangeClicked.asObservable().subscribe((range: any) => {\n      this.rangeClicked.emit(range);\n    });\n    instance.datesUpdated.asObservable().subscribe((range: any) => {\n      this.datesUpdated.emit(range);\n    });\n    instance.choosedDate.asObservable().subscribe((change: any) => {\n      if (change) {\n        const value = {};\n        value[this._startKey] = change.startDate;\n        value[this._endKey] = change.endDate;\n        this.value = value;\n        this.onChange.emit(value);\n        if (typeof change.chosenLabel === 'string') {\n          this._el.nativeElement.value = change.chosenLabel;\n        }\n      }\n    });\n    instance.firstMonthDayClass = this.firstMonthDayClass;\n    instance.lastMonthDayClass = this.lastMonthDayClass;\n    instance.emptyWeekRowClass = this.emptyWeekRowClass;\n    instance.firstDayOfNextMonthClass = this.firstDayOfNextMonthClass;\n    instance.lastDayOfPreviousMonthClass = this.lastDayOfPreviousMonthClass;\n    instance.drops = this.drops;\n    instance.opens = this.opens;\n    instance.minDate = this.minDate;\n    instance.maxDate = this.maxDate;\n    instance.locale = this.locale;\n    instance.showWeekNumbers = this.showWeekNumbers;\n    instance.singleDatePicker = this.singleDatePicker;\n\n    if (this.showRanges) {\n      instance.ranges = this.ranges;\n      instance.keepCalendarOpeningWithRange = true;\n      instance.alwaysShowCalendars = true;\n    }\n    this.localeDiffer = this.differs.find(this.locale).create();\n  }\n\n  // ngOnChanges(changes: SimpleChanges): void  {\n  //   for (let change in changes) {\n  //     if (changes.hasOwnProperty(change)) {\n  //       if (this.notForChangesProperty.indexOf(change) === -1) {\n  //         this.picker[change] = changes[change].currentValue;\n  //       }\n  //     }\n  //   }\n  // }\n\n  // ngDoCheck() {\n  //   if (this.localeDiffer) {\n  //     const changes = this.localeDiffer.diff(this.locale);\n  //     if (changes) {\n  //       this.picker.updateLocale(this.locale);\n  //     }\n  //   }\n  // }\n\n  onBlur() {\n    this._onTouched();\n  }\n\n  open() {\n    if (!this.oTouchUi) {\n      this.openAsPopup();\n\n    } else {\n      this.openAsDialog();\n    }\n  }\n\n  ngOnDestroy() {\n    this.close();\n\n    if (this._popupRef) {\n      this._popupRef.dispose();\n      this._popupComponentRef = null;\n    }\n  }\n\n  clear() {\n    this._popupComponentRef.instance.clear();\n  }\n\n  writeValue(value) {\n    this.setValue(value);\n  }\n  registerOnChange(fn) {\n    this._onChange = fn;\n  }\n  registerOnTouched(fn) {\n    this._onTouched = fn;\n  }\n\n  setValueInDateComponent(instance, val) {\n    if (val) {\n      if (val[this._startKey]) {\n        instance.setStartDate(val[this._startKey]);\n      }\n      if (val[this._endKey]) {\n        instance.setEndDate(val[this._endKey]);\n      }\n      instance.calculateChosenLabel();\n      if (instance.chosenLabel) {\n        this._el.nativeElement.value = instance.chosenLabel;\n      }\n    } else {\n      instance.clear();\n    }\n\n  }\n  private setValue(val: any) {\n    if (val) {\n      this.value = val;\n\n    }\n  }\n  /**\n   * Set position of the calendar\n   */\n  // setPosition() {\n  //   let style;\n  //   let containerTop;\n  //   const container = this.picker.pickerContainer.nativeElement;\n  //   const element = this._el.nativeElement;\n  //   if (this.drops && this.drops == 'up') {\n  //     containerTop = (element.offsetTop - container.clientHeight) + 'px';\n  //   } else {\n  //     containerTop = 'auto';\n  //   }\n  //   if (this.opens == 'left') {\n  //     style = {\n  //         top: containerTop,\n  //         left: (element.offsetLeft - container.clientWidth + element.clientWidth) + 'px',\n  //         right: 'auto'\n  //     };\n  //   } else if (this.opens == 'center') {\n  //       style = {\n  //         top: containerTop,\n  //         left: (element.offsetLeft  +  element.clientWidth / 2\n  //                 - container.clientWidth / 2) + 'px',\n  //         right: 'auto'\n  //       };\n  //   } else {\n  //       style = {\n  //         top: containerTop,\n  //         left: element.offsetLeft  + 'px',\n  //         right: 'auto'\n  //       }\n  //   }\n  //   if (style) {\n  //     this._renderer.setStyle(container, 'top', style.top);\n  //     this._renderer.setStyle(container, 'left', style.left);\n  //     this._renderer.setStyle(container, 'right', style.right);\n  //     this._renderer.setStyle(container, 'position', 'fixed');\n  //   }\n  // }\n  /**\n   * For click outside of the calendar's container\n   * @param event event object\n   * @param targetElement target element object\n   */\n  // @HostListener('document:click', ['$event', '$event.target'])\n  // outsideClick(event, targetElement: HTMLElement): void {\n  //     if (!targetElement) {\n  //       return;\n  //     }\n  //     if (targetElement.classList.contains('ngx-daterangepicker-action')) {\n  //       return;\n  //     }\n  //     const clickedInside = this._el.nativeElement.contains(targetElement);\n  //     if (!clickedInside) {\n  //        this.hide()\n  //     }\n  // }\n\n\n\n  /** */\n  public openAsPopup(): void {\n    if (!this._calendarPortal) {\n      this._calendarPortal = new ComponentPortal<DaterangepickerComponent>(DaterangepickerComponent,\n        this._viewContainerRef);\n    }\n\n    if (!this._popupRef) {\n      this._createPopup();\n    }\n\n\n    if (!this._popupRef.hasAttached()) {\n      this._popupComponentRef = this._popupRef.attach(this._calendarPortal);\n      this.initializeListeners(this._popupComponentRef.instance);\n      if (this.value) {\n        this.setValueInDateComponent(this._popupComponentRef.instance, this.value);\n      }\n\n      // Update the position once the calendar has rendered.\n      this._ngZone.onStable.asObservable().pipe(take(1)).subscribe(() => {\n        this._popupRef.updatePosition();\n      });\n    }\n  }\n  /** Create the popup. */\n  private _createPopup(): void {\n    const overlayConfig = new OverlayConfig({\n      positionStrategy: this._createPopupPositionStrategy(),\n      hasBackdrop: true,\n      backdropClass: 'mat-overlay-transparent-backdrop',\n      direction: 'ltr',\n      panelClass: 'o-daterangepicker-popup',\n      scrollStrategy: this.scrollStrategy.close()\n    });\n\n    this._popupRef = this._overlay.create(overlayConfig);\n    this._popupRef.overlayElement.setAttribute('role', 'dialog');\n\n    merge(\n      this._popupRef.backdropClick(),\n      this._popupRef.detachments(),\n      this._popupRef.keydownEvents().pipe(filter(event => {\n        // Closing on alt + up is only valid when there's an input associated with the datepicker.\n        return event.keyCode === ESCAPE ||\n          (this._el && event.altKey && event.keyCode === UP_ARROW);\n      }))\n    ).subscribe(() => this.close());\n  }\n\n  private _createPopupPositionStrategy(): PositionStrategy {\n    return this._overlay.position()\n      .flexibleConnectedTo(this._el)\n      // .withTransformOriginOn('.mat-datepicker-content')\n      // .withFlexibleDimensions(false)\n      .withViewportMargin(8)\n      // .withLockedPosition()\n      .withPositions([\n        {\n          originX: 'start',\n          originY: 'bottom',\n          overlayX: 'start',\n          overlayY: 'top'\n        },\n        {\n          originX: 'start',\n          originY: 'top',\n          overlayX: 'start',\n          overlayY: 'bottom'\n        },\n        {\n          originX: 'end',\n          originY: 'bottom',\n          overlayX: 'end',\n          overlayY: 'top'\n        },\n        {\n          originX: 'end',\n          originY: 'top',\n          overlayX: 'end',\n          overlayY: 'bottom'\n        }\n      ]);\n  }\n\n\n  /** Open the calendar as a dialog. */\n  public openAsDialog(): void {\n    // Usually this would be handled by `open` which ensures that we can only have one overlay\n    // open at a time, however since we reset the variables in async handlers some overlays\n    // may slip through if the user opens and closes multiple times in quick succession (e.g.\n    // by holding down the enter key).\n    if (this._dialogRef) {\n      this._dialogRef.close();\n    }\n\n    this._dialogRef = this._dialog.open<DaterangepickerComponent>(DaterangepickerComponent, {\n      direction: 'ltr',\n      viewContainerRef: this._viewContainerRef,\n      panelClass: 'mat-datepicker-dialog',\n    });\n\n    this.initializeListeners(this._dialogRef.componentInstance);\n    if (this.value) {\n      this.setValueInDateComponent(this._dialogRef.componentInstance, this.value);\n    }\n    this._dialogRef.afterClosed().subscribe(() => this.close());\n    // this._dialogRef.componentInstance. = this;\n\n  }\n\n  close(): void {\n    if (this._popupRef && this._popupRef.hasAttached()) {\n      this._popupRef.detach();\n    }\n\n    if (this._dialogRef) {\n      this._dialogRef.close();\n    }\n\n    if (this._calendarPortal && this._calendarPortal.isAttached) {\n      this._calendarPortal.detach();\n    }\n  }\n}\n"]}