@ng-matero/extensions 12.5.3 → 12.7.1

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 (143) hide show
  1. package/_all-theme.scss +2 -0
  2. package/_index.scss +2 -0
  3. package/_theming.scss +2 -0
  4. package/bundles/extensions.umd.js +7 -7
  5. package/bundles/extensions.umd.js.map +1 -1
  6. package/bundles/mtxColorpicker.umd.js +1123 -0
  7. package/bundles/mtxColorpicker.umd.js.map +1 -0
  8. package/bundles/mtxDatetimepicker.umd.js +603 -148
  9. package/bundles/mtxDatetimepicker.umd.js.map +1 -1
  10. package/bundles/mtxDialog.umd.js +0 -2
  11. package/bundles/mtxDialog.umd.js.map +1 -1
  12. package/bundles/mtxFormGroup.umd.js +2 -9
  13. package/bundles/mtxFormGroup.umd.js.map +1 -1
  14. package/bundles/mtxLoader.umd.js +7 -4
  15. package/bundles/mtxLoader.umd.js.map +1 -1
  16. package/bundles/mtxPopover.umd.js +5 -8
  17. package/bundles/mtxPopover.umd.js.map +1 -1
  18. package/bundles/mtxSelect.umd.js +1 -0
  19. package/bundles/mtxSelect.umd.js.map +1 -1
  20. package/bundles/mtxSplit.umd.js +80 -81
  21. package/bundles/mtxSplit.umd.js.map +1 -1
  22. package/bundles/mtxText3d.umd.js +0 -8
  23. package/bundles/mtxText3d.umd.js.map +1 -1
  24. package/bundles/mtxTooltip.umd.js +2 -0
  25. package/bundles/mtxTooltip.umd.js.map +1 -1
  26. package/colorpicker/_colorpicker-theme.import.scss +2 -0
  27. package/colorpicker/_colorpicker-theme.scss +43 -0
  28. package/colorpicker/colorpicker-animations.d.ts +8 -0
  29. package/colorpicker/colorpicker-content.scss +4 -0
  30. package/colorpicker/colorpicker-input.d.ts +89 -0
  31. package/colorpicker/colorpicker-module.d.ts +2 -0
  32. package/colorpicker/colorpicker-toggle.d.ts +33 -0
  33. package/colorpicker/colorpicker-toggle.scss +23 -0
  34. package/colorpicker/colorpicker.d.ts +126 -0
  35. package/{color-picker/mtxColorPicker.d.ts → colorpicker/mtxColorpicker.d.ts} +0 -0
  36. package/colorpicker/mtxColorpicker.metadata.json +1 -0
  37. package/colorpicker/package.json +11 -0
  38. package/colorpicker/public-api.d.ts +5 -0
  39. package/datetimepicker/_datetimepicker-theme.scss +12 -0
  40. package/datetimepicker/calendar.d.ts +2 -10
  41. package/datetimepicker/clock.d.ts +10 -9
  42. package/datetimepicker/datetimepicker-animations.d.ts +7 -5
  43. package/datetimepicker/datetimepicker-input.d.ts +4 -2
  44. package/datetimepicker/{datetimepicker.module.d.ts → datetimepicker-module.d.ts} +0 -0
  45. package/datetimepicker/datetimepicker-toggle.d.ts +15 -2
  46. package/datetimepicker/datetimepicker-toggle.scss +23 -0
  47. package/datetimepicker/datetimepicker.d.ts +67 -24
  48. package/datetimepicker/month-view.d.ts +3 -3
  49. package/datetimepicker/mtxDatetimepicker.d.ts +0 -2
  50. package/datetimepicker/mtxDatetimepicker.metadata.json +1 -1
  51. package/datetimepicker/multi-year-view.d.ts +3 -3
  52. package/datetimepicker/public-api.d.ts +3 -1
  53. package/datetimepicker/year-view.d.ts +3 -3
  54. package/dialog/{dialog.config.d.ts → dialog-config.d.ts} +0 -0
  55. package/dialog/dialog.component.d.ts +1 -1
  56. package/dialog/dialog.d.ts +1 -1
  57. package/dialog/mtxDialog.metadata.json +1 -1
  58. package/dialog/public-api.d.ts +2 -2
  59. package/esm2015/colorpicker/colorpicker-animations.js +16 -0
  60. package/esm2015/colorpicker/colorpicker-input.js +228 -0
  61. package/esm2015/colorpicker/colorpicker-module.js +41 -0
  62. package/esm2015/colorpicker/colorpicker-toggle.js +97 -0
  63. package/esm2015/colorpicker/colorpicker.js +372 -0
  64. package/esm2015/colorpicker/mtxColorpicker.js +5 -0
  65. package/esm2015/colorpicker/public-api.js +6 -0
  66. package/esm2015/datetimepicker/calendar-body.js +2 -1
  67. package/esm2015/datetimepicker/calendar.js +14 -29
  68. package/esm2015/datetimepicker/clock.js +7 -7
  69. package/esm2015/datetimepicker/datetimepicker-animations.js +38 -24
  70. package/esm2015/datetimepicker/datetimepicker-input.js +6 -3
  71. package/esm2015/datetimepicker/datetimepicker-module.js +52 -0
  72. package/esm2015/datetimepicker/datetimepicker-toggle.js +30 -8
  73. package/esm2015/datetimepicker/datetimepicker.js +150 -71
  74. package/esm2015/datetimepicker/month-view.js +8 -7
  75. package/esm2015/datetimepicker/mtxDatetimepicker.js +1 -3
  76. package/esm2015/datetimepicker/multi-year-view.js +8 -7
  77. package/esm2015/datetimepicker/public-api.js +4 -2
  78. package/esm2015/datetimepicker/year-view.js +8 -7
  79. package/esm2015/dialog/{dialog.config.js → dialog-config.js} +1 -1
  80. package/esm2015/dialog/dialog.component.js +1 -1
  81. package/esm2015/dialog/dialog.js +1 -1
  82. package/esm2015/dialog/public-api.js +3 -3
  83. package/esm2015/extensions.module.js +3 -3
  84. package/esm2015/form-group/form-group.component.js +4 -11
  85. package/esm2015/loader/loader.component.js +8 -5
  86. package/esm2015/popover/popover.js +5 -9
  87. package/esm2015/public-api.js +2 -2
  88. package/esm2015/select/select.component.js +2 -1
  89. package/esm2015/split/split.component.js +13 -11
  90. package/esm2015/split/utils.js +1 -6
  91. package/esm2015/text3d/text3d.component.js +1 -9
  92. package/esm2015/tooltip/tooltip.js +3 -1
  93. package/extensions.metadata.json +1 -1
  94. package/fesm2015/extensions.js +3 -3
  95. package/fesm2015/extensions.js.map +1 -1
  96. package/fesm2015/mtxColorpicker.js +743 -0
  97. package/fesm2015/mtxColorpicker.js.map +1 -0
  98. package/fesm2015/mtxDatetimepicker.js +259 -146
  99. package/fesm2015/mtxDatetimepicker.js.map +1 -1
  100. package/fesm2015/mtxDialog.js +1 -1
  101. package/fesm2015/mtxDialog.js.map +1 -1
  102. package/fesm2015/mtxFormGroup.js +3 -10
  103. package/fesm2015/mtxFormGroup.js.map +1 -1
  104. package/fesm2015/mtxLoader.js +7 -4
  105. package/fesm2015/mtxLoader.js.map +1 -1
  106. package/fesm2015/mtxPopover.js +4 -8
  107. package/fesm2015/mtxPopover.js.map +1 -1
  108. package/fesm2015/mtxSelect.js +1 -0
  109. package/fesm2015/mtxSelect.js.map +1 -1
  110. package/fesm2015/mtxSplit.js +12 -15
  111. package/fesm2015/mtxSplit.js.map +1 -1
  112. package/fesm2015/mtxText3d.js +0 -8
  113. package/fesm2015/mtxText3d.js.map +1 -1
  114. package/fesm2015/mtxTooltip.js +2 -0
  115. package/fesm2015/mtxTooltip.js.map +1 -1
  116. package/form-group/form-group.component.d.ts +2 -4
  117. package/form-group/mtxFormGroup.metadata.json +1 -1
  118. package/loader/loader.component.d.ts +4 -1
  119. package/loader/mtxLoader.metadata.json +1 -1
  120. package/package.json +1 -1
  121. package/popover/popover.d.ts +0 -4
  122. package/public-api.d.ts +1 -1
  123. package/select/mtxSelect.metadata.json +1 -1
  124. package/split/_split-theme.scss +9 -2
  125. package/split/mtxSplit.metadata.json +1 -1
  126. package/split/split.component.d.ts +9 -1
  127. package/text3d/mtxText3d.metadata.json +1 -1
  128. package/text3d/text3d.component.d.ts +0 -1
  129. package/tooltip/mtxTooltip.metadata.json +1 -1
  130. package/bundles/mtxColorPicker.umd.js +0 -337
  131. package/bundles/mtxColorPicker.umd.js.map +0 -1
  132. package/color-picker/color-picker.component.d.ts +0 -120
  133. package/color-picker/color-picker.module.d.ts +0 -2
  134. package/color-picker/mtxColorPicker.metadata.json +0 -1
  135. package/color-picker/package.json +0 -11
  136. package/color-picker/public-api.d.ts +0 -2
  137. package/esm2015/color-picker/color-picker.component.js +0 -268
  138. package/esm2015/color-picker/color-picker.module.js +0 -26
  139. package/esm2015/color-picker/mtxColorPicker.js +0 -5
  140. package/esm2015/color-picker/public-api.js +0 -3
  141. package/esm2015/datetimepicker/datetimepicker.module.js +0 -49
  142. package/fesm2015/mtxColorPicker.js +0 -295
  143. package/fesm2015/mtxColorPicker.js.map +0 -1
@@ -1,18 +1,36 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, NgZone, Optional, Output, ViewChild, ViewContainerRef, ViewEncapsulation, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Inject, InjectionToken, Input, NgZone, Optional, Output, ViewChild, ViewContainerRef, ViewEncapsulation, } from '@angular/core';
2
2
  import { Directionality } from '@angular/cdk/bidi';
3
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
3
+ import { coerceBooleanProperty, coerceStringArray } from '@angular/cdk/coercion';
4
4
  import { ESCAPE, hasModifierKey, UP_ARROW } from '@angular/cdk/keycodes';
5
5
  import { Overlay, OverlayConfig, } from '@angular/cdk/overlay';
6
6
  import { ComponentPortal } from '@angular/cdk/portal';
7
- import { MAT_DATEPICKER_SCROLL_STRATEGY } from '@angular/material/datepicker';
7
+ import { _getFocusedElementPierceShadowDom } from '@angular/cdk/platform';
8
+ import { mixinColor } from '@angular/material/core';
8
9
  import { merge, Subject, Subscription } from 'rxjs';
9
10
  import { filter, take } from 'rxjs/operators';
10
11
  import { DatetimeAdapter } from '@ng-matero/extensions/core';
11
12
  import { MtxCalendar } from './calendar';
12
13
  import { createMissingDateImplError } from './datetimepicker-errors';
13
- import { _getFocusedElementPierceShadowDom } from '@angular/cdk/platform';
14
+ import { mtxDatetimepickerAnimations } from './datetimepicker-animations';
14
15
  /** Used to generate a unique ID for each datetimepicker instance. */
15
16
  let datetimepickerUid = 0;
17
+ /** Injection token that determines the scroll handling while the calendar is open. */
18
+ export const MTX_DATETIMEPICKER_SCROLL_STRATEGY = new InjectionToken('mtx-datetimepicker-scroll-strategy');
19
+ export function MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY(overlay) {
20
+ return () => overlay.scrollStrategies.reposition();
21
+ }
22
+ export const MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY_PROVIDER = {
23
+ provide: MTX_DATETIMEPICKER_SCROLL_STRATEGY,
24
+ deps: [Overlay],
25
+ useFactory: MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY,
26
+ };
27
+ // Boilerplate for applying mixins to MtxDatetimepickerContent.
28
+ /** @docs-private */
29
+ const _MtxDatetimepickerContentBase = mixinColor(class {
30
+ constructor(_elementRef) {
31
+ this._elementRef = _elementRef;
32
+ }
33
+ });
16
34
  /**
17
35
  * Component used as the content for the datetimepicker dialog and popup. We use this instead of
18
36
  * using MtxCalendar directly as the content so we can control the initial focus. This also gives us
@@ -20,30 +38,60 @@ let datetimepickerUid = 0;
20
38
  * future. (e.g. confirmation buttons).
21
39
  * @docs-private
22
40
  */
23
- export class MtxDatetimepickerContent {
41
+ export class MtxDatetimepickerContent extends _MtxDatetimepickerContentBase {
42
+ constructor(elementRef, _changeDetectorRef) {
43
+ super(elementRef);
44
+ this._changeDetectorRef = _changeDetectorRef;
45
+ /** Emits when an animation has finished. */
46
+ this._animationDone = new Subject();
47
+ }
48
+ ngOnInit() {
49
+ this._animationState = this.datetimepicker.touchUi ? 'enter-dialog' : 'enter-dropdown';
50
+ }
24
51
  ngAfterContentInit() {
25
52
  this._calendar._focusActiveCell();
26
53
  }
27
- onSelectionChange(date) {
28
- this.datetimepicker._select(date);
29
- this.datetimepicker.close();
54
+ _startExitAnimation() {
55
+ this._animationState = 'void';
56
+ this._changeDetectorRef.markForCheck();
57
+ }
58
+ ngOnDestroy() {
59
+ this._animationDone.complete();
30
60
  }
31
61
  }
32
62
  /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
33
63
  MtxDatetimepickerContent.decorators = [
34
64
  { type: Component, args: [{
35
65
  selector: 'mtx-datetimepicker-content',
36
- template: "<div cdkTrapFocus\n class=\"mtx-datetimepicker-content-container\"\n [attr.mode]=\"datetimepicker.mode\">\n <mtx-calendar (_userSelection)=\"datetimepicker.close()\"\n (selectedChange)=\"onSelectionChange($event)\"\n (viewChanged)=\"datetimepicker._viewChanged($event)\"\n [ariaNextMonthLabel]=\"datetimepicker.ariaNextMonthLabel\"\n [ariaNextYearLabel]=\"datetimepicker.ariaNextYearLabel\"\n [ariaPrevMonthLabel]=\"datetimepicker.ariaPrevMonthLabel\"\n [ariaPrevYearLabel]=\"datetimepicker.ariaPrevYearLabel\"\n [preventSameDateTimeSelection]=\"datetimepicker.preventSameDateTimeSelection\"\n [attr.mode]=\"datetimepicker.mode\"\n [id]=\"datetimepicker.id\"\n [maxDate]=\"datetimepicker._maxDate\"\n [minDate]=\"datetimepicker._minDate\"\n [dateFilter]=\"datetimepicker._dateFilter\"\n [selected]=\"datetimepicker._selected\"\n [multiYearSelector]=\"datetimepicker.multiYearSelector\"\n [startAt]=\"datetimepicker.startAt\"\n [startView]=\"datetimepicker.startView\"\n [timeInterval]=\"datetimepicker.timeInterval\"\n [twelvehour]=\"datetimepicker.twelvehour\"\n [type]=\"datetimepicker.type\">\n </mtx-calendar>\n</div>\n",
66
+ template: "<div cdkTrapFocus\n class=\"mtx-datetimepicker-content-container\"\n [attr.mode]=\"datetimepicker.mode\">\n <mtx-calendar [id]=\"datetimepicker.id\"\n [ngClass]=\"datetimepicker.panelClass\"\n [attr.mode]=\"datetimepicker.mode\"\n [type]=\"datetimepicker.type\"\n [startAt]=\"datetimepicker.startAt\"\n [startView]=\"datetimepicker.startView\"\n [maxDate]=\"datetimepicker._maxDate\"\n [minDate]=\"datetimepicker._minDate\"\n [dateFilter]=\"datetimepicker._dateFilter\"\n [multiYearSelector]=\"datetimepicker.multiYearSelector\"\n [preventSameDateTimeSelection]=\"datetimepicker.preventSameDateTimeSelection\"\n [timeInterval]=\"datetimepicker.timeInterval\"\n [twelvehour]=\"datetimepicker.twelvehour\"\n [selected]=\"datetimepicker._selected\"\n [@fadeInCalendar]=\"'enter'\"\n (selectedChange)=\"datetimepicker._select($event)\"\n (viewChanged)=\"datetimepicker._viewChanged($event)\"\n (_userSelection)=\"datetimepicker.close()\">\n </mtx-calendar>\n</div>\n",
37
67
  host: {
38
68
  'class': 'mtx-datetimepicker-content',
39
69
  '[class.mtx-datetimepicker-content-touch]': 'datetimepicker?.touchUi',
40
70
  '[attr.mode]': 'datetimepicker.mode',
71
+ '[@transformPanel]': '_animationState',
72
+ '(@transformPanel.done)': '_animationDone.next()',
41
73
  },
74
+ animations: [
75
+ mtxDatetimepickerAnimations.transformPanel,
76
+ mtxDatetimepickerAnimations.fadeInCalendar,
77
+ ],
42
78
  encapsulation: ViewEncapsulation.None,
43
79
  changeDetection: ChangeDetectionStrategy.OnPush,
80
+ inputs: ['color'],
44
81
  styles: [".mtx-datetimepicker-content{display:block;border-radius:4px}.mtx-datetimepicker-content-container{display:flex;flex-direction:column;justify-content:space-between}.mtx-datetimepicker-content .mtx-calendar{width:296px;height:404px}.mtx-datetimepicker-content .mtx-calendar[mode=landscape]{width:446px;height:328px}@media all and (orientation: landscape){.mtx-datetimepicker-content .mtx-calendar[mode=auto]{width:446px;height:328px}}.mtx-datetimepicker-content-touch{display:block;max-height:80vh;position:relative;overflow:visible}.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container{min-height:300px;max-height:850px;min-width:250px;max-width:750px}.mtx-datetimepicker-content-touch .mtx-calendar{width:100%;height:auto}@media all and (orientation: landscape){.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=auto],.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=landscape]{width:120vh;height:80vh}.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=auto] .mtx-calendar,.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=landscape] .mtx-calendar{width:auto;height:100%}.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=portrait]{width:64vh;height:90vh}.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=portrait] .mtx-calendar{width:100%;height:auto}}@media all and (orientation: portrait){.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=auto],.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=portrait]{width:80vw;height:120vw}.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=auto] .mtx-calendar,.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=portrait] .mtx-calendar{width:100%;height:auto}.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=landscape]{width:90vw;height:64vw}.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container[mode=landscape] .mtx-calendar{width:auto;height:100%}.mtx-datetimepicker-content-touch .mtx-datetimepicker-content-container-with-actions{height:135vw}}\n"]
45
82
  },] }
46
83
  ];
84
+ /**
85
+ * @type {function(): !Array<(null|{
86
+ * type: ?,
87
+ * decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>),
88
+ * })>}
89
+ * @nocollapse
90
+ */
91
+ MtxDatetimepickerContent.ctorParameters = () => [
92
+ { type: ElementRef },
93
+ { type: ChangeDetectorRef }
94
+ ];
47
95
  /** @type {!Object<string, !Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
48
96
  MtxDatetimepickerContent.propDecorators = {
49
97
  _calendar: [{ type: ViewChild, args: [MtxCalendar, { static: true },] }]
@@ -62,10 +110,6 @@ export class MtxDatetimepicker {
62
110
  this.startView = 'month';
63
111
  this.mode = 'auto';
64
112
  this.timeInterval = 1;
65
- this.ariaNextMonthLabel = 'Next month';
66
- this.ariaPrevMonthLabel = 'Previous month';
67
- this.ariaNextYearLabel = 'Next year';
68
- this.ariaPrevYearLabel = 'Previous year';
69
113
  /** Prevent user to select same date time */
70
114
  this.preventSameDateTimeSelection = false;
71
115
  /**
@@ -79,8 +123,7 @@ export class MtxDatetimepicker {
79
123
  this.closedStream = new EventEmitter();
80
124
  /** Emits when the view has been changed. */
81
125
  this.viewChanged = new EventEmitter();
82
- /** Whether the calendar is open. */
83
- this.opened = false;
126
+ this._opened = false;
84
127
  /** The id for the datetimepicker calendar. */
85
128
  this.id = `mtx-datetimepicker-${datetimepickerUid++}`;
86
129
  /** Emits when the datetimepicker is disabled. */
@@ -93,6 +136,11 @@ export class MtxDatetimepicker {
93
136
  this._inputStateChanges = Subscription.EMPTY;
94
137
  this._type = 'date';
95
138
  this._touchUi = false;
139
+ /** Preferred position of the datetimepicker in the X axis. */
140
+ this.xPosition = 'start';
141
+ /** Preferred position of the datetimepicker in the Y axis. */
142
+ this.yPosition = 'below';
143
+ this._restoreFocus = true;
96
144
  if (!this._dateAdapter) {
97
145
  throw createMissingDateImplError('DateAdapter');
98
146
  }
@@ -111,21 +159,40 @@ export class MtxDatetimepicker {
111
159
  set twelvehour(value) {
112
160
  this._twelvehour = coerceBooleanProperty(value);
113
161
  }
162
+ /**
163
+ * Classes to be passed to the date picker panel.
164
+ * Supports string and string array values, similar to `ngClass`.
165
+ */
166
+ get panelClass() {
167
+ return this._panelClass;
168
+ }
169
+ set panelClass(value) {
170
+ this._panelClass = coerceStringArray(value);
171
+ }
172
+ /** Whether the calendar is open. */
173
+ get opened() {
174
+ return this._opened;
175
+ }
176
+ set opened(value) {
177
+ coerceBooleanProperty(value) ? this.open() : this.close();
178
+ }
179
+ /** Color palette to use on the datetimepicker's calendar. */
180
+ get color() {
181
+ return (this._color ||
182
+ (this.datetimepickerInput ? this.datetimepickerInput.getThemePalette() : undefined));
183
+ }
184
+ set color(value) {
185
+ this._color = value;
186
+ }
114
187
  /** The date to open the calendar to initially. */
115
188
  get startAt() {
116
189
  // If an explicit startAt is set we start there, otherwise we start at whatever the currently
117
190
  // selected value is.
118
- return this._startAt || (this._datetimepickerInput ? this._datetimepickerInput.value : null);
191
+ return this._startAt || (this.datetimepickerInput ? this.datetimepickerInput.value : null);
119
192
  }
120
193
  set startAt(date) {
121
194
  this._startAt = this._dateAdapter.getValidDateOrNull(date);
122
195
  }
123
- get openOnFocus() {
124
- return this._openOnFocus;
125
- }
126
- set openOnFocus(value) {
127
- this._openOnFocus = coerceBooleanProperty(value);
128
- }
129
196
  get type() {
130
197
  return this._type;
131
198
  }
@@ -144,8 +211,8 @@ export class MtxDatetimepicker {
144
211
  }
145
212
  /** Whether the datetimepicker pop-up should be disabled. */
146
213
  get disabled() {
147
- return this._disabled === undefined && this._datetimepickerInput
148
- ? this._datetimepickerInput.disabled
214
+ return this._disabled === undefined && this.datetimepickerInput
215
+ ? this.datetimepickerInput.disabled
149
216
  : !!this._disabled;
150
217
  }
151
218
  set disabled(value) {
@@ -155,6 +222,17 @@ export class MtxDatetimepicker {
155
222
  this._disabledChange.next(newValue);
156
223
  }
157
224
  }
225
+ /**
226
+ * Whether to restore focus to the previously-focused element when the panel is closed.
227
+ * Note that automatic focus restoration is an accessibility feature and it is recommended that
228
+ * you provide your own equivalent, if you decide to turn it off.
229
+ */
230
+ get restoreFocus() {
231
+ return this._restoreFocus;
232
+ }
233
+ set restoreFocus(value) {
234
+ this._restoreFocus = coerceBooleanProperty(value);
235
+ }
158
236
  /** The currently selected date. */
159
237
  get _selected() {
160
238
  return this._validSelected;
@@ -164,14 +242,14 @@ export class MtxDatetimepicker {
164
242
  }
165
243
  /** The minimum selectable date. */
166
244
  get _minDate() {
167
- return this._datetimepickerInput && this._datetimepickerInput.min;
245
+ return this.datetimepickerInput && this.datetimepickerInput.min;
168
246
  }
169
247
  /** The maximum selectable date. */
170
248
  get _maxDate() {
171
- return this._datetimepickerInput && this._datetimepickerInput.max;
249
+ return this.datetimepickerInput && this.datetimepickerInput.max;
172
250
  }
173
251
  get _dateFilter() {
174
- return this._datetimepickerInput && this._datetimepickerInput._dateFilter;
252
+ return this.datetimepickerInput && this.datetimepickerInput._dateFilter;
175
253
  }
176
254
  _viewChanged(type) {
177
255
  this.viewChanged.emit(type);
@@ -182,10 +260,7 @@ export class MtxDatetimepicker {
182
260
  this._inputStateChanges.unsubscribe();
183
261
  this._disabledChange.complete();
184
262
  }
185
- /**
186
- * TODO: use model
187
- * Selects the given date
188
- */
263
+ /** Selects the given date */
189
264
  _select(date) {
190
265
  const oldValue = this._selected;
191
266
  this._selected = date;
@@ -198,28 +273,28 @@ export class MtxDatetimepicker {
198
273
  * @param input The datetimepicker input to register with this datetimepicker.
199
274
  */
200
275
  _registerInput(input) {
201
- if (this._datetimepickerInput) {
276
+ if (this.datetimepickerInput) {
202
277
  throw Error('A MtxDatetimepicker can only be associated with a single input.');
203
278
  }
204
- this._datetimepickerInput = input;
205
- this._inputStateChanges = this._datetimepickerInput._valueChange.subscribe((value) => (this._selected = value));
279
+ this.datetimepickerInput = input;
280
+ this._inputStateChanges = this.datetimepickerInput._valueChange.subscribe((value) => (this._selected = value));
206
281
  }
207
282
  /** Open the calendar. */
208
283
  open() {
209
- if (this.opened || this.disabled) {
284
+ if (this._opened || this.disabled) {
210
285
  return;
211
286
  }
212
- if (!this._datetimepickerInput) {
287
+ if (!this.datetimepickerInput) {
213
288
  throw Error('Attempted to open an MtxDatetimepicker with no associated input.');
214
289
  }
215
290
  this._focusedElementBeforeOpen = _getFocusedElementPierceShadowDom();
216
291
  this._openOverlay();
217
- this.opened = true;
292
+ this._opened = true;
218
293
  this.openedStream.emit();
219
294
  }
220
295
  /** Close the calendar. */
221
296
  close() {
222
- if (!this.opened) {
297
+ if (!this._opened) {
223
298
  return;
224
299
  }
225
300
  if (this._componentRef) {
@@ -228,13 +303,14 @@ export class MtxDatetimepicker {
228
303
  const completeClose = () => {
229
304
  // The `_opened` could've been reset already if
230
305
  // we got two events in quick succession.
231
- if (this.opened) {
232
- this.opened = false;
306
+ if (this._opened) {
307
+ this._opened = false;
233
308
  this.closedStream.emit();
234
309
  this._focusedElementBeforeOpen = null;
235
310
  }
236
311
  };
237
- if (this._focusedElementBeforeOpen &&
312
+ if (this._restoreFocus &&
313
+ this._focusedElementBeforeOpen &&
238
314
  typeof this._focusedElementBeforeOpen.focus === 'function') {
239
315
  // Because IE moves focus asynchronously, we can't count on it being restored before we've
240
316
  // marked the datetimepicker as closed. If the event fires out of sequence and the element
@@ -249,18 +325,18 @@ export class MtxDatetimepicker {
249
325
  }
250
326
  }
251
327
  /**
252
- * TODO: add datetimepicker color
253
328
  * Forwards relevant values from the datetimepicker to the
254
329
  * datetimepicker content inside the overlay.
255
330
  */
256
331
  _forwardContentValues(instance) {
257
332
  instance.datetimepicker = this;
333
+ instance.color = this.color;
258
334
  }
259
335
  /** Opens the overlay with the calendar. */
260
336
  _openOverlay() {
261
337
  this._destroyOverlay();
262
338
  const isDialog = this.touchUi;
263
- const labelId = this._datetimepickerInput.getOverlayLabelId();
339
+ const labelId = this.datetimepickerInput.getOverlayLabelId();
264
340
  const portal = new ComponentPortal(MtxDatetimepickerContent, this._viewContainerRef);
265
341
  const overlayRef = (this._overlayRef = this._overlay.create(new OverlayConfig({
266
342
  positionStrategy: isDialog ? this._getDialogStrategy() : this._getDropdownStrategy(),
@@ -309,7 +385,7 @@ export class MtxDatetimepicker {
309
385
  _getDropdownStrategy() {
310
386
  const strategy = this._overlay
311
387
  .position()
312
- .flexibleConnectedTo(this._datetimepickerInput.getConnectedOverlayOrigin())
388
+ .flexibleConnectedTo(this.datetimepickerInput.getConnectedOverlayOrigin())
313
389
  .withTransformOriginOn('.mtx-datetimepicker-content')
314
390
  .withFlexibleDimensions(false)
315
391
  .withViewportMargin(8)
@@ -317,34 +393,37 @@ export class MtxDatetimepicker {
317
393
  return this._setConnectedPositions(strategy);
318
394
  }
319
395
  /**
320
- * TODO: `xPosition` and `yPosition`
321
396
  * Sets the positions of the datetimepicker in dropdown mode based on the current configuration.
322
397
  */
323
398
  _setConnectedPositions(strategy) {
399
+ const primaryX = this.xPosition === 'end' ? 'end' : 'start';
400
+ const secondaryX = primaryX === 'start' ? 'end' : 'start';
401
+ const primaryY = this.yPosition === 'above' ? 'bottom' : 'top';
402
+ const secondaryY = primaryY === 'top' ? 'bottom' : 'top';
324
403
  return strategy.withPositions([
325
404
  {
326
- originX: 'start',
327
- originY: 'bottom',
328
- overlayX: 'start',
329
- overlayY: 'top',
405
+ originX: primaryX,
406
+ originY: secondaryY,
407
+ overlayX: primaryX,
408
+ overlayY: primaryY,
330
409
  },
331
410
  {
332
- originX: 'start',
333
- originY: 'top',
334
- overlayX: 'start',
335
- overlayY: 'bottom',
411
+ originX: primaryX,
412
+ originY: primaryY,
413
+ overlayX: primaryX,
414
+ overlayY: secondaryY,
336
415
  },
337
416
  {
338
- originX: 'end',
339
- originY: 'bottom',
340
- overlayX: 'end',
341
- overlayY: 'top',
417
+ originX: secondaryX,
418
+ originY: secondaryY,
419
+ overlayX: secondaryX,
420
+ overlayY: primaryY,
342
421
  },
343
422
  {
344
- originX: 'end',
345
- originY: 'top',
346
- overlayX: 'end',
347
- overlayY: 'bottom',
423
+ originX: secondaryX,
424
+ originY: primaryY,
425
+ overlayX: secondaryX,
426
+ overlayY: secondaryY,
348
427
  },
349
428
  ]);
350
429
  }
@@ -353,7 +432,7 @@ export class MtxDatetimepicker {
353
432
  return merge(overlayRef.backdropClick(), overlayRef.detachments(), overlayRef.keydownEvents().pipe(filter(event => {
354
433
  // Closing on alt + up is only valid when there's an input associated with the datetimepicker.
355
434
  return ((event.keyCode === ESCAPE && !hasModifierKey(event)) ||
356
- (this._datetimepickerInput &&
435
+ (this.datetimepickerInput &&
357
436
  hasModifierKey(event, 'altKey') &&
358
437
  event.keyCode === UP_ARROW));
359
438
  })));
@@ -381,7 +460,7 @@ MtxDatetimepicker.ctorParameters = () => [
381
460
  { type: Overlay },
382
461
  { type: NgZone },
383
462
  { type: ViewContainerRef },
384
- { type: undefined, decorators: [{ type: Inject, args: [MAT_DATEPICKER_SCROLL_STRATEGY,] }] },
463
+ { type: undefined, decorators: [{ type: Inject, args: [MTX_DATETIMEPICKER_SCROLL_STRATEGY,] }] },
385
464
  { type: DatetimeAdapter, decorators: [{ type: Optional }] },
386
465
  { type: Directionality, decorators: [{ type: Optional }] }
387
466
  ];
@@ -392,20 +471,20 @@ MtxDatetimepicker.propDecorators = {
392
471
  startView: [{ type: Input }],
393
472
  mode: [{ type: Input }],
394
473
  timeInterval: [{ type: Input }],
395
- ariaNextMonthLabel: [{ type: Input }],
396
- ariaPrevMonthLabel: [{ type: Input }],
397
- ariaNextYearLabel: [{ type: Input }],
398
- ariaPrevYearLabel: [{ type: Input }],
399
474
  preventSameDateTimeSelection: [{ type: Input }],
400
475
  selectedChanged: [{ type: Output }],
401
- panelClass: [{ type: Input }],
402
476
  openedStream: [{ type: Output, args: ['opened',] }],
403
477
  closedStream: [{ type: Output, args: ['closed',] }],
404
478
  viewChanged: [{ type: Output }],
479
+ panelClass: [{ type: Input }],
480
+ opened: [{ type: Input }],
481
+ color: [{ type: Input }],
405
482
  startAt: [{ type: Input }],
406
- openOnFocus: [{ type: Input }],
407
483
  type: [{ type: Input }],
408
484
  touchUi: [{ type: Input }],
409
- disabled: [{ type: Input }]
485
+ disabled: [{ type: Input }],
486
+ xPosition: [{ type: Input }],
487
+ yPosition: [{ type: Input }],
488
+ restoreFocus: [{ type: Input }]
410
489
  };
411
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetimepicker.js","sourceRoot":"","sources":["../../../../projects/extensions/datetimepicker/datetimepicker.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Output,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Directionality } from '@angular/cdk/bidi';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { ESCAPE, hasModifierKey, UP_ARROW } from '@angular/cdk/keycodes';\nimport {\n  FlexibleConnectedPositionStrategy,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n} from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { MAT_DATEPICKER_SCROLL_STRATEGY } from '@angular/material/datepicker';\nimport { merge, Observable, Subject, Subscription } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DatetimeAdapter } from '@ng-matero/extensions/core';\nimport { MtxCalendarView, MtxCalendar } from './calendar';\nimport { createMissingDateImplError } from './datetimepicker-errors';\nimport { MtxDatetimepickerFilterType } from './datetimepicker-filtertype';\nimport { MtxDatetimepickerInput } from './datetimepicker-input';\nimport { _getFocusedElementPierceShadowDom } from '@angular/cdk/platform';\n\nexport type MtxDatetimepickerType = 'date' | 'time' | 'month' | 'year' | 'datetime';\nexport type MtxDatetimepickerMode = 'auto' | 'portrait' | 'landscape';\n\n/** Used to generate a unique ID for each datetimepicker instance. */\nlet datetimepickerUid = 0;\n\n/**\n * Component used as the content for the datetimepicker dialog and popup. We use this instead of\n * using MtxCalendar directly as the content so we can control the initial focus. This also gives us\n * a place to put additional features of the popup that are not part of the calendar itself in the\n * future. (e.g. confirmation buttons).\n * @docs-private\n */\n@Component({\n  selector: 'mtx-datetimepicker-content',\n  templateUrl: 'datetimepicker-content.html',\n  styleUrls: ['datetimepicker-content.scss'],\n  host: {\n    'class': 'mtx-datetimepicker-content',\n    '[class.mtx-datetimepicker-content-touch]': 'datetimepicker?.touchUi',\n    '[attr.mode]': 'datetimepicker.mode',\n  },\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MtxDatetimepickerContent<D> implements AfterContentInit {\n  datetimepicker!: MtxDatetimepicker<D>;\n\n  @ViewChild(MtxCalendar, { static: true }) _calendar!: MtxCalendar<D>;\n\n  ngAfterContentInit() {\n    this._calendar._focusActiveCell();\n  }\n\n  onSelectionChange(date: D) {\n    this.datetimepicker._select(date);\n    this.datetimepicker.close();\n  }\n}\n\n@Component({\n  selector: 'mtx-datetimepicker',\n  exportAs: 'mtxDatetimepicker',\n  template: '',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class MtxDatetimepicker<D> implements OnDestroy {\n  /** Active multi year view when click on year. */\n  @Input()\n  get multiYearSelector(): boolean {\n    return this._multiYearSelector;\n  }\n  set multiYearSelector(value: boolean) {\n    this._multiYearSelector = coerceBooleanProperty(value);\n  }\n  private _multiYearSelector = false;\n\n  /** if true change the clock to 12 hour format. */\n  @Input()\n  get twelvehour(): boolean {\n    return this._twelvehour;\n  }\n  set twelvehour(value: boolean) {\n    this._twelvehour = coerceBooleanProperty(value);\n  }\n  private _twelvehour = false;\n\n  /** The view that the calendar should start in. */\n  @Input() startView: MtxCalendarView = 'month';\n\n  @Input() mode: MtxDatetimepickerMode = 'auto';\n\n  @Input() timeInterval: number = 1;\n\n  @Input() ariaNextMonthLabel = 'Next month';\n\n  @Input() ariaPrevMonthLabel = 'Previous month';\n\n  @Input() ariaNextYearLabel = 'Next year';\n\n  @Input() ariaPrevYearLabel = 'Previous year';\n\n  /** Prevent user to select same date time */\n  @Input() preventSameDateTimeSelection = false;\n\n  /**\n   * Emits new selected date when selected date changes.\n   * @deprecated Switch to the `dateChange` and `dateInput` binding on the input element.\n   */\n  @Output() selectedChanged = new EventEmitter<D>();\n\n  /** Classes to be passed to the date picker panel. Supports the same syntax as `ngClass`. */\n  @Input() panelClass!: string | string[];\n\n  /** Emits when the datetimepicker has been opened. */\n  @Output('opened') openedStream: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Emits when the datetimepicker has been closed. */\n  @Output('closed') closedStream: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Emits when the view has been changed. */\n  @Output() viewChanged: EventEmitter<MtxCalendarView> = new EventEmitter<MtxCalendarView>();\n\n  /** Whether the calendar is open. */\n  opened = false;\n\n  /** The id for the datetimepicker calendar. */\n  id = `mtx-datetimepicker-${datetimepickerUid++}`;\n\n  /** The input element this datetimepicker is associated with. */\n  _datetimepickerInput!: MtxDatetimepickerInput<D>;\n\n  /** Emits when the datetimepicker is disabled. */\n  _disabledChange = new Subject<boolean>();\n\n  private _validSelected: D | null = null;\n\n  /** A reference to the overlay into which we've rendered the calendar. */\n  private _overlayRef!: OverlayRef | null;\n\n  /** Reference to the component instance rendered in the overlay. */\n  private _componentRef!: ComponentRef<MtxDatetimepickerContent<D>> | null;\n\n  /** The element that was focused before the datetimepicker was opened. */\n  private _focusedElementBeforeOpen: HTMLElement | null = null;\n\n  /** Unique class that will be added to the backdrop so that the test harnesses can look it up. */\n  private _backdropHarnessClass = `${this.id}-backdrop`;\n\n  private _inputStateChanges = Subscription.EMPTY;\n\n  constructor(\n    private _overlay: Overlay,\n    private _ngZone: NgZone,\n    private _viewContainerRef: ViewContainerRef,\n    @Inject(MAT_DATEPICKER_SCROLL_STRATEGY) private _scrollStrategy: any,\n    @Optional() private _dateAdapter: DatetimeAdapter<D>,\n    @Optional() private _dir: Directionality\n  ) {\n    if (!this._dateAdapter) {\n      throw createMissingDateImplError('DateAdapter');\n    }\n  }\n\n  /** The date to open the calendar to initially. */\n  @Input()\n  get startAt(): D | null {\n    // If an explicit startAt is set we start there, otherwise we start at whatever the currently\n    // selected value is.\n    return this._startAt || (this._datetimepickerInput ? this._datetimepickerInput.value : null);\n  }\n  set startAt(date: D | null) {\n    this._startAt = this._dateAdapter.getValidDateOrNull(date);\n  }\n  private _startAt!: D | null;\n\n  @Input()\n  get openOnFocus(): boolean {\n    return this._openOnFocus;\n  }\n  set openOnFocus(value: boolean) {\n    this._openOnFocus = coerceBooleanProperty(value);\n  }\n  private _openOnFocus!: boolean;\n\n  @Input()\n  get type() {\n    return this._type;\n  }\n  set type(value: MtxDatetimepickerType) {\n    this._type = value || 'date';\n  }\n  private _type: MtxDatetimepickerType = 'date';\n\n  /**\n   * Whether the calendar UI is in touch mode. In touch mode the calendar opens in a dialog rather\n   * than a popup and elements have more padding to allow for bigger touch targets.\n   */\n  @Input()\n  get touchUi(): boolean {\n    return this._touchUi;\n  }\n  set touchUi(value: boolean) {\n    this._touchUi = coerceBooleanProperty(value);\n  }\n  private _touchUi = false;\n\n  /** Whether the datetimepicker pop-up should be disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled === undefined && this._datetimepickerInput\n      ? this._datetimepickerInput.disabled\n      : !!this._disabled;\n  }\n  set disabled(value: boolean) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (newValue !== this._disabled) {\n      this._disabled = newValue;\n      this._disabledChange.next(newValue);\n    }\n  }\n  private _disabled!: boolean;\n\n  /** The currently selected date. */\n  get _selected(): D | null {\n    return this._validSelected;\n  }\n\n  set _selected(value: D | null) {\n    this._validSelected = value;\n  }\n\n  /** The minimum selectable date. */\n  get _minDate(): D | null {\n    return this._datetimepickerInput && this._datetimepickerInput.min;\n  }\n\n  /** The maximum selectable date. */\n  get _maxDate(): D | null {\n    return this._datetimepickerInput && this._datetimepickerInput.max;\n  }\n\n  get _dateFilter(): (date: D | null, type: MtxDatetimepickerFilterType) => boolean {\n    return this._datetimepickerInput && this._datetimepickerInput._dateFilter;\n  }\n\n  _viewChanged(type: MtxCalendarView): void {\n    this.viewChanged.emit(type);\n  }\n\n  ngOnDestroy() {\n    this._destroyOverlay();\n    this.close();\n    this._inputStateChanges.unsubscribe();\n    this._disabledChange.complete();\n  }\n\n  /**\n   * TODO: use model\n   * Selects the given date\n   */\n  _select(date: D): void {\n    const oldValue = this._selected;\n    this._selected = date;\n    if (!this._dateAdapter.sameDatetime(oldValue, this._selected)) {\n      this.selectedChanged.emit(date);\n    }\n  }\n\n  /**\n   * Register an input with this datetimepicker.\n   * @param input The datetimepicker input to register with this datetimepicker.\n   */\n  _registerInput(input: MtxDatetimepickerInput<D>): void {\n    if (this._datetimepickerInput) {\n      throw Error('A MtxDatetimepicker can only be associated with a single input.');\n    }\n    this._datetimepickerInput = input;\n    this._inputStateChanges = this._datetimepickerInput._valueChange.subscribe(\n      (value: D | null) => (this._selected = value)\n    );\n  }\n\n  /** Open the calendar. */\n  open(): void {\n    if (this.opened || this.disabled) {\n      return;\n    }\n    if (!this._datetimepickerInput) {\n      throw Error('Attempted to open an MtxDatetimepicker with no associated input.');\n    }\n\n    this._focusedElementBeforeOpen = _getFocusedElementPierceShadowDom();\n    this._openOverlay();\n    this.opened = true;\n    this.openedStream.emit();\n  }\n\n  /** Close the calendar. */\n  close(): void {\n    if (!this.opened) {\n      return;\n    }\n\n    if (this._componentRef) {\n      this._destroyOverlay();\n    }\n\n    const completeClose = () => {\n      // The `_opened` could've been reset already if\n      // we got two events in quick succession.\n      if (this.opened) {\n        this.opened = false;\n        this.closedStream.emit();\n        this._focusedElementBeforeOpen = null;\n      }\n    };\n\n    if (\n      this._focusedElementBeforeOpen &&\n      typeof this._focusedElementBeforeOpen.focus === 'function'\n    ) {\n      // Because IE moves focus asynchronously, we can't count on it being restored before we've\n      // marked the datetimepicker as closed. If the event fires out of sequence and the element\n      // that we're refocusing opens the datetimepicker on focus, the user could be stuck with not\n      // being able to close the calendar at all. We work around it by making the logic, that marks\n      // the datetimepicker as closed, async as well.\n      this._focusedElementBeforeOpen.focus();\n      setTimeout(completeClose);\n    } else {\n      completeClose();\n    }\n  }\n\n  /**\n   * TODO: add datetimepicker color\n   * Forwards relevant values from the datetimepicker to the\n   * datetimepicker content inside the overlay.\n   */\n  protected _forwardContentValues(instance: MtxDatetimepickerContent<D>) {\n    instance.datetimepicker = this;\n  }\n\n  /** Opens the overlay with the calendar. */\n  private _openOverlay(): void {\n    this._destroyOverlay();\n\n    const isDialog = this.touchUi;\n    const labelId = this._datetimepickerInput.getOverlayLabelId();\n\n    const portal = new ComponentPortal<MtxDatetimepickerContent<D>>(\n      MtxDatetimepickerContent,\n      this._viewContainerRef\n    );\n    const overlayRef = (this._overlayRef = this._overlay.create(\n      new OverlayConfig({\n        positionStrategy: isDialog ? this._getDialogStrategy() : this._getDropdownStrategy(),\n        hasBackdrop: true,\n        backdropClass: [\n          isDialog ? 'cdk-overlay-dark-backdrop' : 'mat-overlay-transparent-backdrop',\n          this._backdropHarnessClass,\n        ],\n        direction: this._dir,\n        scrollStrategy: isDialog ? this._overlay.scrollStrategies.block() : this._scrollStrategy(),\n        panelClass: `mtx-datetimepicker-${isDialog ? 'dialog' : 'popup'}`,\n      })\n    ));\n\n    const overlayElement = overlayRef.overlayElement;\n    overlayElement.setAttribute('role', 'dialog');\n\n    if (labelId) {\n      overlayElement.setAttribute('aria-labelledby', labelId);\n    }\n\n    if (isDialog) {\n      overlayElement.setAttribute('aria-modal', 'true');\n    }\n\n    this._getCloseStream(overlayRef).subscribe(event => {\n      if (event) {\n        event.preventDefault();\n      }\n      this.close();\n    });\n\n    this._componentRef = overlayRef.attach(portal);\n    this._forwardContentValues(this._componentRef.instance);\n\n    // Update the position once the calendar has rendered. Only relevant in dropdown mode.\n    if (!isDialog) {\n      this._ngZone.onStable.pipe(take(1)).subscribe(() => overlayRef.updatePosition());\n    }\n  }\n\n  /** Destroys the current overlay. */\n  private _destroyOverlay() {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = this._componentRef = null;\n    }\n  }\n\n  /** Gets a position strategy that will open the calendar as a dropdown. */\n  private _getDialogStrategy() {\n    return this._overlay.position().global().centerHorizontally().centerVertically();\n  }\n\n  /** Gets a position strategy that will open the calendar as a dropdown. */\n  private _getDropdownStrategy() {\n    const strategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this._datetimepickerInput.getConnectedOverlayOrigin())\n      .withTransformOriginOn('.mtx-datetimepicker-content')\n      .withFlexibleDimensions(false)\n      .withViewportMargin(8)\n      .withLockedPosition();\n\n    return this._setConnectedPositions(strategy);\n  }\n\n  /**\n   * TODO: `xPosition` and `yPosition`\n   * Sets the positions of the datetimepicker in dropdown mode based on the current configuration.\n   */\n  private _setConnectedPositions(strategy: FlexibleConnectedPositionStrategy) {\n    return strategy.withPositions([\n      {\n        originX: 'start',\n        originY: 'bottom',\n        overlayX: 'start',\n        overlayY: 'top',\n      },\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'bottom',\n      },\n      {\n        originX: 'end',\n        originY: 'bottom',\n        overlayX: 'end',\n        overlayY: 'top',\n      },\n      {\n        originX: 'end',\n        originY: 'top',\n        overlayX: 'end',\n        overlayY: 'bottom',\n      },\n    ]);\n  }\n\n  /** Gets an observable that will emit when the overlay is supposed to be closed. */\n  private _getCloseStream(overlayRef: OverlayRef) {\n    return merge(\n      overlayRef.backdropClick(),\n      overlayRef.detachments(),\n      overlayRef.keydownEvents().pipe(\n        filter(event => {\n          // Closing on alt + up is only valid when there's an input associated with the datetimepicker.\n          return (\n            (event.keyCode === ESCAPE && !hasModifierKey(event)) ||\n            (this._datetimepickerInput &&\n              hasModifierKey(event, 'altKey') &&\n              event.keyCode === UP_ARROW)\n          );\n        })\n      )\n    );\n  }\n\n  static ngAcceptInputType_multiYearSelector: BooleanInput;\n  static ngAcceptInputType_twelvehour: BooleanInput;\n  static ngAcceptInputType_touchUi: BooleanInput;\n  static ngAcceptInputType_disabled: BooleanInput;\n  static ngAcceptInputType_openOnFocus: BooleanInput;\n}\n"]}
490
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetimepicker.js","sourceRoot":"","sources":["../../../../projects/extensions/datetimepicker/datetimepicker.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Directionality } from '@angular/cdk/bidi';\nimport { BooleanInput, coerceBooleanProperty, coerceStringArray } from '@angular/cdk/coercion';\nimport { ESCAPE, hasModifierKey, UP_ARROW } from '@angular/cdk/keycodes';\nimport {\n  FlexibleConnectedPositionStrategy,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ScrollStrategy,\n} from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { _getFocusedElementPierceShadowDom } from '@angular/cdk/platform';\nimport { CanColor, mixinColor, ThemePalette } from '@angular/material/core';\nimport { merge, Subject, Subscription } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { DatetimeAdapter } from '@ng-matero/extensions/core';\nimport { MtxCalendarView, MtxCalendar } from './calendar';\nimport { createMissingDateImplError } from './datetimepicker-errors';\nimport { MtxDatetimepickerFilterType } from './datetimepicker-filtertype';\nimport { MtxDatetimepickerInput } from './datetimepicker-input';\nimport { mtxDatetimepickerAnimations } from './datetimepicker-animations';\n\n/** Used to generate a unique ID for each datetimepicker instance. */\nlet datetimepickerUid = 0;\n\nexport type MtxDatetimepickerType = 'date' | 'time' | 'month' | 'year' | 'datetime';\n\nexport type MtxDatetimepickerMode = 'auto' | 'portrait' | 'landscape';\n\n/** Possible positions for the colorpicker dropdown along the X axis. */\nexport type DatetimepickerDropdownPositionX = 'start' | 'end';\n\n/** Possible positions for the colorpicker dropdown along the Y axis. */\nexport type DatetimepickerDropdownPositionY = 'above' | 'below';\n\n/** Injection token that determines the scroll handling while the calendar is open. */\nexport const MTX_DATETIMEPICKER_SCROLL_STRATEGY = new InjectionToken<() => ScrollStrategy>(\n  'mtx-datetimepicker-scroll-strategy'\n);\n\nexport function MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY(overlay: Overlay): () => ScrollStrategy {\n  return () => overlay.scrollStrategies.reposition();\n}\n\nexport const MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY_PROVIDER = {\n  provide: MTX_DATETIMEPICKER_SCROLL_STRATEGY,\n  deps: [Overlay],\n  useFactory: MTX_DATETIMEPICKER_SCROLL_STRATEGY_FACTORY,\n};\n\n// Boilerplate for applying mixins to MtxDatetimepickerContent.\n/** @docs-private */\nconst _MtxDatetimepickerContentBase = mixinColor(\n  class {\n    constructor(public _elementRef: ElementRef) {}\n  }\n);\n\n/**\n * Component used as the content for the datetimepicker dialog and popup. We use this instead of\n * using MtxCalendar directly as the content so we can control the initial focus. This also gives us\n * a place to put additional features of the popup that are not part of the calendar itself in the\n * future. (e.g. confirmation buttons).\n * @docs-private\n */\n@Component({\n  selector: 'mtx-datetimepicker-content',\n  templateUrl: 'datetimepicker-content.html',\n  styleUrls: ['datetimepicker-content.scss'],\n  host: {\n    'class': 'mtx-datetimepicker-content',\n    '[class.mtx-datetimepicker-content-touch]': 'datetimepicker?.touchUi',\n    '[attr.mode]': 'datetimepicker.mode',\n    '[@transformPanel]': '_animationState',\n    '(@transformPanel.done)': '_animationDone.next()',\n  },\n  animations: [\n    mtxDatetimepickerAnimations.transformPanel,\n    mtxDatetimepickerAnimations.fadeInCalendar,\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  inputs: ['color'],\n})\nexport class MtxDatetimepickerContent<D>\n  extends _MtxDatetimepickerContentBase\n  implements OnInit, AfterContentInit, OnDestroy, CanColor\n{\n  @ViewChild(MtxCalendar, { static: true }) _calendar!: MtxCalendar<D>;\n\n  datetimepicker!: MtxDatetimepicker<D>;\n\n  /** Whether the datetimepicker is above or below the input. */\n  _isAbove!: boolean;\n\n  /** Current state of the animation. */\n  _animationState!: 'enter-dropdown' | 'enter-dialog' | 'void';\n\n  /** Emits when an animation has finished. */\n  readonly _animationDone = new Subject<void>();\n\n  constructor(elementRef: ElementRef, private _changeDetectorRef: ChangeDetectorRef) {\n    super(elementRef);\n  }\n\n  ngOnInit() {\n    this._animationState = this.datetimepicker.touchUi ? 'enter-dialog' : 'enter-dropdown';\n  }\n\n  ngAfterContentInit() {\n    this._calendar._focusActiveCell();\n  }\n\n  _startExitAnimation() {\n    this._animationState = 'void';\n    this._changeDetectorRef.markForCheck();\n  }\n\n  ngOnDestroy() {\n    this._animationDone.complete();\n  }\n}\n\n@Component({\n  selector: 'mtx-datetimepicker',\n  exportAs: 'mtxDatetimepicker',\n  template: '',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class MtxDatetimepicker<D> implements OnDestroy {\n  /** Active multi year view when click on year. */\n  @Input()\n  get multiYearSelector(): boolean {\n    return this._multiYearSelector;\n  }\n  set multiYearSelector(value: boolean) {\n    this._multiYearSelector = coerceBooleanProperty(value);\n  }\n  private _multiYearSelector = false;\n\n  /** if true change the clock to 12 hour format. */\n  @Input()\n  get twelvehour(): boolean {\n    return this._twelvehour;\n  }\n  set twelvehour(value: boolean) {\n    this._twelvehour = coerceBooleanProperty(value);\n  }\n  private _twelvehour = false;\n\n  /** The view that the calendar should start in. */\n  @Input() startView: MtxCalendarView = 'month';\n\n  @Input() mode: MtxDatetimepickerMode = 'auto';\n\n  @Input() timeInterval: number = 1;\n\n  /** Prevent user to select same date time */\n  @Input() preventSameDateTimeSelection = false;\n\n  /**\n   * Emits new selected date when selected date changes.\n   * @deprecated Switch to the `dateChange` and `dateInput` binding on the input element.\n   */\n  @Output() selectedChanged = new EventEmitter<D>();\n\n  /** Emits when the datetimepicker has been opened. */\n  @Output('opened') openedStream: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Emits when the datetimepicker has been closed. */\n  @Output('closed') closedStream: EventEmitter<void> = new EventEmitter<void>();\n\n  /** Emits when the view has been changed. */\n  @Output() viewChanged: EventEmitter<MtxCalendarView> = new EventEmitter<MtxCalendarView>();\n\n  /**\n   * Classes to be passed to the date picker panel.\n   * Supports string and string array values, similar to `ngClass`.\n   */\n  @Input()\n  get panelClass(): string | string[] {\n    return this._panelClass;\n  }\n  set panelClass(value: string | string[]) {\n    this._panelClass = coerceStringArray(value);\n  }\n  private _panelClass!: string[];\n\n  /** Whether the calendar is open. */\n  @Input()\n  get opened(): boolean {\n    return this._opened;\n  }\n  set opened(value: boolean) {\n    coerceBooleanProperty(value) ? this.open() : this.close();\n  }\n  private _opened = false;\n\n  /** The id for the datetimepicker calendar. */\n  id = `mtx-datetimepicker-${datetimepickerUid++}`;\n\n  /** Color palette to use on the datetimepicker's calendar. */\n  @Input()\n  get color(): ThemePalette {\n    return (\n      this._color ||\n      (this.datetimepickerInput ? this.datetimepickerInput.getThemePalette() : undefined)\n    );\n  }\n  set color(value: ThemePalette) {\n    this._color = value;\n  }\n  private _color: ThemePalette;\n\n  /** The input element this datetimepicker is associated with. */\n  datetimepickerInput!: MtxDatetimepickerInput<D>;\n\n  /** Emits when the datetimepicker is disabled. */\n  _disabledChange = new Subject<boolean>();\n\n  private _validSelected: D | null = null;\n\n  /** A reference to the overlay into which we've rendered the calendar. */\n  private _overlayRef!: OverlayRef | null;\n\n  /** Reference to the component instance rendered in the overlay. */\n  private _componentRef!: ComponentRef<MtxDatetimepickerContent<D>> | null;\n\n  /** The element that was focused before the datetimepicker was opened. */\n  private _focusedElementBeforeOpen: HTMLElement | null = null;\n\n  /** Unique class that will be added to the backdrop so that the test harnesses can look it up. */\n  private _backdropHarnessClass = `${this.id}-backdrop`;\n\n  private _inputStateChanges = Subscription.EMPTY;\n\n  constructor(\n    private _overlay: Overlay,\n    private _ngZone: NgZone,\n    private _viewContainerRef: ViewContainerRef,\n    @Inject(MTX_DATETIMEPICKER_SCROLL_STRATEGY) private _scrollStrategy: any,\n    @Optional() private _dateAdapter: DatetimeAdapter<D>,\n    @Optional() private _dir: Directionality\n  ) {\n    if (!this._dateAdapter) {\n      throw createMissingDateImplError('DateAdapter');\n    }\n  }\n\n  /** The date to open the calendar to initially. */\n  @Input()\n  get startAt(): D | null {\n    // If an explicit startAt is set we start there, otherwise we start at whatever the currently\n    // selected value is.\n    return this._startAt || (this.datetimepickerInput ? this.datetimepickerInput.value : null);\n  }\n  set startAt(date: D | null) {\n    this._startAt = this._dateAdapter.getValidDateOrNull(date);\n  }\n  private _startAt!: D | null;\n\n  @Input()\n  get type() {\n    return this._type;\n  }\n  set type(value: MtxDatetimepickerType) {\n    this._type = value || 'date';\n  }\n  private _type: MtxDatetimepickerType = 'date';\n\n  /**\n   * Whether the calendar UI is in touch mode. In touch mode the calendar opens in a dialog rather\n   * than a popup and elements have more padding to allow for bigger touch targets.\n   */\n  @Input()\n  get touchUi(): boolean {\n    return this._touchUi;\n  }\n  set touchUi(value: boolean) {\n    this._touchUi = coerceBooleanProperty(value);\n  }\n  private _touchUi = false;\n\n  /** Whether the datetimepicker pop-up should be disabled. */\n  @Input()\n  get disabled(): boolean {\n    return this._disabled === undefined && this.datetimepickerInput\n      ? this.datetimepickerInput.disabled\n      : !!this._disabled;\n  }\n  set disabled(value: boolean) {\n    const newValue = coerceBooleanProperty(value);\n\n    if (newValue !== this._disabled) {\n      this._disabled = newValue;\n      this._disabledChange.next(newValue);\n    }\n  }\n  private _disabled!: boolean;\n\n  /** Preferred position of the datetimepicker in the X axis. */\n  @Input()\n  xPosition: DatetimepickerDropdownPositionX = 'start';\n\n  /** Preferred position of the datetimepicker in the Y axis. */\n  @Input()\n  yPosition: DatetimepickerDropdownPositionY = 'below';\n\n  /**\n   * Whether to restore focus to the previously-focused element when the panel is closed.\n   * Note that automatic focus restoration is an accessibility feature and it is recommended that\n   * you provide your own equivalent, if you decide to turn it off.\n   */\n  @Input()\n  get restoreFocus(): boolean {\n    return this._restoreFocus;\n  }\n  set restoreFocus(value: boolean) {\n    this._restoreFocus = coerceBooleanProperty(value);\n  }\n  private _restoreFocus = true;\n\n  /** The currently selected date. */\n  get _selected(): D | null {\n    return this._validSelected;\n  }\n\n  set _selected(value: D | null) {\n    this._validSelected = value;\n  }\n\n  /** The minimum selectable date. */\n  get _minDate(): D | null {\n    return this.datetimepickerInput && this.datetimepickerInput.min;\n  }\n\n  /** The maximum selectable date. */\n  get _maxDate(): D | null {\n    return this.datetimepickerInput && this.datetimepickerInput.max;\n  }\n\n  get _dateFilter(): (date: D | null, type: MtxDatetimepickerFilterType) => boolean {\n    return this.datetimepickerInput && this.datetimepickerInput._dateFilter;\n  }\n\n  _viewChanged(type: MtxCalendarView): void {\n    this.viewChanged.emit(type);\n  }\n\n  ngOnDestroy() {\n    this._destroyOverlay();\n    this.close();\n    this._inputStateChanges.unsubscribe();\n    this._disabledChange.complete();\n  }\n\n  /** Selects the given date */\n  _select(date: D): void {\n    const oldValue = this._selected;\n    this._selected = date;\n    if (!this._dateAdapter.sameDatetime(oldValue, this._selected)) {\n      this.selectedChanged.emit(date);\n    }\n  }\n\n  /**\n   * Register an input with this datetimepicker.\n   * @param input The datetimepicker input to register with this datetimepicker.\n   */\n  _registerInput(input: MtxDatetimepickerInput<D>): void {\n    if (this.datetimepickerInput) {\n      throw Error('A MtxDatetimepicker can only be associated with a single input.');\n    }\n    this.datetimepickerInput = input;\n    this._inputStateChanges = this.datetimepickerInput._valueChange.subscribe(\n      (value: D | null) => (this._selected = value)\n    );\n  }\n\n  /** Open the calendar. */\n  open(): void {\n    if (this._opened || this.disabled) {\n      return;\n    }\n    if (!this.datetimepickerInput) {\n      throw Error('Attempted to open an MtxDatetimepicker with no associated input.');\n    }\n\n    this._focusedElementBeforeOpen = _getFocusedElementPierceShadowDom();\n    this._openOverlay();\n    this._opened = true;\n    this.openedStream.emit();\n  }\n\n  /** Close the calendar. */\n  close(): void {\n    if (!this._opened) {\n      return;\n    }\n\n    if (this._componentRef) {\n      this._destroyOverlay();\n    }\n\n    const completeClose = () => {\n      // The `_opened` could've been reset already if\n      // we got two events in quick succession.\n      if (this._opened) {\n        this._opened = false;\n        this.closedStream.emit();\n        this._focusedElementBeforeOpen = null;\n      }\n    };\n\n    if (\n      this._restoreFocus &&\n      this._focusedElementBeforeOpen &&\n      typeof this._focusedElementBeforeOpen.focus === 'function'\n    ) {\n      // Because IE moves focus asynchronously, we can't count on it being restored before we've\n      // marked the datetimepicker as closed. If the event fires out of sequence and the element\n      // that we're refocusing opens the datetimepicker on focus, the user could be stuck with not\n      // being able to close the calendar at all. We work around it by making the logic, that marks\n      // the datetimepicker as closed, async as well.\n      this._focusedElementBeforeOpen.focus();\n      setTimeout(completeClose);\n    } else {\n      completeClose();\n    }\n  }\n\n  /**\n   * Forwards relevant values from the datetimepicker to the\n   * datetimepicker content inside the overlay.\n   */\n  protected _forwardContentValues(instance: MtxDatetimepickerContent<D>) {\n    instance.datetimepicker = this;\n    instance.color = this.color;\n  }\n\n  /** Opens the overlay with the calendar. */\n  private _openOverlay(): void {\n    this._destroyOverlay();\n\n    const isDialog = this.touchUi;\n    const labelId = this.datetimepickerInput.getOverlayLabelId();\n\n    const portal = new ComponentPortal<MtxDatetimepickerContent<D>>(\n      MtxDatetimepickerContent,\n      this._viewContainerRef\n    );\n    const overlayRef = (this._overlayRef = this._overlay.create(\n      new OverlayConfig({\n        positionStrategy: isDialog ? this._getDialogStrategy() : this._getDropdownStrategy(),\n        hasBackdrop: true,\n        backdropClass: [\n          isDialog ? 'cdk-overlay-dark-backdrop' : 'mat-overlay-transparent-backdrop',\n          this._backdropHarnessClass,\n        ],\n        direction: this._dir,\n        scrollStrategy: isDialog ? this._overlay.scrollStrategies.block() : this._scrollStrategy(),\n        panelClass: `mtx-datetimepicker-${isDialog ? 'dialog' : 'popup'}`,\n      })\n    ));\n\n    const overlayElement = overlayRef.overlayElement;\n    overlayElement.setAttribute('role', 'dialog');\n\n    if (labelId) {\n      overlayElement.setAttribute('aria-labelledby', labelId);\n    }\n\n    if (isDialog) {\n      overlayElement.setAttribute('aria-modal', 'true');\n    }\n\n    this._getCloseStream(overlayRef).subscribe(event => {\n      if (event) {\n        event.preventDefault();\n      }\n      this.close();\n    });\n\n    this._componentRef = overlayRef.attach(portal);\n    this._forwardContentValues(this._componentRef.instance);\n\n    // Update the position once the calendar has rendered. Only relevant in dropdown mode.\n    if (!isDialog) {\n      this._ngZone.onStable.pipe(take(1)).subscribe(() => overlayRef.updatePosition());\n    }\n  }\n\n  /** Destroys the current overlay. */\n  private _destroyOverlay() {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = this._componentRef = null;\n    }\n  }\n\n  /** Gets a position strategy that will open the calendar as a dropdown. */\n  private _getDialogStrategy() {\n    return this._overlay.position().global().centerHorizontally().centerVertically();\n  }\n\n  /** Gets a position strategy that will open the calendar as a dropdown. */\n  private _getDropdownStrategy() {\n    const strategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this.datetimepickerInput.getConnectedOverlayOrigin())\n      .withTransformOriginOn('.mtx-datetimepicker-content')\n      .withFlexibleDimensions(false)\n      .withViewportMargin(8)\n      .withLockedPosition();\n\n    return this._setConnectedPositions(strategy);\n  }\n\n  /**\n   * Sets the positions of the datetimepicker in dropdown mode based on the current configuration.\n   */\n  private _setConnectedPositions(strategy: FlexibleConnectedPositionStrategy) {\n    const primaryX = this.xPosition === 'end' ? 'end' : 'start';\n    const secondaryX = primaryX === 'start' ? 'end' : 'start';\n    const primaryY = this.yPosition === 'above' ? 'bottom' : 'top';\n    const secondaryY = primaryY === 'top' ? 'bottom' : 'top';\n\n    return strategy.withPositions([\n      {\n        originX: primaryX,\n        originY: secondaryY,\n        overlayX: primaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: primaryX,\n        originY: primaryY,\n        overlayX: primaryX,\n        overlayY: secondaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: secondaryY,\n        overlayX: secondaryX,\n        overlayY: primaryY,\n      },\n      {\n        originX: secondaryX,\n        originY: primaryY,\n        overlayX: secondaryX,\n        overlayY: secondaryY,\n      },\n    ]);\n  }\n\n  /** Gets an observable that will emit when the overlay is supposed to be closed. */\n  private _getCloseStream(overlayRef: OverlayRef) {\n    return merge(\n      overlayRef.backdropClick(),\n      overlayRef.detachments(),\n      overlayRef.keydownEvents().pipe(\n        filter(event => {\n          // Closing on alt + up is only valid when there's an input associated with the datetimepicker.\n          return (\n            (event.keyCode === ESCAPE && !hasModifierKey(event)) ||\n            (this.datetimepickerInput &&\n              hasModifierKey(event, 'altKey') &&\n              event.keyCode === UP_ARROW)\n          );\n        })\n      )\n    );\n  }\n\n  static ngAcceptInputType_multiYearSelector: BooleanInput;\n  static ngAcceptInputType_twelvehour: BooleanInput;\n  static ngAcceptInputType_preventSameDateTimeSelection: BooleanInput;\n  static ngAcceptInputType_disabled: BooleanInput;\n  static ngAcceptInputType_opened: BooleanInput;\n  static ngAcceptInputType_touchUi: BooleanInput;\n  static ngAcceptInputType_restoreFocus: BooleanInput;\n}\n"]}