ecabs-components 1.0.23 → 1.0.25
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/ecabs-components.mjs +4 -4
- package/esm2022/lib/base/consts/date-mask.consts.mjs +56 -56
- package/esm2022/lib/base/directives/date-mask.directive.mjs +65 -67
- package/esm2022/lib/base/directives/date-mask.directive.module.mjs +22 -22
- package/esm2022/lib/base/directives/digits-only.directive.mjs +130 -133
- package/esm2022/lib/base/directives/digits-only.directive.module.mjs +22 -22
- package/esm2022/lib/base/directives/number-border.directive.mjs +54 -58
- package/esm2022/lib/base/directives/number-border.directive.module.mjs +22 -22
- package/esm2022/lib/base/element-base.mjs +100 -105
- package/esm2022/lib/base/element-wrapper/element-wrapper.component.mjs +53 -56
- package/esm2022/lib/base/element-wrapper/element-wrapper.module.mjs +52 -52
- package/esm2022/lib/base/hint/hint.component.mjs +21 -21
- package/esm2022/lib/base/hint/hint.module.mjs +20 -20
- package/esm2022/lib/base/validation/validation.component.mjs +70 -75
- package/esm2022/lib/base/validation/validation.module.mjs +20 -20
- package/esm2022/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.mjs +16 -17
- package/esm2022/lib/ecabs-breadcrumb/ecabs-breadcrumb.module.mjs +20 -20
- package/esm2022/lib/ecabs-buttons/ecabs-buttons.component.mjs +63 -64
- package/esm2022/lib/ecabs-buttons/ecabs-buttons.module.mjs +21 -21
- package/esm2022/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.mjs +101 -94
- package/esm2022/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.module.mjs +36 -36
- package/esm2022/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.mjs +17 -15
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.component.mjs +85 -89
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.module.mjs +48 -48
- package/esm2022/lib/ecabs-date-time-picker/components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component.mjs +17 -15
- package/esm2022/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.mjs +179 -186
- package/esm2022/lib/ecabs-date-time-picker/ecabs-date-time-picker.module.mjs +64 -64
- package/esm2022/lib/ecabs-date-time-range-picker/components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component.mjs +17 -15
- package/esm2022/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.mjs +193 -199
- package/esm2022/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.module.mjs +65 -65
- package/esm2022/lib/ecabs-date-time-range-picker/time-range.directive.mjs +45 -48
- package/esm2022/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.mjs +47 -50
- package/esm2022/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.module.mjs +20 -20
- package/esm2022/lib/ecabs-dialog-message/ecabs-dialog-message.component.mjs +44 -47
- package/esm2022/lib/ecabs-dialog-message/ecabs-dialog-message.module.mjs +20 -20
- package/esm2022/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.component.mjs +19 -22
- package/esm2022/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.module.mjs +19 -19
- package/esm2022/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.mjs +76 -85
- package/esm2022/lib/ecabs-expansion-panel/ecabs-expansion-panel.module.mjs +24 -24
- package/esm2022/lib/ecabs-increment/ecabs-increment.component.mjs +78 -83
- package/esm2022/lib/ecabs-increment/ecabs-increment.module.mjs +23 -23
- package/esm2022/lib/ecabs-input/ecabs-input.component.mjs +83 -90
- package/esm2022/lib/ecabs-input/ecabs-input.module.mjs +22 -22
- package/esm2022/lib/ecabs-language-selector/ecabs-language-selector.component.mjs +62 -64
- package/esm2022/lib/ecabs-language-selector/ecabs-language-selector.module.mjs +39 -39
- package/esm2022/lib/ecabs-loading/ecabs-loading.component.mjs +24 -22
- package/esm2022/lib/ecabs-loading/ecabs-loading.module.mjs +19 -19
- package/esm2022/lib/ecabs-loading/spinner/spinner.component.mjs +16 -14
- package/esm2022/lib/ecabs-note/ecabs-note.component.mjs +30 -28
- package/esm2022/lib/ecabs-note/ecabs-note.module.mjs +19 -19
- package/esm2022/lib/ecabs-phone/ecabs-phone.component.mjs +104 -111
- package/esm2022/lib/ecabs-phone/ecabs-phone.module.mjs +22 -22
- package/esm2022/lib/ecabs-picker-header/ecabs-picker-header.component.mjs +50 -53
- package/esm2022/lib/ecabs-picker-header/ecabs-picker-header.module.mjs +22 -22
- package/esm2022/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.mjs +65 -68
- package/esm2022/lib/ecabs-radio-button-list/ecabs-radio-button-list.module.mjs +32 -32
- package/esm2022/lib/ecabs-select/ecabs-select.component.mjs +310 -316
- package/esm2022/lib/ecabs-select/ecabs-select.module.mjs +60 -60
- package/esm2022/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.mjs +17 -19
- package/esm2022/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.module.mjs +24 -24
- package/esm2022/lib/ecabs-table/ecabs-table.component.mjs +43 -48
- package/esm2022/lib/ecabs-table/ecabs-table.module.mjs +33 -33
- package/esm2022/lib/ecabs-textarea/ecabs-textarea.component.mjs +62 -65
- package/esm2022/lib/ecabs-textarea/ecabs-textarea.module.mjs +20 -20
- package/esm2022/lib/ecabs-timepicker/componets/ecabs-time-list-panel/ecabs-time-list-panel.component.mjs +137 -144
- package/esm2022/lib/ecabs-timepicker/config.model.mjs +1 -1
- package/esm2022/lib/ecabs-timepicker/ecabs-timepicker.component.mjs +312 -322
- package/esm2022/lib/ecabs-timepicker/ecabs-timepicker.module.mjs +20 -20
- package/esm2022/lib/ecabs-timepicker/ecabs-timepicker.service.mjs +31 -29
- package/esm2022/lib/models/bread-crumb.mjs +1 -1
- package/esm2022/lib/models/timepicker.models.mjs +1 -1
- package/esm2022/lib/services/ecabs-components.service.mjs +32 -31
- package/esm2022/public-api.mjs +54 -54
- package/fesm2022/ecabs-components.mjs +3192 -3292
- package/fesm2022/ecabs-components.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/base/consts/date-mask.consts.d.ts +7 -7
- package/lib/base/directives/date-mask.directive.d.ts +16 -16
- package/lib/base/directives/date-mask.directive.module.d.ts +8 -8
- package/lib/base/directives/digits-only.directive.d.ts +26 -26
- package/lib/base/directives/digits-only.directive.module.d.ts +8 -8
- package/lib/base/directives/number-border.directive.d.ts +13 -13
- package/lib/base/directives/number-border.directive.module.d.ts +8 -8
- package/lib/base/element-base.d.ts +28 -28
- package/lib/base/element-wrapper/element-wrapper.component.d.ts +19 -19
- package/lib/base/element-wrapper/element-wrapper.module.d.ts +16 -16
- package/lib/base/hint/hint.component.d.ts +8 -8
- package/lib/base/hint/hint.module.d.ts +10 -10
- package/lib/base/validation/validation.component.d.ts +24 -24
- package/lib/base/validation/validation.module.d.ts +10 -10
- package/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.d.ts +7 -7
- package/lib/ecabs-breadcrumb/ecabs-breadcrumb.module.d.ts +10 -10
- package/lib/ecabs-buttons/ecabs-buttons.component.d.ts +20 -20
- package/lib/ecabs-buttons/ecabs-buttons.module.d.ts +11 -11
- package/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.d.ts +31 -29
- package/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.module.d.ts +12 -12
- package/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.d.ts +6 -6
- package/lib/ecabs-date-picker/ecabs-date-picker.component.d.ts +29 -29
- package/lib/ecabs-date-picker/ecabs-date-picker.module.d.ts +15 -15
- package/lib/ecabs-date-time-picker/components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component.d.ts +6 -6
- package/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.d.ts +51 -51
- package/lib/ecabs-date-time-picker/ecabs-date-time-picker.module.d.ts +19 -19
- package/lib/ecabs-date-time-range-picker/components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component.d.ts +6 -6
- package/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.d.ts +58 -58
- package/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.module.d.ts +20 -20
- package/lib/ecabs-date-time-range-picker/time-range.directive.d.ts +15 -15
- package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.d.ts +31 -31
- package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.module.d.ts +11 -11
- package/lib/ecabs-dialog-message/ecabs-dialog-message.component.d.ts +28 -28
- package/lib/ecabs-dialog-message/ecabs-dialog-message.module.d.ts +11 -11
- package/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.component.d.ts +12 -12
- package/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.module.d.ts +9 -9
- package/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.d.ts +28 -28
- package/lib/ecabs-expansion-panel/ecabs-expansion-panel.module.d.ts +14 -14
- package/lib/ecabs-increment/ecabs-increment.component.d.ts +26 -26
- package/lib/ecabs-increment/ecabs-increment.module.d.ts +13 -13
- package/lib/ecabs-input/ecabs-input.component.d.ts +27 -27
- package/lib/ecabs-input/ecabs-input.module.d.ts +12 -12
- package/lib/ecabs-language-selector/ecabs-language-selector.component.d.ts +20 -20
- package/lib/ecabs-language-selector/ecabs-language-selector.module.d.ts +12 -12
- package/lib/ecabs-loading/ecabs-loading.component.d.ts +8 -8
- package/lib/ecabs-loading/ecabs-loading.module.d.ts +9 -9
- package/lib/ecabs-loading/spinner/spinner.component.d.ts +6 -6
- package/lib/ecabs-note/ecabs-note.component.d.ts +7 -7
- package/lib/ecabs-note/ecabs-note.module.d.ts +9 -9
- package/lib/ecabs-phone/ecabs-phone.component.d.ts +33 -33
- package/lib/ecabs-phone/ecabs-phone.module.d.ts +12 -12
- package/lib/ecabs-picker-header/ecabs-picker-header.component.d.ts +19 -19
- package/lib/ecabs-picker-header/ecabs-picker-header.module.d.ts +12 -12
- package/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.d.ts +24 -24
- package/lib/ecabs-radio-button-list/ecabs-radio-button-list.module.d.ts +11 -11
- package/lib/ecabs-select/ecabs-select.component.d.ts +71 -71
- package/lib/ecabs-select/ecabs-select.module.d.ts +15 -15
- package/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.d.ts +8 -8
- package/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.module.d.ts +9 -9
- package/lib/ecabs-table/ecabs-table.component.d.ts +18 -18
- package/lib/ecabs-table/ecabs-table.module.d.ts +12 -12
- package/lib/ecabs-textarea/ecabs-textarea.component.d.ts +20 -20
- package/lib/ecabs-textarea/ecabs-textarea.module.d.ts +10 -10
- package/lib/ecabs-timepicker/componets/ecabs-time-list-panel/ecabs-time-list-panel.component.d.ts +40 -40
- package/lib/ecabs-timepicker/config.model.d.ts +5 -5
- package/lib/ecabs-timepicker/ecabs-timepicker.component.d.ts +53 -53
- package/lib/ecabs-timepicker/ecabs-timepicker.module.d.ts +10 -10
- package/lib/ecabs-timepicker/ecabs-timepicker.service.d.ts +12 -12
- package/lib/models/bread-crumb.d.ts +5 -5
- package/lib/models/timepicker.models.d.ts +6 -6
- package/lib/services/ecabs-components.service.d.ts +16 -16
- package/package.json +1 -1
- package/public-api.d.ts +54 -54
- package/styles/material/overrides/_form.scss +13 -1
- package/styles/scss/modules/_form.scss +13 -8
- package/styles/scss/utilities/_helpers.scss +9 -0
|
@@ -1,199 +1,193 @@
|
|
|
1
|
-
import { DecimalPipe } from '@angular/common';
|
|
2
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
-
import { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';
|
|
4
|
-
import ElementBaseComponent from '../base/element-base';
|
|
5
|
-
import { EcabsDateTimeRangePickerHeaderComponent } from './components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component';
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/common";
|
|
8
|
-
import * as i2 from "../base/element-wrapper/element-wrapper.component";
|
|
9
|
-
import * as i3 from "@angular/material/icon";
|
|
10
|
-
import * as i4 from "@angular/material/datepicker";
|
|
11
|
-
import * as i5 from "@angular/material/legacy-button";
|
|
12
|
-
import * as i6 from "@angular/forms";
|
|
13
|
-
import * as i7 from "../base/directives/digits-only.directive";
|
|
14
|
-
import * as i8 from "../base/directives/number-border.directive";
|
|
15
|
-
import * as i9 from "./time-range.directive";
|
|
16
|
-
export class EcabsDateTimeRangePickerComponent extends ElementBaseComponent {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
this.
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
this.injector
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
this.
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
this.
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
this.
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
this.
|
|
136
|
-
this.
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
{
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
type: Input
|
|
186
|
-
}],
|
|
187
|
-
type:
|
|
188
|
-
}],
|
|
189
|
-
type: Input
|
|
190
|
-
}],
|
|
191
|
-
type: Input
|
|
192
|
-
}]
|
|
193
|
-
type: Input
|
|
194
|
-
}], from: [{
|
|
195
|
-
type: Input
|
|
196
|
-
}], to: [{
|
|
197
|
-
type: Input
|
|
198
|
-
}] } });
|
|
199
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-time-range-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe } from '@angular/common';\r\nimport { AfterViewInit, Component, EventEmitter, Injector, Input, Output } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport { EcabsDateTimeRangePickerHeaderComponent } from './components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-time-range-picker',\r\n  templateUrl: './ecabs-date-time-range-picker.component.html',\r\n  styleUrls: ['./ecabs-date-time-range-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateTimeRangePickerComponent,\r\n      multi: true,\r\n    },\r\n    DecimalPipe,\r\n  ],\r\n})\r\nexport class EcabsDateTimeRangePickerComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit {\r\n  @Input() touchUi = false;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n\r\n  @Input() cancleLabel = 'Cancel';\r\n  @Input() applyLabel = 'Apply';\r\n  @Input() all = 'All';\r\n  @Input() from = 'From';\r\n  @Input() to = 'To';\r\n\r\n  \r\n\r\n  _hoursFrom = '12';\r\n  _minutesFrom = '00';\r\n  _hoursTo = '12';\r\n  _minutesTo = '00';\r\n  _seconds = '00';\r\n  _date: string;\r\n  _pickerValue: string;\r\n  val: string;\r\n  header = EcabsDateTimeRangePickerHeaderComponent;\r\n  maxValueHours = 23;\r\n  maxValueMinutesSeconds = 59;\r\n  controlDate: UntypedFormControl;\r\n\r\n  get value(): string {\r\n    return this.val;\r\n  }\r\n\r\n  get pickerValue(): string {\r\n    return this._pickerValue;\r\n  }\r\n\r\n  get hoursFrom(): string {\r\n    return this._hoursFrom;\r\n  }\r\n\r\n  get minutesFrom(): string {\r\n    return this._minutesFrom;\r\n  }\r\n\r\n  get hoursTo(): string {\r\n    return this._hoursTo;\r\n  }\r\n\r\n  get minutesTo(): string {\r\n    return this._minutesTo;\r\n  }\r\n\r\n  get seconds(): string {\r\n    return this._seconds;\r\n  }\r\n\r\n  set hoursFrom(value: string) {\r\n    if (value !== undefined && this._hoursFrom !== value) {\r\n      this._hoursFrom = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set minutesFrom(value: string) {\r\n    if (value !== undefined && this._minutesFrom !== value) {\r\n      this._minutesFrom = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set hoursTo(value: string) {\r\n    if (value !== undefined && this._hoursTo !== value) {\r\n      this._hoursTo = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set minutesTo(value: string) {\r\n    if (value !== undefined && this._minutesTo !== value) {\r\n      this._minutesTo = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set seconds(value: string) {\r\n    if (value !== undefined && this._seconds !== value) {\r\n      this._seconds = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set value(val) {\r\n    if (val && this.val !== val) {\r\n      this.val = val;\r\n      this.pickerValue = val;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  set pickerValue(val: string) {\r\n    if (val) {\r\n      this._pickerValue = val;\r\n      this.value = val;\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly decimalPipe: DecimalPipe\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(NgControl, null);\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n\r\n      setTimeout(() => {\r\n        this.controlDate = this.control;\r\n        const controlDate = !!this.control.value ? this.control.value : '';\r\n\r\n        if (controlDate) {\r\n          this.setValues(controlDate);\r\n        }\r\n      }, 10);\r\n    }\r\n  }\r\n\r\n  onChange: any = () => { };\r\n  onTouch: any = () => { };\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  blurChange(e: any): void {\r\n    this.onblur.emit(e);\r\n  }\r\n\r\n  keydownChange(e: any): void {\r\n    if (e?.target.value === this.all) {\r\n      const val = '';\r\n      this.val = val;\r\n      this._pickerValue = val;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  onApply(): void {\r\n    if (this._minutesFrom && this._hoursFrom && this._minutesTo && this._hoursTo) {\r\n      this.setValues(this._hoursFrom + ':' + this._minutesFrom + ' - ' + this._hoursTo + ':' + this._minutesTo);\r\n      this.value = this._hoursFrom + ':' + this._minutesFrom + ' - ' + this._hoursTo + ':' + this._minutesTo;\r\n\r\n      return;\r\n    }\r\n  }\r\n\r\n  opened(): void {\r\n    setTimeout(() => {\r\n      const elements = document.getElementsByClassName('mat-calendar-content');\r\n      while (elements.length > 0) {\r\n        elements[0].parentNode.removeChild(elements[0]);\r\n      }\r\n\r\n      let cols = Array.from(document.getElementsByClassName('mat-calendar') as HTMLCollectionOf<HTMLElement>);\r\n      for(let i=0; i<cols.length; i++) {\r\n        cols[i].style.height = '50px';\r\n      }      \r\n\r\n    });\r\n  }\r\n\r\n  private roundNumber(num: number): string | null {\r\n    return this.decimalPipe.transform(num, '2.0-0') ?? '00';\r\n  }\r\n\r\n  private setValues(date: string): void {\r\n    this._date = date;\r\n  }\r\n}","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <input\r\n      class=\"fake-input\"\r\n      [id]=\"_date\"\r\n      [(ngModel)]=\"_date\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled || controlDate?.disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker\r\n      (opened)=\"opened()\"\r\n      #picker\r\n      [calendarHeaderComponent]=\"header\"\r\n      [touchUi]=\"touchUi\"\r\n    >\r\n      <mat-datepicker-actions>\r\n        <div class=\"flex flex-col w-full gap-y-4\">\r\n          <div class=\"flex gap-2 justify-center items-center\">\r\n            <div class=\"flex flex-col justify-center\">\r\n              <div class=\"text-center\">{{ from }}</div>\r\n              <div class=\"flex gap-2 justify-center items-center\">\r\n                <input\r\n                  class=\"block form-field__input time\"\r\n                  appDigitsOnly\r\n                  appNumberBorder\r\n                  [digitsOnly]=\"true\"\r\n                  [id]=\"hoursFrom\"\r\n                  [maxValue]=\"maxValueHours\"\r\n                  [(ngModel)]=\"hoursFrom\"\r\n                />\r\n\r\n                <span class=\"font-bold\">:</span>\r\n                <input\r\n                  class=\"form-field__input time\"\r\n                  [id]=\"minutesFrom\"\r\n                  [(ngModel)]=\"minutesFrom\"\r\n                  appDigitsOnly\r\n                  appNumberBorder\r\n                  [digitsOnly]=\"true\"\r\n                  [maxValue]=\"maxValueMinutesSeconds\"\r\n                />\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"time--inputs\"></div>\r\n          <div class=\"flex gap-2 justify-center items-center mb-5\">\r\n            <div class=\"flex flex-col justify-center\">\r\n              <div class=\"text-center\">{{ to }}</div>\r\n              <div class=\"flex gap-2 justify-center items-center\">\r\n                <input\r\n                  class=\"form-field__input time\"\r\n                  appDigitsOnly\r\n                  appNumberBorder\r\n                  [digitsOnly]=\"true\"\r\n                  [id]=\"hoursTo\"\r\n                  [maxValue]=\"maxValueHours\"\r\n                  [(ngModel)]=\"hoursTo\"\r\n                />\r\n                <span class=\"font-bold\">:</span>\r\n                <input\r\n                  class=\"form-field__input time\"\r\n                  [id]=\"minutesTo\"\r\n                  [(ngModel)]=\"minutesTo\"\r\n                  appDigitsOnly\r\n                  appNumberBorder\r\n                  [digitsOnly]=\"true\"\r\n                  [maxValue]=\"maxValueMinutesSeconds\"\r\n                />\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"grid-picker-actions\">\r\n            <button\r\n              type=\"button\"\r\n              mat-stroked-button\r\n              class=\"w-full cancel-button\"\r\n              color=\"primary\"\r\n              matDatepickerCancel\r\n            >\r\n              {{ cancleLabel }}\r\n            </button>\r\n\r\n            <button\r\n              type=\"button\"\r\n              mat-button\r\n              class=\"w-full ml-0 apply-button\"\r\n              color=\"primary\"\r\n              matDatepickerApply\r\n              (click)=\"onApply()\"\r\n            >\r\n              {{ applyLabel }}\r\n            </button>\r\n          </div>\r\n        </div>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n    <input\r\n      class=\"form-field__input w-full date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"pickerValue\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled || controlDate?.disabled\"\r\n      appTimeRange\r\n      [all]=\"all\"\r\n      (blur)=\"onTouch()\"\r\n      (blur)=\"blurChange($event)\"\r\n      (keyup)=\"blurChange($event)\"\r\n      (keydown)=\"keydownChange($event)\"\r\n    />\r\n    <button type=\"button\" class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n      <mat-icon>access_time</mat-icon>\r\n    </button>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
1
|
+
import { DecimalPipe } from '@angular/common';
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';
|
|
4
|
+
import ElementBaseComponent from '../base/element-base';
|
|
5
|
+
import { EcabsDateTimeRangePickerHeaderComponent } from './components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "../base/element-wrapper/element-wrapper.component";
|
|
9
|
+
import * as i3 from "@angular/material/icon";
|
|
10
|
+
import * as i4 from "@angular/material/datepicker";
|
|
11
|
+
import * as i5 from "@angular/material/legacy-button";
|
|
12
|
+
import * as i6 from "@angular/forms";
|
|
13
|
+
import * as i7 from "../base/directives/digits-only.directive";
|
|
14
|
+
import * as i8 from "../base/directives/number-border.directive";
|
|
15
|
+
import * as i9 from "./time-range.directive";
|
|
16
|
+
export class EcabsDateTimeRangePickerComponent extends ElementBaseComponent {
|
|
17
|
+
get value() {
|
|
18
|
+
return this.val;
|
|
19
|
+
}
|
|
20
|
+
get pickerValue() {
|
|
21
|
+
return this._pickerValue;
|
|
22
|
+
}
|
|
23
|
+
get hoursFrom() {
|
|
24
|
+
return this._hoursFrom;
|
|
25
|
+
}
|
|
26
|
+
get minutesFrom() {
|
|
27
|
+
return this._minutesFrom;
|
|
28
|
+
}
|
|
29
|
+
get hoursTo() {
|
|
30
|
+
return this._hoursTo;
|
|
31
|
+
}
|
|
32
|
+
get minutesTo() {
|
|
33
|
+
return this._minutesTo;
|
|
34
|
+
}
|
|
35
|
+
get seconds() {
|
|
36
|
+
return this._seconds;
|
|
37
|
+
}
|
|
38
|
+
set hoursFrom(value) {
|
|
39
|
+
if (value !== undefined && this._hoursFrom !== value) {
|
|
40
|
+
this._hoursFrom = this.roundNumber(+value);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
set minutesFrom(value) {
|
|
44
|
+
if (value !== undefined && this._minutesFrom !== value) {
|
|
45
|
+
this._minutesFrom = this.roundNumber(+value);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
set hoursTo(value) {
|
|
49
|
+
if (value !== undefined && this._hoursTo !== value) {
|
|
50
|
+
this._hoursTo = this.roundNumber(+value);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
set minutesTo(value) {
|
|
54
|
+
if (value !== undefined && this._minutesTo !== value) {
|
|
55
|
+
this._minutesTo = this.roundNumber(+value);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
set seconds(value) {
|
|
59
|
+
if (value !== undefined && this._seconds !== value) {
|
|
60
|
+
this._seconds = this.roundNumber(+value);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
set value(val) {
|
|
64
|
+
if (val && this.val !== val) {
|
|
65
|
+
this.val = val;
|
|
66
|
+
this.pickerValue = val;
|
|
67
|
+
this.onChange(val);
|
|
68
|
+
this.onTouch(val);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
set pickerValue(val) {
|
|
72
|
+
if (val) {
|
|
73
|
+
this._pickerValue = val;
|
|
74
|
+
this.value = val;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
constructor(injector, decimalPipe) {
|
|
78
|
+
super();
|
|
79
|
+
this.injector = injector;
|
|
80
|
+
this.decimalPipe = decimalPipe;
|
|
81
|
+
this.touchUi = false;
|
|
82
|
+
this.onblur = new EventEmitter();
|
|
83
|
+
this.cancleLabel = 'Cancel';
|
|
84
|
+
this.applyLabel = 'Apply';
|
|
85
|
+
this.all = 'All';
|
|
86
|
+
this.from = 'From';
|
|
87
|
+
this.to = 'To';
|
|
88
|
+
this._hoursFrom = '12';
|
|
89
|
+
this._minutesFrom = '00';
|
|
90
|
+
this._hoursTo = '12';
|
|
91
|
+
this._minutesTo = '00';
|
|
92
|
+
this._seconds = '00';
|
|
93
|
+
this.header = EcabsDateTimeRangePickerHeaderComponent;
|
|
94
|
+
this.maxValueHours = 23;
|
|
95
|
+
this.maxValueMinutesSeconds = 59;
|
|
96
|
+
this.onChange = () => { };
|
|
97
|
+
this.onTouch = () => { };
|
|
98
|
+
}
|
|
99
|
+
ngAfterViewInit() {
|
|
100
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
101
|
+
if (ngControl) {
|
|
102
|
+
this.control = ngControl.control;
|
|
103
|
+
setTimeout(() => {
|
|
104
|
+
this.controlDate = this.control;
|
|
105
|
+
const controlDate = !!this.control.value ? this.control.value : '';
|
|
106
|
+
if (controlDate) {
|
|
107
|
+
this.setValues(controlDate);
|
|
108
|
+
}
|
|
109
|
+
}, 10);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
writeValue(value) {
|
|
113
|
+
this.value = value;
|
|
114
|
+
}
|
|
115
|
+
registerOnChange(fn) {
|
|
116
|
+
this.onChange = fn;
|
|
117
|
+
}
|
|
118
|
+
registerOnTouched(fn) {
|
|
119
|
+
this.onTouch = fn;
|
|
120
|
+
}
|
|
121
|
+
blurChange(e) {
|
|
122
|
+
this.onblur.emit(e);
|
|
123
|
+
}
|
|
124
|
+
keydownChange(e) {
|
|
125
|
+
if (e?.target.value === this.all) {
|
|
126
|
+
const val = '';
|
|
127
|
+
this.val = val;
|
|
128
|
+
this._pickerValue = val;
|
|
129
|
+
this.onChange(val);
|
|
130
|
+
this.onTouch(val);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
onApply() {
|
|
134
|
+
if (this._minutesFrom && this._hoursFrom && this._minutesTo && this._hoursTo) {
|
|
135
|
+
this.setValues(this._hoursFrom + ':' + this._minutesFrom + ' - ' + this._hoursTo + ':' + this._minutesTo);
|
|
136
|
+
this.value = this._hoursFrom + ':' + this._minutesFrom + ' - ' + this._hoursTo + ':' + this._minutesTo;
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
opened() {
|
|
141
|
+
setTimeout(() => {
|
|
142
|
+
const elements = document.getElementsByClassName('mat-calendar-content');
|
|
143
|
+
while (elements.length > 0) {
|
|
144
|
+
elements[0].parentNode.removeChild(elements[0]);
|
|
145
|
+
}
|
|
146
|
+
let cols = Array.from(document.getElementsByClassName('mat-calendar'));
|
|
147
|
+
for (let i = 0; i < cols.length; i++) {
|
|
148
|
+
cols[i].style.height = '50px';
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
roundNumber(num) {
|
|
153
|
+
return this.decimalPipe.transform(num, '2.0-0') ?? '00';
|
|
154
|
+
}
|
|
155
|
+
setValues(date) {
|
|
156
|
+
this._date = date;
|
|
157
|
+
}
|
|
158
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateTimeRangePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
159
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDateTimeRangePickerComponent, selector: "ecabs-date-time-range-picker", inputs: { touchUi: "touchUi", cancleLabel: "cancleLabel", applyLabel: "applyLabel", all: "all", from: "from", to: "to" }, outputs: { onblur: "onblur" }, providers: [
|
|
160
|
+
{
|
|
161
|
+
provide: NG_VALUE_ACCESSOR,
|
|
162
|
+
useExisting: EcabsDateTimeRangePickerComponent,
|
|
163
|
+
multi: true,
|
|
164
|
+
},
|
|
165
|
+
DecimalPipe,
|
|
166
|
+
], usesInheritance: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper w-full\">\r\n <input\r\n class=\"fake-input\"\r\n [id]=\"_date\"\r\n [(ngModel)]=\"_date\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled || controlDate?.disabled\"\r\n [matDatepicker]=\"picker\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <mat-datepicker\r\n (opened)=\"opened()\"\r\n #picker\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\"\r\n >\r\n <mat-datepicker-actions>\r\n <div class=\"flex flex-col w-full gap-y-4\">\r\n <div class=\"flex gap-2 justify-center items-center\">\r\n <div class=\"flex flex-col justify-center\">\r\n <div class=\"text-center\">{{ from }}</div>\r\n <div class=\"flex gap-2 justify-center items-center\">\r\n <input\r\n class=\"block form-field__input time\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [id]=\"hoursFrom\"\r\n [maxValue]=\"maxValueHours\"\r\n [(ngModel)]=\"hoursFrom\"\r\n />\r\n\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"minutesFrom\"\r\n [(ngModel)]=\"minutesFrom\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"time--inputs\"></div>\r\n <div class=\"flex gap-2 justify-center items-center mb-5\">\r\n <div class=\"flex flex-col justify-center\">\r\n <div class=\"text-center\">{{ to }}</div>\r\n <div class=\"flex gap-2 justify-center items-center\">\r\n <input\r\n class=\"form-field__input time\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [id]=\"hoursTo\"\r\n [maxValue]=\"maxValueHours\"\r\n [(ngModel)]=\"hoursTo\"\r\n />\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"minutesTo\"\r\n [(ngModel)]=\"minutesTo\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"grid-picker-actions\">\r\n <button\r\n type=\"button\"\r\n mat-stroked-button\r\n class=\"w-full cancel-button\"\r\n color=\"primary\"\r\n matDatepickerCancel\r\n >\r\n {{ cancleLabel }}\r\n </button>\r\n\r\n <button\r\n type=\"button\"\r\n mat-button\r\n class=\"w-full ml-0 apply-button\"\r\n color=\"primary\"\r\n matDatepickerApply\r\n (click)=\"onApply()\"\r\n >\r\n {{ applyLabel }}\r\n </button>\r\n </div>\r\n </div>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n <input\r\n class=\"form-field__input w-full date-input\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"pickerValue\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled || controlDate?.disabled\"\r\n appTimeRange\r\n [all]=\"all\"\r\n (blur)=\"onTouch()\"\r\n (blur)=\"blurChange($event)\"\r\n (keyup)=\"blurChange($event)\"\r\n (keydown)=\"keydownChange($event)\"\r\n />\r\n <button type=\"button\" class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n <mat-icon>access_time</mat-icon>\r\n </button>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: [".time--inputs:after{position:absolute;content:\"\"}.datepicker-toggle{transform:translate(-1.75rem)}.time{width:3.375rem}.fake-input{visibility:hidden;width:0;padding:0}.date-input{margin:0rem -.25rem 0rem .125rem}.time--inputs{position:relative;margin-bottom:2.4rem}.time--inputs:after{height:1px;right:0;left:0;background-color:var(--color-gray-300);bottom:-1.6rem}:host ::ng-deep .form-field{margin-right:-1.25rem;margin-left:-.125rem}\n"], dependencies: [{ kind: "component", type: i2.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i4.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i4.MatDatepickerActions, selector: "mat-datepicker-actions, mat-date-range-picker-actions" }, { kind: "directive", type: i4.MatDatepickerCancel, selector: "[matDatepickerCancel], [matDateRangePickerCancel]" }, { kind: "directive", type: i4.MatDatepickerApply, selector: "[matDatepickerApply], [matDateRangePickerApply]" }, { kind: "component", type: i5.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i7.DigitsOnlyDirective, selector: "[appDigitsOnly]", inputs: ["digitsOnly", "allowHyphen", "decimal", "decimalSeparator", "unit"] }, { kind: "directive", type: i8.NumberBorderDirective, selector: "[appNumberBorder]", inputs: ["maxValue", "minValue"] }, { kind: "directive", type: i9.TimeRangeDirective, selector: "[appTimeRange]", inputs: ["isDateTimeMask", "considerSeconds", "all"] }] }); }
|
|
167
|
+
}
|
|
168
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateTimeRangePickerComponent, decorators: [{
|
|
169
|
+
type: Component,
|
|
170
|
+
args: [{ selector: 'ecabs-date-time-range-picker', providers: [
|
|
171
|
+
{
|
|
172
|
+
provide: NG_VALUE_ACCESSOR,
|
|
173
|
+
useExisting: EcabsDateTimeRangePickerComponent,
|
|
174
|
+
multi: true,
|
|
175
|
+
},
|
|
176
|
+
DecimalPipe,
|
|
177
|
+
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper w-full\">\r\n <input\r\n class=\"fake-input\"\r\n [id]=\"_date\"\r\n [(ngModel)]=\"_date\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled || controlDate?.disabled\"\r\n [matDatepicker]=\"picker\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <mat-datepicker\r\n (opened)=\"opened()\"\r\n #picker\r\n [calendarHeaderComponent]=\"header\"\r\n [touchUi]=\"touchUi\"\r\n >\r\n <mat-datepicker-actions>\r\n <div class=\"flex flex-col w-full gap-y-4\">\r\n <div class=\"flex gap-2 justify-center items-center\">\r\n <div class=\"flex flex-col justify-center\">\r\n <div class=\"text-center\">{{ from }}</div>\r\n <div class=\"flex gap-2 justify-center items-center\">\r\n <input\r\n class=\"block form-field__input time\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [id]=\"hoursFrom\"\r\n [maxValue]=\"maxValueHours\"\r\n [(ngModel)]=\"hoursFrom\"\r\n />\r\n\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"minutesFrom\"\r\n [(ngModel)]=\"minutesFrom\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"time--inputs\"></div>\r\n <div class=\"flex gap-2 justify-center items-center mb-5\">\r\n <div class=\"flex flex-col justify-center\">\r\n <div class=\"text-center\">{{ to }}</div>\r\n <div class=\"flex gap-2 justify-center items-center\">\r\n <input\r\n class=\"form-field__input time\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [id]=\"hoursTo\"\r\n [maxValue]=\"maxValueHours\"\r\n [(ngModel)]=\"hoursTo\"\r\n />\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"minutesTo\"\r\n [(ngModel)]=\"minutesTo\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"grid-picker-actions\">\r\n <button\r\n type=\"button\"\r\n mat-stroked-button\r\n class=\"w-full cancel-button\"\r\n color=\"primary\"\r\n matDatepickerCancel\r\n >\r\n {{ cancleLabel }}\r\n </button>\r\n\r\n <button\r\n type=\"button\"\r\n mat-button\r\n class=\"w-full ml-0 apply-button\"\r\n color=\"primary\"\r\n matDatepickerApply\r\n (click)=\"onApply()\"\r\n >\r\n {{ applyLabel }}\r\n </button>\r\n </div>\r\n </div>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n <input\r\n class=\"form-field__input w-full date-input\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"pickerValue\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled || controlDate?.disabled\"\r\n appTimeRange\r\n [all]=\"all\"\r\n (blur)=\"onTouch()\"\r\n (blur)=\"blurChange($event)\"\r\n (keyup)=\"blurChange($event)\"\r\n (keydown)=\"keydownChange($event)\"\r\n />\r\n <button type=\"button\" class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n <mat-icon>access_time</mat-icon>\r\n </button>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: [".time--inputs:after{position:absolute;content:\"\"}.datepicker-toggle{transform:translate(-1.75rem)}.time{width:3.375rem}.fake-input{visibility:hidden;width:0;padding:0}.date-input{margin:0rem -.25rem 0rem .125rem}.time--inputs{position:relative;margin-bottom:2.4rem}.time--inputs:after{height:1px;right:0;left:0;background-color:var(--color-gray-300);bottom:-1.6rem}:host ::ng-deep .form-field{margin-right:-1.25rem;margin-left:-.125rem}\n"] }]
|
|
178
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.DecimalPipe }]; }, propDecorators: { touchUi: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], onblur: [{
|
|
181
|
+
type: Output
|
|
182
|
+
}], cancleLabel: [{
|
|
183
|
+
type: Input
|
|
184
|
+
}], applyLabel: [{
|
|
185
|
+
type: Input
|
|
186
|
+
}], all: [{
|
|
187
|
+
type: Input
|
|
188
|
+
}], from: [{
|
|
189
|
+
type: Input
|
|
190
|
+
}], to: [{
|
|
191
|
+
type: Input
|
|
192
|
+
}] } });
|
|
193
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-time-range-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe } from '@angular/common';\r\nimport { AfterViewInit, Component, EventEmitter, Injector, Input, Output } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport { EcabsDateTimeRangePickerHeaderComponent } from './components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component';\r\n\r\n@Component({\r\n  selector: 'ecabs-date-time-range-picker',\r\n  templateUrl: './ecabs-date-time-range-picker.component.html',\r\n  styleUrls: ['./ecabs-date-time-range-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateTimeRangePickerComponent,\r\n      multi: true,\r\n    },\r\n    DecimalPipe,\r\n  ],\r\n})\r\nexport class EcabsDateTimeRangePickerComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit {\r\n  @Input() touchUi = false;\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n\r\n  @Input() cancleLabel = 'Cancel';\r\n  @Input() applyLabel = 'Apply';\r\n  @Input() all = 'All';\r\n  @Input() from = 'From';\r\n  @Input() to = 'To';\r\n\r\n  \r\n\r\n  _hoursFrom = '12';\r\n  _minutesFrom = '00';\r\n  _hoursTo = '12';\r\n  _minutesTo = '00';\r\n  _seconds = '00';\r\n  _date: string;\r\n  _pickerValue: string;\r\n  val: string;\r\n  header = EcabsDateTimeRangePickerHeaderComponent;\r\n  maxValueHours = 23;\r\n  maxValueMinutesSeconds = 59;\r\n  controlDate: UntypedFormControl;\r\n\r\n  get value(): string {\r\n    return this.val;\r\n  }\r\n\r\n  get pickerValue(): string {\r\n    return this._pickerValue;\r\n  }\r\n\r\n  get hoursFrom(): string {\r\n    return this._hoursFrom;\r\n  }\r\n\r\n  get minutesFrom(): string {\r\n    return this._minutesFrom;\r\n  }\r\n\r\n  get hoursTo(): string {\r\n    return this._hoursTo;\r\n  }\r\n\r\n  get minutesTo(): string {\r\n    return this._minutesTo;\r\n  }\r\n\r\n  get seconds(): string {\r\n    return this._seconds;\r\n  }\r\n\r\n  set hoursFrom(value: string) {\r\n    if (value !== undefined && this._hoursFrom !== value) {\r\n      this._hoursFrom = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set minutesFrom(value: string) {\r\n    if (value !== undefined && this._minutesFrom !== value) {\r\n      this._minutesFrom = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set hoursTo(value: string) {\r\n    if (value !== undefined && this._hoursTo !== value) {\r\n      this._hoursTo = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set minutesTo(value: string) {\r\n    if (value !== undefined && this._minutesTo !== value) {\r\n      this._minutesTo = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set seconds(value: string) {\r\n    if (value !== undefined && this._seconds !== value) {\r\n      this._seconds = this.roundNumber(+value);\r\n    }\r\n  }\r\n\r\n  set value(val) {\r\n    if (val && this.val !== val) {\r\n      this.val = val;\r\n      this.pickerValue = val;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  set pickerValue(val: string) {\r\n    if (val) {\r\n      this._pickerValue = val;\r\n      this.value = val;\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private readonly injector: Injector,\r\n    private readonly decimalPipe: DecimalPipe\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get(NgControl, null);\r\n    if (ngControl) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n\r\n      setTimeout(() => {\r\n        this.controlDate = this.control;\r\n        const controlDate = !!this.control.value ? this.control.value : '';\r\n\r\n        if (controlDate) {\r\n          this.setValues(controlDate);\r\n        }\r\n      }, 10);\r\n    }\r\n  }\r\n\r\n  onChange: any = () => { };\r\n  onTouch: any = () => { };\r\n\r\n  writeValue(value: any): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  blurChange(e: any): void {\r\n    this.onblur.emit(e);\r\n  }\r\n\r\n  keydownChange(e: any): void {\r\n    if (e?.target.value === this.all) {\r\n      const val = '';\r\n      this.val = val;\r\n      this._pickerValue = val;\r\n      this.onChange(val);\r\n      this.onTouch(val);\r\n    }\r\n  }\r\n\r\n  onApply(): void {\r\n    if (this._minutesFrom && this._hoursFrom && this._minutesTo && this._hoursTo) {\r\n      this.setValues(this._hoursFrom + ':' + this._minutesFrom + ' - ' + this._hoursTo + ':' + this._minutesTo);\r\n      this.value = this._hoursFrom + ':' + this._minutesFrom + ' - ' + this._hoursTo + ':' + this._minutesTo;\r\n\r\n      return;\r\n    }\r\n  }\r\n\r\n  opened(): void {\r\n    setTimeout(() => {\r\n      const elements = document.getElementsByClassName('mat-calendar-content');\r\n      while (elements.length > 0) {\r\n        elements[0].parentNode.removeChild(elements[0]);\r\n      }\r\n\r\n      let cols = Array.from(document.getElementsByClassName('mat-calendar') as HTMLCollectionOf<HTMLElement>);\r\n      for(let i=0; i<cols.length; i++) {\r\n        cols[i].style.height = '50px';\r\n      }      \r\n\r\n    });\r\n  }\r\n\r\n  private roundNumber(num: number): string | null {\r\n    return this.decimalPipe.transform(num, '2.0-0') ?? '00';\r\n  }\r\n\r\n  private setValues(date: string): void {\r\n    this._date = date;\r\n  }\r\n}","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <input\r\n      class=\"fake-input\"\r\n      [id]=\"_date\"\r\n      [(ngModel)]=\"_date\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled || controlDate?.disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker\r\n      (opened)=\"opened()\"\r\n      #picker\r\n      [calendarHeaderComponent]=\"header\"\r\n      [touchUi]=\"touchUi\"\r\n    >\r\n      <mat-datepicker-actions>\r\n        <div class=\"flex flex-col w-full gap-y-4\">\r\n          <div class=\"flex gap-2 justify-center items-center\">\r\n            <div class=\"flex flex-col justify-center\">\r\n              <div class=\"text-center\">{{ from }}</div>\r\n              <div class=\"flex gap-2 justify-center items-center\">\r\n                <input\r\n                  class=\"block form-field__input time\"\r\n                  appDigitsOnly\r\n                  appNumberBorder\r\n                  [digitsOnly]=\"true\"\r\n                  [id]=\"hoursFrom\"\r\n                  [maxValue]=\"maxValueHours\"\r\n                  [(ngModel)]=\"hoursFrom\"\r\n                />\r\n\r\n                <span class=\"font-bold\">:</span>\r\n                <input\r\n                  class=\"form-field__input time\"\r\n                  [id]=\"minutesFrom\"\r\n                  [(ngModel)]=\"minutesFrom\"\r\n                  appDigitsOnly\r\n                  appNumberBorder\r\n                  [digitsOnly]=\"true\"\r\n                  [maxValue]=\"maxValueMinutesSeconds\"\r\n                />\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"time--inputs\"></div>\r\n          <div class=\"flex gap-2 justify-center items-center mb-5\">\r\n            <div class=\"flex flex-col justify-center\">\r\n              <div class=\"text-center\">{{ to }}</div>\r\n              <div class=\"flex gap-2 justify-center items-center\">\r\n                <input\r\n                  class=\"form-field__input time\"\r\n                  appDigitsOnly\r\n                  appNumberBorder\r\n                  [digitsOnly]=\"true\"\r\n                  [id]=\"hoursTo\"\r\n                  [maxValue]=\"maxValueHours\"\r\n                  [(ngModel)]=\"hoursTo\"\r\n                />\r\n                <span class=\"font-bold\">:</span>\r\n                <input\r\n                  class=\"form-field__input time\"\r\n                  [id]=\"minutesTo\"\r\n                  [(ngModel)]=\"minutesTo\"\r\n                  appDigitsOnly\r\n                  appNumberBorder\r\n                  [digitsOnly]=\"true\"\r\n                  [maxValue]=\"maxValueMinutesSeconds\"\r\n                />\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"grid-picker-actions\">\r\n            <button\r\n              type=\"button\"\r\n              mat-stroked-button\r\n              class=\"w-full cancel-button\"\r\n              color=\"primary\"\r\n              matDatepickerCancel\r\n            >\r\n              {{ cancleLabel }}\r\n            </button>\r\n\r\n            <button\r\n              type=\"button\"\r\n              mat-button\r\n              class=\"w-full ml-0 apply-button\"\r\n              color=\"primary\"\r\n              matDatepickerApply\r\n              (click)=\"onApply()\"\r\n            >\r\n              {{ applyLabel }}\r\n            </button>\r\n          </div>\r\n        </div>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n    <input\r\n      class=\"form-field__input w-full date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"pickerValue\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled || controlDate?.disabled\"\r\n      appTimeRange\r\n      [all]=\"all\"\r\n      (blur)=\"onTouch()\"\r\n      (blur)=\"blurChange($event)\"\r\n      (keyup)=\"blurChange($event)\"\r\n      (keydown)=\"keydownChange($event)\"\r\n    />\r\n    <button type=\"button\" class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n      <mat-icon>access_time</mat-icon>\r\n    </button>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|