@openmrs/ngx-formentry 4.0.1-pre.323 → 4.0.1-pre.329

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 (140) hide show
  1. package/components/afe-ng-select.component.d.ts +1 -1
  2. package/components/appointments-overview/appointments-overview.component.d.ts +1 -1
  3. package/components/check-box/checkbox.component.d.ts +1 -1
  4. package/components/custom-component-wrapper/custom-component-wrapper.component.d.ts +1 -1
  5. package/components/custom-control-wrapper/custom-control-wrapper.component.d.ts +1 -1
  6. package/components/date-time-picker/date-picker/date-picker.component.d.ts +1 -1
  7. package/components/date-time-picker/date-time-picker.component.d.ts +1 -1
  8. package/components/date-time-picker/picker-modal/modal.component.d.ts +1 -1
  9. package/components/date-time-picker/time-picker/time-picker.component.d.ts +1 -1
  10. package/components/file-upload/file-upload.component.d.ts +1 -1
  11. package/components/input/input.directive.d.ts +1 -1
  12. package/components/input/label.component.d.ts +1 -1
  13. package/components/input/text-area.directive.d.ts +1 -1
  14. package/components/ngx-datetime-picker/ngx-datetime-picker.component.d.ts +1 -1
  15. package/components/ngx-pick-datetime/lib/date-time/calendar-body.component.d.ts +1 -1
  16. package/components/ngx-pick-datetime/lib/date-time/calendar-month-view.component.d.ts +1 -1
  17. package/components/ngx-pick-datetime/lib/date-time/calendar-multi-year-view.component.d.ts +1 -1
  18. package/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.d.ts +1 -1
  19. package/components/ngx-pick-datetime/lib/date-time/calendar.component.d.ts +1 -1
  20. package/components/ngx-pick-datetime/lib/date-time/date-time-inline.component.d.ts +1 -1
  21. package/components/ngx-pick-datetime/lib/date-time/date-time-picker-container.component.d.ts +1 -1
  22. package/components/ngx-pick-datetime/lib/date-time/date-time-picker-input.directive.d.ts +1 -1
  23. package/components/ngx-pick-datetime/lib/date-time/date-time-picker-trigger.directive.d.ts +1 -1
  24. package/components/ngx-pick-datetime/lib/date-time/date-time-picker.component.d.ts +1 -1
  25. package/components/ngx-pick-datetime/lib/date-time/date-time.class.d.ts +3 -3
  26. package/components/ngx-pick-datetime/lib/date-time/timer-box.component.d.ts +1 -1
  27. package/components/ngx-pick-datetime/lib/date-time/timer.component.d.ts +1 -1
  28. package/components/ngx-pick-datetime/lib/dialog/dialog-container.component.d.ts +1 -1
  29. package/components/ngx-remote-select/ngx-remote-select.component.d.ts +1 -1
  30. package/components/ngx-tabset/components/ngx-tab-set.component.d.ts +1 -1
  31. package/components/ngx-tabset/components/tab.component.d.ts +1 -1
  32. package/components/ngx-tabset/directives/hover-class.directive.d.ts +1 -1
  33. package/components/number-input/number-input.component.d.ts +1 -1
  34. package/components/number-input/number.directive.d.ts +1 -1
  35. package/components/radio-button/radio.component.d.ts +1 -1
  36. package/components/select/optgroup.directive.d.ts +1 -1
  37. package/components/select/option.directive.d.ts +1 -1
  38. package/components/select/select.component.d.ts +1 -1
  39. package/components/workspace-launcher/workspace-launcher.component.d.ts +1 -1
  40. package/esm2020/components/afe-ng-select.component.mjs +4 -4
  41. package/esm2020/components/appointments-overview/appointments-overview.component.mjs +4 -4
  42. package/esm2020/components/check-box/checkbox.component.mjs +4 -4
  43. package/esm2020/components/check-box/checkbox.module.mjs +5 -5
  44. package/esm2020/components/custom-component-wrapper/custom-component-wrapper..module.mjs +5 -5
  45. package/esm2020/components/custom-component-wrapper/custom-component-wrapper.component.mjs +4 -4
  46. package/esm2020/components/custom-control-wrapper/custom-control-wrapper..module.mjs +5 -5
  47. package/esm2020/components/custom-control-wrapper/custom-control-wrapper.component.mjs +4 -4
  48. package/esm2020/components/date-time-picker/date-picker/date-picker.component.mjs +4 -4
  49. package/esm2020/components/date-time-picker/date-time-picker.component.mjs +4 -4
  50. package/esm2020/components/date-time-picker/date-time-picker.module.mjs +5 -5
  51. package/esm2020/components/date-time-picker/picker-modal/modal.component.mjs +4 -4
  52. package/esm2020/components/date-time-picker/pipes/moment.pipe.mjs +4 -4
  53. package/esm2020/components/date-time-picker/time-picker/time-picker.component.mjs +4 -4
  54. package/esm2020/components/file-upload/file-upload.component.mjs +10 -10
  55. package/esm2020/components/file-upload/file-upload.module.mjs +5 -5
  56. package/esm2020/components/file-upload/secure.pipe.mjs +4 -4
  57. package/esm2020/components/input/input.directive.mjs +4 -4
  58. package/esm2020/components/input/input.module.mjs +5 -5
  59. package/esm2020/components/input/label.component.mjs +4 -4
  60. package/esm2020/components/input/text-area.directive.mjs +4 -4
  61. package/esm2020/components/ngx-datetime-picker/ngx-datetime-picker.component.mjs +4 -4
  62. package/esm2020/components/ngx-datetime-picker/ngx-datetime-picker.module.mjs +5 -5
  63. package/esm2020/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time-adapter.class.mjs +4 -4
  64. package/esm2020/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time.module.mjs +9 -9
  65. package/esm2020/components/ngx-pick-datetime/lib/date-time/calendar-body.component.mjs +12 -12
  66. package/esm2020/components/ngx-pick-datetime/lib/date-time/calendar-month-view.component.mjs +40 -40
  67. package/esm2020/components/ngx-pick-datetime/lib/date-time/calendar-multi-year-view.component.mjs +27 -27
  68. package/esm2020/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.mjs +34 -34
  69. package/esm2020/components/ngx-pick-datetime/lib/date-time/calendar.component.mjs +55 -55
  70. package/esm2020/components/ngx-pick-datetime/lib/date-time/date-time-inline.component.mjs +33 -33
  71. package/esm2020/components/ngx-pick-datetime/lib/date-time/date-time-picker-container.component.mjs +20 -20
  72. package/esm2020/components/ngx-pick-datetime/lib/date-time/date-time-picker-input.directive.mjs +141 -141
  73. package/esm2020/components/ngx-pick-datetime/lib/date-time/date-time-picker-intl.service.mjs +4 -4
  74. package/esm2020/components/ngx-pick-datetime/lib/date-time/date-time-picker-trigger.directive.mjs +8 -8
  75. package/esm2020/components/ngx-pick-datetime/lib/date-time/date-time-picker.component.mjs +66 -66
  76. package/esm2020/components/ngx-pick-datetime/lib/date-time/date-time.class.mjs +62 -62
  77. package/esm2020/components/ngx-pick-datetime/lib/date-time/date-time.module.mjs +5 -5
  78. package/esm2020/components/ngx-pick-datetime/lib/date-time/numberedFixLen.pipe.mjs +4 -4
  79. package/esm2020/components/ngx-pick-datetime/lib/date-time/timer-box.component.mjs +10 -10
  80. package/esm2020/components/ngx-pick-datetime/lib/date-time/timer.component.mjs +25 -25
  81. package/esm2020/components/ngx-pick-datetime/lib/dialog/dialog-container.component.mjs +28 -28
  82. package/esm2020/components/ngx-pick-datetime/lib/dialog/dialog.module.mjs +5 -5
  83. package/esm2020/components/ngx-pick-datetime/lib/dialog/dialog.service.mjs +20 -20
  84. package/esm2020/components/ngx-remote-select/ngx-remote-select.component.mjs +13 -13
  85. package/esm2020/components/ngx-remote-select/ngx-remote-select.module.mjs +5 -5
  86. package/esm2020/components/ngx-tabset/components/ngx-tab-set.component.mjs +4 -4
  87. package/esm2020/components/ngx-tabset/components/tab.component.mjs +4 -4
  88. package/esm2020/components/ngx-tabset/directives/hover-class.directive.mjs +4 -4
  89. package/esm2020/components/ngx-tabset/modules/ngx-tabset.module.mjs +5 -5
  90. package/esm2020/components/number-input/number-input.component.mjs +17 -17
  91. package/esm2020/components/number-input/number-input.module.mjs +5 -5
  92. package/esm2020/components/number-input/number.directive.mjs +4 -4
  93. package/esm2020/components/radio-button/radio.component.mjs +4 -4
  94. package/esm2020/components/radio-button/radio.module.mjs +5 -5
  95. package/esm2020/components/select/optgroup.directive.mjs +4 -4
  96. package/esm2020/components/select/option.directive.mjs +4 -4
  97. package/esm2020/components/select/select.component.mjs +4 -4
  98. package/esm2020/components/select/select.module.mjs +5 -5
  99. package/esm2020/components/workspace-launcher/workspace-launcher.component.mjs +4 -4
  100. package/esm2020/components/workspace-launcher/workspace-launcher.module.mjs +5 -5
  101. package/esm2020/form-entry/data-sources/data-sources.mjs +4 -4
  102. package/esm2020/form-entry/directives/collapse.directive.mjs +27 -27
  103. package/esm2020/form-entry/directives/historical-value.directive.mjs +4 -4
  104. package/esm2020/form-entry/error-renderer/error-renderer.component.mjs +4 -4
  105. package/esm2020/form-entry/expression-runner/expression-runner.mjs +4 -4
  106. package/esm2020/form-entry/form-entry.module.mjs +5 -5
  107. package/esm2020/form-entry/form-factory/control-relations.factory.mjs +4 -4
  108. package/esm2020/form-entry/form-factory/form-control.service.mjs +4 -4
  109. package/esm2020/form-entry/form-factory/form.factory.mjs +4 -4
  110. package/esm2020/form-entry/form-factory/hiders-disablers.factory.mjs +4 -4
  111. package/esm2020/form-entry/form-factory/question.factory.mjs +14 -4
  112. package/esm2020/form-entry/form-factory/show-messages.factory.mjs +4 -4
  113. package/esm2020/form-entry/form-factory/validation.factory.mjs +4 -4
  114. package/esm2020/form-entry/form-renderer/form-renderer.component.mjs +4 -4
  115. package/esm2020/form-entry/helpers/historical-expression-helper-service.mjs +4 -4
  116. package/esm2020/form-entry/helpers/historical-field-helper-service.mjs +4 -4
  117. package/esm2020/form-entry/helpers/js-expression-helper.mjs +4 -4
  118. package/esm2020/form-entry/pipes/time-ago.pipe.mjs +4 -4
  119. package/esm2020/form-entry/services/debug-mode.service.mjs +4 -4
  120. package/esm2020/form-entry/services/form-errors.service.mjs +4 -4
  121. package/esm2020/form-entry/services/form-schema-compiler.service.mjs +4 -4
  122. package/esm2020/form-entry/services/historical-encounter-data.service.mjs +4 -4
  123. package/esm2020/form-entry/value-adapters/diagnosis.adapter.mjs +4 -4
  124. package/esm2020/form-entry/value-adapters/encounter.adapter.mjs +4 -4
  125. package/esm2020/form-entry/value-adapters/obs-adapter-helper.mjs +4 -4
  126. package/esm2020/form-entry/value-adapters/obs.adapter.mjs +4 -4
  127. package/esm2020/form-entry/value-adapters/order.adapter.mjs +4 -4
  128. package/esm2020/form-entry/value-adapters/patient-identifier.adapter.mjs +4 -4
  129. package/esm2020/form-entry/value-adapters/person-attribute.adapter.mjs +4 -4
  130. package/esm2020/shared.module.mjs +5 -5
  131. package/fesm2015/openmrs-ngx-formentry.mjs +879 -869
  132. package/fesm2015/openmrs-ngx-formentry.mjs.map +1 -1
  133. package/fesm2020/openmrs-ngx-formentry.mjs +898 -888
  134. package/fesm2020/openmrs-ngx-formentry.mjs.map +1 -1
  135. package/form-entry/directives/collapse.directive.d.ts +1 -1
  136. package/form-entry/directives/historical-value.directive.d.ts +1 -1
  137. package/form-entry/error-renderer/error-renderer.component.d.ts +1 -1
  138. package/form-entry/form-factory/form-node.d.ts +1 -1
  139. package/form-entry/form-renderer/form-renderer.component.d.ts +1 -1
  140. package/package.json +1 -1
@@ -10,36 +10,6 @@ import * as i2 from "./calendar-body.component";
10
10
  const MONTHS_PER_YEAR = 12;
11
11
  const MONTHS_PER_ROW = 3;
12
12
  export class OwlYearViewComponent {
13
- constructor(cdRef, dateTimeAdapter, dateTimeFormats) {
14
- this.cdRef = cdRef;
15
- this.dateTimeAdapter = dateTimeAdapter;
16
- this.dateTimeFormats = dateTimeFormats;
17
- /**
18
- * The select mode of the picker;
19
- * */
20
- this._selectMode = 'single';
21
- this._selecteds = [];
22
- this.localeSub = Subscription.EMPTY;
23
- this.initiated = false;
24
- /**
25
- * An array to hold all selectedDates' month value
26
- * the value is the month number in current year
27
- * */
28
- this.selectedMonths = [];
29
- /**
30
- * Callback to invoke when a new month is selected
31
- * */
32
- this.monthChange = new EventEmitter();
33
- /**
34
- * Emits the selected year. This doesn't imply a change on the selected date
35
- * */
36
- this.monthSelected = new EventEmitter();
37
- /** Emits when any date is activated. */
38
- this.pickerMomentChange = new EventEmitter();
39
- /** Emits when use keyboard enter to select a calendar cell */
40
- this.keyboardEnter = new EventEmitter();
41
- this.monthNames = this.dateTimeAdapter.getMonthNames('short');
42
- }
43
13
  get owlDTCalendarView() {
44
14
  return true;
45
15
  }
@@ -128,6 +98,36 @@ export class OwlYearViewComponent {
128
98
  this.selectMode === 'rangeFrom' ||
129
99
  this.selectMode === 'rangeTo');
130
100
  }
101
+ constructor(cdRef, dateTimeAdapter, dateTimeFormats) {
102
+ this.cdRef = cdRef;
103
+ this.dateTimeAdapter = dateTimeAdapter;
104
+ this.dateTimeFormats = dateTimeFormats;
105
+ /**
106
+ * The select mode of the picker;
107
+ * */
108
+ this._selectMode = 'single';
109
+ this._selecteds = [];
110
+ this.localeSub = Subscription.EMPTY;
111
+ this.initiated = false;
112
+ /**
113
+ * An array to hold all selectedDates' month value
114
+ * the value is the month number in current year
115
+ * */
116
+ this.selectedMonths = [];
117
+ /**
118
+ * Callback to invoke when a new month is selected
119
+ * */
120
+ this.monthChange = new EventEmitter();
121
+ /**
122
+ * Emits the selected year. This doesn't imply a change on the selected date
123
+ * */
124
+ this.monthSelected = new EventEmitter();
125
+ /** Emits when any date is activated. */
126
+ this.pickerMomentChange = new EventEmitter();
127
+ /** Emits when use keyboard enter to select a calendar cell */
128
+ this.keyboardEnter = new EventEmitter();
129
+ this.monthNames = this.dateTimeAdapter.getMonthNames('short');
130
+ }
131
131
  ngOnInit() {
132
132
  this.localeSub = this.dateTimeAdapter.localeChanges.subscribe(() => {
133
133
  this.generateMonthList();
@@ -323,9 +323,9 @@ export class OwlYearViewComponent {
323
323
  this.calendarBodyElm.focusActiveCell();
324
324
  }
325
325
  }
326
- OwlYearViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: OwlYearViewComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DateTimeAdapter, optional: true }, { token: OWL_DATE_TIME_FORMATS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
327
- OwlYearViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: OwlYearViewComponent, selector: "ofe-owl-date-time-year-view", inputs: { selectMode: "selectMode", selected: "selected", selecteds: "selecteds", pickerMoment: "pickerMoment", dateFilter: "dateFilter", minDate: "minDate", maxDate: "maxDate" }, outputs: { monthChange: "monthChange", monthSelected: "monthSelected", pickerMomentChange: "pickerMomentChange", keyboardEnter: "keyboardEnter" }, host: { properties: { "class.owl-dt-calendar-view": "this.owlDTCalendarView" } }, viewQueries: [{ propertyName: "calendarBodyElm", first: true, predicate: OwlCalendarBodyComponent, descendants: true, static: true }], exportAs: ["owlMonthView"], ngImport: i0, template: "<table class=\"owl-dt-calendar-table owl-dt-calendar-year-table\">\n <thead class=\"owl-dt-calendar-header\">\n <tr>\n <th\n class=\"owl-dt-calendar-table-divider\"\n aria-hidden=\"true\"\n colspan=\"3\"\n ></th>\n </tr>\n </thead>\n <tbody\n ofe-owl-date-time-calendar-body\n role=\"grid\"\n [rows]=\"months\"\n [numCols]=\"3\"\n [cellRatio]=\"3 / 7\"\n [activeCell]=\"activeCell\"\n [todayValue]=\"todayMonth\"\n [selectedValues]=\"selectedMonths\"\n [selectMode]=\"selectMode\"\n (keydown)=\"handleCalendarKeydown($event)\"\n (cellSelected)=\"selectCalendarCell($event)\"\n ></tbody>\n</table>\n", styles: [""], dependencies: [{ kind: "component", type: i2.OwlCalendarBodyComponent, selector: "[ofe-owl-date-time-calendar-body]", inputs: ["activeCell", "rows", "numCols", "cellRatio", "todayValue", "selectedValues", "selectMode"], outputs: ["cellSelected"], exportAs: ["owlDateTimeCalendarBody"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
328
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: OwlYearViewComponent, decorators: [{
326
+ OwlYearViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OwlYearViewComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DateTimeAdapter, optional: true }, { token: OWL_DATE_TIME_FORMATS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
327
+ OwlYearViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OwlYearViewComponent, selector: "ofe-owl-date-time-year-view", inputs: { selectMode: "selectMode", selected: "selected", selecteds: "selecteds", pickerMoment: "pickerMoment", dateFilter: "dateFilter", minDate: "minDate", maxDate: "maxDate" }, outputs: { monthChange: "monthChange", monthSelected: "monthSelected", pickerMomentChange: "pickerMomentChange", keyboardEnter: "keyboardEnter" }, host: { properties: { "class.owl-dt-calendar-view": "this.owlDTCalendarView" } }, viewQueries: [{ propertyName: "calendarBodyElm", first: true, predicate: OwlCalendarBodyComponent, descendants: true, static: true }], exportAs: ["owlMonthView"], ngImport: i0, template: "<table class=\"owl-dt-calendar-table owl-dt-calendar-year-table\">\n <thead class=\"owl-dt-calendar-header\">\n <tr>\n <th\n class=\"owl-dt-calendar-table-divider\"\n aria-hidden=\"true\"\n colspan=\"3\"\n ></th>\n </tr>\n </thead>\n <tbody\n ofe-owl-date-time-calendar-body\n role=\"grid\"\n [rows]=\"months\"\n [numCols]=\"3\"\n [cellRatio]=\"3 / 7\"\n [activeCell]=\"activeCell\"\n [todayValue]=\"todayMonth\"\n [selectedValues]=\"selectedMonths\"\n [selectMode]=\"selectMode\"\n (keydown)=\"handleCalendarKeydown($event)\"\n (cellSelected)=\"selectCalendarCell($event)\"\n ></tbody>\n</table>\n", styles: [""], dependencies: [{ kind: "component", type: i2.OwlCalendarBodyComponent, selector: "[ofe-owl-date-time-calendar-body]", inputs: ["activeCell", "rows", "numCols", "cellRatio", "todayValue", "selectedValues", "selectMode"], outputs: ["cellSelected"], exportAs: ["owlDateTimeCalendarBody"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
328
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OwlYearViewComponent, decorators: [{
329
329
  type: Component,
330
330
  args: [{ selector: 'ofe-owl-date-time-year-view', exportAs: 'owlMonthView', changeDetection: ChangeDetectionStrategy.OnPush, template: "<table class=\"owl-dt-calendar-table owl-dt-calendar-year-table\">\n <thead class=\"owl-dt-calendar-header\">\n <tr>\n <th\n class=\"owl-dt-calendar-table-divider\"\n aria-hidden=\"true\"\n colspan=\"3\"\n ></th>\n </tr>\n </thead>\n <tbody\n ofe-owl-date-time-calendar-body\n role=\"grid\"\n [rows]=\"months\"\n [numCols]=\"3\"\n [cellRatio]=\"3 / 7\"\n [activeCell]=\"activeCell\"\n [todayValue]=\"todayMonth\"\n [selectedValues]=\"selectedMonths\"\n [selectMode]=\"selectMode\"\n (keydown)=\"handleCalendarKeydown($event)\"\n (cellSelected)=\"selectCalendarCell($event)\"\n ></tbody>\n</table>\n" }]
331
331
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DateTimeAdapter, decorators: [{
@@ -364,4 +364,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
364
364
  type: ViewChild,
365
365
  args: [OwlCalendarBodyComponent, { static: true }]
366
366
  }] } });
367
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-year-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.ts","../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {\n  CalendarCell,\n  OwlCalendarBodyComponent\n} from './calendar-body.component';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport {\n  OWL_DATE_TIME_FORMATS,\n  OwlDateTimeFormats\n} from './adapter/date-time-format.class';\nimport { Subscription } from 'rxjs';\nimport { SelectMode } from './date-time.class';\nimport {\n  DOWN_ARROW,\n  END,\n  ENTER,\n  HOME,\n  LEFT_ARROW,\n  PAGE_DOWN,\n  PAGE_UP,\n  RIGHT_ARROW,\n  UP_ARROW\n} from '@angular/cdk/keycodes';\n\nconst MONTHS_PER_YEAR = 12;\nconst MONTHS_PER_ROW = 3;\n\n@Component({\n  selector: 'ofe-owl-date-time-year-view',\n  exportAs: 'owlMonthView',\n  templateUrl: './calendar-year-view.component.html',\n  styleUrls: ['./calendar-year-view.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OwlYearViewComponent<T>\n  implements OnInit, AfterContentInit, OnDestroy {\n  @HostBinding('class.owl-dt-calendar-view') get owlDTCalendarView() {\n    return true;\n  }\n\n  /**\n   * The select mode of the picker;\n   * */\n  private _selectMode: SelectMode = 'single';\n  @Input()\n  get selectMode(): SelectMode {\n    return this._selectMode;\n  }\n\n  set selectMode(val: SelectMode) {\n    this._selectMode = val;\n    if (this.initiated) {\n      this.generateMonthList();\n      this.cdRef.markForCheck();\n    }\n  }\n\n  /** The currently selected date. */\n  private _selected: T | null;\n  @Input()\n  get selected(): T | null {\n    return this._selected;\n  }\n\n  set selected(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._selected = this.getValidDate(value);\n    this.setSelectedMonths();\n  }\n\n  private _selecteds: T[] = [];\n  @Input()\n  get selecteds(): T[] {\n    return this._selecteds;\n  }\n\n  set selecteds(values: T[]) {\n    this._selecteds = [];\n    for (let i = 0; i < values.length; i++) {\n      const value = this.dateTimeAdapter.deserialize(values[i]);\n      this._selecteds.push(this.getValidDate(value));\n    }\n\n    this.setSelectedMonths();\n  }\n\n  private _pickerMoment: T | null;\n  @Input()\n  get pickerMoment() {\n    return this._pickerMoment;\n  }\n\n  set pickerMoment(value: T) {\n    const oldMoment = this._pickerMoment;\n    value = this.dateTimeAdapter.deserialize(value);\n    this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();\n\n    if (!this.hasSameYear(oldMoment, this._pickerMoment) && this.initiated) {\n      this.generateMonthList();\n    }\n  }\n\n  /**\n   * A function used to filter which dates are selectable\n   * */\n  private _dateFilter: (date: T) => boolean;\n  @Input()\n  get dateFilter() {\n    return this._dateFilter;\n  }\n\n  set dateFilter(filter: (date: T) => boolean) {\n    this._dateFilter = filter;\n    if (this.initiated) {\n      this.generateMonthList();\n    }\n  }\n\n  /** The minimum selectable date. */\n  private _minDate: T | null;\n  @Input()\n  get minDate(): T | null {\n    return this._minDate;\n  }\n\n  set minDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._minDate = this.getValidDate(value);\n    if (this.initiated) {\n      this.generateMonthList();\n    }\n  }\n\n  /** The maximum selectable date. */\n  private _maxDate: T | null;\n  @Input()\n  get maxDate(): T | null {\n    return this._maxDate;\n  }\n\n  set maxDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._maxDate = this.getValidDate(value);\n    if (this.initiated) {\n      this.generateMonthList();\n    }\n  }\n\n  private readonly monthNames: string[];\n\n  private _months: CalendarCell[][];\n  get months() {\n    return this._months;\n  }\n\n  get activeCell(): number {\n    if (this._pickerMoment) {\n      return this.dateTimeAdapter.getMonth(this._pickerMoment);\n    }\n  }\n\n  get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  get isInRangeMode(): boolean {\n    return (\n      this.selectMode === 'range' ||\n      this.selectMode === 'rangeFrom' ||\n      this.selectMode === 'rangeTo'\n    );\n  }\n\n  private localeSub: Subscription = Subscription.EMPTY;\n\n  private initiated = false;\n\n  public todayMonth: number | null;\n\n  /**\n   * An array to hold all selectedDates' month value\n   * the value is the month number in current year\n   * */\n  public selectedMonths: number[] = [];\n\n  /**\n   * Callback to invoke when a new month is selected\n   * */\n  @Output()\n  readonly monthChange = new EventEmitter<T>();\n\n  /**\n   * Emits the selected year. This doesn't imply a change on the selected date\n   * */\n  @Output()\n  readonly monthSelected = new EventEmitter<T>();\n\n  /** Emits when any date is activated. */\n  @Output()\n  readonly pickerMomentChange: EventEmitter<T> = new EventEmitter<T>();\n\n  /** Emits when use keyboard enter to select a calendar cell */\n  @Output()\n  readonly keyboardEnter: EventEmitter<any> = new EventEmitter<any>();\n\n  /** The body of calendar table */\n  @ViewChild(OwlCalendarBodyComponent, { static: true })\n  calendarBodyElm: OwlCalendarBodyComponent;\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    @Optional() private dateTimeAdapter: DateTimeAdapter<T>,\n    @Optional()\n    @Inject(OWL_DATE_TIME_FORMATS)\n    private dateTimeFormats: OwlDateTimeFormats\n  ) {\n    this.monthNames = this.dateTimeAdapter.getMonthNames('short');\n  }\n\n  public ngOnInit() {\n    this.localeSub = this.dateTimeAdapter.localeChanges.subscribe(() => {\n      this.generateMonthList();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  public ngAfterContentInit(): void {\n    this.generateMonthList();\n    this.initiated = true;\n  }\n\n  public ngOnDestroy(): void {\n    this.localeSub.unsubscribe();\n  }\n\n  /**\n   * Handle a calendarCell selected\n   */\n  public selectCalendarCell(cell: CalendarCell): void {\n    this.selectMonth(cell.value);\n  }\n\n  /**\n   * Handle a new month selected\n   */\n  private selectMonth(month: number): void {\n    const firstDateOfMonth = this.dateTimeAdapter.createDate(\n      this.dateTimeAdapter.getYear(this.pickerMoment),\n      month,\n      1\n    );\n\n    this.monthSelected.emit(firstDateOfMonth);\n\n    const daysInMonth = this.dateTimeAdapter.getNumDaysInMonth(\n      firstDateOfMonth\n    );\n    const result = this.dateTimeAdapter.createDate(\n      this.dateTimeAdapter.getYear(this.pickerMoment),\n      month,\n      Math.min(daysInMonth, this.dateTimeAdapter.getDate(this.pickerMoment)),\n      this.dateTimeAdapter.getHours(this.pickerMoment),\n      this.dateTimeAdapter.getMinutes(this.pickerMoment),\n      this.dateTimeAdapter.getSeconds(this.pickerMoment)\n    );\n\n    this.monthChange.emit(result);\n  }\n\n  /**\n   * Handle keydown event on calendar body\n   */\n  public handleCalendarKeydown(event: KeyboardEvent): void {\n    let moment;\n    switch (event.keyCode) {\n      // minus 1 month\n      case LEFT_ARROW:\n        moment = this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -1);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 1 month\n      case RIGHT_ARROW:\n        moment = this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 1);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // minus 3 months\n      case UP_ARROW:\n        moment = this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -3);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 3 months\n      case DOWN_ARROW:\n        moment = this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 3);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // move to first month of current year\n      case HOME:\n        moment = this.dateTimeAdapter.addCalendarMonths(\n          this.pickerMoment,\n          -this.dateTimeAdapter.getMonth(this.pickerMoment)\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // move to last month of current year\n      case END:\n        moment = this.dateTimeAdapter.addCalendarMonths(\n          this.pickerMoment,\n          11 - this.dateTimeAdapter.getMonth(this.pickerMoment)\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // minus 1 year (or 10 year)\n      case PAGE_UP:\n        moment = this.dateTimeAdapter.addCalendarYears(\n          this.pickerMoment,\n          event.altKey ? -10 : -1\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 1 year (or 10 year)\n      case PAGE_DOWN:\n        moment = this.dateTimeAdapter.addCalendarYears(\n          this.pickerMoment,\n          event.altKey ? 10 : 1\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // Select current month\n      case ENTER:\n        this.selectMonth(this.dateTimeAdapter.getMonth(this.pickerMoment));\n        this.keyboardEnter.emit();\n        break;\n      default:\n        return;\n    }\n\n    this.focusActiveCell();\n    event.preventDefault();\n  }\n\n  /**\n   * Generate the calendar month list\n   * */\n  private generateMonthList(): void {\n    if (!this.pickerMoment) {\n      return;\n    }\n\n    this.setSelectedMonths();\n    this.todayMonth = this.getMonthInCurrentYear(this.dateTimeAdapter.now());\n\n    this._months = [];\n    for (let i = 0; i < MONTHS_PER_YEAR / MONTHS_PER_ROW; i++) {\n      const row = [];\n\n      for (let j = 0; j < MONTHS_PER_ROW; j++) {\n        const month = j + i * MONTHS_PER_ROW;\n        const monthCell = this.createMonthCell(month);\n        row.push(monthCell);\n      }\n\n      this._months.push(row);\n    }\n\n    return;\n  }\n\n  /**\n   * Creates an CalendarCell for the given month.\n   */\n  private createMonthCell(month: number): CalendarCell {\n    const startDateOfMonth = this.dateTimeAdapter.createDate(\n      this.dateTimeAdapter.getYear(this.pickerMoment),\n      month,\n      1\n    );\n    const ariaLabel = this.dateTimeAdapter.format(\n      startDateOfMonth,\n      this.dateTimeFormats.monthYearA11yLabel\n    );\n    const cellClass = 'owl-dt-month-' + month;\n    return new CalendarCell(\n      month,\n      this.monthNames[month],\n      ariaLabel,\n      this.isMonthEnabled(month),\n      false,\n      cellClass\n    );\n  }\n\n  /**\n   * Check if the given month is enable\n   */\n  private isMonthEnabled(month: number): boolean {\n    const firstDateOfMonth = this.dateTimeAdapter.createDate(\n      this.dateTimeAdapter.getYear(this.pickerMoment),\n      month,\n      1\n    );\n\n    // If any date in the month is selectable,\n    // we count the month as enable\n    for (\n      let date = firstDateOfMonth;\n      this.dateTimeAdapter.getMonth(date) === month;\n      date = this.dateTimeAdapter.addCalendarDays(date, 1)\n    ) {\n      if (\n        !!date &&\n        (!this.dateFilter || this.dateFilter(date)) &&\n        (!this.minDate ||\n          this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&\n        (!this.maxDate || this.dateTimeAdapter.compare(date, this.maxDate) <= 0)\n      ) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  /**\n   * Gets the month in this year that the given Date falls on.\n   * Returns null if the given Date is in another year.\n   */\n  private getMonthInCurrentYear(date: T | null): number {\n    if (this.getValidDate(date) && this.getValidDate(this._pickerMoment)) {\n      const result = this.dateTimeAdapter.compareYear(date, this._pickerMoment);\n\n      // < 0 : the given date's year is before pickerMoment's year, we return -1 as selected month value.\n      // > 0 : the given date's year is after pickerMoment's year, we return 12 as selected month value.\n      // 0 : the give date's year is same as the pickerMoment's year, we return the actual month value.\n      if (result < 0) {\n        return -1;\n      } else if (result > 0) {\n        return 12;\n      } else {\n        return this.dateTimeAdapter.getMonth(date);\n      }\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Set the selectedMonths value\n   * In single mode, it has only one value which represent the month the selected date in\n   * In range mode, it would has two values, one for the month the fromValue in and the other for the month the toValue in\n   * */\n  private setSelectedMonths(): void {\n    this.selectedMonths = [];\n    if (this.isInSingleMode && this.selected) {\n      this.selectedMonths[0] = this.getMonthInCurrentYear(this.selected);\n    }\n\n    if (this.isInRangeMode && this.selecteds) {\n      this.selectedMonths[0] = this.getMonthInCurrentYear(this.selecteds[0]);\n      this.selectedMonths[1] = this.getMonthInCurrentYear(this.selecteds[1]);\n    }\n  }\n\n  /**\n   * Check the given dates are in the same year\n   */\n  private hasSameYear(dateLeft: T, dateRight: T) {\n    return !!(\n      dateLeft &&\n      dateRight &&\n      this.dateTimeAdapter.getYear(dateLeft) ===\n        this.dateTimeAdapter.getYear(dateRight)\n    );\n  }\n\n  /**\n   * Get a valid date object\n   */\n  private getValidDate(obj: any): T | null {\n    return this.dateTimeAdapter.isDateInstance(obj) &&\n      this.dateTimeAdapter.isValid(obj)\n      ? obj\n      : null;\n  }\n\n  private focusActiveCell() {\n    this.calendarBodyElm.focusActiveCell();\n  }\n}\n","<table class=\"owl-dt-calendar-table owl-dt-calendar-year-table\">\n  <thead class=\"owl-dt-calendar-header\">\n    <tr>\n      <th\n        class=\"owl-dt-calendar-table-divider\"\n        aria-hidden=\"true\"\n        colspan=\"3\"\n      ></th>\n    </tr>\n  </thead>\n  <tbody\n    ofe-owl-date-time-calendar-body\n    role=\"grid\"\n    [rows]=\"months\"\n    [numCols]=\"3\"\n    [cellRatio]=\"3 / 7\"\n    [activeCell]=\"activeCell\"\n    [todayValue]=\"todayMonth\"\n    [selectedValues]=\"selectedMonths\"\n    [selectMode]=\"selectMode\"\n    (keydown)=\"handleCalendarKeydown($event)\"\n    (cellSelected)=\"selectCalendarCell($event)\"\n  ></tbody>\n</table>\n"]}
367
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-year-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.ts","../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {\n  CalendarCell,\n  OwlCalendarBodyComponent\n} from './calendar-body.component';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport {\n  OWL_DATE_TIME_FORMATS,\n  OwlDateTimeFormats\n} from './adapter/date-time-format.class';\nimport { Subscription } from 'rxjs';\nimport { SelectMode } from './date-time.class';\nimport {\n  DOWN_ARROW,\n  END,\n  ENTER,\n  HOME,\n  LEFT_ARROW,\n  PAGE_DOWN,\n  PAGE_UP,\n  RIGHT_ARROW,\n  UP_ARROW\n} from '@angular/cdk/keycodes';\n\nconst MONTHS_PER_YEAR = 12;\nconst MONTHS_PER_ROW = 3;\n\n@Component({\n  selector: 'ofe-owl-date-time-year-view',\n  exportAs: 'owlMonthView',\n  templateUrl: './calendar-year-view.component.html',\n  styleUrls: ['./calendar-year-view.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OwlYearViewComponent<T>\n  implements OnInit, AfterContentInit, OnDestroy {\n  @HostBinding('class.owl-dt-calendar-view') get owlDTCalendarView() {\n    return true;\n  }\n\n  /**\n   * The select mode of the picker;\n   * */\n  private _selectMode: SelectMode = 'single';\n  @Input()\n  get selectMode(): SelectMode {\n    return this._selectMode;\n  }\n\n  set selectMode(val: SelectMode) {\n    this._selectMode = val;\n    if (this.initiated) {\n      this.generateMonthList();\n      this.cdRef.markForCheck();\n    }\n  }\n\n  /** The currently selected date. */\n  private _selected: T | null;\n  @Input()\n  get selected(): T | null {\n    return this._selected;\n  }\n\n  set selected(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._selected = this.getValidDate(value);\n    this.setSelectedMonths();\n  }\n\n  private _selecteds: T[] = [];\n  @Input()\n  get selecteds(): T[] {\n    return this._selecteds;\n  }\n\n  set selecteds(values: T[]) {\n    this._selecteds = [];\n    for (let i = 0; i < values.length; i++) {\n      const value = this.dateTimeAdapter.deserialize(values[i]);\n      this._selecteds.push(this.getValidDate(value));\n    }\n\n    this.setSelectedMonths();\n  }\n\n  private _pickerMoment: T | null;\n  @Input()\n  get pickerMoment() {\n    return this._pickerMoment;\n  }\n\n  set pickerMoment(value: T) {\n    const oldMoment = this._pickerMoment;\n    value = this.dateTimeAdapter.deserialize(value);\n    this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();\n\n    if (!this.hasSameYear(oldMoment, this._pickerMoment) && this.initiated) {\n      this.generateMonthList();\n    }\n  }\n\n  /**\n   * A function used to filter which dates are selectable\n   * */\n  private _dateFilter: (date: T) => boolean;\n  @Input()\n  get dateFilter() {\n    return this._dateFilter;\n  }\n\n  set dateFilter(filter: (date: T) => boolean) {\n    this._dateFilter = filter;\n    if (this.initiated) {\n      this.generateMonthList();\n    }\n  }\n\n  /** The minimum selectable date. */\n  private _minDate: T | null;\n  @Input()\n  get minDate(): T | null {\n    return this._minDate;\n  }\n\n  set minDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._minDate = this.getValidDate(value);\n    if (this.initiated) {\n      this.generateMonthList();\n    }\n  }\n\n  /** The maximum selectable date. */\n  private _maxDate: T | null;\n  @Input()\n  get maxDate(): T | null {\n    return this._maxDate;\n  }\n\n  set maxDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._maxDate = this.getValidDate(value);\n    if (this.initiated) {\n      this.generateMonthList();\n    }\n  }\n\n  private readonly monthNames: string[];\n\n  private _months: CalendarCell[][];\n  get months() {\n    return this._months;\n  }\n\n  get activeCell(): number {\n    if (this._pickerMoment) {\n      return this.dateTimeAdapter.getMonth(this._pickerMoment);\n    }\n  }\n\n  get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  get isInRangeMode(): boolean {\n    return (\n      this.selectMode === 'range' ||\n      this.selectMode === 'rangeFrom' ||\n      this.selectMode === 'rangeTo'\n    );\n  }\n\n  private localeSub: Subscription = Subscription.EMPTY;\n\n  private initiated = false;\n\n  public todayMonth: number | null;\n\n  /**\n   * An array to hold all selectedDates' month value\n   * the value is the month number in current year\n   * */\n  public selectedMonths: number[] = [];\n\n  /**\n   * Callback to invoke when a new month is selected\n   * */\n  @Output()\n  readonly monthChange = new EventEmitter<T>();\n\n  /**\n   * Emits the selected year. This doesn't imply a change on the selected date\n   * */\n  @Output()\n  readonly monthSelected = new EventEmitter<T>();\n\n  /** Emits when any date is activated. */\n  @Output()\n  readonly pickerMomentChange: EventEmitter<T> = new EventEmitter<T>();\n\n  /** Emits when use keyboard enter to select a calendar cell */\n  @Output()\n  readonly keyboardEnter: EventEmitter<any> = new EventEmitter<any>();\n\n  /** The body of calendar table */\n  @ViewChild(OwlCalendarBodyComponent, { static: true })\n  calendarBodyElm: OwlCalendarBodyComponent;\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    @Optional() private dateTimeAdapter: DateTimeAdapter<T>,\n    @Optional()\n    @Inject(OWL_DATE_TIME_FORMATS)\n    private dateTimeFormats: OwlDateTimeFormats\n  ) {\n    this.monthNames = this.dateTimeAdapter.getMonthNames('short');\n  }\n\n  public ngOnInit() {\n    this.localeSub = this.dateTimeAdapter.localeChanges.subscribe(() => {\n      this.generateMonthList();\n      this.cdRef.markForCheck();\n    });\n  }\n\n  public ngAfterContentInit(): void {\n    this.generateMonthList();\n    this.initiated = true;\n  }\n\n  public ngOnDestroy(): void {\n    this.localeSub.unsubscribe();\n  }\n\n  /**\n   * Handle a calendarCell selected\n   */\n  public selectCalendarCell(cell: CalendarCell): void {\n    this.selectMonth(cell.value);\n  }\n\n  /**\n   * Handle a new month selected\n   */\n  private selectMonth(month: number): void {\n    const firstDateOfMonth = this.dateTimeAdapter.createDate(\n      this.dateTimeAdapter.getYear(this.pickerMoment),\n      month,\n      1\n    );\n\n    this.monthSelected.emit(firstDateOfMonth);\n\n    const daysInMonth = this.dateTimeAdapter.getNumDaysInMonth(\n      firstDateOfMonth\n    );\n    const result = this.dateTimeAdapter.createDate(\n      this.dateTimeAdapter.getYear(this.pickerMoment),\n      month,\n      Math.min(daysInMonth, this.dateTimeAdapter.getDate(this.pickerMoment)),\n      this.dateTimeAdapter.getHours(this.pickerMoment),\n      this.dateTimeAdapter.getMinutes(this.pickerMoment),\n      this.dateTimeAdapter.getSeconds(this.pickerMoment)\n    );\n\n    this.monthChange.emit(result);\n  }\n\n  /**\n   * Handle keydown event on calendar body\n   */\n  public handleCalendarKeydown(event: KeyboardEvent): void {\n    let moment;\n    switch (event.keyCode) {\n      // minus 1 month\n      case LEFT_ARROW:\n        moment = this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -1);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 1 month\n      case RIGHT_ARROW:\n        moment = this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 1);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // minus 3 months\n      case UP_ARROW:\n        moment = this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -3);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 3 months\n      case DOWN_ARROW:\n        moment = this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 3);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // move to first month of current year\n      case HOME:\n        moment = this.dateTimeAdapter.addCalendarMonths(\n          this.pickerMoment,\n          -this.dateTimeAdapter.getMonth(this.pickerMoment)\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // move to last month of current year\n      case END:\n        moment = this.dateTimeAdapter.addCalendarMonths(\n          this.pickerMoment,\n          11 - this.dateTimeAdapter.getMonth(this.pickerMoment)\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // minus 1 year (or 10 year)\n      case PAGE_UP:\n        moment = this.dateTimeAdapter.addCalendarYears(\n          this.pickerMoment,\n          event.altKey ? -10 : -1\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 1 year (or 10 year)\n      case PAGE_DOWN:\n        moment = this.dateTimeAdapter.addCalendarYears(\n          this.pickerMoment,\n          event.altKey ? 10 : 1\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // Select current month\n      case ENTER:\n        this.selectMonth(this.dateTimeAdapter.getMonth(this.pickerMoment));\n        this.keyboardEnter.emit();\n        break;\n      default:\n        return;\n    }\n\n    this.focusActiveCell();\n    event.preventDefault();\n  }\n\n  /**\n   * Generate the calendar month list\n   * */\n  private generateMonthList(): void {\n    if (!this.pickerMoment) {\n      return;\n    }\n\n    this.setSelectedMonths();\n    this.todayMonth = this.getMonthInCurrentYear(this.dateTimeAdapter.now());\n\n    this._months = [];\n    for (let i = 0; i < MONTHS_PER_YEAR / MONTHS_PER_ROW; i++) {\n      const row = [];\n\n      for (let j = 0; j < MONTHS_PER_ROW; j++) {\n        const month = j + i * MONTHS_PER_ROW;\n        const monthCell = this.createMonthCell(month);\n        row.push(monthCell);\n      }\n\n      this._months.push(row);\n    }\n\n    return;\n  }\n\n  /**\n   * Creates an CalendarCell for the given month.\n   */\n  private createMonthCell(month: number): CalendarCell {\n    const startDateOfMonth = this.dateTimeAdapter.createDate(\n      this.dateTimeAdapter.getYear(this.pickerMoment),\n      month,\n      1\n    );\n    const ariaLabel = this.dateTimeAdapter.format(\n      startDateOfMonth,\n      this.dateTimeFormats.monthYearA11yLabel\n    );\n    const cellClass = 'owl-dt-month-' + month;\n    return new CalendarCell(\n      month,\n      this.monthNames[month],\n      ariaLabel,\n      this.isMonthEnabled(month),\n      false,\n      cellClass\n    );\n  }\n\n  /**\n   * Check if the given month is enable\n   */\n  private isMonthEnabled(month: number): boolean {\n    const firstDateOfMonth = this.dateTimeAdapter.createDate(\n      this.dateTimeAdapter.getYear(this.pickerMoment),\n      month,\n      1\n    );\n\n    // If any date in the month is selectable,\n    // we count the month as enable\n    for (\n      let date = firstDateOfMonth;\n      this.dateTimeAdapter.getMonth(date) === month;\n      date = this.dateTimeAdapter.addCalendarDays(date, 1)\n    ) {\n      if (\n        !!date &&\n        (!this.dateFilter || this.dateFilter(date)) &&\n        (!this.minDate ||\n          this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&\n        (!this.maxDate || this.dateTimeAdapter.compare(date, this.maxDate) <= 0)\n      ) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  /**\n   * Gets the month in this year that the given Date falls on.\n   * Returns null if the given Date is in another year.\n   */\n  private getMonthInCurrentYear(date: T | null): number {\n    if (this.getValidDate(date) && this.getValidDate(this._pickerMoment)) {\n      const result = this.dateTimeAdapter.compareYear(date, this._pickerMoment);\n\n      // < 0 : the given date's year is before pickerMoment's year, we return -1 as selected month value.\n      // > 0 : the given date's year is after pickerMoment's year, we return 12 as selected month value.\n      // 0 : the give date's year is same as the pickerMoment's year, we return the actual month value.\n      if (result < 0) {\n        return -1;\n      } else if (result > 0) {\n        return 12;\n      } else {\n        return this.dateTimeAdapter.getMonth(date);\n      }\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Set the selectedMonths value\n   * In single mode, it has only one value which represent the month the selected date in\n   * In range mode, it would has two values, one for the month the fromValue in and the other for the month the toValue in\n   * */\n  private setSelectedMonths(): void {\n    this.selectedMonths = [];\n    if (this.isInSingleMode && this.selected) {\n      this.selectedMonths[0] = this.getMonthInCurrentYear(this.selected);\n    }\n\n    if (this.isInRangeMode && this.selecteds) {\n      this.selectedMonths[0] = this.getMonthInCurrentYear(this.selecteds[0]);\n      this.selectedMonths[1] = this.getMonthInCurrentYear(this.selecteds[1]);\n    }\n  }\n\n  /**\n   * Check the given dates are in the same year\n   */\n  private hasSameYear(dateLeft: T, dateRight: T) {\n    return !!(\n      dateLeft &&\n      dateRight &&\n      this.dateTimeAdapter.getYear(dateLeft) ===\n        this.dateTimeAdapter.getYear(dateRight)\n    );\n  }\n\n  /**\n   * Get a valid date object\n   */\n  private getValidDate(obj: any): T | null {\n    return this.dateTimeAdapter.isDateInstance(obj) &&\n      this.dateTimeAdapter.isValid(obj)\n      ? obj\n      : null;\n  }\n\n  private focusActiveCell() {\n    this.calendarBodyElm.focusActiveCell();\n  }\n}\n","<table class=\"owl-dt-calendar-table owl-dt-calendar-year-table\">\n  <thead class=\"owl-dt-calendar-header\">\n    <tr>\n      <th\n        class=\"owl-dt-calendar-table-divider\"\n        aria-hidden=\"true\"\n        colspan=\"3\"\n      ></th>\n    </tr>\n  </thead>\n  <tbody\n    ofe-owl-date-time-calendar-body\n    role=\"grid\"\n    [rows]=\"months\"\n    [numCols]=\"3\"\n    [cellRatio]=\"3 / 7\"\n    [activeCell]=\"activeCell\"\n    [todayValue]=\"todayMonth\"\n    [selectedValues]=\"selectedMonths\"\n    [selectMode]=\"selectMode\"\n    (keydown)=\"handleCalendarKeydown($event)\"\n    (cellSelected)=\"selectCalendarCell($event)\"\n  ></tbody>\n</table>\n"]}
@@ -13,57 +13,6 @@ import * as i5 from "./calendar-multi-year-view.component";
13
13
  import * as i6 from "./calendar-year-view.component";
14
14
  import * as i7 from "./calendar-month-view.component";
15
15
  export class OwlCalendarComponent {
16
- constructor(elmRef, pickerIntl, ngZone, cdRef, dateTimeAdapter, dateTimeFormats) {
17
- this.elmRef = elmRef;
18
- this.pickerIntl = pickerIntl;
19
- this.ngZone = ngZone;
20
- this.cdRef = cdRef;
21
- this.dateTimeAdapter = dateTimeAdapter;
22
- this.dateTimeFormats = dateTimeFormats;
23
- /**
24
- * Set the first day of week
25
- */
26
- this.firstDayOfWeek = 0;
27
- this._selecteds = [];
28
- /**
29
- * The view that the calendar should start in.
30
- */
31
- this.startView = 'month';
32
- /** Emits when the currently picker moment changes. */
33
- this.pickerMomentChange = new EventEmitter();
34
- /** Emits when the currently selected date changes. */
35
- this.selectedChange = new EventEmitter();
36
- /** Emits when any date is selected. */
37
- this.userSelection = new EventEmitter();
38
- /**
39
- * Emits the selected year. This doesn't imply a change on the selected date
40
- * */
41
- this.yearSelected = new EventEmitter();
42
- /**
43
- * Emits the selected month. This doesn't imply a change on the selected date
44
- * */
45
- this.monthSelected = new EventEmitter();
46
- this.intlChangesSub = Subscription.EMPTY;
47
- /**
48
- * Used for scheduling that focus should be moved to the active cell on the next tick.
49
- * We need to schedule it, rather than do it immediately, because we have to wait
50
- * for Angular to re-evaluate the view children.
51
- */
52
- this.moveFocusOnNextTick = false;
53
- /**
54
- * Date filter for the month and year view
55
- */
56
- this.dateFilterForViews = (date) => {
57
- return (!!date &&
58
- (!this.dateFilter || this.dateFilter(date)) &&
59
- (!this.minDate ||
60
- this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&
61
- (!this.maxDate || this.dateTimeAdapter.compare(date, this.maxDate) <= 0));
62
- };
63
- this.intlChangesSub = this.pickerIntl.changes.subscribe(() => {
64
- this.cdRef.markForCheck();
65
- });
66
- }
67
16
  get owlDTCalendarClass() {
68
17
  return true;
69
18
  }
@@ -163,6 +112,57 @@ export class OwlCalendarComponent {
163
112
  get isMonthView() {
164
113
  return this._currentView === 'month';
165
114
  }
115
+ constructor(elmRef, pickerIntl, ngZone, cdRef, dateTimeAdapter, dateTimeFormats) {
116
+ this.elmRef = elmRef;
117
+ this.pickerIntl = pickerIntl;
118
+ this.ngZone = ngZone;
119
+ this.cdRef = cdRef;
120
+ this.dateTimeAdapter = dateTimeAdapter;
121
+ this.dateTimeFormats = dateTimeFormats;
122
+ /**
123
+ * Set the first day of week
124
+ */
125
+ this.firstDayOfWeek = 0;
126
+ this._selecteds = [];
127
+ /**
128
+ * The view that the calendar should start in.
129
+ */
130
+ this.startView = 'month';
131
+ /** Emits when the currently picker moment changes. */
132
+ this.pickerMomentChange = new EventEmitter();
133
+ /** Emits when the currently selected date changes. */
134
+ this.selectedChange = new EventEmitter();
135
+ /** Emits when any date is selected. */
136
+ this.userSelection = new EventEmitter();
137
+ /**
138
+ * Emits the selected year. This doesn't imply a change on the selected date
139
+ * */
140
+ this.yearSelected = new EventEmitter();
141
+ /**
142
+ * Emits the selected month. This doesn't imply a change on the selected date
143
+ * */
144
+ this.monthSelected = new EventEmitter();
145
+ this.intlChangesSub = Subscription.EMPTY;
146
+ /**
147
+ * Used for scheduling that focus should be moved to the active cell on the next tick.
148
+ * We need to schedule it, rather than do it immediately, because we have to wait
149
+ * for Angular to re-evaluate the view children.
150
+ */
151
+ this.moveFocusOnNextTick = false;
152
+ /**
153
+ * Date filter for the month and year view
154
+ */
155
+ this.dateFilterForViews = (date) => {
156
+ return (!!date &&
157
+ (!this.dateFilter || this.dateFilter(date)) &&
158
+ (!this.minDate ||
159
+ this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&
160
+ (!this.maxDate || this.dateTimeAdapter.compare(date, this.maxDate) <= 0));
161
+ };
162
+ this.intlChangesSub = this.pickerIntl.changes.subscribe(() => {
163
+ this.cdRef.markForCheck();
164
+ });
165
+ }
166
166
  ngAfterContentInit() {
167
167
  this._currentView = this.startView;
168
168
  }
@@ -293,9 +293,9 @@ export class OwlCalendarComponent {
293
293
  : null;
294
294
  }
295
295
  }
296
- OwlCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: OwlCalendarComponent, deps: [{ token: i0.ElementRef }, { token: i1.OwlDateTimeIntl }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: i2.DateTimeAdapter, optional: true }, { token: OWL_DATE_TIME_FORMATS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
297
- OwlCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: OwlCalendarComponent, selector: "ofe-owl-date-time-calendar", inputs: { minDate: "minDate", maxDate: "maxDate", pickerMoment: "pickerMoment", selected: "selected", selecteds: "selecteds", dateFilter: "dateFilter", firstDayOfWeek: "firstDayOfWeek", selectMode: "selectMode", startView: "startView", hideOtherMonths: "hideOtherMonths" }, outputs: { pickerMomentChange: "pickerMomentChange", selectedChange: "selectedChange", userSelection: "userSelection", yearSelected: "yearSelected", monthSelected: "monthSelected" }, host: { properties: { "class.owl-dt-calendar": "this.owlDTCalendarClass" } }, exportAs: ["owlDateTimeCalendar"], ngImport: i0, template: "<div class=\"owl-dt-calendar-control\">\n <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n type=\"button\"\n tabindex=\"0\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n [disabled]=\"!prevButtonEnabled()\"\n [attr.aria-label]=\"prevButtonLabel\"\n (click)=\"previousClicked()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n version=\"1.1\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 250.738 250.738\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n xml:space=\"preserve\"\n width=\"100%\"\n height=\"100%\"\n >\n <path\n style=\"fill-rule: evenodd; clip-rule: evenodd\"\n d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546 c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681 l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"\n />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n <div class=\"owl-dt-calendar-control-content\">\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n type=\"button\"\n tabindex=\"0\"\n [attr.aria-label]=\"periodButtonLabel\"\n (click)=\"toggleViews()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n {{ periodButtonText }}\n\n <span\n class=\"owl-dt-control-button-arrow\"\n [style.transform]=\"'rotate(' + (isMonthView ? 0 : 180) + 'deg)'\"\n >\n <!-- <editor-fold desc=\"SVG Arrow\"> -->\n <svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n width=\"50%\"\n height=\"50%\"\n viewBox=\"0 0 292.362 292.362\"\n style=\"enable-background: new 0 0 292.362 292.362\"\n xml:space=\"preserve\"\n >\n <g>\n <path\n d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\"\n />\n </g>\n </svg>\n <!-- </editor-fold> -->\n </span>\n </span>\n </button>\n </div>\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n type=\"button\"\n tabindex=\"0\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n [disabled]=\"!nextButtonEnabled()\"\n [attr.aria-label]=\"nextButtonLabel\"\n (click)=\"nextClicked()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n <svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 250.738 250.738\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n xml:space=\"preserve\"\n >\n <path\n style=\"fill-rule: evenodd; clip-rule: evenodd\"\n d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n C197.237,120.447,195.534,115.448,191.75,111.689z\"\n />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n</div>\n<div\n class=\"owl-dt-calendar-main\"\n cdkMonitorSubtreeFocus\n [ngSwitch]=\"currentView\"\n tabindex=\"-1\"\n>\n <ofe-owl-date-time-month-view\n *ngSwitchCase=\"'month'\"\n [pickerMoment]=\"pickerMoment\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n [hideOtherMonths]=\"hideOtherMonths\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (selectedChange)=\"dateSelected($event)\"\n (userSelection)=\"userSelected()\"\n ></ofe-owl-date-time-month-view>\n\n <ofe-owl-date-time-year-view\n *ngSwitchCase=\"'year'\"\n [pickerMoment]=\"pickerMoment\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (monthSelected)=\"selectMonthInYearView($event)\"\n (monthChange)=\"goToDateInView($event, 'month')\"\n ></ofe-owl-date-time-year-view>\n\n <ofe-owl-date-time-multi-year-view\n *ngSwitchCase=\"'multi-years'\"\n [pickerMoment]=\"pickerMoment\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (yearSelected)=\"selectYearInMultiYearView($event)\"\n (monthChange)=\"goToDateInView($event, 'year')\"\n ></ofe-owl-date-time-multi-year-view>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.CdkMonitorFocus, selector: "[cdkMonitorElementFocus], [cdkMonitorSubtreeFocus]", outputs: ["cdkFocusChange"], exportAs: ["cdkMonitorFocus"] }, { kind: "component", type: i5.OwlMultiYearViewComponent, selector: "ofe-owl-date-time-multi-year-view", inputs: ["selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["monthChange", "yearSelected", "pickerMomentChange", "keyboardEnter"] }, { kind: "component", type: i6.OwlYearViewComponent, selector: "ofe-owl-date-time-year-view", inputs: ["selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["monthChange", "monthSelected", "pickerMomentChange", "keyboardEnter"], exportAs: ["owlMonthView"] }, { kind: "component", type: i7.OwlMonthViewComponent, selector: "ofe-owl-date-time-month-view", inputs: ["hideOtherMonths", "firstDayOfWeek", "selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["selectedChange", "userSelection", "pickerMomentChange"], exportAs: ["owlYearView"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
298
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: OwlCalendarComponent, decorators: [{
296
+ OwlCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OwlCalendarComponent, deps: [{ token: i0.ElementRef }, { token: i1.OwlDateTimeIntl }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: i2.DateTimeAdapter, optional: true }, { token: OWL_DATE_TIME_FORMATS, optional: true }], target: i0.ɵɵFactoryTarget.Component });
297
+ OwlCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OwlCalendarComponent, selector: "ofe-owl-date-time-calendar", inputs: { minDate: "minDate", maxDate: "maxDate", pickerMoment: "pickerMoment", selected: "selected", selecteds: "selecteds", dateFilter: "dateFilter", firstDayOfWeek: "firstDayOfWeek", selectMode: "selectMode", startView: "startView", hideOtherMonths: "hideOtherMonths" }, outputs: { pickerMomentChange: "pickerMomentChange", selectedChange: "selectedChange", userSelection: "userSelection", yearSelected: "yearSelected", monthSelected: "monthSelected" }, host: { properties: { "class.owl-dt-calendar": "this.owlDTCalendarClass" } }, exportAs: ["owlDateTimeCalendar"], ngImport: i0, template: "<div class=\"owl-dt-calendar-control\">\n <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n type=\"button\"\n tabindex=\"0\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n [disabled]=\"!prevButtonEnabled()\"\n [attr.aria-label]=\"prevButtonLabel\"\n (click)=\"previousClicked()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n version=\"1.1\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 250.738 250.738\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n xml:space=\"preserve\"\n width=\"100%\"\n height=\"100%\"\n >\n <path\n style=\"fill-rule: evenodd; clip-rule: evenodd\"\n d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546 c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681 l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"\n />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n <div class=\"owl-dt-calendar-control-content\">\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n type=\"button\"\n tabindex=\"0\"\n [attr.aria-label]=\"periodButtonLabel\"\n (click)=\"toggleViews()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n {{ periodButtonText }}\n\n <span\n class=\"owl-dt-control-button-arrow\"\n [style.transform]=\"'rotate(' + (isMonthView ? 0 : 180) + 'deg)'\"\n >\n <!-- <editor-fold desc=\"SVG Arrow\"> -->\n <svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n width=\"50%\"\n height=\"50%\"\n viewBox=\"0 0 292.362 292.362\"\n style=\"enable-background: new 0 0 292.362 292.362\"\n xml:space=\"preserve\"\n >\n <g>\n <path\n d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\"\n />\n </g>\n </svg>\n <!-- </editor-fold> -->\n </span>\n </span>\n </button>\n </div>\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n type=\"button\"\n tabindex=\"0\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n [disabled]=\"!nextButtonEnabled()\"\n [attr.aria-label]=\"nextButtonLabel\"\n (click)=\"nextClicked()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n <svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 250.738 250.738\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n xml:space=\"preserve\"\n >\n <path\n style=\"fill-rule: evenodd; clip-rule: evenodd\"\n d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n C197.237,120.447,195.534,115.448,191.75,111.689z\"\n />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n</div>\n<div\n class=\"owl-dt-calendar-main\"\n cdkMonitorSubtreeFocus\n [ngSwitch]=\"currentView\"\n tabindex=\"-1\"\n>\n <ofe-owl-date-time-month-view\n *ngSwitchCase=\"'month'\"\n [pickerMoment]=\"pickerMoment\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n [hideOtherMonths]=\"hideOtherMonths\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (selectedChange)=\"dateSelected($event)\"\n (userSelection)=\"userSelected()\"\n ></ofe-owl-date-time-month-view>\n\n <ofe-owl-date-time-year-view\n *ngSwitchCase=\"'year'\"\n [pickerMoment]=\"pickerMoment\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (monthSelected)=\"selectMonthInYearView($event)\"\n (monthChange)=\"goToDateInView($event, 'month')\"\n ></ofe-owl-date-time-year-view>\n\n <ofe-owl-date-time-multi-year-view\n *ngSwitchCase=\"'multi-years'\"\n [pickerMoment]=\"pickerMoment\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (yearSelected)=\"selectYearInMultiYearView($event)\"\n (monthChange)=\"goToDateInView($event, 'year')\"\n ></ofe-owl-date-time-multi-year-view>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.CdkMonitorFocus, selector: "[cdkMonitorElementFocus], [cdkMonitorSubtreeFocus]", outputs: ["cdkFocusChange"], exportAs: ["cdkMonitorFocus"] }, { kind: "component", type: i5.OwlMultiYearViewComponent, selector: "ofe-owl-date-time-multi-year-view", inputs: ["selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["monthChange", "yearSelected", "pickerMomentChange", "keyboardEnter"] }, { kind: "component", type: i6.OwlYearViewComponent, selector: "ofe-owl-date-time-year-view", inputs: ["selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["monthChange", "monthSelected", "pickerMomentChange", "keyboardEnter"], exportAs: ["owlMonthView"] }, { kind: "component", type: i7.OwlMonthViewComponent, selector: "ofe-owl-date-time-month-view", inputs: ["hideOtherMonths", "firstDayOfWeek", "selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["selectedChange", "userSelection", "pickerMomentChange"], exportAs: ["owlYearView"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
298
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OwlCalendarComponent, decorators: [{
299
299
  type: Component,
300
300
  args: [{ selector: 'ofe-owl-date-time-calendar', exportAs: 'owlDateTimeCalendar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"owl-dt-calendar-control\">\n <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n type=\"button\"\n tabindex=\"0\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n [disabled]=\"!prevButtonEnabled()\"\n [attr.aria-label]=\"prevButtonLabel\"\n (click)=\"previousClicked()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n version=\"1.1\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 250.738 250.738\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n xml:space=\"preserve\"\n width=\"100%\"\n height=\"100%\"\n >\n <path\n style=\"fill-rule: evenodd; clip-rule: evenodd\"\n d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546 c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681 l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"\n />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n <div class=\"owl-dt-calendar-control-content\">\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n type=\"button\"\n tabindex=\"0\"\n [attr.aria-label]=\"periodButtonLabel\"\n (click)=\"toggleViews()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n {{ periodButtonText }}\n\n <span\n class=\"owl-dt-control-button-arrow\"\n [style.transform]=\"'rotate(' + (isMonthView ? 0 : 180) + 'deg)'\"\n >\n <!-- <editor-fold desc=\"SVG Arrow\"> -->\n <svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n width=\"50%\"\n height=\"50%\"\n viewBox=\"0 0 292.362 292.362\"\n style=\"enable-background: new 0 0 292.362 292.362\"\n xml:space=\"preserve\"\n >\n <g>\n <path\n d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\"\n />\n </g>\n </svg>\n <!-- </editor-fold> -->\n </span>\n </span>\n </button>\n </div>\n <button\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n type=\"button\"\n tabindex=\"0\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n [disabled]=\"!nextButtonEnabled()\"\n [attr.aria-label]=\"nextButtonLabel\"\n (click)=\"nextClicked()\"\n >\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\"\n >\n <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n <svg\n version=\"1.1\"\n xmlns=\"http://www.w3.org/2000/svg\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n x=\"0px\"\n y=\"0px\"\n viewBox=\"0 0 250.738 250.738\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n xml:space=\"preserve\"\n >\n <path\n style=\"fill-rule: evenodd; clip-rule: evenodd\"\n d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n C197.237,120.447,195.534,115.448,191.75,111.689z\"\n />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n</div>\n<div\n class=\"owl-dt-calendar-main\"\n cdkMonitorSubtreeFocus\n [ngSwitch]=\"currentView\"\n tabindex=\"-1\"\n>\n <ofe-owl-date-time-month-view\n *ngSwitchCase=\"'month'\"\n [pickerMoment]=\"pickerMoment\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n [hideOtherMonths]=\"hideOtherMonths\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (selectedChange)=\"dateSelected($event)\"\n (userSelection)=\"userSelected()\"\n ></ofe-owl-date-time-month-view>\n\n <ofe-owl-date-time-year-view\n *ngSwitchCase=\"'year'\"\n [pickerMoment]=\"pickerMoment\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (monthSelected)=\"selectMonthInYearView($event)\"\n (monthChange)=\"goToDateInView($event, 'month')\"\n ></ofe-owl-date-time-year-view>\n\n <ofe-owl-date-time-multi-year-view\n *ngSwitchCase=\"'multi-years'\"\n [pickerMoment]=\"pickerMoment\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [selectMode]=\"selectMode\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [dateFilter]=\"dateFilter\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (yearSelected)=\"selectYearInMultiYearView($event)\"\n (monthChange)=\"goToDateInView($event, 'year')\"\n ></ofe-owl-date-time-multi-year-view>\n</div>\n" }]
301
301
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.OwlDateTimeIntl }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: i2.DateTimeAdapter, decorators: [{
@@ -339,4 +339,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
339
339
  }], monthSelected: [{
340
340
  type: Output
341
341
  }] } });
342
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/calendar.component.ts","../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/calendar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAGL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,WAAW,EACX,MAAM,EACN,KAAK,EACL,MAAM,EAEN,QAAQ,EACR,MAAM,EACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AAEpC,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EACL,qBAAqB,EAEtB,MAAM,kCAAkC,CAAC;;;;;;;;;AAW1C,MAAM,OAAO,oBAAoB;IAqI/B,YACU,MAAkB,EAClB,UAA2B,EAC3B,MAAc,EACd,KAAwB,EACZ,eAAmC,EAG/C,eAAmC;QAPnC,WAAM,GAAN,MAAM,CAAY;QAClB,eAAU,GAAV,UAAU,CAAiB;QAC3B,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAmB;QACZ,oBAAe,GAAf,eAAe,CAAoB;QAG/C,oBAAe,GAAf,eAAe,CAAoB;QAY7C;;WAEG;QAEH,mBAAc,GAAG,CAAC,CAAC;QAiBX,eAAU,GAAQ,EAAE,CAAC;QAE7B;;WAEG;QAEH,cAAS,GAAqC,OAAO,CAAC;QAQtD,sDAAsD;QAEtD,uBAAkB,GAAG,IAAI,YAAY,EAAK,CAAC;QAE3C,sDAAsD;QAEtD,mBAAc,GAAG,IAAI,YAAY,EAAK,CAAC;QAEvC,uCAAuC;QAEvC,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEzC;;aAEK;QAEI,iBAAY,GAAG,IAAI,YAAY,EAAK,CAAC;QAE9C;;aAEK;QAEI,kBAAa,GAAG,IAAI,YAAY,EAAK,CAAC;QAIvC,mBAAc,GAAG,YAAY,CAAC,KAAK,CAAC;QAE5C;;;;WAIG;QACK,wBAAmB,GAAG,KAAK,CAAC;QAEpC;;WAEG;QACI,uBAAkB,GAAG,CAAC,IAAO,EAAE,EAAE;YACtC,OAAO,CACL,CAAC,CAAC,IAAI;gBACN,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBAC3C,CAAC,CAAC,IAAI,CAAC,OAAO;oBACZ,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;gBACxD,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CACzE,CAAC;QACJ,CAAC,CAAC;QA3FA,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE;YAC3D,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAhJD,IAA0C,kBAAkB;QAC1D,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IAAI,OAAO,CAAC,KAAe;QACzB,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAChD,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAEjC,IAAI,CAAC,QAAQ,GAAG,KAAK;YACnB,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,UAAU,CAC7B,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,EACnC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,EACpC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,CACpC;YACH,CAAC,CAAC,IAAI,CAAC;IACX,CAAC;IACD,IACI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IAAI,OAAO,CAAC,KAAe;QACzB,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAChD,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAEjC,IAAI,CAAC,QAAQ,GAAG,KAAK;YACnB,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,UAAU,CAC7B,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,EACnC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,EACpC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,CACpC;YACH,CAAC,CAAC,IAAI,CAAC;IACX,CAAC;IACD,IACI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,IAAI,YAAY,CAAC,KAAQ;QACvB,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC;IAC9E,CAAC;IACD,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,KAAe;QAC1B,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;IACD,IACI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,SAAS,CAAC,MAAW;QACvB,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACjC,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACxC,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,WAAW;YACrB,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CACzB,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,eAAe,CAAC,cAAc,CACpC;YACH,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1D,CAAC;IAED,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,WAAW;YACrB,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,0BAA0B;YAC5C,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC;IAC7C,CAAC;IAED,IAAI,eAAe;QACjB,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,EAAE;YACjC,OAAO,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC;SACvC;aAAM,IAAI,IAAI,CAAC,YAAY,KAAK,MAAM,EAAE;YACvC,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;SACtC;aAAM;YACL,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAED,IAAI,eAAe;QACjB,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,EAAE;YACjC,OAAO,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC;SACvC;aAAM,IAAI,IAAI,CAAC,YAAY,KAAK,MAAM,EAAE;YACvC,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;SACtC;aAAM;YACL,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IACD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,IAAI,WAAW,CAAC,IAAsC;QACpD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;IAClC,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,UAAU,KAAK,QAAQ,CAAC;IACtC,CAAC;IAED,IAAI,aAAa;QACf,OAAO,CACL,IAAI,CAAC,UAAU,KAAK,OAAO;YAC3B,IAAI,CAAC,UAAU,KAAK,WAAW;YAC/B,IAAI,CAAC,UAAU,KAAK,SAAS,CAC9B,CAAC;IACJ,CAAC;IAED,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,YAAY,KAAK,aAAa,CAAC;IAC7C,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,KAAK,OAAO,CAAC;IACvC,CAAC;IAyGM,kBAAkB;QACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC;IACrC,CAAC;IAEM,kBAAkB;QACvB,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;YACjC,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,KAAK,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC;IAC7E,CAAC;IAED;;SAEK;IACE,eAAe;QACpB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW;YAClC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;YAC/D,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAEjE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAClD,CAAC;IAED;;SAEK;IACE,WAAW;QAChB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW;YAClC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;YAC9D,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;QAEhE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAClD,CAAC;IAEM,YAAY,CAAC,IAAO;QACzB,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE;YAClC,OAAO;SACR;QAED,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE/B;;;eAGO;IACT,CAAC;IAED;;OAEG;IACI,cAAc,CAAC,IAAO,EAAE,IAAsC;QACnE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,OAAO;IACT,CAAC;IAED;;OAEG;IACI,wBAAwB,CAAC,IAAO;QACrC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAChD,IAAI,EACJ,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,OAAO,CACb,CAAC;QACF,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAChD,OAAO;IACT,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IAED;;OAEG;IACI,iBAAiB;QACtB,OAAO,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IAC5E,CAAC;IAED;;OAEG;IACI,iBAAiB;QACtB,OAAO,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IAC5E,CAAC;IAED;;SAEK;IACE,eAAe;QACpB,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;YACjC,IAAI,CAAC,MAAM,CAAC,QAAQ;iBACjB,YAAY,EAAE;iBACd,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACb,SAAS,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,MAAM,CAAC,aAAa;qBACtB,aAAa,CAAC,8BAA8B,CAAC;qBAC7C,KAAK,EAAE,CAAC;YACb,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,yBAAyB,CAAC,cAAiB;QAChD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACzC,CAAC;IAEM,qBAAqB,CAAC,eAAkB;QAC7C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC3C,CAAC;IAED;;OAEG;IACK,UAAU,CAAC,KAAQ,EAAE,KAAQ;QACnC,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,EAAE;YACjC,OAAO,CAAC,CAAC,CACP,KAAK;gBACL,KAAK;gBACL,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC;oBACjC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC;gBACrC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC;oBAClC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,CACvC,CAAC;SACH;aAAM,IAAI,IAAI,CAAC,YAAY,KAAK,MAAM,EAAE;YACvC,OAAO,CAAC,CAAC,CACP,KAAK;gBACL,KAAK;gBACL,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC;oBACjC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,CACtC,CAAC;SACH;aAAM;YACL,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED;;OAEG;IACK,YAAY,CAAC,GAAQ;QAC3B,OAAO,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,GAAG,CAAC;YAC7C,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,CAAC;YACjC,CAAC,CAAC,GAAG;YACL,CAAC,CAAC,IAAI,CAAC;IACX,CAAC;;iHAtYU,oBAAoB,iLA4IrB,qBAAqB;qGA5IpB,oBAAoB,4nBCnCjC,6kMAwKA;2FDrIa,oBAAoB;kBARhC,SAAS;+BACE,4BAA4B,YAC5B,qBAAqB,mBAId,uBAAuB,CAAC,MAAM;;0BA4I5C,QAAQ;;0BACR,QAAQ;;0BACR,MAAM;2BAAC,qBAAqB;4CA1IW,kBAAkB;sBAA3D,WAAW;uBAAC,uBAAuB;gBAKhC,OAAO;sBADV,KAAK;gBAkBF,OAAO;sBADV,KAAK;gBAkBF,YAAY;sBADf,KAAK;gBAUF,QAAQ;sBADX,KAAK;gBAUF,SAAS;sBADZ,KAAK;gBA6FN,UAAU;sBADT,KAAK;gBAON,cAAc;sBADb,KAAK;gBAaN,UAAU;sBADT,KAAK;gBAYN,SAAS;sBADR,KAAK;gBAON,eAAe;sBADd,KAAK;gBAKN,kBAAkB;sBADjB,MAAM;gBAKP,cAAc;sBADb,MAAM;gBAKP,aAAa;sBADZ,MAAM;gBAOE,YAAY;sBADpB,MAAM;gBAOE,aAAa;sBADrB,MAAM","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Output\n} from '@angular/core';\nimport { take } from 'rxjs/operators';\nimport { Subscription } from 'rxjs';\n\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport {\n  OWL_DATE_TIME_FORMATS,\n  OwlDateTimeFormats\n} from './adapter/date-time-format.class';\nimport { SelectMode } from './date-time.class';\n\n@Component({\n  selector: 'ofe-owl-date-time-calendar',\n  exportAs: 'owlDateTimeCalendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OwlCalendarComponent<T>\n  implements AfterContentInit, AfterViewChecked, OnDestroy {\n  @HostBinding('class.owl-dt-calendar') get owlDTCalendarClass() {\n    return true;\n  }\n\n  @Input()\n  get minDate(): T | null {\n    return this._minDate;\n  }\n\n  set minDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n\n    this._minDate = value\n      ? this.dateTimeAdapter.createDate(\n          this.dateTimeAdapter.getYear(value),\n          this.dateTimeAdapter.getMonth(value),\n          this.dateTimeAdapter.getDate(value)\n        )\n      : null;\n  }\n  @Input()\n  get maxDate(): T | null {\n    return this._maxDate;\n  }\n\n  set maxDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n\n    this._maxDate = value\n      ? this.dateTimeAdapter.createDate(\n          this.dateTimeAdapter.getYear(value),\n          this.dateTimeAdapter.getMonth(value),\n          this.dateTimeAdapter.getDate(value)\n        )\n      : null;\n  }\n  @Input()\n  get pickerMoment() {\n    return this._pickerMoment;\n  }\n\n  set pickerMoment(value: T) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();\n  }\n  @Input()\n  get selected(): T | null {\n    return this._selected;\n  }\n\n  set selected(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._selected = this.getValidDate(value);\n  }\n  @Input()\n  get selecteds(): T[] {\n    return this._selecteds;\n  }\n\n  set selecteds(values: T[]) {\n    this._selecteds = values.map((v) => {\n      v = this.dateTimeAdapter.deserialize(v);\n      return this.getValidDate(v);\n    });\n  }\n\n  get periodButtonText(): string {\n    return this.isMonthView\n      ? this.dateTimeAdapter.format(\n          this.pickerMoment,\n          this.dateTimeFormats.monthYearLabel\n        )\n      : this.dateTimeAdapter.getYearName(this.pickerMoment);\n  }\n\n  get periodButtonLabel(): string {\n    return this.isMonthView\n      ? this.pickerIntl.switchToMultiYearViewLabel\n      : this.pickerIntl.switchToMonthViewLabel;\n  }\n\n  get prevButtonLabel(): string {\n    if (this._currentView === 'month') {\n      return this.pickerIntl.prevMonthLabel;\n    } else if (this._currentView === 'year') {\n      return this.pickerIntl.prevYearLabel;\n    } else {\n      return null;\n    }\n  }\n\n  get nextButtonLabel(): string {\n    if (this._currentView === 'month') {\n      return this.pickerIntl.nextMonthLabel;\n    } else if (this._currentView === 'year') {\n      return this.pickerIntl.nextYearLabel;\n    } else {\n      return null;\n    }\n  }\n  get currentView(): 'month' | 'year' | 'multi-years' {\n    return this._currentView;\n  }\n\n  set currentView(view: 'month' | 'year' | 'multi-years') {\n    this._currentView = view;\n    this.moveFocusOnNextTick = true;\n  }\n\n  get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  get isInRangeMode(): boolean {\n    return (\n      this.selectMode === 'range' ||\n      this.selectMode === 'rangeFrom' ||\n      this.selectMode === 'rangeTo'\n    );\n  }\n\n  get showControlArrows(): boolean {\n    return this._currentView !== 'multi-years';\n  }\n\n  get isMonthView() {\n    return this._currentView === 'month';\n  }\n\n  constructor(\n    private elmRef: ElementRef,\n    private pickerIntl: OwlDateTimeIntl,\n    private ngZone: NgZone,\n    private cdRef: ChangeDetectorRef,\n    @Optional() private dateTimeAdapter: DateTimeAdapter<T>,\n    @Optional()\n    @Inject(OWL_DATE_TIME_FORMATS)\n    private dateTimeFormats: OwlDateTimeFormats\n  ) {\n    this.intlChangesSub = this.pickerIntl.changes.subscribe(() => {\n      this.cdRef.markForCheck();\n    });\n  }\n  /**\n   * Date filter for the month and year view\n   * */\n  @Input()\n  dateFilter: Function;\n\n  /**\n   * Set the first day of week\n   */\n  @Input()\n  firstDayOfWeek = 0;\n\n  /** The minimum selectable date. */\n  private _minDate: T | null;\n\n  /** The maximum selectable date. */\n  private _maxDate: T | null;\n\n  /** The current picker moment */\n  private _pickerMoment: T;\n\n  @Input()\n  selectMode: SelectMode;\n\n  /** The currently selected moment. */\n  private _selected: T | null;\n\n  private _selecteds: T[] = [];\n\n  /**\n   * The view that the calendar should start in.\n   */\n  @Input()\n  startView: 'month' | 'year' | 'multi-years' = 'month';\n\n  /**\n   * Whether to hide dates in other months at the start or end of the current month.\n   * */\n  @Input()\n  hideOtherMonths: boolean;\n\n  /** Emits when the currently picker moment changes. */\n  @Output()\n  pickerMomentChange = new EventEmitter<T>();\n\n  /** Emits when the currently selected date changes. */\n  @Output()\n  selectedChange = new EventEmitter<T>();\n\n  /** Emits when any date is selected. */\n  @Output()\n  userSelection = new EventEmitter<void>();\n\n  /**\n   * Emits the selected year. This doesn't imply a change on the selected date\n   * */\n  @Output()\n  readonly yearSelected = new EventEmitter<T>();\n\n  /**\n   * Emits the selected month. This doesn't imply a change on the selected date\n   * */\n  @Output()\n  readonly monthSelected = new EventEmitter<T>();\n\n  private _currentView: 'month' | 'year' | 'multi-years';\n\n  private intlChangesSub = Subscription.EMPTY;\n\n  /**\n   * Used for scheduling that focus should be moved to the active cell on the next tick.\n   * We need to schedule it, rather than do it immediately, because we have to wait\n   * for Angular to re-evaluate the view children.\n   */\n  private moveFocusOnNextTick = false;\n\n  /**\n   * Date filter for the month and year view\n   */\n  public dateFilterForViews = (date: T) => {\n    return (\n      !!date &&\n      (!this.dateFilter || this.dateFilter(date)) &&\n      (!this.minDate ||\n        this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&\n      (!this.maxDate || this.dateTimeAdapter.compare(date, this.maxDate) <= 0)\n    );\n  };\n\n  public ngAfterContentInit(): void {\n    this._currentView = this.startView;\n  }\n\n  public ngAfterViewChecked() {\n    if (this.moveFocusOnNextTick) {\n      this.moveFocusOnNextTick = false;\n      this.focusActiveCell();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.intlChangesSub.unsubscribe();\n  }\n\n  /**\n   * Toggle between month view and year view\n   */\n  public toggleViews(): void {\n    this.currentView = this._currentView === 'month' ? 'multi-years' : 'month';\n  }\n\n  /**\n   * Handles user clicks on the previous button.\n   * */\n  public previousClicked(): void {\n    this.pickerMoment = this.isMonthView\n      ? this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -1)\n      : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, -1);\n\n    this.pickerMomentChange.emit(this.pickerMoment);\n  }\n\n  /**\n   * Handles user clicks on the next button.\n   * */\n  public nextClicked(): void {\n    this.pickerMoment = this.isMonthView\n      ? this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 1)\n      : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, 1);\n\n    this.pickerMomentChange.emit(this.pickerMoment);\n  }\n\n  public dateSelected(date: T): void {\n    if (!this.dateFilterForViews(date)) {\n      return;\n    }\n\n    this.selectedChange.emit(date);\n\n    /*if ((this.isInSingleMode && !this.dateTimeAdapter.isSameDay(date, this.selected)) ||\n            this.isInRangeMode) {\n            this.selectedChange.emit(date);\n        }*/\n  }\n\n  /**\n   * Change the pickerMoment value and switch to a specific view\n   */\n  public goToDateInView(date: T, view: 'month' | 'year' | 'multi-years'): void {\n    this.handlePickerMomentChange(date);\n    this.currentView = view;\n    return;\n  }\n\n  /**\n   * Change the pickerMoment value\n   */\n  public handlePickerMomentChange(date: T): void {\n    this.pickerMoment = this.dateTimeAdapter.clampDate(\n      date,\n      this.minDate,\n      this.maxDate\n    );\n    this.pickerMomentChange.emit(this.pickerMoment);\n    return;\n  }\n\n  public userSelected(): void {\n    this.userSelection.emit();\n  }\n\n  /**\n   * Whether the previous period button is enabled.\n   */\n  public prevButtonEnabled(): boolean {\n    return !this.minDate || !this.isSameView(this.pickerMoment, this.minDate);\n  }\n\n  /**\n   * Whether the next period button is enabled.\n   */\n  public nextButtonEnabled(): boolean {\n    return !this.maxDate || !this.isSameView(this.pickerMoment, this.maxDate);\n  }\n\n  /**\n   * Focus to the host element\n   * */\n  public focusActiveCell() {\n    this.ngZone.runOutsideAngular(() => {\n      this.ngZone.onStable\n        .asObservable()\n        .pipe(take(1))\n        .subscribe(() => {\n          this.elmRef.nativeElement\n            .querySelector('.owl-dt-calendar-cell-active')\n            .focus();\n        });\n    });\n  }\n\n  public selectYearInMultiYearView(normalizedYear: T): void {\n    this.yearSelected.emit(normalizedYear);\n  }\n\n  public selectMonthInYearView(normalizedMonth: T): void {\n    this.monthSelected.emit(normalizedMonth);\n  }\n\n  /**\n   * Whether the two dates represent the same view in the current view mode (month or year).\n   */\n  private isSameView(date1: T, date2: T): boolean {\n    if (this._currentView === 'month') {\n      return !!(\n        date1 &&\n        date2 &&\n        this.dateTimeAdapter.getYear(date1) ===\n          this.dateTimeAdapter.getYear(date2) &&\n        this.dateTimeAdapter.getMonth(date1) ===\n          this.dateTimeAdapter.getMonth(date2)\n      );\n    } else if (this._currentView === 'year') {\n      return !!(\n        date1 &&\n        date2 &&\n        this.dateTimeAdapter.getYear(date1) ===\n          this.dateTimeAdapter.getYear(date2)\n      );\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Get a valid date object\n   */\n  private getValidDate(obj: any): T | null {\n    return this.dateTimeAdapter.isDateInstance(obj) &&\n      this.dateTimeAdapter.isValid(obj)\n      ? obj\n      : null;\n  }\n}\n","<div class=\"owl-dt-calendar-control\">\n  <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n  <button\n    class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n    type=\"button\"\n    tabindex=\"0\"\n    [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n    [disabled]=\"!prevButtonEnabled()\"\n    [attr.aria-label]=\"prevButtonLabel\"\n    (click)=\"previousClicked()\"\n  >\n    <span\n      class=\"owl-dt-control-content owl-dt-control-button-content\"\n      tabindex=\"-1\"\n    >\n      <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n      <svg\n        xmlns=\"http://www.w3.org/2000/svg\"\n        xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n        version=\"1.1\"\n        x=\"0px\"\n        y=\"0px\"\n        viewBox=\"0 0 250.738 250.738\"\n        style=\"enable-background: new 0 0 250.738 250.738\"\n        xml:space=\"preserve\"\n        width=\"100%\"\n        height=\"100%\"\n      >\n        <path\n          style=\"fill-rule: evenodd; clip-rule: evenodd\"\n          d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546   c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681   l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"\n        />\n      </svg>\n      <!-- </editor-fold> -->\n    </span>\n  </button>\n  <div class=\"owl-dt-calendar-control-content\">\n    <button\n      class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n      type=\"button\"\n      tabindex=\"0\"\n      [attr.aria-label]=\"periodButtonLabel\"\n      (click)=\"toggleViews()\"\n    >\n      <span\n        class=\"owl-dt-control-content owl-dt-control-button-content\"\n        tabindex=\"-1\"\n      >\n        {{ periodButtonText }}\n\n        <span\n          class=\"owl-dt-control-button-arrow\"\n          [style.transform]=\"'rotate(' + (isMonthView ? 0 : 180) + 'deg)'\"\n        >\n          <!-- <editor-fold desc=\"SVG Arrow\"> -->\n          <svg\n            version=\"1.1\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n            x=\"0px\"\n            y=\"0px\"\n            width=\"50%\"\n            height=\"50%\"\n            viewBox=\"0 0 292.362 292.362\"\n            style=\"enable-background: new 0 0 292.362 292.362\"\n            xml:space=\"preserve\"\n          >\n            <g>\n              <path\n                d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n                                C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n                                s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\"\n              />\n            </g>\n          </svg>\n          <!-- </editor-fold> -->\n        </span>\n      </span>\n    </button>\n  </div>\n  <button\n    class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n    type=\"button\"\n    tabindex=\"0\"\n    [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n    [disabled]=\"!nextButtonEnabled()\"\n    [attr.aria-label]=\"nextButtonLabel\"\n    (click)=\"nextClicked()\"\n  >\n    <span\n      class=\"owl-dt-control-content owl-dt-control-button-content\"\n      tabindex=\"-1\"\n    >\n      <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n      <svg\n        version=\"1.1\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n        x=\"0px\"\n        y=\"0px\"\n        viewBox=\"0 0 250.738 250.738\"\n        style=\"enable-background: new 0 0 250.738 250.738\"\n        xml:space=\"preserve\"\n      >\n        <path\n          style=\"fill-rule: evenodd; clip-rule: evenodd\"\n          d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n                    c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n                    c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n                    C197.237,120.447,195.534,115.448,191.75,111.689z\"\n        />\n      </svg>\n      <!-- </editor-fold> -->\n    </span>\n  </button>\n</div>\n<div\n  class=\"owl-dt-calendar-main\"\n  cdkMonitorSubtreeFocus\n  [ngSwitch]=\"currentView\"\n  tabindex=\"-1\"\n>\n  <ofe-owl-date-time-month-view\n    *ngSwitchCase=\"'month'\"\n    [pickerMoment]=\"pickerMoment\"\n    [firstDayOfWeek]=\"firstDayOfWeek\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    [selectMode]=\"selectMode\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [dateFilter]=\"dateFilter\"\n    [hideOtherMonths]=\"hideOtherMonths\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n    (selectedChange)=\"dateSelected($event)\"\n    (userSelection)=\"userSelected()\"\n  ></ofe-owl-date-time-month-view>\n\n  <ofe-owl-date-time-year-view\n    *ngSwitchCase=\"'year'\"\n    [pickerMoment]=\"pickerMoment\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    [selectMode]=\"selectMode\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [dateFilter]=\"dateFilter\"\n    (keyboardEnter)=\"focusActiveCell()\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n    (monthSelected)=\"selectMonthInYearView($event)\"\n    (monthChange)=\"goToDateInView($event, 'month')\"\n  ></ofe-owl-date-time-year-view>\n\n  <ofe-owl-date-time-multi-year-view\n    *ngSwitchCase=\"'multi-years'\"\n    [pickerMoment]=\"pickerMoment\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    [selectMode]=\"selectMode\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [dateFilter]=\"dateFilter\"\n    (keyboardEnter)=\"focusActiveCell()\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n    (yearSelected)=\"selectYearInMultiYearView($event)\"\n    (monthChange)=\"goToDateInView($event, 'year')\"\n  ></ofe-owl-date-time-multi-year-view>\n</div>\n"]}
342
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/calendar.component.ts","../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Output\n} from '@angular/core';\nimport { take } from 'rxjs/operators';\nimport { Subscription } from 'rxjs';\n\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport {\n  OWL_DATE_TIME_FORMATS,\n  OwlDateTimeFormats\n} from './adapter/date-time-format.class';\nimport { SelectMode } from './date-time.class';\n\n@Component({\n  selector: 'ofe-owl-date-time-calendar',\n  exportAs: 'owlDateTimeCalendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OwlCalendarComponent<T>\n  implements AfterContentInit, AfterViewChecked, OnDestroy {\n  @HostBinding('class.owl-dt-calendar') get owlDTCalendarClass() {\n    return true;\n  }\n\n  @Input()\n  get minDate(): T | null {\n    return this._minDate;\n  }\n\n  set minDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n\n    this._minDate = value\n      ? this.dateTimeAdapter.createDate(\n          this.dateTimeAdapter.getYear(value),\n          this.dateTimeAdapter.getMonth(value),\n          this.dateTimeAdapter.getDate(value)\n        )\n      : null;\n  }\n  @Input()\n  get maxDate(): T | null {\n    return this._maxDate;\n  }\n\n  set maxDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n\n    this._maxDate = value\n      ? this.dateTimeAdapter.createDate(\n          this.dateTimeAdapter.getYear(value),\n          this.dateTimeAdapter.getMonth(value),\n          this.dateTimeAdapter.getDate(value)\n        )\n      : null;\n  }\n  @Input()\n  get pickerMoment() {\n    return this._pickerMoment;\n  }\n\n  set pickerMoment(value: T) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();\n  }\n  @Input()\n  get selected(): T | null {\n    return this._selected;\n  }\n\n  set selected(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._selected = this.getValidDate(value);\n  }\n  @Input()\n  get selecteds(): T[] {\n    return this._selecteds;\n  }\n\n  set selecteds(values: T[]) {\n    this._selecteds = values.map((v) => {\n      v = this.dateTimeAdapter.deserialize(v);\n      return this.getValidDate(v);\n    });\n  }\n\n  get periodButtonText(): string {\n    return this.isMonthView\n      ? this.dateTimeAdapter.format(\n          this.pickerMoment,\n          this.dateTimeFormats.monthYearLabel\n        )\n      : this.dateTimeAdapter.getYearName(this.pickerMoment);\n  }\n\n  get periodButtonLabel(): string {\n    return this.isMonthView\n      ? this.pickerIntl.switchToMultiYearViewLabel\n      : this.pickerIntl.switchToMonthViewLabel;\n  }\n\n  get prevButtonLabel(): string {\n    if (this._currentView === 'month') {\n      return this.pickerIntl.prevMonthLabel;\n    } else if (this._currentView === 'year') {\n      return this.pickerIntl.prevYearLabel;\n    } else {\n      return null;\n    }\n  }\n\n  get nextButtonLabel(): string {\n    if (this._currentView === 'month') {\n      return this.pickerIntl.nextMonthLabel;\n    } else if (this._currentView === 'year') {\n      return this.pickerIntl.nextYearLabel;\n    } else {\n      return null;\n    }\n  }\n  get currentView(): 'month' | 'year' | 'multi-years' {\n    return this._currentView;\n  }\n\n  set currentView(view: 'month' | 'year' | 'multi-years') {\n    this._currentView = view;\n    this.moveFocusOnNextTick = true;\n  }\n\n  get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  get isInRangeMode(): boolean {\n    return (\n      this.selectMode === 'range' ||\n      this.selectMode === 'rangeFrom' ||\n      this.selectMode === 'rangeTo'\n    );\n  }\n\n  get showControlArrows(): boolean {\n    return this._currentView !== 'multi-years';\n  }\n\n  get isMonthView() {\n    return this._currentView === 'month';\n  }\n\n  constructor(\n    private elmRef: ElementRef,\n    private pickerIntl: OwlDateTimeIntl,\n    private ngZone: NgZone,\n    private cdRef: ChangeDetectorRef,\n    @Optional() private dateTimeAdapter: DateTimeAdapter<T>,\n    @Optional()\n    @Inject(OWL_DATE_TIME_FORMATS)\n    private dateTimeFormats: OwlDateTimeFormats\n  ) {\n    this.intlChangesSub = this.pickerIntl.changes.subscribe(() => {\n      this.cdRef.markForCheck();\n    });\n  }\n  /**\n   * Date filter for the month and year view\n   * */\n  @Input()\n  dateFilter: Function;\n\n  /**\n   * Set the first day of week\n   */\n  @Input()\n  firstDayOfWeek = 0;\n\n  /** The minimum selectable date. */\n  private _minDate: T | null;\n\n  /** The maximum selectable date. */\n  private _maxDate: T | null;\n\n  /** The current picker moment */\n  private _pickerMoment: T;\n\n  @Input()\n  selectMode: SelectMode;\n\n  /** The currently selected moment. */\n  private _selected: T | null;\n\n  private _selecteds: T[] = [];\n\n  /**\n   * The view that the calendar should start in.\n   */\n  @Input()\n  startView: 'month' | 'year' | 'multi-years' = 'month';\n\n  /**\n   * Whether to hide dates in other months at the start or end of the current month.\n   * */\n  @Input()\n  hideOtherMonths: boolean;\n\n  /** Emits when the currently picker moment changes. */\n  @Output()\n  pickerMomentChange = new EventEmitter<T>();\n\n  /** Emits when the currently selected date changes. */\n  @Output()\n  selectedChange = new EventEmitter<T>();\n\n  /** Emits when any date is selected. */\n  @Output()\n  userSelection = new EventEmitter<void>();\n\n  /**\n   * Emits the selected year. This doesn't imply a change on the selected date\n   * */\n  @Output()\n  readonly yearSelected = new EventEmitter<T>();\n\n  /**\n   * Emits the selected month. This doesn't imply a change on the selected date\n   * */\n  @Output()\n  readonly monthSelected = new EventEmitter<T>();\n\n  private _currentView: 'month' | 'year' | 'multi-years';\n\n  private intlChangesSub = Subscription.EMPTY;\n\n  /**\n   * Used for scheduling that focus should be moved to the active cell on the next tick.\n   * We need to schedule it, rather than do it immediately, because we have to wait\n   * for Angular to re-evaluate the view children.\n   */\n  private moveFocusOnNextTick = false;\n\n  /**\n   * Date filter for the month and year view\n   */\n  public dateFilterForViews = (date: T) => {\n    return (\n      !!date &&\n      (!this.dateFilter || this.dateFilter(date)) &&\n      (!this.minDate ||\n        this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&\n      (!this.maxDate || this.dateTimeAdapter.compare(date, this.maxDate) <= 0)\n    );\n  };\n\n  public ngAfterContentInit(): void {\n    this._currentView = this.startView;\n  }\n\n  public ngAfterViewChecked() {\n    if (this.moveFocusOnNextTick) {\n      this.moveFocusOnNextTick = false;\n      this.focusActiveCell();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.intlChangesSub.unsubscribe();\n  }\n\n  /**\n   * Toggle between month view and year view\n   */\n  public toggleViews(): void {\n    this.currentView = this._currentView === 'month' ? 'multi-years' : 'month';\n  }\n\n  /**\n   * Handles user clicks on the previous button.\n   * */\n  public previousClicked(): void {\n    this.pickerMoment = this.isMonthView\n      ? this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -1)\n      : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, -1);\n\n    this.pickerMomentChange.emit(this.pickerMoment);\n  }\n\n  /**\n   * Handles user clicks on the next button.\n   * */\n  public nextClicked(): void {\n    this.pickerMoment = this.isMonthView\n      ? this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 1)\n      : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, 1);\n\n    this.pickerMomentChange.emit(this.pickerMoment);\n  }\n\n  public dateSelected(date: T): void {\n    if (!this.dateFilterForViews(date)) {\n      return;\n    }\n\n    this.selectedChange.emit(date);\n\n    /*if ((this.isInSingleMode && !this.dateTimeAdapter.isSameDay(date, this.selected)) ||\n            this.isInRangeMode) {\n            this.selectedChange.emit(date);\n        }*/\n  }\n\n  /**\n   * Change the pickerMoment value and switch to a specific view\n   */\n  public goToDateInView(date: T, view: 'month' | 'year' | 'multi-years'): void {\n    this.handlePickerMomentChange(date);\n    this.currentView = view;\n    return;\n  }\n\n  /**\n   * Change the pickerMoment value\n   */\n  public handlePickerMomentChange(date: T): void {\n    this.pickerMoment = this.dateTimeAdapter.clampDate(\n      date,\n      this.minDate,\n      this.maxDate\n    );\n    this.pickerMomentChange.emit(this.pickerMoment);\n    return;\n  }\n\n  public userSelected(): void {\n    this.userSelection.emit();\n  }\n\n  /**\n   * Whether the previous period button is enabled.\n   */\n  public prevButtonEnabled(): boolean {\n    return !this.minDate || !this.isSameView(this.pickerMoment, this.minDate);\n  }\n\n  /**\n   * Whether the next period button is enabled.\n   */\n  public nextButtonEnabled(): boolean {\n    return !this.maxDate || !this.isSameView(this.pickerMoment, this.maxDate);\n  }\n\n  /**\n   * Focus to the host element\n   * */\n  public focusActiveCell() {\n    this.ngZone.runOutsideAngular(() => {\n      this.ngZone.onStable\n        .asObservable()\n        .pipe(take(1))\n        .subscribe(() => {\n          this.elmRef.nativeElement\n            .querySelector('.owl-dt-calendar-cell-active')\n            .focus();\n        });\n    });\n  }\n\n  public selectYearInMultiYearView(normalizedYear: T): void {\n    this.yearSelected.emit(normalizedYear);\n  }\n\n  public selectMonthInYearView(normalizedMonth: T): void {\n    this.monthSelected.emit(normalizedMonth);\n  }\n\n  /**\n   * Whether the two dates represent the same view in the current view mode (month or year).\n   */\n  private isSameView(date1: T, date2: T): boolean {\n    if (this._currentView === 'month') {\n      return !!(\n        date1 &&\n        date2 &&\n        this.dateTimeAdapter.getYear(date1) ===\n          this.dateTimeAdapter.getYear(date2) &&\n        this.dateTimeAdapter.getMonth(date1) ===\n          this.dateTimeAdapter.getMonth(date2)\n      );\n    } else if (this._currentView === 'year') {\n      return !!(\n        date1 &&\n        date2 &&\n        this.dateTimeAdapter.getYear(date1) ===\n          this.dateTimeAdapter.getYear(date2)\n      );\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Get a valid date object\n   */\n  private getValidDate(obj: any): T | null {\n    return this.dateTimeAdapter.isDateInstance(obj) &&\n      this.dateTimeAdapter.isValid(obj)\n      ? obj\n      : null;\n  }\n}\n","<div class=\"owl-dt-calendar-control\">\n  <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n  <button\n    class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n    type=\"button\"\n    tabindex=\"0\"\n    [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n    [disabled]=\"!prevButtonEnabled()\"\n    [attr.aria-label]=\"prevButtonLabel\"\n    (click)=\"previousClicked()\"\n  >\n    <span\n      class=\"owl-dt-control-content owl-dt-control-button-content\"\n      tabindex=\"-1\"\n    >\n      <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n      <svg\n        xmlns=\"http://www.w3.org/2000/svg\"\n        xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n        version=\"1.1\"\n        x=\"0px\"\n        y=\"0px\"\n        viewBox=\"0 0 250.738 250.738\"\n        style=\"enable-background: new 0 0 250.738 250.738\"\n        xml:space=\"preserve\"\n        width=\"100%\"\n        height=\"100%\"\n      >\n        <path\n          style=\"fill-rule: evenodd; clip-rule: evenodd\"\n          d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546   c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681   l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"\n        />\n      </svg>\n      <!-- </editor-fold> -->\n    </span>\n  </button>\n  <div class=\"owl-dt-calendar-control-content\">\n    <button\n      class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n      type=\"button\"\n      tabindex=\"0\"\n      [attr.aria-label]=\"periodButtonLabel\"\n      (click)=\"toggleViews()\"\n    >\n      <span\n        class=\"owl-dt-control-content owl-dt-control-button-content\"\n        tabindex=\"-1\"\n      >\n        {{ periodButtonText }}\n\n        <span\n          class=\"owl-dt-control-button-arrow\"\n          [style.transform]=\"'rotate(' + (isMonthView ? 0 : 180) + 'deg)'\"\n        >\n          <!-- <editor-fold desc=\"SVG Arrow\"> -->\n          <svg\n            version=\"1.1\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n            x=\"0px\"\n            y=\"0px\"\n            width=\"50%\"\n            height=\"50%\"\n            viewBox=\"0 0 292.362 292.362\"\n            style=\"enable-background: new 0 0 292.362 292.362\"\n            xml:space=\"preserve\"\n          >\n            <g>\n              <path\n                d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n                                C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n                                s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\"\n              />\n            </g>\n          </svg>\n          <!-- </editor-fold> -->\n        </span>\n      </span>\n    </button>\n  </div>\n  <button\n    class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n    type=\"button\"\n    tabindex=\"0\"\n    [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n    [disabled]=\"!nextButtonEnabled()\"\n    [attr.aria-label]=\"nextButtonLabel\"\n    (click)=\"nextClicked()\"\n  >\n    <span\n      class=\"owl-dt-control-content owl-dt-control-button-content\"\n      tabindex=\"-1\"\n    >\n      <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n      <svg\n        version=\"1.1\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n        x=\"0px\"\n        y=\"0px\"\n        viewBox=\"0 0 250.738 250.738\"\n        style=\"enable-background: new 0 0 250.738 250.738\"\n        xml:space=\"preserve\"\n      >\n        <path\n          style=\"fill-rule: evenodd; clip-rule: evenodd\"\n          d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n                    c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n                    c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n                    C197.237,120.447,195.534,115.448,191.75,111.689z\"\n        />\n      </svg>\n      <!-- </editor-fold> -->\n    </span>\n  </button>\n</div>\n<div\n  class=\"owl-dt-calendar-main\"\n  cdkMonitorSubtreeFocus\n  [ngSwitch]=\"currentView\"\n  tabindex=\"-1\"\n>\n  <ofe-owl-date-time-month-view\n    *ngSwitchCase=\"'month'\"\n    [pickerMoment]=\"pickerMoment\"\n    [firstDayOfWeek]=\"firstDayOfWeek\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    [selectMode]=\"selectMode\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [dateFilter]=\"dateFilter\"\n    [hideOtherMonths]=\"hideOtherMonths\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n    (selectedChange)=\"dateSelected($event)\"\n    (userSelection)=\"userSelected()\"\n  ></ofe-owl-date-time-month-view>\n\n  <ofe-owl-date-time-year-view\n    *ngSwitchCase=\"'year'\"\n    [pickerMoment]=\"pickerMoment\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    [selectMode]=\"selectMode\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [dateFilter]=\"dateFilter\"\n    (keyboardEnter)=\"focusActiveCell()\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n    (monthSelected)=\"selectMonthInYearView($event)\"\n    (monthChange)=\"goToDateInView($event, 'month')\"\n  ></ofe-owl-date-time-year-view>\n\n  <ofe-owl-date-time-multi-year-view\n    *ngSwitchCase=\"'multi-years'\"\n    [pickerMoment]=\"pickerMoment\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    [selectMode]=\"selectMode\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [dateFilter]=\"dateFilter\"\n    (keyboardEnter)=\"focusActiveCell()\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n    (yearSelected)=\"selectYearInMultiYearView($event)\"\n    (monthChange)=\"goToDateInView($event, 'year')\"\n  ></ofe-owl-date-time-multi-year-view>\n</div>\n"]}