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.
- package/esm2022/lib/ca-components.module.mjs +16 -4
- package/esm2022/lib/components/ca-activity-log-list/ca-activity-log-list.component.mjs +1 -1
- package/esm2022/lib/components/ca-app-tooltip-v2/ca-app-tooltip-v2.component.mjs +1 -1
- package/esm2022/lib/components/ca-filters/components/ca-dispatcher-filter/ca-dispatcher-filter.component.mjs +2 -2
- package/esm2022/lib/components/ca-filters/components/ca-money-filter/ca-money-filter.component.mjs +2 -2
- package/esm2022/lib/components/ca-filters/components/ca-state-filter/ca-state-filter.component.mjs +2 -2
- package/esm2022/lib/components/ca-filters/components/ca-trailer-type-filter/ca-trailer-type-filter.component.mjs +1 -1
- package/esm2022/lib/components/ca-filters/components/ca-truck-type-filter/ca-truck-type-filter.component.mjs +1 -1
- package/esm2022/lib/components/ca-filters/components/ca-user-filter/ca-user-filter.component.mjs +2 -2
- package/esm2022/lib/components/ca-input/base-classes/ca-input-base-helpres.mjs +237 -0
- package/esm2022/lib/components/ca-input/base-classes/ca-input-base.mjs +1020 -0
- package/esm2022/lib/components/ca-input/base-classes/ca-input-event-manager.mjs +24 -0
- package/esm2022/lib/components/ca-input/ca-input.component.mjs +53 -163
- package/esm2022/lib/components/ca-input/components/ca-input-clear/ca-input-clear.component.mjs +4 -4
- package/esm2022/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.mjs +11 -17
- package/esm2022/lib/components/ca-input/config/ca-input.config.mjs +1 -1
- package/esm2022/lib/components/ca-input/directives/caps-lock.directive.mjs +50 -0
- package/esm2022/lib/components/ca-input/directives/index.mjs +5 -1
- package/esm2022/lib/components/ca-input/directives/input-max-value.directive.mjs +53 -0
- package/esm2022/lib/components/ca-input/directives/min-max-value.directive.mjs +1 -1
- package/esm2022/lib/components/ca-input/directives/price_format.directive.mjs +41 -0
- package/esm2022/lib/components/ca-input/directives/restrict-input.directive.mjs +98 -0
- package/esm2022/lib/components/ca-input/enums/input-text-transform.enum.mjs +9 -0
- package/esm2022/lib/components/ca-input/input-test/input-test.component.mjs +175 -0
- package/esm2022/lib/components/ca-input/pipes/input-container-class.pipe.mjs +16 -16
- package/esm2022/lib/components/ca-input/pipes/input-datetime-picker-class.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/input-error.pipe.mjs +18 -15
- package/esm2022/lib/components/ca-input/pipes/input-pattern.pipe.mjs +322 -0
- package/esm2022/lib/components/ca-input/services/index.mjs +1 -2
- package/esm2022/lib/components/ca-input/utils/constants/input-constants.mjs +102 -1
- package/esm2022/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.mjs +2 -2
- package/esm2022/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.mjs +809 -0
- package/esm2022/lib/components/ca-input-dropdown/ca-input-dropdown.component.mjs +18 -18
- package/esm2022/lib/components/ca-rating-review/ca-rating-review.component.mjs +2 -2
- package/esm2022/lib/components/ca-rating-review/components/ca-ratings-reviews-popup/ca-ratings-reviews-popup.component.mjs +1 -1
- package/esm2022/lib/components/ca-upload-files/components/ca-upload-file/ca-upload-file.component.mjs +1 -1
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/ca-components.mjs +7690 -7171
- package/fesm2022/ca-components.mjs.map +1 -1
- package/lib/ca-components.module.d.ts +32 -30
- package/lib/components/ca-filters/ca-filter.component.d.ts +2 -2
- package/lib/components/ca-input/base-classes/ca-input-base-helpres.d.ts +29 -0
- package/lib/components/ca-input/base-classes/ca-input-base.d.ts +82 -0
- package/lib/components/ca-input/base-classes/ca-input-event-manager.d.ts +16 -0
- package/lib/components/ca-input/ca-input.component.d.ts +30 -48
- package/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.d.ts +3 -7
- package/lib/components/ca-input/config/ca-input.config.d.ts +10 -1
- package/lib/components/ca-input/directives/caps-lock.directive.d.ts +14 -0
- package/lib/components/ca-input/directives/index.d.ts +4 -0
- package/lib/components/ca-input/directives/input-max-value.directive.d.ts +12 -0
- package/lib/components/ca-input/directives/price_format.directive.d.ts +11 -0
- package/lib/components/ca-input/directives/restrict-input.directive.d.ts +15 -0
- package/lib/components/ca-input/enums/input-text-transform.enum.d.ts +6 -0
- package/lib/components/ca-input/input-test/input-test.component.d.ts +47 -0
- package/lib/components/ca-input/pipes/input-container-class.pipe.d.ts +3 -3
- package/lib/components/ca-input/pipes/input-datetime-picker-class.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/input-pattern.pipe.d.ts +25 -0
- package/lib/components/ca-input/services/index.d.ts +0 -1
- package/lib/components/ca-input/utils/constants/input-constants.d.ts +11 -0
- package/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.d.ts +99 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/esm2022/lib/components/ca-input/components/ca-input-datetime-picker/ca-input-datetime-picker.component.mjs +0 -100
- package/esm2022/lib/components/ca-input/services/ca-input-state.service.mjs +0 -2173
- package/lib/components/ca-input/components/ca-input-datetime-picker/ca-input-datetime-picker.component.d.ts +0 -48
- package/lib/components/ca-input/services/ca-input-state.service.d.ts +0 -196
package/esm2022/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.mjs
ADDED
|
@@ -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"]}
|