ca-components 1.0.78 → 1.0.80

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 (66) hide show
  1. package/esm2022/lib/ca-components.module.mjs +16 -4
  2. package/esm2022/lib/components/ca-activity-log-list/ca-activity-log-list.component.mjs +1 -1
  3. package/esm2022/lib/components/ca-app-tooltip-v2/ca-app-tooltip-v2.component.mjs +1 -1
  4. package/esm2022/lib/components/ca-filters/components/ca-dispatcher-filter/ca-dispatcher-filter.component.mjs +2 -2
  5. package/esm2022/lib/components/ca-filters/components/ca-money-filter/ca-money-filter.component.mjs +2 -2
  6. package/esm2022/lib/components/ca-filters/components/ca-state-filter/ca-state-filter.component.mjs +2 -2
  7. package/esm2022/lib/components/ca-filters/components/ca-trailer-type-filter/ca-trailer-type-filter.component.mjs +1 -1
  8. package/esm2022/lib/components/ca-filters/components/ca-truck-type-filter/ca-truck-type-filter.component.mjs +1 -1
  9. package/esm2022/lib/components/ca-filters/components/ca-user-filter/ca-user-filter.component.mjs +2 -2
  10. package/esm2022/lib/components/ca-input/base-classes/ca-input-base-helpres.mjs +237 -0
  11. package/esm2022/lib/components/ca-input/base-classes/ca-input-base.mjs +1020 -0
  12. package/esm2022/lib/components/ca-input/base-classes/ca-input-event-manager.mjs +24 -0
  13. package/esm2022/lib/components/ca-input/ca-input.component.mjs +53 -163
  14. package/esm2022/lib/components/ca-input/components/ca-input-clear/ca-input-clear.component.mjs +4 -4
  15. package/esm2022/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.mjs +11 -17
  16. package/esm2022/lib/components/ca-input/config/ca-input.config.mjs +1 -1
  17. package/esm2022/lib/components/ca-input/directives/caps-lock.directive.mjs +50 -0
  18. package/esm2022/lib/components/ca-input/directives/index.mjs +5 -1
  19. package/esm2022/lib/components/ca-input/directives/input-max-value.directive.mjs +53 -0
  20. package/esm2022/lib/components/ca-input/directives/min-max-value.directive.mjs +1 -1
  21. package/esm2022/lib/components/ca-input/directives/price_format.directive.mjs +41 -0
  22. package/esm2022/lib/components/ca-input/directives/restrict-input.directive.mjs +98 -0
  23. package/esm2022/lib/components/ca-input/enums/input-text-transform.enum.mjs +9 -0
  24. package/esm2022/lib/components/ca-input/input-test/input-test.component.mjs +175 -0
  25. package/esm2022/lib/components/ca-input/pipes/input-container-class.pipe.mjs +16 -16
  26. package/esm2022/lib/components/ca-input/pipes/input-datetime-picker-class.pipe.mjs +1 -1
  27. package/esm2022/lib/components/ca-input/pipes/input-error.pipe.mjs +18 -15
  28. package/esm2022/lib/components/ca-input/pipes/input-pattern.pipe.mjs +322 -0
  29. package/esm2022/lib/components/ca-input/services/index.mjs +1 -2
  30. package/esm2022/lib/components/ca-input/utils/constants/input-constants.mjs +102 -1
  31. package/esm2022/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.mjs +2 -2
  32. package/esm2022/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.mjs +809 -0
  33. package/esm2022/lib/components/ca-input-dropdown/ca-input-dropdown.component.mjs +18 -18
  34. package/esm2022/lib/components/ca-rating-review/ca-rating-review.component.mjs +2 -2
  35. package/esm2022/lib/components/ca-rating-review/components/ca-ratings-reviews-popup/ca-ratings-reviews-popup.component.mjs +1 -1
  36. package/esm2022/lib/components/ca-upload-files/components/ca-upload-file/ca-upload-file.component.mjs +1 -1
  37. package/esm2022/public-api.mjs +3 -1
  38. package/fesm2022/ca-components.mjs +7690 -7171
  39. package/fesm2022/ca-components.mjs.map +1 -1
  40. package/lib/ca-components.module.d.ts +32 -30
  41. package/lib/components/ca-filters/ca-filter.component.d.ts +2 -2
  42. package/lib/components/ca-input/base-classes/ca-input-base-helpres.d.ts +29 -0
  43. package/lib/components/ca-input/base-classes/ca-input-base.d.ts +82 -0
  44. package/lib/components/ca-input/base-classes/ca-input-event-manager.d.ts +16 -0
  45. package/lib/components/ca-input/ca-input.component.d.ts +30 -48
  46. package/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.d.ts +3 -7
  47. package/lib/components/ca-input/config/ca-input.config.d.ts +10 -1
  48. package/lib/components/ca-input/directives/caps-lock.directive.d.ts +14 -0
  49. package/lib/components/ca-input/directives/index.d.ts +4 -0
  50. package/lib/components/ca-input/directives/input-max-value.directive.d.ts +12 -0
  51. package/lib/components/ca-input/directives/price_format.directive.d.ts +11 -0
  52. package/lib/components/ca-input/directives/restrict-input.directive.d.ts +15 -0
  53. package/lib/components/ca-input/enums/input-text-transform.enum.d.ts +6 -0
  54. package/lib/components/ca-input/input-test/input-test.component.d.ts +47 -0
  55. package/lib/components/ca-input/pipes/input-container-class.pipe.d.ts +3 -3
  56. package/lib/components/ca-input/pipes/input-datetime-picker-class.pipe.d.ts +1 -1
  57. package/lib/components/ca-input/pipes/input-pattern.pipe.d.ts +25 -0
  58. package/lib/components/ca-input/services/index.d.ts +0 -1
  59. package/lib/components/ca-input/utils/constants/input-constants.d.ts +11 -0
  60. package/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.d.ts +99 -0
  61. package/package.json +1 -1
  62. package/public-api.d.ts +2 -0
  63. package/esm2022/lib/components/ca-input/components/ca-input-datetime-picker/ca-input-datetime-picker.component.mjs +0 -100
  64. package/esm2022/lib/components/ca-input/services/ca-input-state.service.mjs +0 -2173
  65. package/lib/components/ca-input/components/ca-input-datetime-picker/ca-input-datetime-picker.component.d.ts +0 -48
  66. package/lib/components/ca-input/services/ca-input-state.service.d.ts +0 -196
@@ -0,0 +1,809 @@
1
+ import { Component, EventEmitter, Input, Output, Self, ViewChild, } from '@angular/core';
2
+ import { FormsModule, ReactiveFormsModule, } from '@angular/forms';
3
+ import { CommonModule } from '@angular/common';
4
+ // Imports
5
+ import moment from 'moment';
6
+ import { Subject, takeUntil } from 'rxjs';
7
+ import { InputSvgRoutes } from '../ca-input/utils';
8
+ // Pipe
9
+ import { InputContainerClassPipe, InputDatetimePickerClassPipe, } from '../ca-input/pipes';
10
+ // Components
11
+ import { CaInputComponent } from '../ca-input/ca-input.component';
12
+ import { CaCustomDatetimePickersComponent } from '../ca-custom-datetime-pickers/ca-custom-datetime-pickers.component';
13
+ import { CaInputPlaceholderIconComponent } from '../ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component';
14
+ // Enums
15
+ import { InputConfigNameStringEnum } from '../ca-input/enums';
16
+ // Services
17
+ import { CalendarDateTimePickerService } from '../ca-custom-datetime-pickers/services/calendar-datetime-picker.service';
18
+ import { AngularSvgIconModule } from 'angular-svg-icon';
19
+ import { FormControlPipe } from '../ca-input/pipes/form-control.pipe';
20
+ import * as i0 from "@angular/core";
21
+ import * as i1 from "@angular/forms";
22
+ import * as i2 from "../ca-custom-datetime-pickers/services/calendar-datetime-picker.service";
23
+ import * as i3 from "@angular/common";
24
+ export class CaInputDatetimePickerComponent {
25
+ constructor(superControl, calendarService) {
26
+ this.superControl = superControl;
27
+ this.calendarService = calendarService;
28
+ this.clearInputEvent = new EventEmitter();
29
+ this.blurInputEvent = new EventEmitter();
30
+ this.showDateInput = false;
31
+ this.dateTimeInputDate = new Date();
32
+ this.selectionInput = -1;
33
+ this.inputSvgRoutes = InputSvgRoutes;
34
+ this.isTouchedInput = false;
35
+ this.preventBlur = false;
36
+ // Date
37
+ this.newInputChanged = false;
38
+ this.selectLastOneForSelectionEmitter = new EventEmitter();
39
+ this.selectLastOneAfterMouseUpEmitter = new EventEmitter();
40
+ this.onDatePasteEmitter = new EventEmitter();
41
+ this.onFocusEmitter = new EventEmitter();
42
+ this.changeSelectionEmmiter = new EventEmitter();
43
+ this.setSelectionEmmiter = new EventEmitter();
44
+ this.destroy$ = new Subject();
45
+ this.superControl.valueAccessor = this;
46
+ }
47
+ ngAfterViewInit() {
48
+ this.setTimePickerTime();
49
+ setTimeout(() => {
50
+ if (this.superControl.control?.value)
51
+ this.setTimeDateInput(this.superControl.control?.value, true);
52
+ }, 300);
53
+ this.calendarService.dateChanged
54
+ .pipe(takeUntil(this.destroy$))
55
+ .subscribe((date) => {
56
+ if (!this.inputConfig.isDisabled) {
57
+ this.setTimeDateInput(date);
58
+ this.caInputComponent.caInputPlaceholderIconComponent.t2?.close();
59
+ }
60
+ });
61
+ }
62
+ get getSuperControl() {
63
+ return this.superControl.control;
64
+ }
65
+ selectLastOneForSelection() {
66
+ let range, selection;
67
+ this.showDateInput = true;
68
+ this.selectionInput = -1;
69
+ this.caInputComponent.isFocusInput = true;
70
+ if (window.getSelection && document.createRange) {
71
+ selection = window.getSelection();
72
+ range = document.createRange();
73
+ if (this.inputConfig.name !==
74
+ InputConfigNameStringEnum.DATE_PICKER_BANK_CARD) {
75
+ range.setStart(this.span3.nativeElement, 1);
76
+ range.setEnd(this.span3.nativeElement, 1);
77
+ }
78
+ else {
79
+ range.setStart(this.span2.nativeElement, 1);
80
+ range.setEnd(this.span2.nativeElement, 1);
81
+ }
82
+ selection?.removeAllRanges();
83
+ selection?.addRange(range);
84
+ }
85
+ this.timeoutCleaner = setTimeout(() => {
86
+ clearTimeout(this.dateTimeMainTimer);
87
+ clearTimeout(this.focusBlur);
88
+ }, 90);
89
+ }
90
+ selectLastOneAfterMouseUp() {
91
+ if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD) {
92
+ this.selectionInput = 1;
93
+ this.span2.nativeElement.focus();
94
+ this.setSpanSelection(this.span2.nativeElement);
95
+ }
96
+ else {
97
+ this.selectionInput = 2;
98
+ this.span3.nativeElement.focus();
99
+ this.setSpanSelection(this.span3.nativeElement);
100
+ }
101
+ this.showDateInput = true;
102
+ this.timeoutCleaner = setTimeout(() => {
103
+ clearTimeout(this.dateTimeMainTimer);
104
+ clearTimeout(this.focusBlur);
105
+ }, 90);
106
+ }
107
+ onDatePaste(event) {
108
+ event.preventDefault();
109
+ const pasteText = event.clipboardData?.getData('text');
110
+ const pastedDate = new Date(pasteText);
111
+ if (!isNaN(pastedDate.getTime())) {
112
+ this.setTimeDateInput(pastedDate);
113
+ this.selectSpanByTabIndex(this.selectionInput);
114
+ }
115
+ }
116
+ changeSelection(event, noPreventDefault = false) {
117
+ if (!noPreventDefault) {
118
+ event.preventDefault();
119
+ event.stopPropagation();
120
+ }
121
+ const isNavigationKey = this.isNavigationKey(event);
122
+ const isSpecialTimePickerKey = this.selectionInput === 3 &&
123
+ this.inputConfig.name === InputConfigNameStringEnum.TIME_PICKER;
124
+ if (isNavigationKey || isSpecialTimePickerKey) {
125
+ event.preventDefault();
126
+ this.handleNavigationKey(event);
127
+ }
128
+ else if (!this.isNumber(event)) {
129
+ if (!noPreventDefault)
130
+ event.preventDefault();
131
+ else {
132
+ if (!noPreventDefault)
133
+ event.preventDefault();
134
+ if (this.selectionInput === -1)
135
+ this.selectionInput = 0;
136
+ this.handleKeyboardInputs(event);
137
+ }
138
+ }
139
+ }
140
+ isNumber(evt) {
141
+ evt = evt ? evt : window.event;
142
+ let charCode = evt.which ? evt.which : evt.keyCode;
143
+ return ((charCode >= 48 && charCode <= 57) || (charCode >= 96 && charCode <= 105));
144
+ }
145
+ isNavigationKey(e) {
146
+ const navigationKeys = [37, 38, 39, 40, 8, 9, 46]; // Arrow keys, Backspace, Tab, Delete
147
+ return navigationKeys.includes(e.keyCode);
148
+ }
149
+ onFocus(event) {
150
+ this.onFocusEmitter.emit(event);
151
+ }
152
+ closePopover() {
153
+ if (this.caInputComponent.caInputPlaceholderIconComponent.t2)
154
+ this.caInputComponent.caInputPlaceholderIconComponent.t2.close();
155
+ }
156
+ toggleDropdownOptions() {
157
+ if (this.caInputComponent.caInputPlaceholderIconComponent.t2) {
158
+ if (!this.caInputComponent.caInputPlaceholderIconComponent.t2.isOpen()) {
159
+ clearTimeout(this.dateTimeMainTimer);
160
+ clearTimeout(this.focusBlur);
161
+ this.holder1.nativeElement.focus();
162
+ this.selectionInput = -1;
163
+ this.setSpanSelection(this.holder1.nativeElement);
164
+ this.caInputComponent.caInputPlaceholderIconComponent.t2.open();
165
+ }
166
+ else {
167
+ this.holder1.nativeElement.blur();
168
+ // this.setIsFocusInput(false);
169
+ let selection = window.getSelection();
170
+ selection?.removeAllRanges();
171
+ }
172
+ return;
173
+ }
174
+ }
175
+ handleFocusInput(e) {
176
+ const event = e;
177
+ if (!this.inputConfig.isDisabled) {
178
+ clearTimeout(this.dateTimeMainTimer);
179
+ clearTimeout(this.focusBlur);
180
+ this.showDateInput = true;
181
+ if ((this.selectionInput === -1 &&
182
+ event?.target?.nodeName === 'INPUT') ||
183
+ event?.relatedTarget?.nodeName === 'INPUT' ||
184
+ event?.relatedTarget === null) {
185
+ this.preventBlur = true;
186
+ this.holder1.nativeElement.focus();
187
+ this.setSpanSelection(this.holder1.nativeElement);
188
+ this.selectionInput = -1;
189
+ }
190
+ this.caInputComponent.caInputPlaceholderIconComponent.t2.toggle();
191
+ }
192
+ }
193
+ setSpanSelection(element) {
194
+ let range;
195
+ let selection;
196
+ if (window.getSelection && document.createRange) {
197
+ selection = window.getSelection();
198
+ range = document.createRange();
199
+ range.selectNodeContents(element);
200
+ selection?.removeAllRanges();
201
+ selection?.addRange(range);
202
+ }
203
+ }
204
+ setSelection(event) {
205
+ const element = event.target;
206
+ const selectionInput = parseInt(element.getAttribute('tabindex'));
207
+ const currentSelection = window.getSelection();
208
+ if (currentSelection && currentSelection.toString().length > 10) {
209
+ this.holder1.nativeElement.focus();
210
+ this.selectionInput = 0;
211
+ this.setSpanSelection(this.holder1.nativeElement);
212
+ clearTimeout(this.dateTimeMainTimer);
213
+ clearTimeout(this.focusBlur);
214
+ return;
215
+ }
216
+ clearTimeout(this.dateTimeMainTimer);
217
+ if (element.classList.contains('main')) {
218
+ this.selectionInput = selectionInput;
219
+ this.setSpanSelection(element);
220
+ }
221
+ else {
222
+ if (this.selectionInput === -1) {
223
+ this.span1.nativeElement.focus();
224
+ this.selectionInput = 0;
225
+ this.setSpanSelection(this.span1.nativeElement);
226
+ }
227
+ else {
228
+ event.preventDefault();
229
+ this.selectSpanByTabIndex(this.selectionInput);
230
+ }
231
+ }
232
+ }
233
+ registerOnChange(fn) {
234
+ this.onChange = fn;
235
+ }
236
+ onChange(_) {
237
+ this.superControl.control?.setValue(_);
238
+ this.superControl.control?.markAsTouched(); // Mark the control as touched
239
+ this.superControl.control?.markAsDirty();
240
+ }
241
+ writeValue(obj) { }
242
+ registerOnTouched() { }
243
+ // BLUR ON INPUT
244
+ blurOnDateTime() {
245
+ clearTimeout(this.dateTimeMainTimer);
246
+ this.dateTimeMainTimer = setTimeout(() => {
247
+ if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER) {
248
+ if (!isNaN(this.span1?.nativeElement.innerHTML) &&
249
+ !isNaN(this.span2?.nativeElement.innerHTML) &&
250
+ !isNaN(this.span3?.nativeElement.innerHTML)) {
251
+ if (this.inputConfig.isFutureDateDisabled &&
252
+ moment(this.dateTimeInputDate).isAfter(moment()))
253
+ this.superControl.control?.setErrors({
254
+ invalid: true,
255
+ });
256
+ // don't accept future dates
257
+ else {
258
+ if (this.inputConfig.expiredDateInvalid &&
259
+ moment(this.dateTimeInputDate).isBefore(moment())) {
260
+ this.superControl.control?.setErrors({ invalid: true }); // don't accept expired dates
261
+ }
262
+ else {
263
+ this.calendarService.dateChanged.next(this.dateTimeInputDate);
264
+ }
265
+ }
266
+ }
267
+ else {
268
+ this.span1.nativeElement.innerHTML = 'mm';
269
+ this.span2.nativeElement.innerHTML = 'dd';
270
+ this.span3.nativeElement.innerHTML = 'yy';
271
+ this.dateTimeInputDate = new Date();
272
+ this.showDateInput = false;
273
+ }
274
+ }
275
+ else if (this.inputConfig.name ===
276
+ InputConfigNameStringEnum.DATE_PICKER_BANK_CARD) {
277
+ if (!isNaN(this.span1.nativeElement.innerHTML) &&
278
+ !isNaN(this.span2.nativeElement.innerHTML)) {
279
+ if (this.inputConfig.expiredDateInvalid &&
280
+ moment(this.dateTimeInputDate).isBefore(moment())) {
281
+ this.superControl.control?.setErrors({ invalid: true }); // don't accept expired dates
282
+ }
283
+ else {
284
+ this.calendarService.dateChanged.next(this.dateTimeInputDate);
285
+ }
286
+ }
287
+ else {
288
+ this.span1.nativeElement.innerHTML = 'mm';
289
+ this.span2.nativeElement.innerHTML = 'yy';
290
+ this.dateTimeInputDate = new Date();
291
+ this.showDateInput = false;
292
+ }
293
+ }
294
+ else {
295
+ if (!isNaN(this.span1.nativeElement.innerHTML) &&
296
+ !isNaN(this.span2.nativeElement.innerHTML)) {
297
+ this.calendarService.dateChanged.next(this.dateTimeInputDate);
298
+ }
299
+ else {
300
+ this.span1.nativeElement.innerHTML = 'HH';
301
+ this.span2.nativeElement.innerHTML = 'MM';
302
+ this.setTimePickerTime();
303
+ this.showDateInput = false;
304
+ }
305
+ }
306
+ clearTimeout(this.dateTimeMainTimer);
307
+ this.selectionInput = -1;
308
+ this.newInputChanged = true;
309
+ }, 100);
310
+ }
311
+ onPopoverShown() {
312
+ this.showDateInput = true;
313
+ this.holder1.nativeElement.focus();
314
+ }
315
+ onPopoverHidden() {
316
+ this.blurOnDateTime();
317
+ }
318
+ setTimeDateInput(date, hasValue) {
319
+ let text, dateFormat, timeFormat;
320
+ if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER) {
321
+ text = moment(new Date(date)).format('MM/DD/YY');
322
+ dateFormat = text.split('/');
323
+ }
324
+ else if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD) {
325
+ text = moment(new Date(date)).format('MM/DD/YY');
326
+ dateFormat = text.split('/');
327
+ }
328
+ else {
329
+ date =
330
+ date instanceof Date
331
+ ? date
332
+ : new Date(moment().format('MM/DD/YYYY') + ' ' + date);
333
+ text = moment(new Date(date)).format('HH:mm');
334
+ timeFormat = moment(new Date(date)).format('hh/mm/A');
335
+ dateFormat = timeFormat.split('/');
336
+ }
337
+ if (!hasValue)
338
+ this.onChange(text);
339
+ // this.input.nativeElement.value = text;
340
+ this.setIsFocusInput(false);
341
+ if (this.span1)
342
+ this.span1.nativeElement.innerHTML = dateFormat[0];
343
+ if (this.span2)
344
+ if (this.inputConfig.name !==
345
+ InputConfigNameStringEnum.DATE_PICKER_BANK_CARD) {
346
+ this.span2.nativeElement.innerHTML = dateFormat[1];
347
+ this.span3.nativeElement.innerHTML = dateFormat[2];
348
+ }
349
+ else {
350
+ this.span2.nativeElement.innerHTML = dateFormat[2];
351
+ }
352
+ this.dateTimeInputDate = new Date(date);
353
+ this.showDateInput = true;
354
+ }
355
+ handleKeyboardInputs(e, isRestart) {
356
+ const spanOneValue = isNaN(this.span1.nativeElement.innerHTML) || this.newInputChanged
357
+ ? undefined
358
+ : parseInt(this.span1.nativeElement.innerHTML);
359
+ const span2Value = isNaN(this.span2.nativeElement.innerHTML) || this.newInputChanged
360
+ ? undefined
361
+ : parseInt(this.span2.nativeElement.innerHTML);
362
+ let span3Value;
363
+ if (this.inputConfig.name !== InputConfigNameStringEnum.DATE_PICKER_BANK_CARD) {
364
+ span3Value =
365
+ isNaN(this.span3.nativeElement.innerHTML) || this.newInputChanged
366
+ ? ''
367
+ : parseInt(this.span3.nativeElement.innerHTML);
368
+ }
369
+ this.newInputChanged = false;
370
+ if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER) {
371
+ if (this.selectionInput === 0) {
372
+ if (isRestart) {
373
+ this.span1.nativeElement.innerHTML = 'mm';
374
+ this.selectionInput = 0;
375
+ this.selectSpanByTabIndex(0);
376
+ }
377
+ else if (spanOneValue !== undefined) {
378
+ let final_value = parseInt(`${spanOneValue}${e.key}`);
379
+ if (final_value > 12) {
380
+ this.span1.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(-2);
381
+ this.selectionInput = 1;
382
+ this.selectSpanByTabIndex(1, true);
383
+ }
384
+ else {
385
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setMonth(parseInt(this.span1.nativeElement.innerHTML + parseInt(e.key)) -
386
+ 1));
387
+ if (!final_value)
388
+ this.span1.nativeElement.innerHTML = 'mm';
389
+ else
390
+ this.span1.nativeElement.innerHTML = (this.span1.nativeElement.innerHTML + parseInt(e.key)).slice(-2);
391
+ this.selectionInput = 1;
392
+ this.selectSpanByTabIndex(1, true);
393
+ }
394
+ }
395
+ else {
396
+ if (parseInt(e.key))
397
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setMonth(parseInt(e.key) - 1));
398
+ const final_value = ('0' + parseInt(e.key)).slice(-2);
399
+ this.span1.nativeElement.innerHTML = final_value;
400
+ if (parseInt(`1${e.key}`) > 12) {
401
+ this.selectionInput = 1;
402
+ this.selectSpanByTabIndex(1, true);
403
+ }
404
+ else
405
+ this.selectSpanByTabIndex(0);
406
+ }
407
+ }
408
+ else if (this.selectionInput === 1) {
409
+ if (isRestart) {
410
+ this.span2.nativeElement.innerHTML = 'dd';
411
+ this.selectionInput = 0;
412
+ this.selectSpanByTabIndex(0, true);
413
+ }
414
+ else if (span2Value !== undefined) {
415
+ let final_value = parseInt(`${span2Value}${e.key}`);
416
+ if (final_value > 31) {
417
+ this.span2.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(-2);
418
+ this.selectionInput = 2;
419
+ this.selectSpanByTabIndex(2, true);
420
+ }
421
+ else {
422
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setDate(parseInt(this.span2.nativeElement.innerHTML + parseInt(e.key))));
423
+ if (!final_value) {
424
+ this.span2.nativeElement.innerHTML = 'dd';
425
+ }
426
+ else {
427
+ this.span2.nativeElement.innerHTML = (this.span2.nativeElement.innerHTML + parseInt(e.key)).slice(-2);
428
+ }
429
+ this.selectionInput = 2;
430
+ this.selectSpanByTabIndex(2, true);
431
+ }
432
+ }
433
+ else {
434
+ if (parseInt(e.key))
435
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setDate(parseInt(e.key)));
436
+ this.span2.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(-2);
437
+ if (parseInt(`1${e.key}`) > 31) {
438
+ this.selectionInput = 2;
439
+ this.selectSpanByTabIndex(2, true);
440
+ }
441
+ else {
442
+ this.selectSpanByTabIndex(1);
443
+ }
444
+ }
445
+ }
446
+ else {
447
+ if (isRestart) {
448
+ this.span3.nativeElement.innerHTML = 'yy';
449
+ this.selectionInput = 1;
450
+ this.selectSpanByTabIndex(1, true);
451
+ }
452
+ else if (!span3Value || span3Value.toString().length === 2) {
453
+ this.span3.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(-2);
454
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setFullYear(parseInt(`200${parseInt(e.key)}`)));
455
+ this.selectSpanByTabIndex(2);
456
+ }
457
+ else {
458
+ const finalYear = parseInt(this.span3.nativeElement.innerHTML + parseInt(e.key));
459
+ const finalShowYear = finalYear > 31
460
+ ? parseInt(`19${finalYear}`)
461
+ : parseInt(`20${finalYear}`);
462
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setFullYear(finalShowYear));
463
+ this.span3.nativeElement.innerHTML = (this.span3.nativeElement.innerHTML + parseInt(e.key)).slice(-2);
464
+ this.selectSpanByTabIndex(2);
465
+ }
466
+ }
467
+ }
468
+ else if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD) {
469
+ if (!this.selectionInput) {
470
+ if (isRestart) {
471
+ this.span1.nativeElement.innerHTML = 'mm';
472
+ this.selectionInput = 0;
473
+ this.selectSpanByTabIndex(0);
474
+ }
475
+ else if (spanOneValue) {
476
+ const final_value = parseInt(`${spanOneValue}${e.key}`);
477
+ if (final_value > 12) {
478
+ this.span1.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(-2);
479
+ this.selectionInput = 1;
480
+ this.selectSpanByTabIndex(1, true);
481
+ }
482
+ else {
483
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setMonth(parseInt(this.span1.nativeElement.innerHTML + parseInt(e.key)) -
484
+ 1));
485
+ if (!final_value) {
486
+ this.span1.nativeElement.innerHTML = 'mm';
487
+ }
488
+ else {
489
+ this.span1.nativeElement.innerHTML = (this.span1.nativeElement.innerHTML + parseInt(e.key)).slice(-2);
490
+ }
491
+ this.selectionInput = 1;
492
+ this.selectSpanByTabIndex(1, true);
493
+ }
494
+ }
495
+ else {
496
+ if (parseInt(e.key))
497
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setMonth(parseInt(e.key) - 1));
498
+ const final_value = ('0' + parseInt(e.key)).slice(-2);
499
+ this.span1.nativeElement.innerHTML = final_value;
500
+ if (parseInt(`1${e.key}`) > 12) {
501
+ this.selectionInput = 1;
502
+ this.selectSpanByTabIndex(1, true);
503
+ }
504
+ else
505
+ this.selectSpanByTabIndex(0);
506
+ }
507
+ }
508
+ else {
509
+ if (isRestart) {
510
+ this.span2.nativeElement.innerHTML = 'yy';
511
+ this.selectionInput = 2;
512
+ this.selectSpanByTabIndex(2, true);
513
+ }
514
+ else if (!span2Value || span2Value.toString().length === 2) {
515
+ this.span2.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(-2);
516
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setFullYear(parseInt(`200${parseInt(e.key)}`)));
517
+ this.selectSpanByTabIndex(1);
518
+ }
519
+ else {
520
+ const finalYear = parseInt(this.span2.nativeElement.innerHTML + parseInt(e.key));
521
+ const finalShowYear = finalYear > 31
522
+ ? parseInt(`19${finalYear}`)
523
+ : parseInt(`20${finalYear}`);
524
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setFullYear(finalShowYear));
525
+ this.span2.nativeElement.innerHTML = (this.span2.nativeElement.innerHTML + parseInt(e.key)).slice(-2);
526
+ this.selectSpanByTabIndex(1);
527
+ }
528
+ }
529
+ }
530
+ }
531
+ selectSpanByTabIndex(indx, changeTab) {
532
+ switch (indx) {
533
+ case 0:
534
+ this.setSpanSelection(this.span1.nativeElement);
535
+ break;
536
+ case 1:
537
+ this.setSpanSelection(this.span2.nativeElement);
538
+ break;
539
+ case 2:
540
+ this.setSpanSelection(this.span3.nativeElement);
541
+ break;
542
+ default:
543
+ this.setSpanSelection(this.holder1.nativeElement);
544
+ }
545
+ if (changeTab)
546
+ this.newInputChanged = true;
547
+ }
548
+ handleNavigationKey(event) {
549
+ switch (event.keyCode) {
550
+ case 37: // Left arrow
551
+ this.moveSelectionLeft();
552
+ break;
553
+ case 39: // Right arrow
554
+ case 9: // Tab
555
+ this.moveSelectionRightOrTab(event);
556
+ break;
557
+ case 38: // Up arrow
558
+ this.setDateTimeModel('up');
559
+ break;
560
+ case 40: // Down arrow
561
+ this.setDateTimeModel('down');
562
+ break;
563
+ case 8: // Backspace
564
+ case 46: // Delete
565
+ this.handleKeyboardInputs(event, true);
566
+ break;
567
+ }
568
+ }
569
+ handleDatePickerInput(isUp, isDatePicker) {
570
+ if (this.selectionInput === 0)
571
+ this.updateMonth(isUp);
572
+ else if (this.selectionInput === 1)
573
+ this.updateDate(isUp, isDatePicker);
574
+ else
575
+ this.updateYear(isUp, isDatePicker);
576
+ }
577
+ setDateTimeModel(direction) {
578
+ if (this.selectionInput === -1)
579
+ this.selectionInput = 0;
580
+ const isUp = direction === 'up';
581
+ const isDatePicker = this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER;
582
+ const isBankCardPicker = this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD;
583
+ if (isDatePicker || isBankCardPicker)
584
+ this.handleDatePickerInput(isUp, isDatePicker);
585
+ else
586
+ this.handleTimePickerInput(isUp);
587
+ }
588
+ moveSelectionRightOrTab(e) {
589
+ const isDatepickerBankCard = this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD;
590
+ const maxIndex = isDatepickerBankCard ? 1 : 2;
591
+ if (this.selectionInput < maxIndex && !e.shiftKey) {
592
+ this.selectionInput += 1;
593
+ this.selectSpanByTabIndex(this.selectionInput, true);
594
+ }
595
+ else if (e.keyCode === 9 && !e.shiftKey) {
596
+ this.focusNextInput();
597
+ }
598
+ else if (e.shiftKey && e.keyCode === 9) {
599
+ this.focusPreviousInput();
600
+ }
601
+ }
602
+ focusPreviousInput() {
603
+ const allInputs = Array.from(document.querySelectorAll('input.input-control'));
604
+ const currentIndex = allInputs.findIndex((input) => input === this.caInputComponent.input.nativeElement);
605
+ if (currentIndex === -1)
606
+ this.selectionInput = 3;
607
+ else if (currentIndex === 0)
608
+ this.selectionInput = 0;
609
+ else {
610
+ this.selectionInput -= 1;
611
+ this.selectSpanByTabIndex(this.selectionInput);
612
+ }
613
+ if (currentIndex > 0)
614
+ allInputs[currentIndex - 1].focus();
615
+ this.selectionInput = -1;
616
+ }
617
+ focusNextInput() {
618
+ const allInputs = Array.from(document.querySelectorAll('input.input-control'));
619
+ const currentIndex = allInputs.findIndex((input) => input === this.caInputComponent.input.nativeElement);
620
+ if (allInputs[currentIndex + 1])
621
+ allInputs[currentIndex + 1].focus();
622
+ else {
623
+ this.setIsFocusInput(false);
624
+ this.blurOnDateTime();
625
+ }
626
+ this.selectionInput = -1;
627
+ }
628
+ setIsFocusInput(value) {
629
+ this.caInputComponent.isFocusInput = value;
630
+ }
631
+ moveSelectionLeft() {
632
+ if (this.selectionInput > 0) {
633
+ this.selectionInput -= 1;
634
+ this.selectSpanByTabIndex(this.selectionInput, true);
635
+ }
636
+ }
637
+ updateMonth(isUp) {
638
+ const monthDelta = isUp ? 1 : -1;
639
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setMonth(this.dateTimeInputDate.getMonth() + monthDelta));
640
+ this.span1.nativeElement.innerHTML = this.padValue(this.dateTimeInputDate.getMonth() + 1);
641
+ this.setSpanSelection(this.span1.nativeElement);
642
+ }
643
+ updateDate(isUp, isDatePicker) {
644
+ const dateDelta = isUp ? 1 : -1;
645
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setDate(this.dateTimeInputDate.getDate() + dateDelta));
646
+ const spanElement = isDatePicker
647
+ ? this.span2.nativeElement
648
+ : this.span1.nativeElement;
649
+ spanElement.innerHTML = this.padValue(this.dateTimeInputDate.getDate());
650
+ this.setSpanSelection(spanElement);
651
+ }
652
+ updateYear(isUp, isDatePicker) {
653
+ const yearDelta = isUp ? 1 : -1;
654
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setFullYear(this.dateTimeInputDate.getFullYear() + yearDelta));
655
+ const spanElement = isDatePicker
656
+ ? this.span3.nativeElement
657
+ : this.span2.nativeElement;
658
+ spanElement.innerHTML = this.dateTimeInputDate
659
+ .getFullYear()
660
+ .toString()
661
+ .slice(-2);
662
+ this.setSpanSelection(spanElement);
663
+ }
664
+ padValue(value) {
665
+ return ('0' + value).slice(-2);
666
+ }
667
+ handleTimePickerInput(isUp) {
668
+ if (this.selectionInput === 0)
669
+ this.updateHours(isUp);
670
+ else if (this.selectionInput === 1)
671
+ this.updateMinutes(isUp);
672
+ else
673
+ this.toggleAMPM();
674
+ }
675
+ updateHours(isUp) {
676
+ const hoursDelta = isUp ? 1 : -1;
677
+ let selectedHours = this.dateTimeInputDate.getHours() + hoursDelta;
678
+ if (selectedHours === 0)
679
+ selectedHours = 24;
680
+ if (selectedHours === -1)
681
+ selectedHours = 23;
682
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setHours(selectedHours));
683
+ this.span1.nativeElement.innerHTML = this.padValue(selectedHours > 12 ? selectedHours - 12 : selectedHours);
684
+ this.setSpanSelection(this.span1.nativeElement);
685
+ this.span3.nativeElement.innerHTML =
686
+ selectedHours > 11 && selectedHours < 24 ? 'PM' : 'AM';
687
+ }
688
+ updateMinutes(isUp) {
689
+ const minutesDelta = isUp ? 1 : -1;
690
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setMinutes(this.dateTimeInputDate.getMinutes() + minutesDelta));
691
+ this.span2.nativeElement.innerHTML = this.padValue(this.dateTimeInputDate.getMinutes());
692
+ this.setSpanSelection(this.span2.nativeElement);
693
+ }
694
+ toggleAMPM() {
695
+ this.span3.nativeElement.innerHTML =
696
+ this.span3.nativeElement.innerHTML === 'AM' ? 'PM' : 'AM';
697
+ const hoursToAdd = this.span3.nativeElement.innerHTML === 'AM' ? -12 : 12;
698
+ this.dateTimeInputDate = new Date(this.dateTimeInputDate.setHours(this.dateTimeInputDate.getHours() + hoursToAdd));
699
+ this.setSpanSelection(this.span3.nativeElement);
700
+ }
701
+ clearInput(event) {
702
+ this.clearInputEvent.emit(event);
703
+ this.setIsFocusInput(false);
704
+ this.resetDateTimeInputs();
705
+ }
706
+ onBlurInput(event) {
707
+ this.blurInputEvent.emit(event);
708
+ }
709
+ resetDateTimeInputs() {
710
+ if (this.span1)
711
+ if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER) {
712
+ this.span1.nativeElement.innerHTML = 'mm';
713
+ this.span2.nativeElement.innerHTML = 'dd';
714
+ this.span3.nativeElement.innerHTML = 'yy';
715
+ }
716
+ else if (this.inputConfig.name ===
717
+ InputConfigNameStringEnum.DATE_PICKER_BANK_CARD) {
718
+ this.span1.nativeElement.innerHTML = 'mm';
719
+ this.span2.nativeElement.innerHTML = 'yy';
720
+ }
721
+ else if (this.inputConfig.name === InputConfigNameStringEnum.TIME_PICKER) {
722
+ this.span1.nativeElement.innerHTML = 'HH';
723
+ this.span2.nativeElement.innerHTML = 'MM';
724
+ this.span3.nativeElement.innerHTML = 'AM';
725
+ }
726
+ this.setTimePickerTime();
727
+ this.newInputChanged = true;
728
+ this.setIsFocusInput(false);
729
+ this.showDateInput = false;
730
+ }
731
+ setTimePickerTime() {
732
+ if (this.inputConfig.name === InputConfigNameStringEnum.TIME_PICKER)
733
+ this.dateTimeInputDate = new Date(moment().format('MM/DD/YYYY') +
734
+ (this.inputConfig?.isFromDate ? ' 12:15' : ' 12:00'));
735
+ }
736
+ ngOnDestroy() {
737
+ this.destroy$.next();
738
+ this.destroy$.complete();
739
+ }
740
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaInputDatetimePickerComponent, deps: [{ token: i1.NgControl, self: true }, { token: i2.CalendarDateTimePickerService }], target: i0.ɵɵFactoryTarget.Component }); }
741
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CaInputDatetimePickerComponent, isStandalone: true, selector: "app-ca-input-datetime-picker", inputs: { inputConfig: "inputConfig" }, outputs: { clearInputEvent: "clear", blurInputEvent: "blurInput", selectLastOneForSelectionEmitter: "selectLastOneForSelectionEmitter", selectLastOneAfterMouseUpEmitter: "selectLastOneAfterMouseUpEmitter", onDatePasteEmitter: "onDatePasteEmitter", onFocusEmitter: "onFocusEmitter", changeSelectionEmmiter: "changeSelectionEmmiter", setSelectionEmmiter: "setSelectionEmmiter" }, providers: [CalendarDateTimePickerService], viewQueries: [{ propertyName: "caInputPlaceholderIconComponent", first: true, predicate: CaInputPlaceholderIconComponent, descendants: true }, { propertyName: "dateTimePopover", first: true, predicate: ["dateTimePopover"], descendants: true }, { propertyName: "caInputComponent", first: true, predicate: CaInputComponent, descendants: true, static: true }, { propertyName: "span1", first: true, predicate: ["span1"], descendants: true }, { propertyName: "span2", first: true, predicate: ["span2"], descendants: true }, { propertyName: "span3", first: true, predicate: ["span3"], descendants: true }, { propertyName: "holder1", first: true, predicate: ["holder1"], descendants: true }], ngImport: i0, template: "<div\n class=\"datetime-picker-main-holder input-custom-group datetimeclass\"\n [ngClass]=\"\n getSuperControl\n | inputContainerClass\n : caInputComponent.isFocusInput\n : caInputComponent.isTouchedInput\n : inputConfig\n : getSuperControl?.value\n \"\n>\n <div\n #holder1\n class=\"date_time_holder input-control\"\n [class.active]=\"showDateInput\"\n tabindex=\"-1\"\n (mousedown)=\"selectLastOneForSelection()\"\n (mouseup)=\"selectLastOneAfterMouseUp()\"\n (paste)=\"onDatePaste($event)\"\n (keydown)=\"changeSelection($event, true)\"\n (click)=\"toggleDropdownOptions()\"\n [ngStyle]=\"{\n 'padding-left': inputConfig.isIconHidden ? '2px' : '27px'\n }\"\n [ngClass]=\"\n caInputComponent.isFocusInput\n | inputDatetimePickerClass\n : false\n : getSuperControl\n : inputConfig\n : caInputComponent.isTouchedInput\n : getSuperControl?.value\n \"\n >\n <span\n #span1\n class=\"main\"\n [ngClass]=\"{\n 'reset-selection-color': !caInputComponent.isFocusInput\n }\"\n tabindex=\"0\"\n (mouseup)=\"setSelection($event)\"\n (keydown)=\"changeSelection($event)\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? 'mm' : 'HH'\"\n ></span>\n <span>\n <div\n class=\"border-picker\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? '/' : ':'\"\n ></div>\n </span>\n <span\n #span2\n class=\"main\"\n [ngClass]=\"{\n 'reset-selection-color': !caInputComponent.isFocusInput\n }\"\n tabindex=\"1\"\n (mouseup)=\"setSelection($event)\"\n (keydown)=\"changeSelection($event)\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? 'dd' : 'MM'\"\n ></span>\n <span>\n <div\n class=\"border-picker\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? '/' : ' '\"\n ></div>\n </span>\n <span\n #span3\n class=\"main\"\n [ngClass]=\"{\n 'reset-selection-color': !caInputComponent.isFocusInput\n }\"\n tabindex=\"2\"\n (mouseup)=\"setSelection($event)\"\n (keydown)=\"changeSelection($event)\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? 'yy' : 'AM'\"\n ></span>\n </div>\n <app-ca-input\n [inputConfig]=\"inputConfig\"\n [dateTimePopover]=\"dateTimePopover\"\n (focusInputEvent)=\"handleFocusInput($event)\"\n (handleToggleDropdownOptions)=\"toggleDropdownOptions()\"\n (closePopover)=\"blurOnDateTime()\"\n (blurInput)=\"onBlurInput($event)\"\n (clear)=\"clearInput($event)\"\n [formControl]=\"getSuperControl! | formControl\"\n ></app-ca-input>\n</div>\n\n<!-- Popover for DateTime Pickers -->\n<ng-template #dateTimePopover let-data=\"data\">\n <div class=\"datetime-dropdown-holder\">\n <app-ca-custom-datetime-pickers\n [calendarType]=\"\n inputConfig.name === 'datepicker' ||\n inputConfig.name === 'datepickerBankCard'\n ? 'date'\n : 'time'\n \"\n [inputConfig]=\"inputConfig\"\n [placeholder]=\"'MM/DD/YY'\"\n [dateTime]=\"dateTimeInputDate\"\n (closePopover)=\"closePopover()\"\n ></app-ca-custom-datetime-pickers>\n </div>\n</ng-template>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap\";@import\"https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/css/bootstrap.min.css\";.ca-font-thin{font-weight:100!important}.ca-font-extra-light{font-weight:200!important}.ca-font-light{font-weight:300!important}.ca-font-regular{font-weight:400!important}.ca-font-medium{font-weight:500!important}.ca-font-semi-bold{font-weight:600!important}.ca-font-bold{font-weight:700!important}.ca-font-extra-bold{font-weight:800!important}.ca-font-black{font-weight:900!important}.pickup-delivery-popover{top:-38px!important;max-width:340px!important}.pickup-delivery-popover.bs-popover-top{top:auto!important;bottom:-38px!important}.pickup-delivery-popover.bs-popover-top .load-component .assigned-load-holder{order:3;margin-top:4px;margin-bottom:0!important}.pickup-delivery-popover.bs-popover-top .load-component .statusBar{order:2;margin-top:4px}.pickup-delivery-popover.bs-popover-top .load-component .animation-three-tabs{order:1}.gps_dropdown_popover{top:-38px;max-width:494px}.gps_dropdown_popover .popover-body{padding:0}.table-progress-popover{background-color:unset!important;margin-left:-10px}.table-progress-popover .progress-dropdown{margin-top:-6px;width:260px;height:200px;background:#2f2f2f;border-radius:3px;padding:8px;box-shadow:0 0 4px #00000026;overflow:hidden;-webkit-animation:progressAnimation .25s ease-in-out;animation:progressAnimation .25s ease-in-out}.table-progress-popover .progress-dropdown .progress-header .progress-title{font-size:18px;font-weight:600;color:#dadada}.table-progress-popover .progress-dropdown .progress-header .progress-title span{font-weight:400}.table-progress-popover .progress-dropdown .progress-header .progress-total{font-size:14px;line-height:17px;color:#dadada}.table-progress-popover .progress-dropdown .table-progress-bar-container{width:100%;height:8px;margin-top:6px;border-radius:2px;overflow:hidden}.table-progress-popover .progress-dropdown .table-progress-bar-container .table-progress-bar{height:100%}.table-progress-popover .progress-dropdown .progress-dropdown-body .progress-dual-info-container .progress-info-container{width:50%}.table-progress-popover .progress-dropdown .progress-dropdown-body .progress-info-container{margin-top:10px}.table-progress-popover .progress-dropdown .progress-dropdown-body .progress-info-container .progress-info-title{margin-bottom:2px;font-size:11px;font-weight:700;line-height:14px;color:#ffffffb2}.table-progress-popover .progress-dropdown .progress-dropdown-body .progress-info-container .progress-info-text{font-size:14px;line-height:18px;color:#dadada}.table-progress-popover .progress-dropdown.credit-dropdown{height:100px}@-webkit-keyframes progressAnimation{0%{height:0px}to{height:220px}}@keyframes progressAnimation{0%{height:0px}to{height:220px}}ngb-popover-window{padding:unset!important;border:unset!important}ngb-popover-window .popover-arrow{display:none!important}ngb-popover-window .popover-body{padding:unset!important}.dispatch-note .popover-body{position:relative;top:-4px;left:-4px}.tooltip{font-size:12px;position:relative}.tooltip.show{opacity:.83}.tooltip.fade:after,.tooltip.fade:before{transform:translateY(-10px);transition:all .15s ease-in-out}.tooltip.fade:hover:after,.tooltip.fade:hover:before{opacity:1;transform:translate(0)}.tooltip-inner{padding:4px 10px;white-space:nowrap;max-width:none;border-radius:3px}.tooltip-inner:empty{padding:0}.placeholder-delete .tooltip-inner{background-color:#f66}.placeholder-delete .arrow:before{border-top-color:#f66}.custom-popup-owners-for-flag .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(126%) translate(-50%)!important;width:130px;border-radius:3px;box-shadow:0 0 3px #0003}.custom-popup-owners-for-flag .arrow{bottom:-18%;transform:rotate(180deg);left:calc(50% + 2.7rem)}.custom-popup-owners-for-flag .tooltip{opacity:.93!important;width:0}.custom-popup-owners{z-index:999}.custom-popup-owners .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(132%);z-index:999;box-shadow:0 0 3px #0003}.custom-popup-owners .arrow{bottom:-20%;transform:rotate(180deg)}.custom-popup-owners .tooltip{transform:translateY(-61px)!important}.custom-popup-owners-year{z-index:999}.custom-popup-owners-year .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(132%);z-index:999;box-shadow:0 0 3px #0003}.custom-popup-owners-year .arrow{bottom:-20%;transform:rotate(180deg)}.custom-popup-owners-year .tooltip{transform:translate(70px,-61px)!important}.custom-popup-owners-info .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(-100%) translate(-10%);width:200px;height:36px;display:flex;justify-content:center;align-items:center;border-radius:3px;margin-top:3px;box-shadow:0 0 3px #0003}.custom-popup-owners-info .tooltip{opacity:.93;width:0}.custom-popup-owners-info .arrow{display:none}.custom-popup-owners-info #phone-inside{position:relative;right:26px;bottom:0}.custom-popup-owners-info-at .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(-108%) translate(-7%);width:270px;height:36px;display:flex;justify-content:center;align-items:center;border-radius:3px;box-shadow:0 0 3px #0003}.custom-popup-owners-info-at .tooltip{opacity:1;width:0}.custom-popup-owners-info-at .arrow{display:none}.custom-popup-owners-for-tag .tooltip-inner{color:#3b3b3b;background-color:#fff;width:100px;border-radius:3px;box-shadow:0 0 3px #0003!important}.custom-popup-owners-for-tag .tooltip{top:5px!important}.custom-popup-owners-for-tag .arrow{bottom:-24%}.align-items-flex-start{justify-content:center;align-items:center}.align-items-flex-end{display:flex;justify-content:center;flex-direction:column;align-self:flex-end;align-items:flex-start}.label-add{align-self:flex-start}.fadeInLoad{animation:fadeInLoad .25s}@keyframes fadeInLoad{0%{opacity:0}to{opacity:1}}.fadeIn{opacity:1;-webkit-transition:.25s;-moz-transition:.25s;-o-transition:.25s;transition:.25s}.thisText:hover .fadeIn{opacity:0}.fadeInLoad{animation-name:example;animation-duration:.25s}@keyframes example{0%{transform:scale(.5)}to{transform:scale(1)}}.tooltip.tooltip-table-icons{left:12px!important;opacity:1}.tooltip.tooltip-table-icons .arrow{display:none!important}.tooltip.tooltip-table-icons .tooltip-inner{border-radius:0 50px 50px;background:#28529f}.tooltip.show{opacity:1;animation:fadeIn ease .5s!important;-webkit-animation:fadeIn ease .5s!important;-moz-animation:fadeIn ease .5s!important;-o-animation:fadeIn ease .5s!important;-ms-animation:fadeIn ease .5s!important}.ta-tooltip{position:absolute;font-size:12px;text-align:center;color:#fff;line-height:22px;z-index:999999!important;opacity:0;white-space:nowrap;transform:scale(.7)}.ta-tooltip.ta-tooltip-show{opacity:.85;transform:scale(1);padding:0 12px}.ta-tooltip.ta-tooltip-bottom-right,.ta-tooltip.ta-tooltip-bottom-right-corner{transform-origin:top left;border-radius:0 15px 15px}.ta-tooltip.ta-tooltip-bottom-left{transform-origin:top right;border-radius:15px 0 15px 15px}@keyframes scaleItem{0%{transform:scale(.4)}to{transform:scale(1)}}.app-ca-main-tooltip{pointer-events:none}.app-ca-main-tooltip .tooltip-inner{padding:0;background-color:transparent;pointer-events:none}.app-ca-main-tooltip .tooltip-inner .tooltip-holder{display:flex;font-size:11px;font-weight:700;border-radius:2px;padding:2px 8px;animation:scaleItem .3s;white-space:normal}.app-ca-main-tooltip .tooltip-inner .tooltip-holder:empty{padding:0}.tooltip-arrow{display:none!important}.trucks.semitruck svg path,.trucks.semisleeper svg path,.trucks.flatbed svg path,.trucks.stepdeck svg path,.trucks.lowboyrgn svg path,.trucks.chassis svg path,.trucks.conestoga svg path,.trucks.sidekit svg path,.trucks.container svg path,.trailers.semitruck svg path,.trailers.semisleeper svg path,.trailers.flatbed svg path,.trailers.stepdeck svg path,.trailers.lowboyrgn svg path,.trailers.chassis svg path,.trailers.conestoga svg path,.trailers.sidekit svg path,.trailers.container svg path{fill:#92b1f5}.trucks.boxtruck svg path,.trucks.reefertruck svg path,.trucks.cargovan svg path,.trucks.dryvan svg path,.trucks.reefer svg path,.trailers.boxtruck svg path,.trailers.reefertruck svg path,.trailers.cargovan svg path,.trailers.dryvan svg path,.trailers.reefer svg path{fill:#fbc88b}.trucks.dumptruck svg path,.trucks.cementtruck svg path,.trucks.garbagetruck svg path,.trucks.enddump svg path,.trucks.bottomdump svg path,.trucks.hopper svg path,.trucks.tanker svg path,.trucks.pneumatictanker svg path,.trailers.dumptruck svg path,.trailers.cementtruck svg path,.trailers.garbagetruck svg path,.trailers.enddump svg path,.trailers.bottomdump svg path,.trailers.hopper svg path,.trailers.tanker svg path,.trailers.pneumatictanker svg path{fill:#ed9292}.trucks.towtruck svg path,.trucks.carhauler svg path,.trucks.spotter svg path,.trucks.carhaulerstigner svg path,.trailers.towtruck svg path,.trailers.carhauler svg path,.trailers.spotter svg path,.trailers.carhaulerstigner svg path{fill:#86c9c3}.trucks .svgtext-template-text,.trailers .svgtext-template-text{color:#fff;transition:color .3s ease-in-out}.colors .black svg #droplet{fill:#6c6c6c}.colors .brown svg #droplet{fill:#a1887f}.colors .darkgreen svg #droplet{fill:#4db6a2}.colors .lightgreen svg #droplet{fill:#81c784}.colors .darkblue svg #droplet{fill:#546fd2}.colors .lightblue svg #droplet{fill:#64b5f6}.colors .gray svg #droplet{fill:#aaa}.colors .purple svg #droplet{fill:#ba68c8}.colors .gold svg #droplet{fill:#bcad79}.colors .silver svg #droplet{fill:#dadada}.colors .red svg #droplet{fill:#f96b69}.colors .pink svg #droplet{fill:#f26ec2}.colors .white svg #droplet{fill:#f1f1f1}.colors .orange svg #droplet{fill:#ff8a65}.colors .yellow svg #droplet{fill:#ffd54f}.colors:hover{transition:all .3s ease-in-out}.colors:hover .black svg #droplet{fill:#3c3c3c}.colors:hover .brown svg #droplet{fill:#8d6e63}.colors:hover .darkgreen svg #droplet{fill:#26a690}.colors:hover .lightgreen svg #droplet{fill:#66bb6a}.colors:hover .darkblue svg #droplet{fill:#304fc1}.colors:hover .lightblue svg #droplet{fill:#42a5f5}.colors:hover .gray svg #droplet{fill:#919191}.colors:hover .purple svg #droplet{fill:#ab47bc}.colors:hover .gold svg #droplet{fill:#aa9c6e}.colors:hover .silver svg #droplet{fill:#b7b7b7}.colors:hover .red svg #droplet{fill:#ef5350}.colors:hover .pink svg #droplet{fill:#fa4daa}.colors:hover .white svg #droplet{fill:#fff}.colors:hover .orange svg #droplet{fill:#ff7043}.colors:hover .yellow svg #droplet{fill:#ffca28}.text-color-black{color:#424242!important}.text-color-black::-moz-selection{background:#42424233!important;color:#424242!important}.text-color-black::selection{background:#42424233!important;color:#424242!important}.text-color-black-2{color:#2f2f2f!important}.text-color-black-2::-moz-selection{background:#2f2f2f33!important;color:#2f2f2f!important}.text-color-black-2::selection{background:#2f2f2f33!important;color:#2f2f2f!important}.text-color-muted{color:#919191!important}.text-color-muted::-moz-selection{background:#91919133!important;color:#919191!important}.text-color-muted::selection{background:#91919133!important;color:#919191!important}.text-color-green{color:#56b4ac!important}.text-color-green::-moz-selection{background:#56b4ac33!important;color:#56b4ac!important}.text-color-green::selection{background:#56b4ac33!important;color:#56b4ac!important}.text-color-blue-13{color:#6692f1!important}.text-color-blue-13::-moz-selection{background:#66921833!important;color:#6692f1!important}.text-color-blue-13::selection{background:#66921833!important;color:#6692f1!important}.text-color-blue-18{color:#3b73ed!important}.text-color-blue-18::-moz-selection{background:#3b73ed33!important;color:#3b73ed!important}.text-color-blue-18::selection{background:#3b73ed33!important;color:#3b73ed!important}.text-color-red-10{color:#e66767!important}.text-color-red-10::-moz-selection{background:#e6676733!important;color:#e66767!important}.text-color-red-10::selection{background:#e6676733!important;color:#e66767!important}.text-color-light-grey{color:#e5e5e5!important}.text-color-light-grey::-moz-selection{background:#e5e5e533!important;color:#e5e5e5!important}.text-color-light-grey::selection{background:#e5e5e533!important;color:#e5e5e5!important}.text-color-light-grey-2{color:#aaa!important}.text-color-light-grey-2::-moz-selection{background:#aaa3!important;color:#aaa!important}.text-color-light-grey-2::selection{background:#aaa3!important;color:#aaa!important}.text-color-light-grey-6{color:#ccc!important}.text-color-light-grey-6::-moz-selection{color:#ccc!important;background:#aaa3!important}.text-color-light-grey-6::selection{color:#ccc!important;background:#aaa3!important}.text-color-white{color:#dadada!important}.text-color-white::-moz-selection{color:#dadada!important;background:#fff3!important}.text-color-white::selection{color:#dadada!important;background:#fff3!important}.text-color-white-4{color:#ffffffb2!important}.text-color-white-4::-moz-selection{color:#ffffffb2!important;background:#fff3!important}.text-color-white-4::selection{color:#ffffffb2!important;background:#fff3!important}.text-color-dark-grey{color:#6c6c6c!important}.text-color-dark-grey::-moz-selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-dark-grey::selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-bw6-2{color:#6c6c6c!important}.text-color-bw6-2::-moz-selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-bw6-2::selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-bw-9{color:#dadada!important}.text-color-bw-9::-moz-selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-bw-9::selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-grey{color:#919191!important}.text-color-grey::-moz-selection{color:#919191!important;background:#91919133!important}.text-color-grey::selection{color:#919191!important;background:#91919133!important}.text-color-grey .address-text::-moz-selection,.text-color-grey .marker-bold-text::-moz-selection{color:#919191!important;background:#91919133!important}.text-color-grey .address-text::selection,.text-color-grey .marker-bold-text::selection{color:#919191!important;background:#91919133!important}.text-size-11{font-size:11px!important;line-height:14px!important}.text-size-14{font-size:14px!important;line-height:18px!important}.text-size-16{font-size:16px!important;line-height:19px!important}.text-size-18{font-size:18px!important;line-height:22px!important}.text-size-26{font-size:26px!important;line-height:32px!important}.text-size-28{font-size:28px!important;line-height:34px!important}@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.svg-fill-black svg path{fill:#424242!important}.svg-fill-muted svg path{fill:#919191!important}.svg-fill-bw-9 svg path{fill:#dadada!important}.svg-fill-light-grey-2 svg path{fill:#aaa!important}.svg-fill-light-grey-6 svg path{fill:#ccc!important}.svg-fill-blue-13 svg path{fill:#6692f1!important}.svg-fill-blue-19 svg path{fill:#92b1f5!important}.svg-fill-blue-26 svg path{fill:#4dc5eb!important}.svg-hover-muted svg path{transition:all .3s ease-in-out}.svg-hover-muted:hover svg path{fill:#919191!important}.svg-hover-black svg path{transition:all .3s ease-in-out}.svg-hover-black:hover svg path{fill:#424242!important}.svg-hover-blue-15 svg path{transition:all .3s ease-in-out}.svg-hover-blue-15:hover svg path{fill:#0b49d1!important}.svg-hover-bw6-2 svg path{transition:all .3s ease-in-out}.svg-hover-bw6-2:hover svg path{fill:#6c6c6c!important}.svg-hover-trash-red svg path{transition:all .3s ease-in-out}.svg-hover-trash-red:hover svg path{fill:#ff5050!important}.svg-hover-red-14 svg path{transition:all .3s ease-in-out}.svg-hover-red-14:hover svg path{fill:#c20c0c!important}.svg-size-12 svg{width:12px;height:12px}.svg-size-14 svg{width:14px;height:14px}.svg-size-16 svg{width:16px;height:16px}.svg-size-18 svg{width:18px;height:18px}.svg-size-44-16 svg{width:44px;height:16px}*{margin:0;font-family:Montserrat,sans-serif}html{scroll-behavior:auto!important}.gm-style-iw-chr,.gm-style-iw-tc{display:none}.gm-style .gm-style-iw-c{border-radius:0}.gm-style-iw{overflow-y:auto!important;overflow-x:hidden!important}.gm-style-iw>div{overflow:visible!important}.infoWindow{overflow:hidden!important}.gm-style-iw-d,.gm-style-iw.gm-style-iw-c{max-height:350px!important}::ng-deep .popover{--bs-popover-border-width: 0;--bs-popover-body-padding-y: 0;--bs-popover-body-padding-x: 0}::ng-deep .popover .popover-arrow{display:none}.datetime-picker-main-holder{position:relative}.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover{transition:.3s ease-in-out}.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-clear{display:inline-block}.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-dropdown-arrow:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-icon:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover app-ca-input-placeholder-icon:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-clear:hover~.input-control{background-color:#dadada}.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-dropdown-arrow:before:hover,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-dropdown-arrow:after:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-icon:before:hover,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-icon:after:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover app-ca-input-placeholder-icon:before:hover,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover app-ca-input-placeholder-icon:after:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-clear:before:hover,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-clear:after:hover~.input-control{background-color:#dadada}.datetime-picker-main-holder.input-custom-group.datetimeclass{border-radius:2px!important}.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-out-filled),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-in),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-out),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-out-filled),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-in),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-out-empty){background-color:#eee}.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-out-filled):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-in):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-out):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-out-filled):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-in):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-out-empty):hover{background-color:#dadada}.datetime-picker-main-holder.input-custom-group.datetimeclass.invalid-empty-focus-out{background-color:#fae3e3}.datetime-picker-main-holder.input-custom-group.datetimeclass.invalid-empty-focus-out:hover{background-color:#f5c7c7}.datetime-picker-main-holder.input-custom-group.datetimeclass.valid-focus-out{background-color:#e2ecf9}.datetime-picker-main-holder.input-custom-group.datetimeclass.valid-focus-out:hover{background-color:#c5d8f3}.datetime-picker-main-holder.input-custom-group.datetimeclass.inactive-empty,.datetime-picker-main-holder.input-custom-group.datetimeclass.inactive-filled{background-color:#f7f7f7}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-out-filled),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-in),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-out),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-out-filled),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-in),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-out-empty){background-color:#424242}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-out-filled):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-in):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-out):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-out-filled):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-in):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-out-empty):hover{background-color:#6c6c6c}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark.valid-focus-out-filled{background-color:red}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark.valid-focus-out-filled:hover{background-color:#c5d8f3}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark.inactive-empty,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark.inactive-filled{background-color:#f7f7f7}\n", "@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.date_time_holder{display:flex;align-items:center;position:absolute;top:0;width:100%;height:100%;padding:0 6px;opacity:0;z-index:20;cursor:text}.date_time_holder span{position:relative;line-height:14px;display:flex;height:100%;align-items:center;z-index:10}.date_time_holder span .border-picker{position:absolute;top:0;left:50%;transform:translate(-50%);height:100%;display:flex;align-items:center;justify-content:center;width:0px}.date_time_holder span::selection{background-color:#fff3;color:#fff}.date_time_holder span div::selection{background-color:#fff3;color:#fff}.date_time_holder::selection{background-color:transparent!important;color:#fff}.date_time_holder span.main{padding:0 2px;outline:none;font-size:14px;z-index:11}.date_time_holder span.main::selection{z-index:10}.date_time_holder span.main:first-child{padding-left:4px}.date_time_holder span.reset-selection-color::selection{background-color:transparent!important;color:#2f2f2f!important}.date_time_holder.focus{opacity:1;padding-left:35px}.date_time_holder.focus span:nth-child(2){z-index:12;pointer-events:none}.date_time_holder.focus span:nth-child(3){z-index:13}.date_time_holder.focus span:nth-child(4){z-index:14;pointer-events:none}.date_time_holder.focus span:nth-child(5){z-index:15}.date_time_holder.valid-focus-out-filled{opacity:1}.date_time_holder.valid-focus-out-filled span,.date_time_holder.valid-focus-out-filled span .border-picker{color:#2f2f2f!important;-webkit-user-select:none;user-select:none}.date_time_holder.dark.valid-focus-out-filled{background:#3b73ed33!important}.date_time_holder.dark.valid-focus-out-filled span,.date_time_holder.dark.valid-focus-out-filled span .border-picker{color:#fff!important}.date_time_holder.dark.valid-focus-out-filled:hover{background:#3b73ed66!important}.date_time_holder.dark.valid-focus-in{background:#0b49d1!important}.date_time_holder.dark.valid-focus-in span,.date_time_holder.dark.valid-focus-in span .border-picker{color:#fff!important}.date_time_holder.focus{background-color:#1d1d1d;color:#fff;transition:.2s ease-in-out}.date_time_holder.valid-focus-in{opacity:1}.date_time_holder.valid-focus-in::selection,.date_time_holder.valid-focus-in div::selection{background-color:#fff3;color:#fff}.date_time_holder.invalid-focus-out-filled{opacity:1}.date_time_holder.date_time_holder_bank_card span.main{padding:0 3px}\n"], dependencies: [{ kind: "ngmodule", type:
742
+ // modules
743
+ CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "component", type:
744
+ // components
745
+ CaInputComponent, selector: "app-ca-input", inputs: ["inputConfig", "dateTimePopover", "incorrectValue", "selectedDropdownLabelColor", "template"], outputs: ["handleToggleDropdownOptions", "incorrectEvent", "blurInput", "focusInput", "change", "commandEvent", "clear", "showHideDropdown", "dropDownKeyNavigation"] }, { kind: "component", type: CaCustomDatetimePickersComponent, selector: "app-ca-custom-datetime-pickers", inputs: ["dateTime", "inputConfig", "calendarType", "placeholder"], outputs: ["closePopover"] }, { kind: "pipe", type:
746
+ // pipes
747
+ InputDatetimePickerClassPipe, name: "inputDatetimePickerClass" }, { kind: "pipe", type: InputContainerClassPipe, name: "inputContainerClass" }, { kind: "pipe", type: FormControlPipe, name: "formControl" }] }); }
748
+ }
749
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaInputDatetimePickerComponent, decorators: [{
750
+ type: Component,
751
+ args: [{ selector: 'app-ca-input-datetime-picker', standalone: true, imports: [
752
+ // modules
753
+ CommonModule,
754
+ FormsModule,
755
+ ReactiveFormsModule,
756
+ AngularSvgIconModule,
757
+ // components
758
+ CaInputComponent,
759
+ CaCustomDatetimePickersComponent,
760
+ // pipes
761
+ InputDatetimePickerClassPipe,
762
+ InputContainerClassPipe,
763
+ FormControlPipe,
764
+ ], providers: [CalendarDateTimePickerService], template: "<div\n class=\"datetime-picker-main-holder input-custom-group datetimeclass\"\n [ngClass]=\"\n getSuperControl\n | inputContainerClass\n : caInputComponent.isFocusInput\n : caInputComponent.isTouchedInput\n : inputConfig\n : getSuperControl?.value\n \"\n>\n <div\n #holder1\n class=\"date_time_holder input-control\"\n [class.active]=\"showDateInput\"\n tabindex=\"-1\"\n (mousedown)=\"selectLastOneForSelection()\"\n (mouseup)=\"selectLastOneAfterMouseUp()\"\n (paste)=\"onDatePaste($event)\"\n (keydown)=\"changeSelection($event, true)\"\n (click)=\"toggleDropdownOptions()\"\n [ngStyle]=\"{\n 'padding-left': inputConfig.isIconHidden ? '2px' : '27px'\n }\"\n [ngClass]=\"\n caInputComponent.isFocusInput\n | inputDatetimePickerClass\n : false\n : getSuperControl\n : inputConfig\n : caInputComponent.isTouchedInput\n : getSuperControl?.value\n \"\n >\n <span\n #span1\n class=\"main\"\n [ngClass]=\"{\n 'reset-selection-color': !caInputComponent.isFocusInput\n }\"\n tabindex=\"0\"\n (mouseup)=\"setSelection($event)\"\n (keydown)=\"changeSelection($event)\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? 'mm' : 'HH'\"\n ></span>\n <span>\n <div\n class=\"border-picker\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? '/' : ':'\"\n ></div>\n </span>\n <span\n #span2\n class=\"main\"\n [ngClass]=\"{\n 'reset-selection-color': !caInputComponent.isFocusInput\n }\"\n tabindex=\"1\"\n (mouseup)=\"setSelection($event)\"\n (keydown)=\"changeSelection($event)\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? 'dd' : 'MM'\"\n ></span>\n <span>\n <div\n class=\"border-picker\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? '/' : ' '\"\n ></div>\n </span>\n <span\n #span3\n class=\"main\"\n [ngClass]=\"{\n 'reset-selection-color': !caInputComponent.isFocusInput\n }\"\n tabindex=\"2\"\n (mouseup)=\"setSelection($event)\"\n (keydown)=\"changeSelection($event)\"\n [innerHTML]=\"inputConfig.name === 'datepicker' ? 'yy' : 'AM'\"\n ></span>\n </div>\n <app-ca-input\n [inputConfig]=\"inputConfig\"\n [dateTimePopover]=\"dateTimePopover\"\n (focusInputEvent)=\"handleFocusInput($event)\"\n (handleToggleDropdownOptions)=\"toggleDropdownOptions()\"\n (closePopover)=\"blurOnDateTime()\"\n (blurInput)=\"onBlurInput($event)\"\n (clear)=\"clearInput($event)\"\n [formControl]=\"getSuperControl! | formControl\"\n ></app-ca-input>\n</div>\n\n<!-- Popover for DateTime Pickers -->\n<ng-template #dateTimePopover let-data=\"data\">\n <div class=\"datetime-dropdown-holder\">\n <app-ca-custom-datetime-pickers\n [calendarType]=\"\n inputConfig.name === 'datepicker' ||\n inputConfig.name === 'datepickerBankCard'\n ? 'date'\n : 'time'\n \"\n [inputConfig]=\"inputConfig\"\n [placeholder]=\"'MM/DD/YY'\"\n [dateTime]=\"dateTimeInputDate\"\n (closePopover)=\"closePopover()\"\n ></app-ca-custom-datetime-pickers>\n </div>\n</ng-template>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap\";@import\"https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/css/bootstrap.min.css\";.ca-font-thin{font-weight:100!important}.ca-font-extra-light{font-weight:200!important}.ca-font-light{font-weight:300!important}.ca-font-regular{font-weight:400!important}.ca-font-medium{font-weight:500!important}.ca-font-semi-bold{font-weight:600!important}.ca-font-bold{font-weight:700!important}.ca-font-extra-bold{font-weight:800!important}.ca-font-black{font-weight:900!important}.pickup-delivery-popover{top:-38px!important;max-width:340px!important}.pickup-delivery-popover.bs-popover-top{top:auto!important;bottom:-38px!important}.pickup-delivery-popover.bs-popover-top .load-component .assigned-load-holder{order:3;margin-top:4px;margin-bottom:0!important}.pickup-delivery-popover.bs-popover-top .load-component .statusBar{order:2;margin-top:4px}.pickup-delivery-popover.bs-popover-top .load-component .animation-three-tabs{order:1}.gps_dropdown_popover{top:-38px;max-width:494px}.gps_dropdown_popover .popover-body{padding:0}.table-progress-popover{background-color:unset!important;margin-left:-10px}.table-progress-popover .progress-dropdown{margin-top:-6px;width:260px;height:200px;background:#2f2f2f;border-radius:3px;padding:8px;box-shadow:0 0 4px #00000026;overflow:hidden;-webkit-animation:progressAnimation .25s ease-in-out;animation:progressAnimation .25s ease-in-out}.table-progress-popover .progress-dropdown .progress-header .progress-title{font-size:18px;font-weight:600;color:#dadada}.table-progress-popover .progress-dropdown .progress-header .progress-title span{font-weight:400}.table-progress-popover .progress-dropdown .progress-header .progress-total{font-size:14px;line-height:17px;color:#dadada}.table-progress-popover .progress-dropdown .table-progress-bar-container{width:100%;height:8px;margin-top:6px;border-radius:2px;overflow:hidden}.table-progress-popover .progress-dropdown .table-progress-bar-container .table-progress-bar{height:100%}.table-progress-popover .progress-dropdown .progress-dropdown-body .progress-dual-info-container .progress-info-container{width:50%}.table-progress-popover .progress-dropdown .progress-dropdown-body .progress-info-container{margin-top:10px}.table-progress-popover .progress-dropdown .progress-dropdown-body .progress-info-container .progress-info-title{margin-bottom:2px;font-size:11px;font-weight:700;line-height:14px;color:#ffffffb2}.table-progress-popover .progress-dropdown .progress-dropdown-body .progress-info-container .progress-info-text{font-size:14px;line-height:18px;color:#dadada}.table-progress-popover .progress-dropdown.credit-dropdown{height:100px}@-webkit-keyframes progressAnimation{0%{height:0px}to{height:220px}}@keyframes progressAnimation{0%{height:0px}to{height:220px}}ngb-popover-window{padding:unset!important;border:unset!important}ngb-popover-window .popover-arrow{display:none!important}ngb-popover-window .popover-body{padding:unset!important}.dispatch-note .popover-body{position:relative;top:-4px;left:-4px}.tooltip{font-size:12px;position:relative}.tooltip.show{opacity:.83}.tooltip.fade:after,.tooltip.fade:before{transform:translateY(-10px);transition:all .15s ease-in-out}.tooltip.fade:hover:after,.tooltip.fade:hover:before{opacity:1;transform:translate(0)}.tooltip-inner{padding:4px 10px;white-space:nowrap;max-width:none;border-radius:3px}.tooltip-inner:empty{padding:0}.placeholder-delete .tooltip-inner{background-color:#f66}.placeholder-delete .arrow:before{border-top-color:#f66}.custom-popup-owners-for-flag .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(126%) translate(-50%)!important;width:130px;border-radius:3px;box-shadow:0 0 3px #0003}.custom-popup-owners-for-flag .arrow{bottom:-18%;transform:rotate(180deg);left:calc(50% + 2.7rem)}.custom-popup-owners-for-flag .tooltip{opacity:.93!important;width:0}.custom-popup-owners{z-index:999}.custom-popup-owners .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(132%);z-index:999;box-shadow:0 0 3px #0003}.custom-popup-owners .arrow{bottom:-20%;transform:rotate(180deg)}.custom-popup-owners .tooltip{transform:translateY(-61px)!important}.custom-popup-owners-year{z-index:999}.custom-popup-owners-year .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(132%);z-index:999;box-shadow:0 0 3px #0003}.custom-popup-owners-year .arrow{bottom:-20%;transform:rotate(180deg)}.custom-popup-owners-year .tooltip{transform:translate(70px,-61px)!important}.custom-popup-owners-info .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(-100%) translate(-10%);width:200px;height:36px;display:flex;justify-content:center;align-items:center;border-radius:3px;margin-top:3px;box-shadow:0 0 3px #0003}.custom-popup-owners-info .tooltip{opacity:.93;width:0}.custom-popup-owners-info .arrow{display:none}.custom-popup-owners-info #phone-inside{position:relative;right:26px;bottom:0}.custom-popup-owners-info-at .tooltip-inner{color:#3b3b3b;background-color:#fff;transform:translateY(-108%) translate(-7%);width:270px;height:36px;display:flex;justify-content:center;align-items:center;border-radius:3px;box-shadow:0 0 3px #0003}.custom-popup-owners-info-at .tooltip{opacity:1;width:0}.custom-popup-owners-info-at .arrow{display:none}.custom-popup-owners-for-tag .tooltip-inner{color:#3b3b3b;background-color:#fff;width:100px;border-radius:3px;box-shadow:0 0 3px #0003!important}.custom-popup-owners-for-tag .tooltip{top:5px!important}.custom-popup-owners-for-tag .arrow{bottom:-24%}.align-items-flex-start{justify-content:center;align-items:center}.align-items-flex-end{display:flex;justify-content:center;flex-direction:column;align-self:flex-end;align-items:flex-start}.label-add{align-self:flex-start}.fadeInLoad{animation:fadeInLoad .25s}@keyframes fadeInLoad{0%{opacity:0}to{opacity:1}}.fadeIn{opacity:1;-webkit-transition:.25s;-moz-transition:.25s;-o-transition:.25s;transition:.25s}.thisText:hover .fadeIn{opacity:0}.fadeInLoad{animation-name:example;animation-duration:.25s}@keyframes example{0%{transform:scale(.5)}to{transform:scale(1)}}.tooltip.tooltip-table-icons{left:12px!important;opacity:1}.tooltip.tooltip-table-icons .arrow{display:none!important}.tooltip.tooltip-table-icons .tooltip-inner{border-radius:0 50px 50px;background:#28529f}.tooltip.show{opacity:1;animation:fadeIn ease .5s!important;-webkit-animation:fadeIn ease .5s!important;-moz-animation:fadeIn ease .5s!important;-o-animation:fadeIn ease .5s!important;-ms-animation:fadeIn ease .5s!important}.ta-tooltip{position:absolute;font-size:12px;text-align:center;color:#fff;line-height:22px;z-index:999999!important;opacity:0;white-space:nowrap;transform:scale(.7)}.ta-tooltip.ta-tooltip-show{opacity:.85;transform:scale(1);padding:0 12px}.ta-tooltip.ta-tooltip-bottom-right,.ta-tooltip.ta-tooltip-bottom-right-corner{transform-origin:top left;border-radius:0 15px 15px}.ta-tooltip.ta-tooltip-bottom-left{transform-origin:top right;border-radius:15px 0 15px 15px}@keyframes scaleItem{0%{transform:scale(.4)}to{transform:scale(1)}}.app-ca-main-tooltip{pointer-events:none}.app-ca-main-tooltip .tooltip-inner{padding:0;background-color:transparent;pointer-events:none}.app-ca-main-tooltip .tooltip-inner .tooltip-holder{display:flex;font-size:11px;font-weight:700;border-radius:2px;padding:2px 8px;animation:scaleItem .3s;white-space:normal}.app-ca-main-tooltip .tooltip-inner .tooltip-holder:empty{padding:0}.tooltip-arrow{display:none!important}.trucks.semitruck svg path,.trucks.semisleeper svg path,.trucks.flatbed svg path,.trucks.stepdeck svg path,.trucks.lowboyrgn svg path,.trucks.chassis svg path,.trucks.conestoga svg path,.trucks.sidekit svg path,.trucks.container svg path,.trailers.semitruck svg path,.trailers.semisleeper svg path,.trailers.flatbed svg path,.trailers.stepdeck svg path,.trailers.lowboyrgn svg path,.trailers.chassis svg path,.trailers.conestoga svg path,.trailers.sidekit svg path,.trailers.container svg path{fill:#92b1f5}.trucks.boxtruck svg path,.trucks.reefertruck svg path,.trucks.cargovan svg path,.trucks.dryvan svg path,.trucks.reefer svg path,.trailers.boxtruck svg path,.trailers.reefertruck svg path,.trailers.cargovan svg path,.trailers.dryvan svg path,.trailers.reefer svg path{fill:#fbc88b}.trucks.dumptruck svg path,.trucks.cementtruck svg path,.trucks.garbagetruck svg path,.trucks.enddump svg path,.trucks.bottomdump svg path,.trucks.hopper svg path,.trucks.tanker svg path,.trucks.pneumatictanker svg path,.trailers.dumptruck svg path,.trailers.cementtruck svg path,.trailers.garbagetruck svg path,.trailers.enddump svg path,.trailers.bottomdump svg path,.trailers.hopper svg path,.trailers.tanker svg path,.trailers.pneumatictanker svg path{fill:#ed9292}.trucks.towtruck svg path,.trucks.carhauler svg path,.trucks.spotter svg path,.trucks.carhaulerstigner svg path,.trailers.towtruck svg path,.trailers.carhauler svg path,.trailers.spotter svg path,.trailers.carhaulerstigner svg path{fill:#86c9c3}.trucks .svgtext-template-text,.trailers .svgtext-template-text{color:#fff;transition:color .3s ease-in-out}.colors .black svg #droplet{fill:#6c6c6c}.colors .brown svg #droplet{fill:#a1887f}.colors .darkgreen svg #droplet{fill:#4db6a2}.colors .lightgreen svg #droplet{fill:#81c784}.colors .darkblue svg #droplet{fill:#546fd2}.colors .lightblue svg #droplet{fill:#64b5f6}.colors .gray svg #droplet{fill:#aaa}.colors .purple svg #droplet{fill:#ba68c8}.colors .gold svg #droplet{fill:#bcad79}.colors .silver svg #droplet{fill:#dadada}.colors .red svg #droplet{fill:#f96b69}.colors .pink svg #droplet{fill:#f26ec2}.colors .white svg #droplet{fill:#f1f1f1}.colors .orange svg #droplet{fill:#ff8a65}.colors .yellow svg #droplet{fill:#ffd54f}.colors:hover{transition:all .3s ease-in-out}.colors:hover .black svg #droplet{fill:#3c3c3c}.colors:hover .brown svg #droplet{fill:#8d6e63}.colors:hover .darkgreen svg #droplet{fill:#26a690}.colors:hover .lightgreen svg #droplet{fill:#66bb6a}.colors:hover .darkblue svg #droplet{fill:#304fc1}.colors:hover .lightblue svg #droplet{fill:#42a5f5}.colors:hover .gray svg #droplet{fill:#919191}.colors:hover .purple svg #droplet{fill:#ab47bc}.colors:hover .gold svg #droplet{fill:#aa9c6e}.colors:hover .silver svg #droplet{fill:#b7b7b7}.colors:hover .red svg #droplet{fill:#ef5350}.colors:hover .pink svg #droplet{fill:#fa4daa}.colors:hover .white svg #droplet{fill:#fff}.colors:hover .orange svg #droplet{fill:#ff7043}.colors:hover .yellow svg #droplet{fill:#ffca28}.text-color-black{color:#424242!important}.text-color-black::-moz-selection{background:#42424233!important;color:#424242!important}.text-color-black::selection{background:#42424233!important;color:#424242!important}.text-color-black-2{color:#2f2f2f!important}.text-color-black-2::-moz-selection{background:#2f2f2f33!important;color:#2f2f2f!important}.text-color-black-2::selection{background:#2f2f2f33!important;color:#2f2f2f!important}.text-color-muted{color:#919191!important}.text-color-muted::-moz-selection{background:#91919133!important;color:#919191!important}.text-color-muted::selection{background:#91919133!important;color:#919191!important}.text-color-green{color:#56b4ac!important}.text-color-green::-moz-selection{background:#56b4ac33!important;color:#56b4ac!important}.text-color-green::selection{background:#56b4ac33!important;color:#56b4ac!important}.text-color-blue-13{color:#6692f1!important}.text-color-blue-13::-moz-selection{background:#66921833!important;color:#6692f1!important}.text-color-blue-13::selection{background:#66921833!important;color:#6692f1!important}.text-color-blue-18{color:#3b73ed!important}.text-color-blue-18::-moz-selection{background:#3b73ed33!important;color:#3b73ed!important}.text-color-blue-18::selection{background:#3b73ed33!important;color:#3b73ed!important}.text-color-red-10{color:#e66767!important}.text-color-red-10::-moz-selection{background:#e6676733!important;color:#e66767!important}.text-color-red-10::selection{background:#e6676733!important;color:#e66767!important}.text-color-light-grey{color:#e5e5e5!important}.text-color-light-grey::-moz-selection{background:#e5e5e533!important;color:#e5e5e5!important}.text-color-light-grey::selection{background:#e5e5e533!important;color:#e5e5e5!important}.text-color-light-grey-2{color:#aaa!important}.text-color-light-grey-2::-moz-selection{background:#aaa3!important;color:#aaa!important}.text-color-light-grey-2::selection{background:#aaa3!important;color:#aaa!important}.text-color-light-grey-6{color:#ccc!important}.text-color-light-grey-6::-moz-selection{color:#ccc!important;background:#aaa3!important}.text-color-light-grey-6::selection{color:#ccc!important;background:#aaa3!important}.text-color-white{color:#dadada!important}.text-color-white::-moz-selection{color:#dadada!important;background:#fff3!important}.text-color-white::selection{color:#dadada!important;background:#fff3!important}.text-color-white-4{color:#ffffffb2!important}.text-color-white-4::-moz-selection{color:#ffffffb2!important;background:#fff3!important}.text-color-white-4::selection{color:#ffffffb2!important;background:#fff3!important}.text-color-dark-grey{color:#6c6c6c!important}.text-color-dark-grey::-moz-selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-dark-grey::selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-bw6-2{color:#6c6c6c!important}.text-color-bw6-2::-moz-selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-bw6-2::selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-bw-9{color:#dadada!important}.text-color-bw-9::-moz-selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-bw-9::selection{color:#6c6c6c!important;background:#6c6c6c33!important}.text-color-grey{color:#919191!important}.text-color-grey::-moz-selection{color:#919191!important;background:#91919133!important}.text-color-grey::selection{color:#919191!important;background:#91919133!important}.text-color-grey .address-text::-moz-selection,.text-color-grey .marker-bold-text::-moz-selection{color:#919191!important;background:#91919133!important}.text-color-grey .address-text::selection,.text-color-grey .marker-bold-text::selection{color:#919191!important;background:#91919133!important}.text-size-11{font-size:11px!important;line-height:14px!important}.text-size-14{font-size:14px!important;line-height:18px!important}.text-size-16{font-size:16px!important;line-height:19px!important}.text-size-18{font-size:18px!important;line-height:22px!important}.text-size-26{font-size:26px!important;line-height:32px!important}.text-size-28{font-size:28px!important;line-height:34px!important}@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.svg-fill-black svg path{fill:#424242!important}.svg-fill-muted svg path{fill:#919191!important}.svg-fill-bw-9 svg path{fill:#dadada!important}.svg-fill-light-grey-2 svg path{fill:#aaa!important}.svg-fill-light-grey-6 svg path{fill:#ccc!important}.svg-fill-blue-13 svg path{fill:#6692f1!important}.svg-fill-blue-19 svg path{fill:#92b1f5!important}.svg-fill-blue-26 svg path{fill:#4dc5eb!important}.svg-hover-muted svg path{transition:all .3s ease-in-out}.svg-hover-muted:hover svg path{fill:#919191!important}.svg-hover-black svg path{transition:all .3s ease-in-out}.svg-hover-black:hover svg path{fill:#424242!important}.svg-hover-blue-15 svg path{transition:all .3s ease-in-out}.svg-hover-blue-15:hover svg path{fill:#0b49d1!important}.svg-hover-bw6-2 svg path{transition:all .3s ease-in-out}.svg-hover-bw6-2:hover svg path{fill:#6c6c6c!important}.svg-hover-trash-red svg path{transition:all .3s ease-in-out}.svg-hover-trash-red:hover svg path{fill:#ff5050!important}.svg-hover-red-14 svg path{transition:all .3s ease-in-out}.svg-hover-red-14:hover svg path{fill:#c20c0c!important}.svg-size-12 svg{width:12px;height:12px}.svg-size-14 svg{width:14px;height:14px}.svg-size-16 svg{width:16px;height:16px}.svg-size-18 svg{width:18px;height:18px}.svg-size-44-16 svg{width:44px;height:16px}*{margin:0;font-family:Montserrat,sans-serif}html{scroll-behavior:auto!important}.gm-style-iw-chr,.gm-style-iw-tc{display:none}.gm-style .gm-style-iw-c{border-radius:0}.gm-style-iw{overflow-y:auto!important;overflow-x:hidden!important}.gm-style-iw>div{overflow:visible!important}.infoWindow{overflow:hidden!important}.gm-style-iw-d,.gm-style-iw.gm-style-iw-c{max-height:350px!important}::ng-deep .popover{--bs-popover-border-width: 0;--bs-popover-body-padding-y: 0;--bs-popover-body-padding-x: 0}::ng-deep .popover .popover-arrow{display:none}.datetime-picker-main-holder{position:relative}.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover{transition:.3s ease-in-out}.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-clear{display:inline-block}.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-dropdown-arrow:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-icon:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover app-ca-input-placeholder-icon:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-clear:hover~.input-control{background-color:#dadada}.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-dropdown-arrow:before:hover,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-dropdown-arrow:after:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-icon:before:hover,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-icon:after:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover app-ca-input-placeholder-icon:before:hover,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover app-ca-input-placeholder-icon:after:hover~.input-control,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-clear:before:hover,.datetime-picker-main-holder.input-custom-group.custom-filled-hover:hover .input-clear:after:hover~.input-control{background-color:#dadada}.datetime-picker-main-holder.input-custom-group.datetimeclass{border-radius:2px!important}.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-out-filled),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-in),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-out),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-out-filled),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-in),.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-out-empty){background-color:#eee}.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-out-filled):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-in):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-out):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.valid-focus-out-filled):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-in):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass:not(.invalid-focus-out-empty):hover{background-color:#dadada}.datetime-picker-main-holder.input-custom-group.datetimeclass.invalid-empty-focus-out{background-color:#fae3e3}.datetime-picker-main-holder.input-custom-group.datetimeclass.invalid-empty-focus-out:hover{background-color:#f5c7c7}.datetime-picker-main-holder.input-custom-group.datetimeclass.valid-focus-out{background-color:#e2ecf9}.datetime-picker-main-holder.input-custom-group.datetimeclass.valid-focus-out:hover{background-color:#c5d8f3}.datetime-picker-main-holder.input-custom-group.datetimeclass.inactive-empty,.datetime-picker-main-holder.input-custom-group.datetimeclass.inactive-filled{background-color:#f7f7f7}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-out-filled),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-in),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-out),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-out-filled),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-in),.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-out-empty){background-color:#424242}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-out-filled):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-in):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-out):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.valid-focus-out-filled):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-in):hover,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark:not(.invalid-focus-out-empty):hover{background-color:#6c6c6c}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark.valid-focus-out-filled{background-color:red}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark.valid-focus-out-filled:hover{background-color:#c5d8f3}.datetime-picker-main-holder.input-custom-group.datetimeclass.dark.inactive-empty,.datetime-picker-main-holder.input-custom-group.datetimeclass.dark.inactive-filled{background-color:#f7f7f7}\n", "@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.date_time_holder{display:flex;align-items:center;position:absolute;top:0;width:100%;height:100%;padding:0 6px;opacity:0;z-index:20;cursor:text}.date_time_holder span{position:relative;line-height:14px;display:flex;height:100%;align-items:center;z-index:10}.date_time_holder span .border-picker{position:absolute;top:0;left:50%;transform:translate(-50%);height:100%;display:flex;align-items:center;justify-content:center;width:0px}.date_time_holder span::selection{background-color:#fff3;color:#fff}.date_time_holder span div::selection{background-color:#fff3;color:#fff}.date_time_holder::selection{background-color:transparent!important;color:#fff}.date_time_holder span.main{padding:0 2px;outline:none;font-size:14px;z-index:11}.date_time_holder span.main::selection{z-index:10}.date_time_holder span.main:first-child{padding-left:4px}.date_time_holder span.reset-selection-color::selection{background-color:transparent!important;color:#2f2f2f!important}.date_time_holder.focus{opacity:1;padding-left:35px}.date_time_holder.focus span:nth-child(2){z-index:12;pointer-events:none}.date_time_holder.focus span:nth-child(3){z-index:13}.date_time_holder.focus span:nth-child(4){z-index:14;pointer-events:none}.date_time_holder.focus span:nth-child(5){z-index:15}.date_time_holder.valid-focus-out-filled{opacity:1}.date_time_holder.valid-focus-out-filled span,.date_time_holder.valid-focus-out-filled span .border-picker{color:#2f2f2f!important;-webkit-user-select:none;user-select:none}.date_time_holder.dark.valid-focus-out-filled{background:#3b73ed33!important}.date_time_holder.dark.valid-focus-out-filled span,.date_time_holder.dark.valid-focus-out-filled span .border-picker{color:#fff!important}.date_time_holder.dark.valid-focus-out-filled:hover{background:#3b73ed66!important}.date_time_holder.dark.valid-focus-in{background:#0b49d1!important}.date_time_holder.dark.valid-focus-in span,.date_time_holder.dark.valid-focus-in span .border-picker{color:#fff!important}.date_time_holder.focus{background-color:#1d1d1d;color:#fff;transition:.2s ease-in-out}.date_time_holder.valid-focus-in{opacity:1}.date_time_holder.valid-focus-in::selection,.date_time_holder.valid-focus-in div::selection{background-color:#fff3;color:#fff}.date_time_holder.invalid-focus-out-filled{opacity:1}.date_time_holder.date_time_holder_bank_card span.main{padding:0 3px}\n"] }]
765
+ }], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
766
+ type: Self
767
+ }] }, { type: i2.CalendarDateTimePickerService }], propDecorators: { inputConfig: [{
768
+ type: Input
769
+ }], clearInputEvent: [{
770
+ type: Output,
771
+ args: ['clear']
772
+ }], blurInputEvent: [{
773
+ type: Output,
774
+ args: ['blurInput']
775
+ }], caInputPlaceholderIconComponent: [{
776
+ type: ViewChild,
777
+ args: [CaInputPlaceholderIconComponent]
778
+ }], dateTimePopover: [{
779
+ type: ViewChild,
780
+ args: ['dateTimePopover']
781
+ }], caInputComponent: [{
782
+ type: ViewChild,
783
+ args: [CaInputComponent, { static: true }]
784
+ }], selectLastOneForSelectionEmitter: [{
785
+ type: Output
786
+ }], selectLastOneAfterMouseUpEmitter: [{
787
+ type: Output
788
+ }], onDatePasteEmitter: [{
789
+ type: Output
790
+ }], onFocusEmitter: [{
791
+ type: Output
792
+ }], changeSelectionEmmiter: [{
793
+ type: Output
794
+ }], setSelectionEmmiter: [{
795
+ type: Output
796
+ }], span1: [{
797
+ type: ViewChild,
798
+ args: ['span1', { static: false }]
799
+ }], span2: [{
800
+ type: ViewChild,
801
+ args: ['span2', { static: false }]
802
+ }], span3: [{
803
+ type: ViewChild,
804
+ args: ['span3', { static: false }]
805
+ }], holder1: [{
806
+ type: ViewChild,
807
+ args: ['holder1', { static: false }]
808
+ }] } });
809
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-datetime-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  Self,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NgControl,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { CommonModule } from '@angular/common';\n\n// Imports\nimport moment from 'moment';\nimport { NgbPopover } from '@ng-bootstrap/ng-bootstrap';\nimport { Subject, takeUntil } from 'rxjs';\n\n// Models\nimport { ICaInput } from '../ca-input/config';\nimport { InputChangeValue, InputSvgRoutes } from '../ca-input/utils';\n\n// Pipe\nimport {\n  InputContainerClassPipe,\n  InputDatetimePickerClassPipe,\n} from '../ca-input/pipes';\n\n// Components\nimport { CaInputComponent } from '../ca-input/ca-input.component';\nimport { CaCustomDatetimePickersComponent } from '../ca-custom-datetime-pickers/ca-custom-datetime-pickers.component';\nimport { CaInputPlaceholderIconComponent } from '../ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component';\n\n// Enums\nimport { InputConfigNameStringEnum } from '../ca-input/enums';\n\n// Services\nimport { CalendarDateTimePickerService } from '../ca-custom-datetime-pickers/services/calendar-datetime-picker.service';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { FormControlPipe } from '../ca-input/pipes/form-control.pipe';\n@Component({\n  selector: 'app-ca-input-datetime-picker',\n  templateUrl: './ca-input-datetime-picker.component.html',\n  styleUrls: [\n    './ca-input-datetime-picker.component.scss',\n    '../ca-input/scss//ca-input.datepicker.scss',\n  ],\n  standalone: true,\n  imports: [\n    // modules\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    AngularSvgIconModule,\n    // components\n    CaInputComponent,\n    CaCustomDatetimePickersComponent,\n    // pipes\n    InputDatetimePickerClassPipe,\n    InputContainerClassPipe,\n    FormControlPipe,\n  ],\n  providers: [CalendarDateTimePickerService],\n})\nexport class CaInputDatetimePickerComponent\n  implements AfterViewInit, ControlValueAccessor, OnDestroy\n{\n  @Input() inputConfig!: ICaInput;\n\n  @Output('clear') clearInputEvent: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n  @Output('blurInput') blurInputEvent: EventEmitter<boolean> =\n    new EventEmitter<boolean>();\n\n  @ViewChild(CaInputPlaceholderIconComponent)\n  caInputPlaceholderIconComponent!: CaInputPlaceholderIconComponent;\n\n  @ViewChild('dateTimePopover') dateTimePopover!: NgbPopover;\n  @ViewChild(CaInputComponent, { static: true })\n  caInputComponent!: CaInputComponent;\n\n  public showDateInput: boolean = false;\n  public dateTimeInputDate: Date = new Date();\n  public selectionInput: number = -1;\n\n  private dateTimeMainTimer!: NodeJS.Timeout | number;\n  private focusBlur!: NodeJS.Timeout | number;\n  private timeoutCleaner!: NodeJS.Timeout | number;\n\n  public inputSvgRoutes = InputSvgRoutes;\n\n  public isTouchedInput: boolean = false;\n  public preventBlur: boolean = false;\n  // Date\n  public newInputChanged: boolean = false;\n\n  @Output() selectLastOneForSelectionEmitter = new EventEmitter<boolean>();\n  @Output() selectLastOneAfterMouseUpEmitter = new EventEmitter<boolean>();\n  @Output() onDatePasteEmitter = new EventEmitter<ClipboardEvent>();\n  @Output() onFocusEmitter = new EventEmitter<FocusEvent>();\n  @Output() changeSelectionEmmiter = new EventEmitter<{\n    e: KeyboardEvent;\n    noPreventDefault: boolean;\n  }>();\n  @Output() setSelectionEmmiter = new EventEmitter<{\n    preventDefault: () => void;\n    stopPropagation: () => void;\n    target: any;\n  }>();\n\n  @ViewChild('span1', { static: false }) span1!: ElementRef;\n  @ViewChild('span2', { static: false }) span2!: ElementRef;\n  @ViewChild('span3', { static: false }) span3!: ElementRef;\n  @ViewChild('holder1', { static: false }) holder1!: ElementRef;\n\n  private destroy$: Subject<void> = new Subject<void>();\n\n  constructor(\n    @Self() public superControl: NgControl,\n    private calendarService: CalendarDateTimePickerService\n  ) {\n    this.superControl.valueAccessor = this;\n  }\n\n  ngAfterViewInit(): void {\n    this.setTimePickerTime();\n\n    setTimeout(() => {\n      if (this.superControl.control?.value)\n        this.setTimeDateInput(this.superControl.control?.value, true);\n    }, 300);\n\n    this.calendarService.dateChanged\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((date) => {\n        if (!this.inputConfig.isDisabled) {\n          this.setTimeDateInput(date);\n          this.caInputComponent.caInputPlaceholderIconComponent.t2?.close();\n        }\n      });\n  }\n\n  get getSuperControl() {\n    return this.superControl.control;\n  }\n\n  public selectLastOneForSelection(): void {\n    let range, selection;\n\n    this.showDateInput = true;\n    this.selectionInput = -1;\n    this.caInputComponent.isFocusInput = true;\n\n    if (window.getSelection && document.createRange) {\n      selection = window.getSelection();\n      range = document.createRange();\n\n      if (\n        this.inputConfig.name !==\n        InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n      ) {\n        range.setStart(this.span3.nativeElement, 1);\n        range.setEnd(this.span3.nativeElement, 1);\n      } else {\n        range.setStart(this.span2.nativeElement, 1);\n        range.setEnd(this.span2.nativeElement, 1);\n      }\n\n      selection?.removeAllRanges();\n      selection?.addRange(range);\n    }\n\n    this.timeoutCleaner = setTimeout(() => {\n      clearTimeout(this.dateTimeMainTimer);\n      clearTimeout(this.focusBlur);\n    }, 90);\n  }\n\n  public selectLastOneAfterMouseUp(): void {\n    if (\n      this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n    ) {\n      this.selectionInput = 1;\n      this.span2.nativeElement.focus();\n      this.setSpanSelection(this.span2.nativeElement);\n    } else {\n      this.selectionInput = 2;\n      this.span3.nativeElement.focus();\n      this.setSpanSelection(this.span3.nativeElement);\n    }\n\n    this.showDateInput = true;\n\n    this.timeoutCleaner = setTimeout(() => {\n      clearTimeout(this.dateTimeMainTimer);\n      clearTimeout(this.focusBlur);\n    }, 90);\n  }\n\n  public onDatePaste(event: ClipboardEvent): void {\n    event.preventDefault();\n\n    const pasteText = event.clipboardData?.getData('text') as string;\n    const pastedDate = new Date(pasteText);\n    if (!isNaN(pastedDate.getTime())) {\n      this.setTimeDateInput(pastedDate);\n      this.selectSpanByTabIndex(this.selectionInput);\n    }\n  }\n\n  public changeSelection(event: KeyboardEvent, noPreventDefault = false): void {\n    if (!noPreventDefault) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n\n    const isNavigationKey = this.isNavigationKey(event);\n    const isSpecialTimePickerKey =\n      this.selectionInput === 3 &&\n      this.inputConfig.name === InputConfigNameStringEnum.TIME_PICKER;\n\n    if (isNavigationKey || isSpecialTimePickerKey) {\n      event.preventDefault();\n      this.handleNavigationKey(event);\n    } else if (!this.isNumber(event)) {\n      if (!noPreventDefault) event.preventDefault();\n      else {\n        if (!noPreventDefault) event.preventDefault();\n\n        if (this.selectionInput === -1) this.selectionInput = 0;\n        this.handleKeyboardInputs(event);\n      }\n    }\n  }\n\n  private isNumber(evt: KeyboardEvent): boolean {\n    evt = evt ? evt : (window.event as KeyboardEvent);\n    let charCode = evt.which ? evt.which : evt.keyCode;\n    return (\n      (charCode >= 48 && charCode <= 57) || (charCode >= 96 && charCode <= 105)\n    );\n  }\n\n  private isNavigationKey(e: KeyboardEvent): boolean {\n    const navigationKeys = [37, 38, 39, 40, 8, 9, 46]; // Arrow keys, Backspace, Tab, Delete\n    return navigationKeys.includes(e.keyCode);\n  }\n\n  public onFocus(event?: FocusEvent): void {\n    this.onFocusEmitter.emit(event);\n  }\n\n  public closePopover(): void {\n    if (this.caInputComponent.caInputPlaceholderIconComponent.t2)\n      this.caInputComponent.caInputPlaceholderIconComponent.t2.close();\n  }\n\n  public toggleDropdownOptions() {\n    if (this.caInputComponent.caInputPlaceholderIconComponent.t2) {\n      if (!this.caInputComponent.caInputPlaceholderIconComponent.t2.isOpen()) {\n        clearTimeout(this.dateTimeMainTimer);\n        clearTimeout(this.focusBlur);\n        this.holder1.nativeElement.focus();\n        this.selectionInput = -1;\n        this.setSpanSelection(this.holder1.nativeElement);\n        this.caInputComponent.caInputPlaceholderIconComponent.t2.open();\n      } else {\n        this.holder1.nativeElement.blur();\n        // this.setIsFocusInput(false);\n        let selection = window.getSelection();\n        selection?.removeAllRanges();\n      }\n      return;\n    }\n  }\n\n  public handleFocusInput(e: Event) {\n    const event = e as FocusEvent;\n\n    if (!this.inputConfig.isDisabled) {\n      clearTimeout(this.dateTimeMainTimer);\n      clearTimeout(this.focusBlur);\n      this.showDateInput = true;\n      if (\n        (this.selectionInput === -1 &&\n          (event?.target as HTMLElement)?.nodeName === 'INPUT') ||\n        (event?.relatedTarget as HTMLElement)?.nodeName === 'INPUT' ||\n        event?.relatedTarget === null\n      ) {\n        this.preventBlur = true;\n        this.holder1.nativeElement.focus();\n        this.setSpanSelection(this.holder1.nativeElement);\n        this.selectionInput = -1;\n      }\n\n      this.caInputComponent.caInputPlaceholderIconComponent.t2.toggle();\n    }\n  }\n\n  public setSpanSelection(element: Node): void {\n    let range: Range;\n    let selection: Selection | null;\n\n    if (window.getSelection && document.createRange) {\n      selection = window.getSelection();\n      range = document.createRange();\n      range.selectNodeContents(element);\n      selection?.removeAllRanges();\n      selection?.addRange(range);\n    }\n  }\n\n  public setSelection(event: {\n    preventDefault: () => void;\n    stopPropagation: () => void;\n    target: any;\n  }): void {\n    const element = event.target;\n\n    const selectionInput = parseInt(element.getAttribute('tabindex'));\n\n    const currentSelection = window.getSelection();\n\n    if (currentSelection && currentSelection.toString().length > 10) {\n      this.holder1.nativeElement.focus();\n      this.selectionInput = 0;\n      this.setSpanSelection(this.holder1.nativeElement);\n      clearTimeout(this.dateTimeMainTimer);\n      clearTimeout(this.focusBlur);\n      return;\n    }\n\n    clearTimeout(this.dateTimeMainTimer);\n    if (element.classList.contains('main')) {\n      this.selectionInput = selectionInput;\n      this.setSpanSelection(element);\n    } else {\n      if (this.selectionInput === -1) {\n        this.span1.nativeElement.focus();\n        this.selectionInput = 0;\n        this.setSpanSelection(this.span1.nativeElement);\n      } else {\n        event.preventDefault();\n        this.selectSpanByTabIndex(this.selectionInput);\n      }\n    }\n  }\n\n  public registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  public onChange(_: InputChangeValue): void {\n    this.superControl.control?.setValue(_);\n    this.superControl.control?.markAsTouched(); // Mark the control as touched\n    this.superControl.control?.markAsDirty();\n  }\n\n  public writeValue(obj: InputChangeValue): void {}\n\n  public registerOnTouched(): void {}\n\n  // BLUR ON INPUT\n  public blurOnDateTime(): void {\n    clearTimeout(this.dateTimeMainTimer);\n    this.dateTimeMainTimer = setTimeout(() => {\n      if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER) {\n        if (\n          !isNaN(this.span1?.nativeElement.innerHTML) &&\n          !isNaN(this.span2?.nativeElement.innerHTML) &&\n          !isNaN(this.span3?.nativeElement.innerHTML)\n        ) {\n          if (\n            this.inputConfig.isFutureDateDisabled &&\n            moment(this.dateTimeInputDate).isAfter(moment())\n          )\n            this.superControl.control?.setErrors({\n              invalid: true,\n            });\n          // don't accept future dates\n          else {\n            if (\n              this.inputConfig.expiredDateInvalid &&\n              moment(this.dateTimeInputDate).isBefore(moment())\n            ) {\n              this.superControl.control?.setErrors({ invalid: true }); // don't accept expired dates\n            } else {\n              this.calendarService.dateChanged.next(this.dateTimeInputDate);\n            }\n          }\n        } else {\n          this.span1.nativeElement.innerHTML = 'mm';\n          this.span2.nativeElement.innerHTML = 'dd';\n          this.span3.nativeElement.innerHTML = 'yy';\n          this.dateTimeInputDate = new Date();\n          this.showDateInput = false;\n        }\n      } else if (\n        this.inputConfig.name ===\n        InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n      ) {\n        if (\n          !isNaN(this.span1.nativeElement.innerHTML) &&\n          !isNaN(this.span2.nativeElement.innerHTML)\n        ) {\n          if (\n            this.inputConfig.expiredDateInvalid &&\n            moment(this.dateTimeInputDate).isBefore(moment())\n          ) {\n            this.superControl.control?.setErrors({ invalid: true }); // don't accept expired dates\n          } else {\n            this.calendarService.dateChanged.next(this.dateTimeInputDate);\n          }\n        } else {\n          this.span1.nativeElement.innerHTML = 'mm';\n          this.span2.nativeElement.innerHTML = 'yy';\n          this.dateTimeInputDate = new Date();\n          this.showDateInput = false;\n        }\n      } else {\n        if (\n          !isNaN(this.span1.nativeElement.innerHTML) &&\n          !isNaN(this.span2.nativeElement.innerHTML)\n        ) {\n          this.calendarService.dateChanged.next(this.dateTimeInputDate);\n        } else {\n          this.span1.nativeElement.innerHTML = 'HH';\n          this.span2.nativeElement.innerHTML = 'MM';\n          this.setTimePickerTime();\n          this.showDateInput = false;\n        }\n      }\n\n      clearTimeout(this.dateTimeMainTimer);\n      this.selectionInput = -1;\n      this.newInputChanged = true;\n    }, 100);\n  }\n\n  public onPopoverShown(): void {\n    this.showDateInput = true;\n    this.holder1.nativeElement.focus();\n  }\n\n  public onPopoverHidden(): void {\n    this.blurOnDateTime();\n  }\n\n  public setTimeDateInput(date: InputChangeValue, hasValue?: boolean): void {\n    let text, dateFormat, timeFormat;\n    if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER) {\n      text = moment(new Date(date)).format('MM/DD/YY');\n      dateFormat = text.split('/');\n    } else if (\n      this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n    ) {\n      text = moment(new Date(date)).format('MM/DD/YY');\n      dateFormat = text.split('/');\n    } else {\n      date =\n        date instanceof Date\n          ? date\n          : new Date(moment().format('MM/DD/YYYY') + ' ' + date);\n      text = moment(new Date(date)).format('HH:mm');\n\n      timeFormat = moment(new Date(date)).format('hh/mm/A');\n      dateFormat = timeFormat.split('/');\n    }\n\n    if (!hasValue) this.onChange(text);\n    // this.input.nativeElement.value = text;\n    this.setIsFocusInput(false);\n\n    if (this.span1) this.span1.nativeElement.innerHTML = dateFormat[0];\n\n    if (this.span2)\n      if (\n        this.inputConfig.name !==\n        InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n      ) {\n        this.span2.nativeElement.innerHTML = dateFormat[1];\n        this.span3.nativeElement.innerHTML = dateFormat[2];\n      } else {\n        this.span2.nativeElement.innerHTML = dateFormat[2];\n      }\n\n    this.dateTimeInputDate = new Date(date);\n    this.showDateInput = true;\n  }\n\n  public handleKeyboardInputs(e: KeyboardEvent, isRestart?: boolean): void {\n    const spanOneValue: number | undefined =\n      isNaN(this.span1.nativeElement.innerHTML) || this.newInputChanged\n        ? undefined\n        : parseInt(this.span1.nativeElement.innerHTML);\n    const span2Value: number | undefined =\n      isNaN(this.span2.nativeElement.innerHTML) || this.newInputChanged\n        ? undefined\n        : parseInt(this.span2.nativeElement.innerHTML);\n\n    let span3Value: string | number | undefined;\n\n    if (\n      this.inputConfig.name !== InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n    ) {\n      span3Value =\n        isNaN(this.span3.nativeElement.innerHTML) || this.newInputChanged\n          ? ''\n          : parseInt(this.span3.nativeElement.innerHTML);\n    }\n\n    this.newInputChanged = false;\n    if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER) {\n      if (this.selectionInput === 0) {\n        if (isRestart) {\n          this.span1.nativeElement.innerHTML = 'mm';\n          this.selectionInput = 0;\n          this.selectSpanByTabIndex(0);\n        } else if (spanOneValue !== undefined) {\n          let final_value = parseInt(`${spanOneValue}${e.key}`);\n          if (final_value > 12) {\n            this.span1.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(\n              -2\n            );\n            this.selectionInput = 1;\n            this.selectSpanByTabIndex(1, true);\n          } else {\n            this.dateTimeInputDate = new Date(\n              this.dateTimeInputDate.setMonth(\n                parseInt(this.span1.nativeElement.innerHTML + parseInt(e.key)) -\n                  1\n              )\n            );\n\n            if (!final_value) this.span1.nativeElement.innerHTML = 'mm';\n            else\n              this.span1.nativeElement.innerHTML = (\n                this.span1.nativeElement.innerHTML + parseInt(e.key)\n              ).slice(-2);\n\n            this.selectionInput = 1;\n            this.selectSpanByTabIndex(1, true);\n          }\n        } else {\n          if (parseInt(e.key))\n            this.dateTimeInputDate = new Date(\n              this.dateTimeInputDate.setMonth(parseInt(e.key) - 1)\n            );\n\n          const final_value = ('0' + parseInt(e.key)).slice(-2);\n\n          this.span1.nativeElement.innerHTML = final_value;\n\n          if (parseInt(`1${e.key}`) > 12) {\n            this.selectionInput = 1;\n            this.selectSpanByTabIndex(1, true);\n          } else this.selectSpanByTabIndex(0);\n        }\n      } else if (this.selectionInput === 1) {\n        if (isRestart) {\n          this.span2.nativeElement.innerHTML = 'dd';\n          this.selectionInput = 0;\n          this.selectSpanByTabIndex(0, true);\n        } else if (span2Value !== undefined) {\n          let final_value = parseInt(`${span2Value}${e.key}`);\n          if (final_value > 31) {\n            this.span2.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(\n              -2\n            );\n            this.selectionInput = 2;\n            this.selectSpanByTabIndex(2, true);\n          } else {\n            this.dateTimeInputDate = new Date(\n              this.dateTimeInputDate.setDate(\n                parseInt(this.span2.nativeElement.innerHTML + parseInt(e.key))\n              )\n            );\n\n            if (!final_value) {\n              this.span2.nativeElement.innerHTML = 'dd';\n            } else {\n              this.span2.nativeElement.innerHTML = (\n                this.span2.nativeElement.innerHTML + parseInt(e.key)\n              ).slice(-2);\n            }\n\n            this.selectionInput = 2;\n            this.selectSpanByTabIndex(2, true);\n          }\n        } else {\n          if (parseInt(e.key))\n            this.dateTimeInputDate = new Date(\n              this.dateTimeInputDate.setDate(parseInt(e.key))\n            );\n\n          this.span2.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(\n            -2\n          );\n\n          if (parseInt(`1${e.key}`) > 31) {\n            this.selectionInput = 2;\n            this.selectSpanByTabIndex(2, true);\n          } else {\n            this.selectSpanByTabIndex(1);\n          }\n        }\n      } else {\n        if (isRestart) {\n          this.span3.nativeElement.innerHTML = 'yy';\n          this.selectionInput = 1;\n          this.selectSpanByTabIndex(1, true);\n        } else if (!span3Value || span3Value.toString().length === 2) {\n          this.span3.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(\n            -2\n          );\n          this.dateTimeInputDate = new Date(\n            this.dateTimeInputDate.setFullYear(\n              parseInt(`200${parseInt(e.key)}`)\n            )\n          );\n\n          this.selectSpanByTabIndex(2);\n        } else {\n          const finalYear = parseInt(\n            this.span3.nativeElement.innerHTML + parseInt(e.key)\n          );\n\n          const finalShowYear =\n            finalYear > 31\n              ? parseInt(`19${finalYear}`)\n              : parseInt(`20${finalYear}`);\n          this.dateTimeInputDate = new Date(\n            this.dateTimeInputDate.setFullYear(finalShowYear)\n          );\n\n          this.span3.nativeElement.innerHTML = (\n            this.span3.nativeElement.innerHTML + parseInt(e.key)\n          ).slice(-2);\n          this.selectSpanByTabIndex(2);\n        }\n      }\n    } else if (\n      this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n    ) {\n      if (!this.selectionInput) {\n        if (isRestart) {\n          this.span1.nativeElement.innerHTML = 'mm';\n          this.selectionInput = 0;\n          this.selectSpanByTabIndex(0);\n        } else if (spanOneValue) {\n          const final_value = parseInt(`${spanOneValue}${e.key}`);\n          if (final_value > 12) {\n            this.span1.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(\n              -2\n            );\n            this.selectionInput = 1;\n            this.selectSpanByTabIndex(1, true);\n          } else {\n            this.dateTimeInputDate = new Date(\n              this.dateTimeInputDate.setMonth(\n                parseInt(this.span1.nativeElement.innerHTML + parseInt(e.key)) -\n                  1\n              )\n            );\n\n            if (!final_value) {\n              this.span1.nativeElement.innerHTML = 'mm';\n            } else {\n              this.span1.nativeElement.innerHTML = (\n                this.span1.nativeElement.innerHTML + parseInt(e.key)\n              ).slice(-2);\n            }\n\n            this.selectionInput = 1;\n            this.selectSpanByTabIndex(1, true);\n          }\n        } else {\n          if (parseInt(e.key))\n            this.dateTimeInputDate = new Date(\n              this.dateTimeInputDate.setMonth(parseInt(e.key) - 1)\n            );\n\n          const final_value = ('0' + parseInt(e.key)).slice(-2);\n\n          this.span1.nativeElement.innerHTML = final_value;\n\n          if (parseInt(`1${e.key}`) > 12) {\n            this.selectionInput = 1;\n            this.selectSpanByTabIndex(1, true);\n          } else this.selectSpanByTabIndex(0);\n        }\n      } else {\n        if (isRestart) {\n          this.span2.nativeElement.innerHTML = 'yy';\n          this.selectionInput = 2;\n          this.selectSpanByTabIndex(2, true);\n        } else if (!span2Value || span2Value.toString().length === 2) {\n          this.span2.nativeElement.innerHTML = ('0' + parseInt(e.key)).slice(\n            -2\n          );\n          this.dateTimeInputDate = new Date(\n            this.dateTimeInputDate.setFullYear(\n              parseInt(`200${parseInt(e.key)}`)\n            )\n          );\n\n          this.selectSpanByTabIndex(1);\n        } else {\n          const finalYear = parseInt(\n            this.span2.nativeElement.innerHTML + parseInt(e.key)\n          );\n\n          const finalShowYear =\n            finalYear > 31\n              ? parseInt(`19${finalYear}`)\n              : parseInt(`20${finalYear}`);\n          this.dateTimeInputDate = new Date(\n            this.dateTimeInputDate.setFullYear(finalShowYear)\n          );\n\n          this.span2.nativeElement.innerHTML = (\n            this.span2.nativeElement.innerHTML + parseInt(e.key)\n          ).slice(-2);\n          this.selectSpanByTabIndex(1);\n        }\n      }\n    }\n  }\n\n  selectSpanByTabIndex(indx: number, changeTab?: boolean): void {\n    switch (indx) {\n      case 0:\n        this.setSpanSelection(this.span1.nativeElement);\n        break;\n      case 1:\n        this.setSpanSelection(this.span2.nativeElement);\n        break;\n      case 2:\n        this.setSpanSelection(this.span3.nativeElement);\n        break;\n      default:\n        this.setSpanSelection(this.holder1.nativeElement);\n    }\n\n    if (changeTab) this.newInputChanged = true;\n  }\n\n  private handleNavigationKey(event: KeyboardEvent): void {\n    switch (event.keyCode) {\n      case 37: // Left arrow\n        this.moveSelectionLeft();\n        break;\n      case 39: // Right arrow\n      case 9: // Tab\n        this.moveSelectionRightOrTab(event);\n        break;\n      case 38: // Up arrow\n        this.setDateTimeModel('up');\n        break;\n      case 40: // Down arrow\n        this.setDateTimeModel('down');\n        break;\n      case 8: // Backspace\n      case 46: // Delete\n        this.handleKeyboardInputs(event, true);\n        break;\n    }\n  }\n\n  private handleDatePickerInput(isUp: boolean, isDatePicker: boolean): void {\n    if (this.selectionInput === 0) this.updateMonth(isUp);\n    else if (this.selectionInput === 1) this.updateDate(isUp, isDatePicker);\n    else this.updateYear(isUp, isDatePicker);\n  }\n\n  private setDateTimeModel(direction: string): void {\n    if (this.selectionInput === -1) this.selectionInput = 0;\n\n    const isUp = direction === 'up';\n    const isDatePicker =\n      this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER;\n    const isBankCardPicker =\n      this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD;\n\n    if (isDatePicker || isBankCardPicker)\n      this.handleDatePickerInput(isUp, isDatePicker);\n    else this.handleTimePickerInput(isUp);\n  }\n\n  private moveSelectionRightOrTab(e: KeyboardEvent): void {\n    const isDatepickerBankCard =\n      this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER_BANK_CARD;\n    const maxIndex = isDatepickerBankCard ? 1 : 2;\n\n    if (this.selectionInput < maxIndex && !e.shiftKey) {\n      this.selectionInput += 1;\n      this.selectSpanByTabIndex(this.selectionInput, true);\n    } else if (e.keyCode === 9 && !e.shiftKey) {\n      this.focusNextInput();\n    } else if (e.shiftKey && e.keyCode === 9) {\n      this.focusPreviousInput();\n    }\n  }\n\n  private focusPreviousInput(): void {\n    const allInputs = Array.from(\n      document.querySelectorAll('input.input-control')\n    ) as HTMLInputElement[];\n\n    const currentIndex = allInputs.findIndex(\n      (input) => input === this.caInputComponent.input.nativeElement\n    );\n\n    if (currentIndex === -1) this.selectionInput = 3;\n    else if (currentIndex === 0) this.selectionInput = 0;\n    else {\n      this.selectionInput -= 1;\n      this.selectSpanByTabIndex(this.selectionInput);\n    }\n\n    if (currentIndex > 0) allInputs[currentIndex - 1].focus();\n\n    this.selectionInput = -1;\n  }\n\n  private focusNextInput(): void {\n    const allInputs = Array.from(\n      document.querySelectorAll('input.input-control')\n    ) as HTMLInputElement[];\n    const currentIndex = allInputs.findIndex(\n      (input) => input === this.caInputComponent.input.nativeElement\n    );\n\n    if (allInputs[currentIndex + 1]) allInputs[currentIndex + 1].focus();\n    else {\n      this.setIsFocusInput(false);\n      this.blurOnDateTime();\n    }\n\n    this.selectionInput = -1;\n  }\n\n  public setIsFocusInput(value: boolean): void {\n    this.caInputComponent.isFocusInput = value;\n  }\n\n  private moveSelectionLeft(): void {\n    if (this.selectionInput > 0) {\n      this.selectionInput -= 1;\n      this.selectSpanByTabIndex(this.selectionInput, true);\n    }\n  }\n\n  private updateMonth(isUp: boolean): void {\n    const monthDelta = isUp ? 1 : -1;\n    this.dateTimeInputDate = new Date(\n      this.dateTimeInputDate.setMonth(\n        this.dateTimeInputDate.getMonth() + monthDelta\n      )\n    );\n\n    this.span1.nativeElement.innerHTML = this.padValue(\n      this.dateTimeInputDate.getMonth() + 1\n    );\n    this.setSpanSelection(this.span1.nativeElement);\n  }\n\n  private updateDate(isUp: boolean, isDatePicker: boolean): void {\n    const dateDelta = isUp ? 1 : -1;\n    this.dateTimeInputDate = new Date(\n      this.dateTimeInputDate.setDate(\n        this.dateTimeInputDate.getDate() + dateDelta\n      )\n    );\n\n    const spanElement = isDatePicker\n      ? this.span2.nativeElement\n      : this.span1.nativeElement;\n    spanElement.innerHTML = this.padValue(this.dateTimeInputDate.getDate());\n    this.setSpanSelection(spanElement);\n  }\n\n  private updateYear(isUp: boolean, isDatePicker: boolean): void {\n    const yearDelta = isUp ? 1 : -1;\n    this.dateTimeInputDate = new Date(\n      this.dateTimeInputDate.setFullYear(\n        this.dateTimeInputDate.getFullYear() + yearDelta\n      )\n    );\n\n    const spanElement = isDatePicker\n      ? this.span3.nativeElement\n      : this.span2.nativeElement;\n    spanElement.innerHTML = this.dateTimeInputDate\n      .getFullYear()\n      .toString()\n      .slice(-2);\n    this.setSpanSelection(spanElement);\n  }\n\n  private padValue(value: number): string {\n    return ('0' + value).slice(-2);\n  }\n\n  private handleTimePickerInput(isUp: boolean): void {\n    if (this.selectionInput === 0) this.updateHours(isUp);\n    else if (this.selectionInput === 1) this.updateMinutes(isUp);\n    else this.toggleAMPM();\n  }\n\n  private updateHours(isUp: boolean): void {\n    const hoursDelta = isUp ? 1 : -1;\n    let selectedHours = this.dateTimeInputDate.getHours() + hoursDelta;\n\n    if (selectedHours === 0) selectedHours = 24;\n    if (selectedHours === -1) selectedHours = 23;\n\n    this.dateTimeInputDate = new Date(\n      this.dateTimeInputDate.setHours(selectedHours)\n    );\n\n    this.span1.nativeElement.innerHTML = this.padValue(\n      selectedHours > 12 ? selectedHours - 12 : selectedHours\n    );\n    this.setSpanSelection(this.span1.nativeElement);\n\n    this.span3.nativeElement.innerHTML =\n      selectedHours > 11 && selectedHours < 24 ? 'PM' : 'AM';\n  }\n\n  private updateMinutes(isUp: boolean): void {\n    const minutesDelta = isUp ? 1 : -1;\n    this.dateTimeInputDate = new Date(\n      this.dateTimeInputDate.setMinutes(\n        this.dateTimeInputDate.getMinutes() + minutesDelta\n      )\n    );\n\n    this.span2.nativeElement.innerHTML = this.padValue(\n      this.dateTimeInputDate.getMinutes()\n    );\n    this.setSpanSelection(this.span2.nativeElement);\n  }\n\n  private toggleAMPM(): void {\n    this.span3.nativeElement.innerHTML =\n      this.span3.nativeElement.innerHTML === 'AM' ? 'PM' : 'AM';\n\n    const hoursToAdd = this.span3.nativeElement.innerHTML === 'AM' ? -12 : 12;\n    this.dateTimeInputDate = new Date(\n      this.dateTimeInputDate.setHours(\n        this.dateTimeInputDate.getHours() + hoursToAdd\n      )\n    );\n\n    this.setSpanSelection(this.span3.nativeElement);\n  }\n\n  public clearInput(event: boolean): void {\n    this.clearInputEvent.emit(event);\n\n    this.setIsFocusInput(false);\n    this.resetDateTimeInputs();\n  }\n\n  public onBlurInput(event: boolean): void {\n    this.blurInputEvent.emit(event);\n  }\n\n  public resetDateTimeInputs(): void {\n    if (this.span1)\n      if (this.inputConfig.name === InputConfigNameStringEnum.DATE_PICKER) {\n        this.span1.nativeElement.innerHTML = 'mm';\n        this.span2.nativeElement.innerHTML = 'dd';\n        this.span3.nativeElement.innerHTML = 'yy';\n      } else if (\n        this.inputConfig.name ===\n        InputConfigNameStringEnum.DATE_PICKER_BANK_CARD\n      ) {\n        this.span1.nativeElement.innerHTML = 'mm';\n        this.span2.nativeElement.innerHTML = 'yy';\n      } else if (\n        this.inputConfig.name === InputConfigNameStringEnum.TIME_PICKER\n      ) {\n        this.span1.nativeElement.innerHTML = 'HH';\n        this.span2.nativeElement.innerHTML = 'MM';\n        this.span3.nativeElement.innerHTML = 'AM';\n      }\n\n    this.setTimePickerTime();\n    this.newInputChanged = true;\n    this.setIsFocusInput(false);\n    this.showDateInput = false;\n  }\n\n  public setTimePickerTime(): void {\n    if (this.inputConfig.name === InputConfigNameStringEnum.TIME_PICKER)\n      this.dateTimeInputDate = new Date(\n        moment().format('MM/DD/YYYY') +\n          (this.inputConfig?.isFromDate ? ' 12:15' : ' 12:00')\n      );\n  }\n\n  public ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n","<div\n  class=\"datetime-picker-main-holder input-custom-group datetimeclass\"\n  [ngClass]=\"\n    getSuperControl\n      | inputContainerClass\n        : caInputComponent.isFocusInput\n        : caInputComponent.isTouchedInput\n        : inputConfig\n        : getSuperControl?.value\n  \"\n>\n  <div\n    #holder1\n    class=\"date_time_holder input-control\"\n    [class.active]=\"showDateInput\"\n    tabindex=\"-1\"\n    (mousedown)=\"selectLastOneForSelection()\"\n    (mouseup)=\"selectLastOneAfterMouseUp()\"\n    (paste)=\"onDatePaste($event)\"\n    (keydown)=\"changeSelection($event, true)\"\n    (click)=\"toggleDropdownOptions()\"\n    [ngStyle]=\"{\n      'padding-left': inputConfig.isIconHidden ? '2px' : '27px'\n    }\"\n    [ngClass]=\"\n      caInputComponent.isFocusInput\n        | inputDatetimePickerClass\n          : false\n          : getSuperControl\n          : inputConfig\n          : caInputComponent.isTouchedInput\n          : getSuperControl?.value\n    \"\n  >\n    <span\n      #span1\n      class=\"main\"\n      [ngClass]=\"{\n        'reset-selection-color': !caInputComponent.isFocusInput\n      }\"\n      tabindex=\"0\"\n      (mouseup)=\"setSelection($event)\"\n      (keydown)=\"changeSelection($event)\"\n      [innerHTML]=\"inputConfig.name === 'datepicker' ? 'mm' : 'HH'\"\n    ></span>\n    <span>\n      <div\n        class=\"border-picker\"\n        [innerHTML]=\"inputConfig.name === 'datepicker' ? '/' : ':'\"\n      ></div>\n    </span>\n    <span\n      #span2\n      class=\"main\"\n      [ngClass]=\"{\n        'reset-selection-color': !caInputComponent.isFocusInput\n      }\"\n      tabindex=\"1\"\n      (mouseup)=\"setSelection($event)\"\n      (keydown)=\"changeSelection($event)\"\n      [innerHTML]=\"inputConfig.name === 'datepicker' ? 'dd' : 'MM'\"\n    ></span>\n    <span>\n      <div\n        class=\"border-picker\"\n        [innerHTML]=\"inputConfig.name === 'datepicker' ? '/' : ' '\"\n      ></div>\n    </span>\n    <span\n      #span3\n      class=\"main\"\n      [ngClass]=\"{\n        'reset-selection-color': !caInputComponent.isFocusInput\n      }\"\n      tabindex=\"2\"\n      (mouseup)=\"setSelection($event)\"\n      (keydown)=\"changeSelection($event)\"\n      [innerHTML]=\"inputConfig.name === 'datepicker' ? 'yy' : 'AM'\"\n    ></span>\n  </div>\n  <app-ca-input\n    [inputConfig]=\"inputConfig\"\n    [dateTimePopover]=\"dateTimePopover\"\n    (focusInputEvent)=\"handleFocusInput($event)\"\n    (handleToggleDropdownOptions)=\"toggleDropdownOptions()\"\n    (closePopover)=\"blurOnDateTime()\"\n    (blurInput)=\"onBlurInput($event)\"\n    (clear)=\"clearInput($event)\"\n    [formControl]=\"getSuperControl! | formControl\"\n    ></app-ca-input>\n</div>\n\n<!-- Popover for DateTime Pickers -->\n<ng-template #dateTimePopover let-data=\"data\">\n  <div class=\"datetime-dropdown-holder\">\n    <app-ca-custom-datetime-pickers\n      [calendarType]=\"\n        inputConfig.name === 'datepicker' ||\n        inputConfig.name === 'datepickerBankCard'\n          ? 'date'\n          : 'time'\n      \"\n      [inputConfig]=\"inputConfig\"\n      [placeholder]=\"'MM/DD/YY'\"\n      [dateTime]=\"dateTimeInputDate\"\n      (closePopover)=\"closePopover()\"\n    ></app-ca-custom-datetime-pickers>\n  </div>\n</ng-template>\n"]}