@hug/ngx-time-picker 1.1.13 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,172 +1,186 @@
1
- ## 1.1.13 (2024-08-03)
1
+ # 2.0.0 (2024-09-11)
2
2
 
3
3
 
4
- ### 🐛 Fixes
4
+ ### 🚀 Features
5
5
 
6
- - **ngx-time-picker:** fix NG_VALUE_ACCESSOR error ([ec24577](https://github.com/DSI-HUG/ngx-components/commit/ec24577))
6
+ - update to angular 15 - FC-67 ([6bad712](https://github.com/DSI-HUG/ngx-components/commit/6bad712))
7
7
 
8
+ - update material to angular 15 - FC-67 ([44406c1](https://github.com/DSI-HUG/ngx-components/commit/44406c1))
8
9
 
9
- ### ❤️ Thank You
10
+ - time picker angular15 ([1d53f68](https://github.com/DSI-HUG/ngx-components/commit/1d53f68))
10
11
 
11
- - Serge
12
+ - remove NgxDetroy ([c64d8bb](https://github.com/DSI-HUG/ngx-components/commit/c64d8bb))
12
13
 
13
- ## 1.1.12 (2024-08-03)
14
+ - prettier ([2aa36f0](https://github.com/DSI-HUG/ngx-components/commit/2aa36f0))
15
+
16
+ - **ng18:** remove no more necessary files ([54c46a1](https://github.com/DSI-HUG/ngx-components/commit/54c46a1))
14
17
 
15
18
 
16
19
  ### 🐛 Fixes
17
20
 
18
- - **ngx-time-picker:** fix NG_VALUE_ACCESSOR error ([28bce28](https://github.com/DSI-HUG/ngx-components/commit/28bce28))
21
+ - lint ([11a9b75](https://github.com/DSI-HUG/ngx-components/commit/11a9b75))
19
22
 
23
+ - correctif passage compelt ng18 ([3fe864e](https://github.com/DSI-HUG/ngx-components/commit/3fe864e))
20
24
 
21
- ### ❤️ Thank You
25
+ - **ci:** tests ([9387ba8](https://github.com/DSI-HUG/ngx-components/commit/9387ba8))
22
26
 
23
- - Serge
24
-
25
- ## 1.1.11 (2024-08-03)
26
27
 
28
+ ### 🌱 Dependencies
27
29
 
28
- ### 🐛 Fixes
30
+ - **@hug/ngx-numeric-stepper:** upgrade to v2.0.0 ([67c347f](https://github.com/DSI-HUG/ngx-components/commit/67c347f))
29
31
 
30
- - **ngx-time-picker:** fix NG_VALUE_ACCESSOR error ([01df020](https://github.com/DSI-HUG/ngx-components/commit/01df020))
32
+ - **@hug/ngx-core:** upgrade to v2.0.0 ([ce6226c](https://github.com/DSI-HUG/ngx-components/commit/ce6226c))
31
33
 
32
34
 
33
35
  ### ❤️ Thank You
34
36
 
35
- - Serge
37
+ - Badisi
38
+ - dsi-hug-bot @dsi-hug-bot
39
+ - rfrt
36
40
 
37
- ## 1.1.10 (2024-07-25)
41
+ ## 1.1.13 (2024-08-03)
42
+
43
+ ### 🐛 Fixes
44
+
45
+ - **ngx-time-picker:** fix NG_VALUE_ACCESSOR error ([ec24577](https://github.com/DSI-HUG/ngx-components/commit/ec24577))
46
+
47
+ ### ❤️ Thank You
48
+
49
+ - Serge
38
50
 
51
+ ## 1.1.12 (2024-08-03)
39
52
 
40
53
  ### 🐛 Fixes
41
54
 
42
- - **ngx-time-picker:** update patch version ([98352e2](https://github.com/DSI-HUG/ngx-components/commit/98352e2))
55
+ - **ngx-time-picker:** fix NG_VALUE_ACCESSOR error ([28bce28](https://github.com/DSI-HUG/ngx-components/commit/28bce28))
43
56
 
57
+ ### ❤️ Thank You
44
58
 
45
- ### 🌱 Dependencies
59
+ - Serge
46
60
 
47
- - **@hug/ngx-numeric-stepper:** upgrade to v1.1.11 ([71e5911](https://github.com/DSI-HUG/ngx-components/commit/71e5911))
61
+ ## 1.1.11 (2024-08-03)
48
62
 
49
- - **@hug/ngx-core:** upgrade to v1.1.14 ([12ee5d4](https://github.com/DSI-HUG/ngx-components/commit/12ee5d4))
63
+ ### 🐛 Fixes
50
64
 
65
+ - **ngx-time-picker:** fix NG_VALUE_ACCESSOR error ([01df020](https://github.com/DSI-HUG/ngx-components/commit/01df020))
51
66
 
52
- ### ❤️ Thank You
67
+ ### ❤️ Thank You
53
68
 
54
- - dsi-hug-bot @dsi-hug-bot
55
- - Serge
69
+ - Serge
56
70
 
57
- ## 1.1.9 (2024-07-25)
71
+ ## 1.1.10 (2024-07-25)
58
72
 
73
+ ### 🐛 Fixes
74
+
75
+ - **ngx-time-picker:** update patch version ([98352e2](https://github.com/DSI-HUG/ngx-components/commit/98352e2))
59
76
 
60
77
  ### 🌱 Dependencies
61
78
 
62
- - **@hug/ngx-core:** upgrade to v1.1.13 ([15e11d7](https://github.com/DSI-HUG/ngx-components/commit/15e11d7))
79
+ - **@hug/ngx-numeric-stepper:** upgrade to v1.1.11 ([71e5911](https://github.com/DSI-HUG/ngx-components/commit/71e5911))
63
80
 
81
+ - **@hug/ngx-core:** upgrade to v1.1.14 ([12ee5d4](https://github.com/DSI-HUG/ngx-components/commit/12ee5d4))
64
82
 
65
- ### ❤️ Thank You
83
+ ### ❤️ Thank You
66
84
 
67
- - dsi-hug-bot @dsi-hug-bot
85
+ - dsi-hug-bot @dsi-hug-bot
86
+ - Serge
68
87
 
69
- ## 1.1.8 (2024-07-24)
88
+ ## 1.1.9 (2024-07-25)
70
89
 
90
+ ### 🌱 Dependencies
71
91
 
72
- ### 🐛 Fixes
92
+ - **@hug/ngx-core:** upgrade to v1.1.13 ([15e11d7](https://github.com/DSI-HUG/ngx-components/commit/15e11d7))
73
93
 
74
- - **ngx-time-picker:** update patch version ([f8a7d86](https://github.com/DSI-HUG/ngx-components/commit/f8a7d86))
94
+ ### ❤️ Thank You
75
95
 
96
+ - dsi-hug-bot @dsi-hug-bot
76
97
 
77
- ### 🌱 Dependencies
98
+ ## 1.1.8 (2024-07-24)
78
99
 
79
- - **@hug/ngx-numeric-stepper:** upgrade to v1.1.9 ([34f74e7](https://github.com/DSI-HUG/ngx-components/commit/34f74e7))
100
+ ### 🐛 Fixes
80
101
 
81
- - **@hug/ngx-core:** upgrade to v1.1.12 ([78a2936](https://github.com/DSI-HUG/ngx-components/commit/78a2936))
102
+ - **ngx-time-picker:** update patch version ([f8a7d86](https://github.com/DSI-HUG/ngx-components/commit/f8a7d86))
82
103
 
104
+ ### 🌱 Dependencies
83
105
 
84
- ### ❤️ Thank You
106
+ - **@hug/ngx-numeric-stepper:** upgrade to v1.1.9 ([34f74e7](https://github.com/DSI-HUG/ngx-components/commit/34f74e7))
85
107
 
86
- - dsi-hug-bot @dsi-hug-bot
87
- - Serge
108
+ - **@hug/ngx-core:** upgrade to v1.1.12 ([78a2936](https://github.com/DSI-HUG/ngx-components/commit/78a2936))
88
109
 
89
- ## 1.1.7 (2024-07-24)
110
+ ### ❤️ Thank You
90
111
 
112
+ - dsi-hug-bot @dsi-hug-bot
113
+ - Serge
91
114
 
92
- ### 🐛 Fixes
115
+ ## 1.1.7 (2024-07-24)
93
116
 
94
- - **ngx-time-picker:** update patch version ([f251f4a](https://github.com/DSI-HUG/ngx-components/commit/f251f4a))
117
+ ### 🐛 Fixes
95
118
 
119
+ - **ngx-time-picker:** update patch version ([f251f4a](https://github.com/DSI-HUG/ngx-components/commit/f251f4a))
96
120
 
97
121
  ### 🌱 Dependencies
98
122
 
99
- - **@hug/ngx-core:** upgrade to v1.1.11 ([bda1d8c](https://github.com/DSI-HUG/ngx-components/commit/bda1d8c))
100
-
101
- - **@hug/ngx-numeric-stepper:** upgrade to v1.1.8 ([b79bfa0](https://github.com/DSI-HUG/ngx-components/commit/b79bfa0))
123
+ - **@hug/ngx-core:** upgrade to v1.1.11 ([bda1d8c](https://github.com/DSI-HUG/ngx-components/commit/bda1d8c))
102
124
 
125
+ - **@hug/ngx-numeric-stepper:** upgrade to v1.1.8 ([b79bfa0](https://github.com/DSI-HUG/ngx-components/commit/b79bfa0))
103
126
 
104
- ### ❤️ Thank You
127
+ ### ❤️ Thank You
105
128
 
106
- - dsi-hug-bot @dsi-hug-bot
107
- - Serge
129
+ - dsi-hug-bot @dsi-hug-bot
130
+ - Serge
108
131
 
109
132
  ## 1.1.6 (2024-07-23)
110
133
 
111
-
112
134
  ### 🐛 Fixes
113
135
 
114
- - **ngx-time-picker:** compile path ([5fdb256](https://github.com/DSI-HUG/ngx-components/commit/5fdb256))
115
-
136
+ - **ngx-time-picker:** compile path ([5fdb256](https://github.com/DSI-HUG/ngx-components/commit/5fdb256))
116
137
 
117
138
  ### 🌱 Dependencies
118
139
 
119
- - **@hug/ngx-core:** upgrade to v1.1.9 ([3692c68](https://github.com/DSI-HUG/ngx-components/commit/3692c68))
120
-
121
- - **@hug/ngx-numeric-stepper:** upgrade to v1.1.7 ([1d42ddd](https://github.com/DSI-HUG/ngx-components/commit/1d42ddd))
140
+ - **@hug/ngx-core:** upgrade to v1.1.9 ([3692c68](https://github.com/DSI-HUG/ngx-components/commit/3692c68))
122
141
 
123
- - **@hug/ngx-core:** upgrade to v1.1.10 ([78dbe21](https://github.com/DSI-HUG/ngx-components/commit/78dbe21))
142
+ - **@hug/ngx-numeric-stepper:** upgrade to v1.1.7 ([1d42ddd](https://github.com/DSI-HUG/ngx-components/commit/1d42ddd))
124
143
 
144
+ - **@hug/ngx-core:** upgrade to v1.1.10 ([78dbe21](https://github.com/DSI-HUG/ngx-components/commit/78dbe21))
125
145
 
126
- ### ❤️ Thank You
146
+ ### ❤️ Thank You
127
147
 
128
- - dsi-hug-bot @dsi-hug-bot
129
- - Serge
148
+ - dsi-hug-bot @dsi-hug-bot
149
+ - Serge
130
150
 
131
151
  ## 1.1.5 (2024-07-23)
132
152
 
133
-
134
153
  ### 🐛 Fixes
135
154
 
136
- - **ngx-time-picker:** ngx prefix ([2c62859](https://github.com/DSI-HUG/ngx-components/commit/2c62859))
137
-
138
- - **ngx-time-picker:** ngx prefix ([bd4b65e](https://github.com/DSI-HUG/ngx-components/commit/bd4b65e))
155
+ - **ngx-time-picker:** ngx prefix ([2c62859](https://github.com/DSI-HUG/ngx-components/commit/2c62859))
139
156
 
157
+ - **ngx-time-picker:** ngx prefix ([bd4b65e](https://github.com/DSI-HUG/ngx-components/commit/bd4b65e))
140
158
 
141
159
  ### 🌱 Dependencies
142
160
 
143
- - **@hug/ngx-numeric-stepper:** upgrade to v1.1.6 ([094b0f2](https://github.com/DSI-HUG/ngx-components/commit/094b0f2))
161
+ - **@hug/ngx-numeric-stepper:** upgrade to v1.1.6 ([094b0f2](https://github.com/DSI-HUG/ngx-components/commit/094b0f2))
144
162
 
163
+ ### ❤️ Thank You
145
164
 
146
- ### ❤️ Thank You
147
-
148
- - dsi-hug-bot @dsi-hug-bot
149
- - Serge
165
+ - dsi-hug-bot @dsi-hug-bot
166
+ - Serge
150
167
 
151
168
  ## 1.1.4 (2024-07-23)
152
169
 
153
-
154
170
  ### 🐛 Fixes
155
171
 
156
- - **ngx-time-picker:** use inject ([16ab25a](https://github.com/DSI-HUG/ngx-components/commit/16ab25a))
157
-
172
+ - **ngx-time-picker:** use inject ([16ab25a](https://github.com/DSI-HUG/ngx-components/commit/16ab25a))
158
173
 
159
174
  ### 🌱 Dependencies
160
175
 
161
- - **@hug/ngx-core:** upgrade to v1.1.8 ([26f0d10](https://github.com/DSI-HUG/ngx-components/commit/26f0d10))
176
+ - **@hug/ngx-core:** upgrade to v1.1.8 ([26f0d10](https://github.com/DSI-HUG/ngx-components/commit/26f0d10))
162
177
 
163
- - **@hug/ngx-numeric-stepper:** upgrade to v1.1.5 ([a76174a](https://github.com/DSI-HUG/ngx-components/commit/a76174a))
178
+ - **@hug/ngx-numeric-stepper:** upgrade to v1.1.5 ([a76174a](https://github.com/DSI-HUG/ngx-components/commit/a76174a))
164
179
 
180
+ ### ❤️ Thank You
165
181
 
166
- ### ❤️ Thank You
167
-
168
- - dsi-hug-bot @dsi-hug-bot
169
- - Serge
182
+ - dsi-hug-bot @dsi-hug-bot
183
+ - Serge
170
184
 
171
185
  ## 1.1.3 (2024-07-08)
172
186
 
package/README.md CHANGED
@@ -1,4 +1,5 @@
1
- # @hug/ngx-time-picker
1
+ @hug/ngx-time-picker
2
+ =======
2
3
 
3
4
  The sources for this package are in the main [DSI-HUG/ngx-components](https://github.com/dsi-hug/ngx-components) repo. Please file issues and pull requests against that repo.
4
5
 
@@ -0,0 +1,298 @@
1
+ import { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
2
+ import { DecimalPipe } from '@angular/common';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, DestroyRef, EventEmitter, inject, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
4
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
5
+ import { FormsModule, NgControl } from '@angular/forms';
6
+ import { MatFormField } from '@angular/material/form-field';
7
+ import { MatInput } from '@angular/material/input';
8
+ import { NgxNumericStepperComponent } from '@hug/ngx-numeric-stepper';
9
+ import { isSameHour, set } from 'date-fns';
10
+ import { debounce, distinctUntilChanged, map, Subject, timer } from 'rxjs';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/forms";
13
+ // TODO sdil refactor rxjs flows
14
+ export class NgxTimePickerComponent {
15
+ hours;
16
+ minutes;
17
+ timeChange = new EventEmitter();
18
+ /** Display mode for the time-picker */
19
+ mode = 'fullTime';
20
+ /** Data type to manage (Date or Duration) */
21
+ dataType = 'date';
22
+ /**
23
+ * Force the hour or minute to be null (only if the other field is disabled)
24
+ *
25
+ * For instance, if set to true and the hours are disabled, the minutes input value will be null
26
+ * This is useful to force the user to provide a value
27
+ */
28
+ forceNullValue = false;
29
+ appearance = 'outline';
30
+ set autoFocus(value) {
31
+ this._autoFocus = coerceBooleanProperty(value);
32
+ }
33
+ defaultPlaceholderHours = '_ _';
34
+ defaultPlaceholderMinutes = '_ _';
35
+ set time(value) {
36
+ this.writeValue(value);
37
+ }
38
+ get time() {
39
+ return this.value;
40
+ }
41
+ /** Step of the arrows */
42
+ set step(value) {
43
+ this._step = coerceNumberProperty(value);
44
+ this.changeDetectorRef.markForCheck();
45
+ }
46
+ /** To get the step of the minutes arrows */
47
+ get step() {
48
+ return this._step;
49
+ }
50
+ /** Disabled property setter. Can be string or empty so you can use it like : <time-picker disabled></time-picker> */
51
+ set disabled(value) {
52
+ this._disabled = coerceBooleanProperty(value);
53
+ this.changeDetectorRef.markForCheck();
54
+ }
55
+ /** To get disabled attribute. */
56
+ get disabled() {
57
+ return this._disabled;
58
+ }
59
+ onHoursChange$ = new Subject();
60
+ onMinutesChange$ = new Subject();
61
+ _step = 1;
62
+ changeDetectorRef = inject(ChangeDetectorRef);
63
+ control = inject(NgControl, { optional: true, self: true });
64
+ destroyRef = inject(DestroyRef);
65
+ _disabled = false;
66
+ _value;
67
+ _autoFocus = true;
68
+ constructor() {
69
+ if (this.control) {
70
+ this.control.valueAccessor = this;
71
+ }
72
+ this.onHoursChange$.pipe(debounce(hours => timer(typeof hours === 'object' ? 0 : 10)), distinctUntilChanged(), map(hours => {
73
+ if (typeof hours === 'object') {
74
+ const value = hours.target.value;
75
+ return [value !== undefined ? parseInt(value, 10) : undefined, true];
76
+ }
77
+ return [!isNaN(hours) ? hours : 0, false];
78
+ }), takeUntilDestroyed(this.destroyRef)).subscribe(([hours, isEvent]) => {
79
+ if (!this.value) {
80
+ this.value = this.dataType === 'date' ? set(new Date(), { hours, minutes: 0, seconds: 0, milliseconds: 0 }) : { hours, minutes: 0 };
81
+ }
82
+ else if (this.value instanceof Date) {
83
+ const value = this.value?.getTime();
84
+ const clone = new Date(value);
85
+ if (hours !== undefined) {
86
+ clone.setHours(hours);
87
+ }
88
+ this.value = clone;
89
+ }
90
+ else {
91
+ this.value = {
92
+ hours: hours && hours < 0 ? 0 : hours,
93
+ minutes: this.value.minutes
94
+ };
95
+ }
96
+ this.changeDetectorRef.markForCheck();
97
+ if (isEvent && this._autoFocus && this.minutes) {
98
+ this.minutes.nativeElement.focus({
99
+ preventScroll: true
100
+ });
101
+ this.minutes.nativeElement.select();
102
+ }
103
+ });
104
+ this.onMinutesChange$.pipe(debounce(minutes => timer(typeof minutes === 'object' ? 0 : 10)), distinctUntilChanged(), map(event => {
105
+ let minutes;
106
+ if (typeof event === 'object') {
107
+ const value = event.target.value;
108
+ minutes = value !== undefined ? parseInt(value, 10) : undefined;
109
+ }
110
+ else {
111
+ minutes = event;
112
+ }
113
+ return minutes && !isNaN(minutes) && minutes || 0;
114
+ }), takeUntilDestroyed(this.destroyRef)).subscribe(minutes => {
115
+ if (!this.value) {
116
+ this.value = this.dataType === 'date' ? set(new Date(), { hours: 0, minutes, seconds: 0, milliseconds: 0 }) : { hours: 0, minutes };
117
+ }
118
+ else if (this.value instanceof Date) {
119
+ const newValue = new Date(this.value.getTime());
120
+ if (minutes < 0) {
121
+ minutes += 60;
122
+ }
123
+ else if (minutes >= 60) {
124
+ minutes -= 60;
125
+ }
126
+ newValue.setMinutes(minutes);
127
+ if (this.mode !== 'fullTimeWithHoursDisabled' || (this.mode === 'fullTimeWithHoursDisabled' && isSameHour(this.value, newValue))) {
128
+ this.value = newValue;
129
+ }
130
+ }
131
+ else {
132
+ this.value = {
133
+ hours: this.value.hours,
134
+ minutes: minutes < 0 || minutes >= 60 ? 0 : minutes
135
+ };
136
+ }
137
+ this.changeDetectorRef.markForCheck();
138
+ });
139
+ }
140
+ onKeyDown($event, mode) {
141
+ // Get input element
142
+ const inputElement = mode === 'hours' ? this.hours?.nativeElement : this.minutes?.nativeElement;
143
+ if ($event.key?.toLowerCase() === 'd') {
144
+ $event.stopPropagation();
145
+ $event.preventDefault();
146
+ this.value = new Date();
147
+ }
148
+ else if (inputElement) {
149
+ if ($event.key?.toLowerCase() === 'a' && $event.ctrlKey) {
150
+ inputElement.select();
151
+ }
152
+ else if ($event.key && !['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight', 'Backspace', 'Delete', 'Tab', 'Enter', 'Control', 'Shift'].includes($event.key)) {
153
+ // Set regex for input format validation (differs if we are dealing with a date or a duration)
154
+ let regex;
155
+ if (mode === 'hours') {
156
+ regex = this.dataType === 'date' ? /^(\d|[01]\d|2[0-3])$/ : /^(\d+)$/;
157
+ }
158
+ else {
159
+ regex = /^(\d|[0-5]\d)$/;
160
+ }
161
+ // Get the selection in input element
162
+ const [selectionStart, selectionEnd] = [inputElement.selectionStart || 0, inputElement.selectionEnd || 0].sort((a, b) => a - b);
163
+ const selectionDiff = selectionEnd - selectionStart;
164
+ // Get the current value in input element and update it with the new touched key
165
+ const inputValue = inputElement.value || '';
166
+ const inputValueArr = Array.from(inputValue);
167
+ inputValueArr.splice(selectionStart, selectionDiff, $event.key);
168
+ const newInputValue = inputValueArr.join('');
169
+ // Prevent event if the time is not valid
170
+ if (!regex.test(newInputValue)) {
171
+ $event.stopPropagation();
172
+ $event.preventDefault();
173
+ }
174
+ else if (this._autoFocus && mode === 'hours' && ((this.dataType === 'date' && parseFloat(newInputValue) >= 3) || newInputValue.length === 2)) {
175
+ this.onHoursChange$.next($event);
176
+ }
177
+ }
178
+ }
179
+ }
180
+ get hoursValue() {
181
+ if (!this.value || (this.forceNullValue && this.mode === 'fullTimeWithMinutesDisabled' && !!this.control?.pristine)) {
182
+ return undefined;
183
+ }
184
+ return this.value instanceof Date ? this.value.getHours() : this.value.hours;
185
+ }
186
+ get minutesValue() {
187
+ if (!this.value || (this.forceNullValue && this.mode === 'fullTimeWithHoursDisabled' && !!this.control?.pristine)) {
188
+ return undefined;
189
+ }
190
+ return this.value instanceof Date ? this.value.getMinutes() : this.value.minutes;
191
+ }
192
+ incrementValue(fieldType) {
193
+ if (fieldType === 'hours') {
194
+ this.onHoursChange$.next((this.hoursValue || 0) + 1);
195
+ }
196
+ else {
197
+ this.onMinutesChange$.next((this.minutesValue || 0) + this._step);
198
+ }
199
+ }
200
+ decrementValue(fieldType) {
201
+ if (fieldType === 'hours') {
202
+ this.onHoursChange$.next((this.hoursValue || 0) - 1);
203
+ }
204
+ else {
205
+ this.onMinutesChange$.next((this.minutesValue || 0) - this._step);
206
+ }
207
+ }
208
+ onClick(mode) {
209
+ if (this._autoFocus) {
210
+ if (mode === 'hours') {
211
+ this.hours?.nativeElement.select();
212
+ }
213
+ else {
214
+ this.minutes?.nativeElement.select();
215
+ }
216
+ }
217
+ }
218
+ // ************* ControlValueAccessor Implementation **************
219
+ /** set accessor including call the onchange callback */
220
+ set value(v) {
221
+ if (v !== this._value) {
222
+ this.writeValue(v);
223
+ this.onChangeCallback(v);
224
+ this.timeChange.emit(v);
225
+ }
226
+ }
227
+ /** get accessor */
228
+ get value() {
229
+ return this._value;
230
+ }
231
+ /** From ControlValueAccessor interface */
232
+ writeValue(value) {
233
+ if ((value ?? null) !== (this._value ?? null)) {
234
+ if (value instanceof Date) {
235
+ this._value = value ? new Date(value.getTime()) : set(new Date(), { hours: 0, minutes: 0, seconds: 0 });
236
+ }
237
+ else {
238
+ this._value = value;
239
+ }
240
+ this.changeDetectorRef.markForCheck();
241
+ }
242
+ }
243
+ /** From ControlValueAccessor interface */
244
+ registerOnChange(fn) {
245
+ this.onChangeCallback = fn;
246
+ }
247
+ /** From ControlValueAccessor interface */
248
+ registerOnTouched(fn) {
249
+ this.onTouchedCallback = fn;
250
+ }
251
+ setDisabledState(isDisabled) {
252
+ this.disabled = isDisabled;
253
+ }
254
+ // ************* End of ControlValueAccessor Implementation **************
255
+ onChangeCallback = (_a) => undefined;
256
+ onTouchedCallback = () => undefined;
257
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NgxTimePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
258
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.3", type: NgxTimePickerComponent, isStandalone: true, selector: "ngx-time-picker", inputs: { mode: "mode", dataType: "dataType", forceNullValue: "forceNullValue", appearance: "appearance", autoFocus: "autoFocus", defaultPlaceholderHours: "defaultPlaceholderHours", defaultPlaceholderMinutes: "defaultPlaceholderMinutes", time: "time", step: "step", disabled: "disabled" }, outputs: { timeChange: "timeChange" }, viewQueries: [{ propertyName: "hours", first: true, predicate: ["hours"], descendants: true }, { propertyName: "minutes", first: true, predicate: ["minutes"], descendants: true }], ngImport: i0, template: "<!-- Hours -->\n<mat-form-field\n [appearance]=\"appearance\"\n class=\"hours\"\n [class.disabled]=\"disabled || mode === 'fullTimeWithHoursDisabled'\"\n [style.display]=\"mode === 'minutesOnly' ? 'none' : 'block'\">\n <input\n #hours\n matInput\n type=\"text\"\n [ngModel]=\"hoursValue | number: '2.'\"\n (change)=\"onHoursChange$.next($event)\"\n (keydown)=\"onKeyDown($event, 'hours')\"\n [disabled]=\"disabled || mode === 'fullTimeWithHoursDisabled'\"\n [maxLength]=\"2\"\n autocomplete=\"off\"\n [placeholder]=\"defaultPlaceholderHours\"\n (click)=\"onClick('hours')\" />\n <ngx-numeric-stepper\n (increment)=\"incrementValue('hours')\"\n (decrement)=\"decrementValue('hours')\"></ngx-numeric-stepper>\n</mat-form-field>\n\n<!-- Separator -->\n<span class=\"time-separator\" [style.display]=\"mode === 'minutesOnly' || mode === 'hoursOnly' ? 'none' : 'block'\">\n :\n</span>\n\n<!-- Minutes -->\n<mat-form-field\n [appearance]=\"appearance\"\n class=\"minutes\"\n [class.disabled]=\"disabled || mode === 'fullTimeWithMinutesDisabled'\"\n [style.display]=\"mode === 'hoursOnly' ? 'none' : 'block'\">\n <input\n #minutes\n matInput\n type=\"text\"\n [ngModel]=\"minutesValue | number: '2.'\"\n (change)=\"onMinutesChange$.next($event)\"\n (keydown)=\"onKeyDown($event, 'minutes')\"\n [disabled]=\"disabled || mode === 'fullTimeWithMinutesDisabled'\"\n [maxLength]=\"2\"\n autocomplete=\"off\"\n [placeholder]=\"defaultPlaceholderMinutes\"\n (click)=\"onClick('minutes')\" />\n <ngx-numeric-stepper\n (increment)=\"incrementValue('minutes')\"\n (decrement)=\"decrementValue('minutes')\"></ngx-numeric-stepper>\n</mat-form-field>\n", styles: ["ngx-time-picker{display:flex;flex-direction:row;align-items:baseline;justify-content:center}ngx-time-picker:not([inform]) .mat-form-field-appearance-outline .mat-mdc-form-field-wrapper{padding-bottom:0}ngx-time-picker:not([inform]) .mat-form-field-appearance-outline .mat-mdc-form-field-wrapper .mat-mdc-form-field-infix{border-bottom:.7em solid transparent}ngx-time-picker mat-form-field[ngx-numeric-stepper-form-field]{width:52px}ngx-time-picker .time-separator{width:4px;font-size:14.5px;line-height:17px;margin:0 8px}\n"], dependencies: [{ kind: "pipe", type: DecimalPipe, name: "number" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: NgxNumericStepperComponent, selector: "ngx-numeric-stepper", inputs: ["layout", "input", "arrowIcons", "showOnInit"], outputs: ["increment", "decrement"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
259
+ }
260
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NgxTimePickerComponent, decorators: [{
261
+ type: Component,
262
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'ngx-time-picker', encapsulation: ViewEncapsulation.None, standalone: true, imports: [
263
+ DecimalPipe,
264
+ FormsModule,
265
+ MatFormField,
266
+ MatInput,
267
+ NgxNumericStepperComponent
268
+ ], template: "<!-- Hours -->\n<mat-form-field\n [appearance]=\"appearance\"\n class=\"hours\"\n [class.disabled]=\"disabled || mode === 'fullTimeWithHoursDisabled'\"\n [style.display]=\"mode === 'minutesOnly' ? 'none' : 'block'\">\n <input\n #hours\n matInput\n type=\"text\"\n [ngModel]=\"hoursValue | number: '2.'\"\n (change)=\"onHoursChange$.next($event)\"\n (keydown)=\"onKeyDown($event, 'hours')\"\n [disabled]=\"disabled || mode === 'fullTimeWithHoursDisabled'\"\n [maxLength]=\"2\"\n autocomplete=\"off\"\n [placeholder]=\"defaultPlaceholderHours\"\n (click)=\"onClick('hours')\" />\n <ngx-numeric-stepper\n (increment)=\"incrementValue('hours')\"\n (decrement)=\"decrementValue('hours')\"></ngx-numeric-stepper>\n</mat-form-field>\n\n<!-- Separator -->\n<span class=\"time-separator\" [style.display]=\"mode === 'minutesOnly' || mode === 'hoursOnly' ? 'none' : 'block'\">\n :\n</span>\n\n<!-- Minutes -->\n<mat-form-field\n [appearance]=\"appearance\"\n class=\"minutes\"\n [class.disabled]=\"disabled || mode === 'fullTimeWithMinutesDisabled'\"\n [style.display]=\"mode === 'hoursOnly' ? 'none' : 'block'\">\n <input\n #minutes\n matInput\n type=\"text\"\n [ngModel]=\"minutesValue | number: '2.'\"\n (change)=\"onMinutesChange$.next($event)\"\n (keydown)=\"onKeyDown($event, 'minutes')\"\n [disabled]=\"disabled || mode === 'fullTimeWithMinutesDisabled'\"\n [maxLength]=\"2\"\n autocomplete=\"off\"\n [placeholder]=\"defaultPlaceholderMinutes\"\n (click)=\"onClick('minutes')\" />\n <ngx-numeric-stepper\n (increment)=\"incrementValue('minutes')\"\n (decrement)=\"decrementValue('minutes')\"></ngx-numeric-stepper>\n</mat-form-field>\n", styles: ["ngx-time-picker{display:flex;flex-direction:row;align-items:baseline;justify-content:center}ngx-time-picker:not([inform]) .mat-form-field-appearance-outline .mat-mdc-form-field-wrapper{padding-bottom:0}ngx-time-picker:not([inform]) .mat-form-field-appearance-outline .mat-mdc-form-field-wrapper .mat-mdc-form-field-infix{border-bottom:.7em solid transparent}ngx-time-picker mat-form-field[ngx-numeric-stepper-form-field]{width:52px}ngx-time-picker .time-separator{width:4px;font-size:14.5px;line-height:17px;margin:0 8px}\n"] }]
269
+ }], ctorParameters: () => [], propDecorators: { hours: [{
270
+ type: ViewChild,
271
+ args: ['hours']
272
+ }], minutes: [{
273
+ type: ViewChild,
274
+ args: ['minutes']
275
+ }], timeChange: [{
276
+ type: Output
277
+ }], mode: [{
278
+ type: Input
279
+ }], dataType: [{
280
+ type: Input
281
+ }], forceNullValue: [{
282
+ type: Input
283
+ }], appearance: [{
284
+ type: Input
285
+ }], autoFocus: [{
286
+ type: Input
287
+ }], defaultPlaceholderHours: [{
288
+ type: Input
289
+ }], defaultPlaceholderMinutes: [{
290
+ type: Input
291
+ }], time: [{
292
+ type: Input
293
+ }], step: [{
294
+ type: Input
295
+ }], disabled: [{
296
+ type: Input
297
+ }] } });
298
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../projects/time-picker/src/time-picker.component.ts","../../../projects/time-picker/src/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty, coerceNumberProperty, NumberInput } from '@angular/cdk/coercion';\nimport { DecimalPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, DestroyRef, ElementRef, EventEmitter, inject, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { MatFormField, MatFormFieldAppearance } from '@angular/material/form-field';\nimport { MatInput } from '@angular/material/input';\nimport { NgxNumericStepperComponent } from '@hug/ngx-numeric-stepper';\nimport { isSameHour, set } from 'date-fns';\nimport { debounce, distinctUntilChanged, map, Subject, timer } from 'rxjs';\n\nexport type NgxTimePickerDisplayMode = 'fullTime' | 'fullTimeWithHoursDisabled' | 'fullTimeWithMinutesDisabled' | 'hoursOnly' | 'minutesOnly';\n\nexport type NgxDateOrDuration = Date | Duration;\n\ntype DataType = 'date' | 'duration';\n\ntype FieldType = 'hours' | 'minutes';\n\n// TODO sdil refactor rxjs flows\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ngx-time-picker',\n    styleUrls: ['./time-picker.component.scss'],\n    templateUrl: './time-picker.component.html',\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [\n        DecimalPipe,\n        FormsModule,\n        MatFormField,\n        MatInput,\n        NgxNumericStepperComponent\n    ]\n})\nexport class NgxTimePickerComponent implements ControlValueAccessor {\n    @ViewChild('hours') public hours?: ElementRef<HTMLInputElement>;\n    @ViewChild('minutes') public minutes?: ElementRef<HTMLInputElement>;\n\n    @Output() public readonly timeChange = new EventEmitter<NgxDateOrDuration>();\n\n    /** Display mode for the time-picker */\n    @Input() public mode: NgxTimePickerDisplayMode = 'fullTime';\n\n    /** Data type to manage (Date or Duration) */\n    @Input() public dataType: DataType = 'date';\n\n    /**\n     * Force the hour or minute to be null (only if the other field is disabled)\n     *\n     * For instance, if set to true and the hours are disabled, the minutes input value will be null\n     * This is useful to force the user to provide a value\n     */\n    @Input() public forceNullValue = false;\n\n    @Input() public appearance: MatFormFieldAppearance = 'outline';\n\n    @Input()\n    public set autoFocus(value: BooleanInput) {\n        this._autoFocus = coerceBooleanProperty(value);\n    }\n\n    @Input() public defaultPlaceholderHours = '_ _';\n    @Input() public defaultPlaceholderMinutes = '_ _';\n\n    @Input()\n    public set time(value: NgxDateOrDuration | undefined) {\n        this.writeValue(value);\n    }\n\n    public get time(): NgxDateOrDuration | undefined {\n        return this.value;\n    }\n\n    /** Step of the arrows */\n    @Input()\n    public set step(value: NumberInput) {\n        this._step = coerceNumberProperty(value);\n        this.changeDetectorRef.markForCheck();\n    }\n\n    /** To get the step of the minutes arrows */\n    public get step(): NumberInput {\n        return this._step;\n    }\n\n    /** Disabled property setter. Can be string or empty so you can use it like : <time-picker disabled></time-picker> */\n    @Input()\n    public set disabled(value: BooleanInput) {\n        this._disabled = coerceBooleanProperty(value);\n        this.changeDetectorRef.markForCheck();\n    }\n\n    /** To get disabled attribute. */\n    public get disabled(): BooleanInput {\n        return this._disabled;\n    }\n\n    public onHoursChange$ = new Subject<Event | number>();\n    public onMinutesChange$ = new Subject<Event | number>();\n    public _step = 1;\n\n    protected changeDetectorRef = inject(ChangeDetectorRef);\n    protected control = inject(NgControl, { optional: true, self: true });\n    private destroyRef = inject(DestroyRef);\n\n    private _disabled = false;\n    private _value?: NgxDateOrDuration;\n    private _autoFocus = true;\n\n    public constructor() {\n        if (this.control) {\n            this.control.valueAccessor = this;\n        }\n\n        this.onHoursChange$.pipe(\n            debounce(hours => timer(typeof hours === 'object' ? 0 : 10)),\n            distinctUntilChanged(),\n            map(hours => {\n                if (typeof hours === 'object') {\n                    const value = (hours.target as HTMLInputElement).value;\n                    return [value !== undefined ? parseInt(value, 10) : undefined, true] as const;\n                }\n                return [!isNaN(hours) ? hours : 0, false] as const;\n            }),\n            takeUntilDestroyed(this.destroyRef)\n        ).subscribe(([hours, isEvent]) => {\n            if (!this.value) {\n                this.value = this.dataType === 'date' ? set(new Date(), { hours, minutes: 0, seconds: 0, milliseconds: 0 }) : { hours, minutes: 0 } as Duration;\n            } else if (this.value instanceof Date) {\n                const value = this.value?.getTime();\n                const clone = new Date(value);\n                if (hours !== undefined) {\n                    clone.setHours(hours);\n                }\n                this.value = clone;\n            } else {\n                this.value = {\n                    hours: hours && hours < 0 ? 0 : hours,\n                    minutes: this.value.minutes\n                };\n            }\n            this.changeDetectorRef.markForCheck();\n\n            if (isEvent && this._autoFocus && this.minutes) {\n                this.minutes.nativeElement.focus({\n                    preventScroll: true\n                });\n                this.minutes.nativeElement.select();\n            }\n        });\n\n        this.onMinutesChange$.pipe(\n            debounce(minutes => timer(typeof minutes === 'object' ? 0 : 10)),\n            distinctUntilChanged(),\n            map(event => {\n                let minutes: number | undefined;\n                if (typeof event === 'object') {\n                    const value = (event.target as HTMLInputElement).value;\n                    minutes = value !== undefined ? parseInt(value, 10) : undefined;\n                } else {\n                    minutes = event;\n                }\n                return minutes && !isNaN(minutes) && minutes || 0;\n            }),\n            takeUntilDestroyed(this.destroyRef)\n        ).subscribe(minutes => {\n            if (!this.value) {\n                this.value = this.dataType === 'date' ? set(new Date(), { hours: 0, minutes, seconds: 0, milliseconds: 0 }) : { hours: 0, minutes } as Duration;\n            } else if (this.value instanceof Date) {\n                const newValue = new Date(this.value.getTime());\n                if (minutes < 0) {\n                    minutes += 60;\n                } else if (minutes >= 60) {\n                    minutes -= 60;\n                }\n                newValue.setMinutes(minutes);\n\n                if (this.mode !== 'fullTimeWithHoursDisabled' || (this.mode === 'fullTimeWithHoursDisabled' && isSameHour(this.value, newValue))) {\n                    this.value = newValue;\n                }\n            } else {\n                this.value = {\n                    hours: this.value.hours,\n                    minutes: minutes < 0 || minutes >= 60 ? 0 : minutes\n                };\n            }\n            this.changeDetectorRef.markForCheck();\n        });\n    }\n\n    public onKeyDown($event: KeyboardEvent, mode: 'hours' | 'minutes'): void {\n        // Get input element\n        const inputElement = mode === 'hours' ? this.hours?.nativeElement : this.minutes?.nativeElement;\n        if ($event.key?.toLowerCase() === 'd') {\n            $event.stopPropagation();\n            $event.preventDefault();\n            this.value = new Date();\n        } else if (inputElement) {\n            if ($event.key?.toLowerCase() === 'a' && $event.ctrlKey) {\n                inputElement.select();\n            } else if ($event.key && !['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight', 'Backspace', 'Delete', 'Tab', 'Enter', 'Control', 'Shift'].includes($event.key)) {\n                // Set regex for input format validation (differs if we are dealing with a date or a duration)\n                let regex;\n                if (mode === 'hours') {\n                    regex = this.dataType === 'date' ? /^(\\d|[01]\\d|2[0-3])$/ : /^(\\d+)$/;\n                } else {\n                    regex = /^(\\d|[0-5]\\d)$/;\n                }\n\n                // Get the selection in input element\n                const [selectionStart, selectionEnd] = [inputElement.selectionStart || 0, inputElement.selectionEnd || 0].sort((a, b) => a - b);\n                const selectionDiff = selectionEnd - selectionStart;\n\n                // Get the current value in input element and update it with the new touched key\n                const inputValue = inputElement.value || '';\n                const inputValueArr = Array.from(inputValue);\n                inputValueArr.splice(selectionStart, selectionDiff, $event.key);\n                const newInputValue = inputValueArr.join('');\n\n                // Prevent event if the time is not valid\n                if (!regex.test(newInputValue)) {\n                    $event.stopPropagation();\n                    $event.preventDefault();\n                } else if (this._autoFocus && mode === 'hours' && ((this.dataType === 'date' && parseFloat(newInputValue) >= 3) || newInputValue.length === 2)) {\n                    this.onHoursChange$.next($event);\n                }\n            }\n        }\n    }\n\n    public get hoursValue(): number | undefined {\n        if (!this.value || (this.forceNullValue && this.mode === 'fullTimeWithMinutesDisabled' && !!this.control?.pristine)) {\n            return undefined;\n        }\n        return this.value instanceof Date ? this.value.getHours() : this.value.hours;\n    }\n\n    public get minutesValue(): number | undefined {\n        if (!this.value || (this.forceNullValue && this.mode === 'fullTimeWithHoursDisabled' && !!this.control?.pristine)) {\n            return undefined;\n        }\n        return this.value instanceof Date ? this.value.getMinutes() : this.value.minutes;\n    }\n\n    public incrementValue(fieldType: FieldType): void {\n        if (fieldType === 'hours') {\n            this.onHoursChange$.next((this.hoursValue || 0) + 1);\n        } else {\n            this.onMinutesChange$.next((this.minutesValue || 0) + this._step);\n        }\n    }\n\n    public decrementValue(fieldType: FieldType): void {\n        if (fieldType === 'hours') {\n            this.onHoursChange$.next((this.hoursValue || 0) - 1);\n        } else {\n            this.onMinutesChange$.next((this.minutesValue || 0) - this._step);\n        }\n    }\n\n    public onClick(mode: 'hours' | 'minutes'): void {\n        if (this._autoFocus) {\n            if (mode === 'hours') {\n                this.hours?.nativeElement.select();\n            } else {\n                this.minutes?.nativeElement.select();\n            }\n        }\n    }\n\n    // ************* ControlValueAccessor Implementation **************\n    /** set accessor including call the onchange callback */\n    public set value(v: NgxDateOrDuration | undefined) {\n        if (v !== this._value) {\n            this.writeValue(v);\n            this.onChangeCallback(v);\n            this.timeChange.emit(v);\n        }\n    }\n\n    /** get accessor */\n    public get value(): NgxDateOrDuration | undefined {\n        return this._value;\n    }\n\n    /** From ControlValueAccessor interface */\n    public writeValue(value: NgxDateOrDuration | undefined): void {\n        if ((value ?? null) !== (this._value ?? null)) {\n            if (value instanceof Date) {\n                this._value = value ? new Date(value.getTime()) : set(new Date(), { hours: 0, minutes: 0, seconds: 0 });\n            } else {\n                this._value = value;\n            }\n\n            this.changeDetectorRef.markForCheck();\n        }\n    }\n\n    /** From ControlValueAccessor interface */\n    public registerOnChange(fn: (_a: unknown) => void): void {\n        this.onChangeCallback = fn;\n    }\n\n    /** From ControlValueAccessor interface */\n    public registerOnTouched(fn: () => void): void {\n        this.onTouchedCallback = fn;\n    }\n\n    public setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n    // ************* End of ControlValueAccessor Implementation **************\n\n    protected onChangeCallback = (_a: unknown): void => undefined;\n    protected onTouchedCallback = (): void => undefined;\n}\n","<!-- Hours -->\n<mat-form-field\n    [appearance]=\"appearance\"\n    class=\"hours\"\n    [class.disabled]=\"disabled || mode === 'fullTimeWithHoursDisabled'\"\n    [style.display]=\"mode === 'minutesOnly' ? 'none' : 'block'\">\n    <input\n        #hours\n        matInput\n        type=\"text\"\n        [ngModel]=\"hoursValue | number: '2.'\"\n        (change)=\"onHoursChange$.next($event)\"\n        (keydown)=\"onKeyDown($event, 'hours')\"\n        [disabled]=\"disabled || mode === 'fullTimeWithHoursDisabled'\"\n        [maxLength]=\"2\"\n        autocomplete=\"off\"\n        [placeholder]=\"defaultPlaceholderHours\"\n        (click)=\"onClick('hours')\" />\n    <ngx-numeric-stepper\n        (increment)=\"incrementValue('hours')\"\n        (decrement)=\"decrementValue('hours')\"></ngx-numeric-stepper>\n</mat-form-field>\n\n<!-- Separator -->\n<span class=\"time-separator\" [style.display]=\"mode === 'minutesOnly' || mode === 'hoursOnly' ? 'none' : 'block'\">\n    :\n</span>\n\n<!-- Minutes -->\n<mat-form-field\n    [appearance]=\"appearance\"\n    class=\"minutes\"\n    [class.disabled]=\"disabled || mode === 'fullTimeWithMinutesDisabled'\"\n    [style.display]=\"mode === 'hoursOnly' ? 'none' : 'block'\">\n    <input\n        #minutes\n        matInput\n        type=\"text\"\n        [ngModel]=\"minutesValue | number: '2.'\"\n        (change)=\"onMinutesChange$.next($event)\"\n        (keydown)=\"onKeyDown($event, 'minutes')\"\n        [disabled]=\"disabled || mode === 'fullTimeWithMinutesDisabled'\"\n        [maxLength]=\"2\"\n        autocomplete=\"off\"\n        [placeholder]=\"defaultPlaceholderMinutes\"\n        (click)=\"onClick('minutes')\" />\n    <ngx-numeric-stepper\n        (increment)=\"incrementValue('minutes')\"\n        (decrement)=\"decrementValue('minutes')\"></ngx-numeric-stepper>\n</mat-form-field>\n"]}