ng-zenduit 2.0.1 → 2.0.2

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.
@@ -41,6 +41,7 @@ import { TranslateLoader, TranslateModule } from '@ngx-translate/core';
41
41
  import { TranslateHttpLoader } from '@ngx-translate/http-loader';
42
42
  import { HttpClient } from '@angular/common/http';
43
43
  import { ZenduSelectButtonDirective } from './select/templates/zendu-select-button.directive';
44
+ import { ZenduTimepickerComponent } from './timepicker/zendu-timepicker.component';
44
45
  import { OverlayModule } from '@angular/cdk/overlay';
45
46
  import * as i0 from "@angular/core";
46
47
  import * as i1 from "@ngx-translate/core";
@@ -83,7 +84,8 @@ NgZenduitModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
83
84
  ZenHlsPlayerComponent,
84
85
  ZenSnapshotPlayerComponent,
85
86
  ZenWebRTCPlayerComponent,
86
- ZenduSelectButtonDirective], imports: [CommonModule,
87
+ ZenduSelectButtonDirective,
88
+ ZenduTimepickerComponent], imports: [CommonModule,
87
89
  FormsModule,
88
90
  DragDropModule,
89
91
  AngularSignaturePadModule,
@@ -116,7 +118,8 @@ NgZenduitModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version
116
118
  ZenduProgress,
117
119
  ZenduLocationSearch,
118
120
  ZenLiveViewPlayerComponent,
119
- ZenduSelectButtonDirective] });
121
+ ZenduSelectButtonDirective,
122
+ ZenduTimepickerComponent] });
120
123
  NgZenduitModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NgZenduitModule, providers: [
121
124
  OpenCVService,
122
125
  ], imports: [CommonModule,
@@ -169,7 +172,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
169
172
  ZenHlsPlayerComponent,
170
173
  ZenSnapshotPlayerComponent,
171
174
  ZenWebRTCPlayerComponent,
172
- ZenduSelectButtonDirective
175
+ ZenduSelectButtonDirective,
176
+ ZenduTimepickerComponent
173
177
  ],
174
178
  providers: [
175
179
  OpenCVService,
@@ -218,8 +222,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
218
222
  ZenduProgress,
219
223
  ZenduLocationSearch,
220
224
  ZenLiveViewPlayerComponent,
221
- ZenduSelectButtonDirective
225
+ ZenduSelectButtonDirective,
226
+ ZenduTimepickerComponent
222
227
  ]
223
228
  }]
224
229
  }] });
225
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-zenduit.module.js","sourceRoot":"","sources":["../../../../projects/ng-zenduit/src/lib/ng-zenduit.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { ZenduCheckboxComponent } from './checkbox/zendu-checkbox.component';\nimport { ZenduColorPickerComponent } from './colorpicker/zendu-colorpicker.component';\nimport { ZenduColumnConfigurationComponent } from './column-configuration/zendu-column-configuration.component';\nimport { ZenduDatepickerComponent } from './datepicker/zendu-datepicker.component';\nimport { ZenduFilterComponent } from './filter/zendu-filter.component';\nimport { ZenduGroupsComponent } from './groups/zendu-groups.component';\nimport { ZenduPaginationBarComponent } from './pagination-bar/zendu-pagination-bar.component';\nimport { ZenduPhoneInputComponent } from './phone-input/zendu-phone-input.component';\nimport { ZenduRadioButtonComponent } from './radio-button/radio-button.component';\nimport { ZenduSearchBoxComponent } from './search-box/zendu-search-box.component';\nimport { ZenduSelectComponent } from './select/zendu-select.component';\nimport { ZenduSelectOptionDirective } from './select/templates/zendu-select-option.directive';\nimport { ZenduSelectValueDirective } from './select/templates/zendu-select-value.directive';\nimport { ZenduSortHeaderComponent } from './sort-header/zendu-sort-header.component';\nimport { ZenduToggleSlideComponent } from './toggle-slide/zendu-toggle-slide.component';\nimport { ZenduToggleComponent } from './toggle/zendu-toggle.component';\nimport { DragDropModule } from '@angular/cdk/drag-drop';\nimport { ZenduIconComponent } from './icon/zendu-icon.component';\nimport { ZenduCardBlockComponent } from './card-block/zendu-card-block.component';\nimport { ZenduMapPreviewComponent } from './map-preview/zendu-map-preview.component';\nimport { ZenduSpinner } from './spinner/zendu-spinner.component';\nimport { ZenduDocScanner } from './doc-scanner/zendu-doc-scanner.component';\nimport { ZenduBreadcrumbs } from './breadcrumbs/zendu-breadcrumbs.component';\nimport { ZenduMapComponent } from './map/zendu-map.component';\nimport { ZenduFileUpload } from './file-upload/zendu-file-upload.component';\nimport { ZenduProgress } from './progress/zendu-progress.component';\nimport { OpenCVService } from './services/opencv.service';\nimport { ZenduLocationSearch } from './location-search/zendu-location-search.component';\nimport { AngularSignaturePadModule } from '@almothafar/angular-signature-pad';\nimport { HttpClientModule } from '@angular/common/http';\nimport { ZenLiveViewPlayerComponent } from './live-view-player/live-view-player/live-view-player.component';\nimport { ZenHTML5VideoPlayerComponent } from './live-view-player/html5-video-player/html5-video-player.component';\nimport { ZenFlvPlayerComponent } from './live-view-player/flv-player/flv-player.component';\nimport { ZenHlsPlayerComponent } from './live-view-player/hls-player/hls-player.component';\nimport { ZenWebRTCPlayerComponent } from './live-view-player/web-rtc/web-rtc-player.component';\nimport { ZenSnapshotPlayerComponent } from './live-view-player/snapshot-player/snapshot-player.component';\nimport { TranslateLoader, TranslateModule } from '@ngx-translate/core';\nimport { TranslateHttpLoader } from '@ngx-translate/http-loader';\nimport { HttpClient } from '@angular/common/http';\nimport { ZenduSelectButtonDirective } from './select/templates/zendu-select-button.directive';\nimport { OverlayModule } from '@angular/cdk/overlay';\n\n// AoT requires an exported function for factories\nexport function HttpLoaderFactory(httpClient: HttpClient) {\n    return new TranslateHttpLoader(httpClient);\n}\n\n@NgModule({\n  declarations: [\n    ZenduCheckboxComponent,\n    ZenduToggleComponent,\n    ZenduToggleSlideComponent,\n    ZenduSearchBoxComponent,\n    ZenduSelectComponent,\n    ZenduSelectOptionDirective,\n    ZenduSelectValueDirective,\n    ZenduDatepickerComponent,\n    ZenduFilterComponent,\n    ZenduGroupsComponent,\n    ZenduPaginationBarComponent,\n    ZenduColumnConfigurationComponent,\n    ZenduSortHeaderComponent,\n    ZenduPhoneInputComponent,\n    ZenduColorPickerComponent,\n    ZenduRadioButtonComponent,\n    ZenduIconComponent,\n    ZenduCardBlockComponent,\n    ZenduMapPreviewComponent,\n    ZenduSpinner,\n    ZenduDocScanner,\n    ZenduBreadcrumbs,\n    ZenduMapComponent,\n    ZenduFileUpload,\n    ZenduProgress,\n    ZenduLocationSearch,\n    ZenLiveViewPlayerComponent,\n    ZenHTML5VideoPlayerComponent,\n    ZenFlvPlayerComponent,\n    ZenHlsPlayerComponent,\n    ZenSnapshotPlayerComponent,\n    ZenWebRTCPlayerComponent,\n    ZenduSelectButtonDirective\n  ],\n  providers: [\n    OpenCVService,\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    DragDropModule,\n    AngularSignaturePadModule,\n    ReactiveFormsModule,\n    HttpClientModule,\n    OverlayModule,\n    TranslateModule.forRoot({\n        loader: {\n            provide: TranslateLoader,\n            useFactory: HttpLoaderFactory,\n            deps: [HttpClient]\n        }\n    })\n  ],\n  exports: [\n    ZenduCheckboxComponent,\n    ZenduToggleComponent,\n    ZenduToggleSlideComponent,\n    ZenduSearchBoxComponent,\n    ZenduSelectComponent,\n    ZenduSelectOptionDirective,\n    ZenduSelectValueDirective,\n    ZenduDatepickerComponent,\n    ZenduFilterComponent,\n    ZenduGroupsComponent,\n    ZenduPaginationBarComponent,\n    ZenduColumnConfigurationComponent,\n    ZenduSortHeaderComponent,\n    ZenduPhoneInputComponent,\n    ZenduColorPickerComponent,\n    ZenduRadioButtonComponent,\n    ZenduIconComponent,\n    ZenduCardBlockComponent,\n    ZenduMapPreviewComponent,\n    ZenduSpinner,\n    ZenduDocScanner,\n    ZenduBreadcrumbs,\n    ZenduMapComponent,\n    ZenduFileUpload,\n    ZenduProgress,\n    ZenduLocationSearch,\n    ZenLiveViewPlayerComponent,\n    ZenduSelectButtonDirective\n  ]\n})\nexport class NgZenduitModule { }\n\n"]}
230
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-zenduit.module.js","sourceRoot":"","sources":["../../../../projects/ng-zenduit/src/lib/ng-zenduit.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { ZenduCheckboxComponent } from './checkbox/zendu-checkbox.component';\nimport { ZenduColorPickerComponent } from './colorpicker/zendu-colorpicker.component';\nimport { ZenduColumnConfigurationComponent } from './column-configuration/zendu-column-configuration.component';\nimport { ZenduDatepickerComponent } from './datepicker/zendu-datepicker.component';\nimport { ZenduFilterComponent } from './filter/zendu-filter.component';\nimport { ZenduGroupsComponent } from './groups/zendu-groups.component';\nimport { ZenduPaginationBarComponent } from './pagination-bar/zendu-pagination-bar.component';\nimport { ZenduPhoneInputComponent } from './phone-input/zendu-phone-input.component';\nimport { ZenduRadioButtonComponent } from './radio-button/radio-button.component';\nimport { ZenduSearchBoxComponent } from './search-box/zendu-search-box.component';\nimport { ZenduSelectComponent } from './select/zendu-select.component';\nimport { ZenduSelectOptionDirective } from './select/templates/zendu-select-option.directive';\nimport { ZenduSelectValueDirective } from './select/templates/zendu-select-value.directive';\nimport { ZenduSortHeaderComponent } from './sort-header/zendu-sort-header.component';\nimport { ZenduToggleSlideComponent } from './toggle-slide/zendu-toggle-slide.component';\nimport { ZenduToggleComponent } from './toggle/zendu-toggle.component';\nimport { DragDropModule } from '@angular/cdk/drag-drop';\nimport { ZenduIconComponent } from './icon/zendu-icon.component';\nimport { ZenduCardBlockComponent } from './card-block/zendu-card-block.component';\nimport { ZenduMapPreviewComponent } from './map-preview/zendu-map-preview.component';\nimport { ZenduSpinner } from './spinner/zendu-spinner.component';\nimport { ZenduDocScanner } from './doc-scanner/zendu-doc-scanner.component';\nimport { ZenduBreadcrumbs } from './breadcrumbs/zendu-breadcrumbs.component';\nimport { ZenduMapComponent } from './map/zendu-map.component';\nimport { ZenduFileUpload } from './file-upload/zendu-file-upload.component';\nimport { ZenduProgress } from './progress/zendu-progress.component';\nimport { OpenCVService } from './services/opencv.service';\nimport { ZenduLocationSearch } from './location-search/zendu-location-search.component';\nimport { AngularSignaturePadModule } from '@almothafar/angular-signature-pad';\nimport { HttpClientModule } from '@angular/common/http';\nimport { ZenLiveViewPlayerComponent } from './live-view-player/live-view-player/live-view-player.component';\nimport { ZenHTML5VideoPlayerComponent } from './live-view-player/html5-video-player/html5-video-player.component';\nimport { ZenFlvPlayerComponent } from './live-view-player/flv-player/flv-player.component';\nimport { ZenHlsPlayerComponent } from './live-view-player/hls-player/hls-player.component';\nimport { ZenWebRTCPlayerComponent } from './live-view-player/web-rtc/web-rtc-player.component';\nimport { ZenSnapshotPlayerComponent } from './live-view-player/snapshot-player/snapshot-player.component';\nimport { TranslateLoader, TranslateModule } from '@ngx-translate/core';\nimport { TranslateHttpLoader } from '@ngx-translate/http-loader';\nimport { HttpClient } from '@angular/common/http';\nimport { ZenduSelectButtonDirective } from './select/templates/zendu-select-button.directive';\nimport { ZenduTimepickerComponent } from './timepicker/zendu-timepicker.component';\nimport { OverlayModule } from '@angular/cdk/overlay';\n\n// AoT requires an exported function for factories\nexport function HttpLoaderFactory(httpClient: HttpClient) {\n    return new TranslateHttpLoader(httpClient);\n}\n\n@NgModule({\n  declarations: [\n    ZenduCheckboxComponent,\n    ZenduToggleComponent,\n    ZenduToggleSlideComponent,\n    ZenduSearchBoxComponent,\n    ZenduSelectComponent,\n    ZenduSelectOptionDirective,\n    ZenduSelectValueDirective,\n    ZenduDatepickerComponent,\n    ZenduFilterComponent,\n    ZenduGroupsComponent,\n    ZenduPaginationBarComponent,\n    ZenduColumnConfigurationComponent,\n    ZenduSortHeaderComponent,\n    ZenduPhoneInputComponent,\n    ZenduColorPickerComponent,\n    ZenduRadioButtonComponent,\n    ZenduIconComponent,\n    ZenduCardBlockComponent,\n    ZenduMapPreviewComponent,\n    ZenduSpinner,\n    ZenduDocScanner,\n    ZenduBreadcrumbs,\n    ZenduMapComponent,\n    ZenduFileUpload,\n    ZenduProgress,\n    ZenduLocationSearch,\n    ZenLiveViewPlayerComponent,\n    ZenHTML5VideoPlayerComponent,\n    ZenFlvPlayerComponent,\n    ZenHlsPlayerComponent,\n    ZenSnapshotPlayerComponent,\n    ZenWebRTCPlayerComponent,\n    ZenduSelectButtonDirective,\n    ZenduTimepickerComponent\n  ],\n  providers: [\n    OpenCVService,\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    DragDropModule,\n    AngularSignaturePadModule,\n    ReactiveFormsModule,\n    HttpClientModule,\n    OverlayModule,\n    TranslateModule.forRoot({\n        loader: {\n            provide: TranslateLoader,\n            useFactory: HttpLoaderFactory,\n            deps: [HttpClient]\n        }\n    })\n  ],\n  exports: [\n    ZenduCheckboxComponent,\n    ZenduToggleComponent,\n    ZenduToggleSlideComponent,\n    ZenduSearchBoxComponent,\n    ZenduSelectComponent,\n    ZenduSelectOptionDirective,\n    ZenduSelectValueDirective,\n    ZenduDatepickerComponent,\n    ZenduFilterComponent,\n    ZenduGroupsComponent,\n    ZenduPaginationBarComponent,\n    ZenduColumnConfigurationComponent,\n    ZenduSortHeaderComponent,\n    ZenduPhoneInputComponent,\n    ZenduColorPickerComponent,\n    ZenduRadioButtonComponent,\n    ZenduIconComponent,\n    ZenduCardBlockComponent,\n    ZenduMapPreviewComponent,\n    ZenduSpinner,\n    ZenduDocScanner,\n    ZenduBreadcrumbs,\n    ZenduMapComponent,\n    ZenduFileUpload,\n    ZenduProgress,\n    ZenduLocationSearch,\n    ZenLiveViewPlayerComponent,\n    ZenduSelectButtonDirective,\n    ZenduTimepickerComponent\n  ]\n})\nexport class NgZenduitModule { }\n\n"]}
@@ -0,0 +1,247 @@
1
+ import { Component, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ import * as i2 from "../icon/zendu-icon.component";
5
+ export class ZenduTimepickerComponent {
6
+ constructor(_element) {
7
+ this._element = _element;
8
+ this.mode = 'clock';
9
+ this.showSeconds = false;
10
+ this.disabled = false;
11
+ this.readonly = false;
12
+ this.valueChange = new EventEmitter();
13
+ this.apply = new EventEmitter();
14
+ this.clear = new EventEmitter();
15
+ this.isPickerVisible = false;
16
+ this.hours = [];
17
+ this.minutes = [];
18
+ this.seconds = [];
19
+ this.selectedHours = 0;
20
+ this.selectedMinutes = 0;
21
+ this.selectedSeconds = 0;
22
+ this.selectedPeriod = 'AM';
23
+ this.right = false;
24
+ this.bottom = false;
25
+ this.ITEM_HEIGHT = 42;
26
+ this.isDragging = false;
27
+ this.dragStartY = 0;
28
+ this.dragStartScroll = 0;
29
+ }
30
+ outsideClick(event) {
31
+ if (!document.body.contains(event.target)) {
32
+ return;
33
+ }
34
+ if (this._element.nativeElement.contains(event.target)) {
35
+ return;
36
+ }
37
+ this.isPickerVisible = false;
38
+ }
39
+ get defaultLabel() {
40
+ return this.mode === 'clock' ? 'Select a time' : 'Stop Duration';
41
+ }
42
+ get defaultPlaceholder() {
43
+ if (this.placeholder)
44
+ return this.placeholder;
45
+ return this.mode === 'clock' ? 'Select Time' : '0 min';
46
+ }
47
+ get hourSeparator() {
48
+ return this.mode === 'clock' ? ':' : 'hr';
49
+ }
50
+ get minuteSeparator() {
51
+ return this.mode === 'clock' ? ':' : 'min';
52
+ }
53
+ get secondSeparator() {
54
+ return this.mode === 'duration' ? 'sec' : '';
55
+ }
56
+ get formattedDisplayValue() {
57
+ if (!this.value)
58
+ return '';
59
+ if (this.mode === 'clock') {
60
+ const h = this.formatNum(this.value.hours);
61
+ const m = this.formatNum(this.value.minutes);
62
+ if (this.showSeconds) {
63
+ const s = this.formatNum(this.value.seconds);
64
+ return `${h}.${m}.${s} ${this.value.period || 'AM'}`;
65
+ }
66
+ return `${h}.${m} ${this.value.period || 'AM'}`;
67
+ }
68
+ // Duration mode
69
+ const parts = [];
70
+ if (this.value.hours > 0) {
71
+ parts.push(`${this.value.hours} hr`);
72
+ }
73
+ if (this.value.minutes > 0) {
74
+ parts.push(`${this.value.minutes} min`);
75
+ }
76
+ if (this.showSeconds && this.value.seconds > 0) {
77
+ parts.push(`${this.value.seconds} sec`);
78
+ }
79
+ return parts.length > 0 ? parts.join(' ') : '0 min';
80
+ }
81
+ ngOnInit() {
82
+ this.buildRanges();
83
+ if (this.value) {
84
+ this.applyValue(this.value);
85
+ }
86
+ }
87
+ ngOnChanges(changes) {
88
+ if (changes['mode']) {
89
+ this.buildRanges();
90
+ }
91
+ if (changes['value'] && this.value) {
92
+ this.applyValue(this.value);
93
+ }
94
+ }
95
+ togglePicker() {
96
+ if (this.disabled || this.readonly)
97
+ return;
98
+ this.isPickerVisible = !this.isPickerVisible;
99
+ if (this.isPickerVisible) {
100
+ if (this.value) {
101
+ this.applyValue(this.value);
102
+ }
103
+ this.updatePlacement();
104
+ }
105
+ }
106
+ updatePlacement() {
107
+ this.right = false;
108
+ this.bottom = false;
109
+ const el = this._element.nativeElement;
110
+ const rect = el.getBoundingClientRect();
111
+ if (rect.left > window.innerWidth / 2) {
112
+ this.right = true;
113
+ }
114
+ if (rect.top > window.innerHeight / 2) {
115
+ this.bottom = true;
116
+ }
117
+ }
118
+ buildRanges() {
119
+ const maxHour = this.mode === 'clock' ? 12 : 23;
120
+ const startHour = this.mode === 'clock' ? 1 : 0;
121
+ this.hours = this.range(startHour, maxHour);
122
+ this.minutes = this.range(0, 59);
123
+ this.seconds = this.range(0, 59);
124
+ }
125
+ applyValue(val) {
126
+ this.selectedHours = val.hours;
127
+ this.selectedMinutes = val.minutes;
128
+ this.selectedSeconds = val.seconds;
129
+ if (val.period) {
130
+ this.selectedPeriod = val.period;
131
+ }
132
+ }
133
+ range(start, end) {
134
+ const arr = [];
135
+ for (let i = start; i <= end; i++) {
136
+ arr.push(i);
137
+ }
138
+ return arr;
139
+ }
140
+ formatNum(n) {
141
+ return n < 10 ? '0' + n : '' + n;
142
+ }
143
+ selectHour(val) {
144
+ this.selectedHours = val;
145
+ }
146
+ selectMinute(val) {
147
+ this.selectedMinutes = val;
148
+ }
149
+ selectSecond(val) {
150
+ this.selectedSeconds = val;
151
+ }
152
+ selectPeriod(period) {
153
+ this.selectedPeriod = period;
154
+ }
155
+ onScroll(event, type) {
156
+ const el = event.target;
157
+ const scrollTop = el.scrollTop;
158
+ const index = Math.round(scrollTop / this.ITEM_HEIGHT);
159
+ if (type === 'hours' && index >= 0 && index < this.hours.length) {
160
+ this.selectedHours = this.hours[index];
161
+ }
162
+ else if (type === 'minutes' && index >= 0 && index < this.minutes.length) {
163
+ this.selectedMinutes = this.minutes[index];
164
+ }
165
+ else if (type === 'seconds' && index >= 0 && index < this.seconds.length) {
166
+ this.selectedSeconds = this.seconds[index];
167
+ }
168
+ }
169
+ onMouseDown(event, scrollEl) {
170
+ this.isDragging = true;
171
+ this.dragStartY = event.clientY;
172
+ this.dragStartScroll = scrollEl.scrollTop;
173
+ event.preventDefault();
174
+ }
175
+ onMouseMove(event, scrollEl) {
176
+ if (!this.isDragging)
177
+ return;
178
+ const delta = this.dragStartY - event.clientY;
179
+ scrollEl.scrollTop = this.dragStartScroll + delta;
180
+ }
181
+ onMouseUp() {
182
+ this.isDragging = false;
183
+ }
184
+ onApply() {
185
+ const val = this.getCurrentValue();
186
+ this.value = val;
187
+ this.valueChange.emit(val);
188
+ this.apply.emit(val);
189
+ this.isPickerVisible = false;
190
+ }
191
+ onClear() {
192
+ this.selectedHours = this.mode === 'clock' ? 12 : 0;
193
+ this.selectedMinutes = 0;
194
+ this.selectedSeconds = 0;
195
+ this.selectedPeriod = 'AM';
196
+ this.value = null;
197
+ this.valueChange.emit(null);
198
+ this.clear.emit();
199
+ this.isPickerVisible = false;
200
+ }
201
+ getCurrentValue() {
202
+ const val = {
203
+ hours: this.selectedHours,
204
+ minutes: this.selectedMinutes,
205
+ seconds: this.selectedSeconds,
206
+ };
207
+ if (this.mode === 'clock') {
208
+ val.period = this.selectedPeriod;
209
+ }
210
+ return val;
211
+ }
212
+ }
213
+ ZenduTimepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ZenduTimepickerComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
214
+ ZenduTimepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ZenduTimepickerComponent, selector: "zen-timepicker", inputs: { mode: "mode", label: "label", value: "value", showSeconds: "showSeconds", disabled: "disabled", readonly: "readonly", placeholder: "placeholder", width: "width" }, outputs: { valueChange: "valueChange", apply: "apply", clear: "clear" }, host: { listeners: { "window:mousedown": "outsideClick($event)" } }, viewQueries: [{ propertyName: "pickerPopup", first: true, predicate: ["pickerPopup"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"zen-tp\">\n <!-- Input toggle button -->\n <button class=\"zen-tp__toggle zen-tp__toggle--box\"\n [class.zen-tp__toggle--active]=\"isPickerVisible\"\n [class.zen-tp__toggle--disabled]=\"disabled\"\n [class.zen-tp__toggle--readonly]=\"readonly\"\n [style.width]=\"width || null\"\n [disabled]=\"disabled || readonly\"\n (click)=\"togglePicker()\">\n <span class=\"zen-tp__display\" [class.zen-tp__display--placeholder]=\"!value\">\n {{ value ? formattedDisplayValue : defaultPlaceholder }}\n </span>\n <zen-icon class=\"zen-tp__icon\"\n [class.zen-tp__icon--filled]=\"value\"\n src=\"assets/ng-zenduit/icons/time.svg\">\n </zen-icon>\n </button>\n\n <!-- Picker dropdown -->\n <div class=\"zen-tp__dropdown\"\n #pickerPopup\n *ngIf=\"isPickerVisible\"\n [class.zen-tp__dropdown--right]=\"right\"\n [class.zen-tp__dropdown--bottom]=\"bottom\">\n <div class=\"zen-tp__popup\">\n <!-- Header -->\n <div class=\"zen-tp__popup-label\">{{ label || defaultLabel }}</div>\n\n <!-- Scroll Columns -->\n <div class=\"zen-tp__columns\">\n <!-- Hours -->\n <div class=\"zen-tp__scroll-group\">\n <div class=\"zen-tp__scroll-col\"\n #scrollCol\n (scroll)=\"onScroll($event, 'hours')\"\n (mousedown)=\"onMouseDown($event, scrollCol)\"\n (mousemove)=\"onMouseMove($event, scrollCol)\"\n (mouseup)=\"onMouseUp()\"\n (mouseleave)=\"onMouseUp()\">\n <div class=\"zen-tp__scroll-spacer\"></div>\n <div *ngFor=\"let h of hours\"\n class=\"zen-tp__scroll-item\"\n [class.zen-tp__scroll-item--selected]=\"h === selectedHours\"\n (click)=\"selectHour(h)\">\n {{ formatNum(h) }}\n </div>\n <div class=\"zen-tp__scroll-spacer\"></div>\n </div>\n <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n <div class=\"zen-tp__highlight\"></div>\n </div>\n\n <span class=\"zen-tp__separator\">{{ hourSeparator }}</span>\n\n <!-- Minutes -->\n <div class=\"zen-tp__scroll-group\">\n <div class=\"zen-tp__scroll-col\"\n #scrollCol\n (scroll)=\"onScroll($event, 'minutes')\"\n (mousedown)=\"onMouseDown($event, scrollCol)\"\n (mousemove)=\"onMouseMove($event, scrollCol)\"\n (mouseup)=\"onMouseUp()\"\n (mouseleave)=\"onMouseUp()\">\n <div class=\"zen-tp__scroll-spacer\"></div>\n <div *ngFor=\"let m of minutes\"\n class=\"zen-tp__scroll-item\"\n [class.zen-tp__scroll-item--selected]=\"m === selectedMinutes\"\n (click)=\"selectMinute(m)\">\n {{ formatNum(m) }}\n </div>\n <div class=\"zen-tp__scroll-spacer\"></div>\n </div>\n <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n <div class=\"zen-tp__highlight\"></div>\n </div>\n\n <span class=\"zen-tp__separator\" *ngIf=\"showSeconds && mode === 'clock'\">:</span>\n <span class=\"zen-tp__separator zen-tp__separator--unit\" *ngIf=\"mode === 'duration'\">min</span>\n\n <!-- Seconds -->\n <div class=\"zen-tp__scroll-group\" *ngIf=\"showSeconds\">\n <div class=\"zen-tp__scroll-col\"\n #scrollCol\n (scroll)=\"onScroll($event, 'seconds')\"\n (mousedown)=\"onMouseDown($event, scrollCol)\"\n (mousemove)=\"onMouseMove($event, scrollCol)\"\n (mouseup)=\"onMouseUp()\"\n (mouseleave)=\"onMouseUp()\">\n <div class=\"zen-tp__scroll-spacer\"></div>\n <div *ngFor=\"let s of seconds\"\n class=\"zen-tp__scroll-item\"\n [class.zen-tp__scroll-item--selected]=\"s === selectedSeconds\"\n (click)=\"selectSecond(s)\">\n {{ formatNum(s) }}\n </div>\n <div class=\"zen-tp__scroll-spacer\"></div>\n </div>\n <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n <div class=\"zen-tp__highlight\"></div>\n </div>\n\n <span class=\"zen-tp__separator zen-tp__separator--unit\"\n *ngIf=\"mode === 'duration' && showSeconds\">\n sec\n </span>\n\n <!-- AM/PM Toggle (Clock mode only) -->\n <div class=\"zen-tp__period\" *ngIf=\"mode === 'clock'\">\n <button class=\"zen-tp__period-btn\"\n [class.zen-tp__period-btn--active]=\"selectedPeriod === 'AM'\"\n (click)=\"selectPeriod('AM')\">\n AM\n </button>\n <button class=\"zen-tp__period-btn\"\n [class.zen-tp__period-btn--active]=\"selectedPeriod === 'PM'\"\n (click)=\"selectPeriod('PM')\">\n PM\n </button>\n </div>\n </div>\n\n <!-- Divider -->\n <div class=\"zen-tp__divider\"></div>\n\n <!-- Actions -->\n <div class=\"zen-tp__actions\" [class.zen-tp__actions--full]=\"mode === 'duration'\">\n <button class=\"zen-tp__btn zen-tp__btn--clear\" (click)=\"onClear()\">Clear</button>\n <button class=\"zen-tp__btn zen-tp__btn--apply\" (click)=\"onApply()\">Apply</button>\n </div>\n </div>\n </div>\n</div>\n", styles: [":host{display:inline-block;position:relative;width:100%}.zen-tp{width:100%;position:relative}.zen-tp *{box-sizing:border-box}.zen-tp__toggle{display:inline-flex;align-items:center;gap:8px;min-width:150px;transition:.3s;background:var(--color-white-primary, #ffffff);-webkit-appearance:none;appearance:none;outline:none;cursor:pointer;border:none;border-radius:0;border-bottom:1px solid var(--color-white-tint-4, #d6d6d8);padding:0 0 8px;font-size:16px;font-weight:400;line-height:130%;color:var(--color-grey-primary, #4f4f4f)}.zen-tp__toggle--box{border:1px solid #d0d5dd;border-radius:8px;padding:10px 14px;gap:8px}.zen-tp__toggle:hover{border-color:#667085}.zen-tp__toggle:focus,.zen-tp__toggle--active{border-color:#136ab6;box-shadow:0 0 0 3px #136ab61f}.zen-tp__toggle--disabled{cursor:not-allowed;border-color:var(--color-white-tint-3, #e0e0e0)}.zen-tp__toggle--disabled .zen-tp__display{color:var(--color-white-tint-3, #e0e0e0)!important}.zen-tp__toggle--disabled .zen-tp__icon{background-color:var(--color-white-tint-3, #e0e0e0)!important}.zen-tp__toggle--readonly{cursor:default;border-color:var(--color-white-tint-3, #e0e0e0)}.zen-tp__toggle--readonly .zen-tp__display{color:var(--color-white-tint-3, #e0e0e0)!important}.zen-tp__toggle--readonly .zen-tp__icon{background-color:var(--color-white-tint-3, #e0e0e0)!important}.zen-tp__display{flex:1;text-align:left;font-size:16px;font-weight:400;line-height:24px;color:#1d2939}.zen-tp__display--placeholder{color:#667085}.zen-tp__icon{width:20px;height:20px;flex-shrink:0;background-color:#667085;transition:.2s}.zen-tp__icon--filled{background-color:#344054}.zen-tp__dropdown{position:absolute;top:100%;left:0;z-index:1000;margin-top:4px}.zen-tp__dropdown--right{left:auto;right:0}.zen-tp__dropdown--bottom{top:auto;bottom:100%;margin-top:0;margin-bottom:4px}.zen-tp__popup{background:#ffffff;border-radius:8px;box-shadow:0 8px 8px -4px #10182808,0 20px 24px -4px #10182814;padding:16px;display:flex;flex-direction:column;gap:16px;align-items:flex-end;font-family:inherit}.zen-tp__popup-label{width:100%;font-size:14px;font-weight:500;line-height:20px;color:#1d2939}.zen-tp__columns{display:flex;align-items:center;gap:24px}.zen-tp__scroll-group{position:relative;width:38px;height:126px;overflow:hidden}.zen-tp__scroll-col{width:100%;height:100%;overflow-y:auto;scroll-snap-type:y mandatory;-ms-overflow-style:none;scrollbar-width:none;cursor:grab;-webkit-user-select:none;user-select:none}.zen-tp__scroll-col::-webkit-scrollbar{display:none}.zen-tp__scroll-col:active{cursor:grabbing}.zen-tp__scroll-spacer{height:42px;flex-shrink:0}.zen-tp__scroll-item{height:42px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:500;line-height:24px;color:#1d2939;scroll-snap-align:center;cursor:pointer;transition:opacity .15s ease;opacity:.4;position:relative;z-index:1}.zen-tp__scroll-item--selected{opacity:1}.zen-tp__highlight{position:absolute;top:50%;left:0;right:0;height:42px;transform:translateY(-50%);background:#f2f4f7;border-radius:8px;pointer-events:none;z-index:0}.zen-tp__fade{position:absolute;left:0;right:0;height:44px;pointer-events:none;z-index:2}.zen-tp__fade--top{top:0;background:linear-gradient(to bottom,#ffffff,rgba(255,255,255,0))}.zen-tp__fade--bottom{bottom:0;background:linear-gradient(to top,#ffffff,rgba(255,255,255,0))}.zen-tp__separator{font-size:14px;font-weight:500;line-height:20px;color:#667085;flex-shrink:0;-webkit-user-select:none;user-select:none}.zen-tp__period{display:flex;flex-direction:column;gap:16px;flex-shrink:0}.zen-tp__period-btn{display:flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;line-height:20px;cursor:pointer;transition:all .15s ease;white-space:nowrap;border:1px solid #d0d5dd;background:#ffffff;color:#344054;box-shadow:0 1px 2px #1018280d}.zen-tp__period-btn:hover{background:#fafafa}.zen-tp__period-btn--active{background:#f1f7fe;border-color:#f1f7fe;color:#105494}.zen-tp__period-btn--active:hover{background:#e7f2fd}.zen-tp__divider{width:100%;height:1px;background:#eaecf0}.zen-tp__actions{display:flex;gap:12px}.zen-tp__actions--full{width:100%}.zen-tp__actions--full .zen-tp__btn{flex:1}.zen-tp__btn{display:flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;line-height:20px;cursor:pointer;transition:all .15s ease;white-space:nowrap;box-shadow:0 1px 2px #1018280d}.zen-tp__btn--clear{background:#ffffff;border:1px solid #d0d5dd;color:#344054}.zen-tp__btn--clear:hover{background:#fafafa}.zen-tp__btn--apply{background:#136ab6;border:1px solid #136ab6;color:#fff}.zen-tp__btn--apply:hover{background:#115d9f}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ZenduIconComponent, selector: "zen-icon", inputs: ["src"] }] });
215
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ZenduTimepickerComponent, decorators: [{
216
+ type: Component,
217
+ args: [{ selector: 'zen-timepicker', template: "<div class=\"zen-tp\">\n <!-- Input toggle button -->\n <button class=\"zen-tp__toggle zen-tp__toggle--box\"\n [class.zen-tp__toggle--active]=\"isPickerVisible\"\n [class.zen-tp__toggle--disabled]=\"disabled\"\n [class.zen-tp__toggle--readonly]=\"readonly\"\n [style.width]=\"width || null\"\n [disabled]=\"disabled || readonly\"\n (click)=\"togglePicker()\">\n <span class=\"zen-tp__display\" [class.zen-tp__display--placeholder]=\"!value\">\n {{ value ? formattedDisplayValue : defaultPlaceholder }}\n </span>\n <zen-icon class=\"zen-tp__icon\"\n [class.zen-tp__icon--filled]=\"value\"\n src=\"assets/ng-zenduit/icons/time.svg\">\n </zen-icon>\n </button>\n\n <!-- Picker dropdown -->\n <div class=\"zen-tp__dropdown\"\n #pickerPopup\n *ngIf=\"isPickerVisible\"\n [class.zen-tp__dropdown--right]=\"right\"\n [class.zen-tp__dropdown--bottom]=\"bottom\">\n <div class=\"zen-tp__popup\">\n <!-- Header -->\n <div class=\"zen-tp__popup-label\">{{ label || defaultLabel }}</div>\n\n <!-- Scroll Columns -->\n <div class=\"zen-tp__columns\">\n <!-- Hours -->\n <div class=\"zen-tp__scroll-group\">\n <div class=\"zen-tp__scroll-col\"\n #scrollCol\n (scroll)=\"onScroll($event, 'hours')\"\n (mousedown)=\"onMouseDown($event, scrollCol)\"\n (mousemove)=\"onMouseMove($event, scrollCol)\"\n (mouseup)=\"onMouseUp()\"\n (mouseleave)=\"onMouseUp()\">\n <div class=\"zen-tp__scroll-spacer\"></div>\n <div *ngFor=\"let h of hours\"\n class=\"zen-tp__scroll-item\"\n [class.zen-tp__scroll-item--selected]=\"h === selectedHours\"\n (click)=\"selectHour(h)\">\n {{ formatNum(h) }}\n </div>\n <div class=\"zen-tp__scroll-spacer\"></div>\n </div>\n <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n <div class=\"zen-tp__highlight\"></div>\n </div>\n\n <span class=\"zen-tp__separator\">{{ hourSeparator }}</span>\n\n <!-- Minutes -->\n <div class=\"zen-tp__scroll-group\">\n <div class=\"zen-tp__scroll-col\"\n #scrollCol\n (scroll)=\"onScroll($event, 'minutes')\"\n (mousedown)=\"onMouseDown($event, scrollCol)\"\n (mousemove)=\"onMouseMove($event, scrollCol)\"\n (mouseup)=\"onMouseUp()\"\n (mouseleave)=\"onMouseUp()\">\n <div class=\"zen-tp__scroll-spacer\"></div>\n <div *ngFor=\"let m of minutes\"\n class=\"zen-tp__scroll-item\"\n [class.zen-tp__scroll-item--selected]=\"m === selectedMinutes\"\n (click)=\"selectMinute(m)\">\n {{ formatNum(m) }}\n </div>\n <div class=\"zen-tp__scroll-spacer\"></div>\n </div>\n <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n <div class=\"zen-tp__highlight\"></div>\n </div>\n\n <span class=\"zen-tp__separator\" *ngIf=\"showSeconds && mode === 'clock'\">:</span>\n <span class=\"zen-tp__separator zen-tp__separator--unit\" *ngIf=\"mode === 'duration'\">min</span>\n\n <!-- Seconds -->\n <div class=\"zen-tp__scroll-group\" *ngIf=\"showSeconds\">\n <div class=\"zen-tp__scroll-col\"\n #scrollCol\n (scroll)=\"onScroll($event, 'seconds')\"\n (mousedown)=\"onMouseDown($event, scrollCol)\"\n (mousemove)=\"onMouseMove($event, scrollCol)\"\n (mouseup)=\"onMouseUp()\"\n (mouseleave)=\"onMouseUp()\">\n <div class=\"zen-tp__scroll-spacer\"></div>\n <div *ngFor=\"let s of seconds\"\n class=\"zen-tp__scroll-item\"\n [class.zen-tp__scroll-item--selected]=\"s === selectedSeconds\"\n (click)=\"selectSecond(s)\">\n {{ formatNum(s) }}\n </div>\n <div class=\"zen-tp__scroll-spacer\"></div>\n </div>\n <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n <div class=\"zen-tp__highlight\"></div>\n </div>\n\n <span class=\"zen-tp__separator zen-tp__separator--unit\"\n *ngIf=\"mode === 'duration' && showSeconds\">\n sec\n </span>\n\n <!-- AM/PM Toggle (Clock mode only) -->\n <div class=\"zen-tp__period\" *ngIf=\"mode === 'clock'\">\n <button class=\"zen-tp__period-btn\"\n [class.zen-tp__period-btn--active]=\"selectedPeriod === 'AM'\"\n (click)=\"selectPeriod('AM')\">\n AM\n </button>\n <button class=\"zen-tp__period-btn\"\n [class.zen-tp__period-btn--active]=\"selectedPeriod === 'PM'\"\n (click)=\"selectPeriod('PM')\">\n PM\n </button>\n </div>\n </div>\n\n <!-- Divider -->\n <div class=\"zen-tp__divider\"></div>\n\n <!-- Actions -->\n <div class=\"zen-tp__actions\" [class.zen-tp__actions--full]=\"mode === 'duration'\">\n <button class=\"zen-tp__btn zen-tp__btn--clear\" (click)=\"onClear()\">Clear</button>\n <button class=\"zen-tp__btn zen-tp__btn--apply\" (click)=\"onApply()\">Apply</button>\n </div>\n </div>\n </div>\n</div>\n", styles: [":host{display:inline-block;position:relative;width:100%}.zen-tp{width:100%;position:relative}.zen-tp *{box-sizing:border-box}.zen-tp__toggle{display:inline-flex;align-items:center;gap:8px;min-width:150px;transition:.3s;background:var(--color-white-primary, #ffffff);-webkit-appearance:none;appearance:none;outline:none;cursor:pointer;border:none;border-radius:0;border-bottom:1px solid var(--color-white-tint-4, #d6d6d8);padding:0 0 8px;font-size:16px;font-weight:400;line-height:130%;color:var(--color-grey-primary, #4f4f4f)}.zen-tp__toggle--box{border:1px solid #d0d5dd;border-radius:8px;padding:10px 14px;gap:8px}.zen-tp__toggle:hover{border-color:#667085}.zen-tp__toggle:focus,.zen-tp__toggle--active{border-color:#136ab6;box-shadow:0 0 0 3px #136ab61f}.zen-tp__toggle--disabled{cursor:not-allowed;border-color:var(--color-white-tint-3, #e0e0e0)}.zen-tp__toggle--disabled .zen-tp__display{color:var(--color-white-tint-3, #e0e0e0)!important}.zen-tp__toggle--disabled .zen-tp__icon{background-color:var(--color-white-tint-3, #e0e0e0)!important}.zen-tp__toggle--readonly{cursor:default;border-color:var(--color-white-tint-3, #e0e0e0)}.zen-tp__toggle--readonly .zen-tp__display{color:var(--color-white-tint-3, #e0e0e0)!important}.zen-tp__toggle--readonly .zen-tp__icon{background-color:var(--color-white-tint-3, #e0e0e0)!important}.zen-tp__display{flex:1;text-align:left;font-size:16px;font-weight:400;line-height:24px;color:#1d2939}.zen-tp__display--placeholder{color:#667085}.zen-tp__icon{width:20px;height:20px;flex-shrink:0;background-color:#667085;transition:.2s}.zen-tp__icon--filled{background-color:#344054}.zen-tp__dropdown{position:absolute;top:100%;left:0;z-index:1000;margin-top:4px}.zen-tp__dropdown--right{left:auto;right:0}.zen-tp__dropdown--bottom{top:auto;bottom:100%;margin-top:0;margin-bottom:4px}.zen-tp__popup{background:#ffffff;border-radius:8px;box-shadow:0 8px 8px -4px #10182808,0 20px 24px -4px #10182814;padding:16px;display:flex;flex-direction:column;gap:16px;align-items:flex-end;font-family:inherit}.zen-tp__popup-label{width:100%;font-size:14px;font-weight:500;line-height:20px;color:#1d2939}.zen-tp__columns{display:flex;align-items:center;gap:24px}.zen-tp__scroll-group{position:relative;width:38px;height:126px;overflow:hidden}.zen-tp__scroll-col{width:100%;height:100%;overflow-y:auto;scroll-snap-type:y mandatory;-ms-overflow-style:none;scrollbar-width:none;cursor:grab;-webkit-user-select:none;user-select:none}.zen-tp__scroll-col::-webkit-scrollbar{display:none}.zen-tp__scroll-col:active{cursor:grabbing}.zen-tp__scroll-spacer{height:42px;flex-shrink:0}.zen-tp__scroll-item{height:42px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:500;line-height:24px;color:#1d2939;scroll-snap-align:center;cursor:pointer;transition:opacity .15s ease;opacity:.4;position:relative;z-index:1}.zen-tp__scroll-item--selected{opacity:1}.zen-tp__highlight{position:absolute;top:50%;left:0;right:0;height:42px;transform:translateY(-50%);background:#f2f4f7;border-radius:8px;pointer-events:none;z-index:0}.zen-tp__fade{position:absolute;left:0;right:0;height:44px;pointer-events:none;z-index:2}.zen-tp__fade--top{top:0;background:linear-gradient(to bottom,#ffffff,rgba(255,255,255,0))}.zen-tp__fade--bottom{bottom:0;background:linear-gradient(to top,#ffffff,rgba(255,255,255,0))}.zen-tp__separator{font-size:14px;font-weight:500;line-height:20px;color:#667085;flex-shrink:0;-webkit-user-select:none;user-select:none}.zen-tp__period{display:flex;flex-direction:column;gap:16px;flex-shrink:0}.zen-tp__period-btn{display:flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;line-height:20px;cursor:pointer;transition:all .15s ease;white-space:nowrap;border:1px solid #d0d5dd;background:#ffffff;color:#344054;box-shadow:0 1px 2px #1018280d}.zen-tp__period-btn:hover{background:#fafafa}.zen-tp__period-btn--active{background:#f1f7fe;border-color:#f1f7fe;color:#105494}.zen-tp__period-btn--active:hover{background:#e7f2fd}.zen-tp__divider{width:100%;height:1px;background:#eaecf0}.zen-tp__actions{display:flex;gap:12px}.zen-tp__actions--full{width:100%}.zen-tp__actions--full .zen-tp__btn{flex:1}.zen-tp__btn{display:flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;line-height:20px;cursor:pointer;transition:all .15s ease;white-space:nowrap;box-shadow:0 1px 2px #1018280d}.zen-tp__btn--clear{background:#ffffff;border:1px solid #d0d5dd;color:#344054}.zen-tp__btn--clear:hover{background:#fafafa}.zen-tp__btn--apply{background:#136ab6;border:1px solid #136ab6;color:#fff}.zen-tp__btn--apply:hover{background:#115d9f}\n"] }]
218
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { mode: [{
219
+ type: Input
220
+ }], label: [{
221
+ type: Input
222
+ }], value: [{
223
+ type: Input
224
+ }], showSeconds: [{
225
+ type: Input
226
+ }], disabled: [{
227
+ type: Input
228
+ }], readonly: [{
229
+ type: Input
230
+ }], placeholder: [{
231
+ type: Input
232
+ }], width: [{
233
+ type: Input
234
+ }], valueChange: [{
235
+ type: Output
236
+ }], apply: [{
237
+ type: Output
238
+ }], clear: [{
239
+ type: Output
240
+ }], pickerPopup: [{
241
+ type: ViewChild,
242
+ args: ['pickerPopup']
243
+ }], outsideClick: [{
244
+ type: HostListener,
245
+ args: ['window:mousedown', ['$event']]
246
+ }] } });
247
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-timepicker.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/timepicker/zendu-timepicker.component.ts","../../../../../projects/ng-zenduit/src/lib/timepicker/zendu-timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\n\nexport type TimePickerMode = 'clock' | 'duration';\n\nexport interface TimePickerValue {\n  hours: number;\n  minutes: number;\n  seconds: number;\n  period?: 'AM' | 'PM';\n}\n\n@Component({\n  selector: 'zen-timepicker',\n  templateUrl: './zendu-timepicker.component.html',\n  styleUrls: ['./zendu-timepicker.component.scss'],\n})\nexport class ZenduTimepickerComponent implements OnInit, OnChanges {\n  @Input() mode: TimePickerMode = 'clock';\n  @Input() label: string;\n  @Input() value: TimePickerValue;\n  @Input() showSeconds: boolean = false;\n  @Input() disabled: boolean = false;\n  @Input() readonly: boolean = false;\n  @Input() placeholder: string;\n  @Input() width: string;\n\n  @Output() valueChange = new EventEmitter<TimePickerValue>();\n  @Output() apply = new EventEmitter<TimePickerValue>();\n  @Output() clear = new EventEmitter<void>();\n\n  @ViewChild('pickerPopup') pickerPopup: ElementRef;\n\n  isPickerVisible = false;\n\n  hours: number[] = [];\n  minutes: number[] = [];\n  seconds: number[] = [];\n\n  selectedHours = 0;\n  selectedMinutes = 0;\n  selectedSeconds = 0;\n  selectedPeriod: 'AM' | 'PM' = 'AM';\n\n  right = false;\n  bottom = false;\n\n  private readonly ITEM_HEIGHT = 42;\n  private isDragging = false;\n  private dragStartY = 0;\n  private dragStartScroll = 0;\n\n  constructor(private _element: ElementRef) {}\n\n  @HostListener('window:mousedown', ['$event'])\n  outsideClick(event: MouseEvent): void {\n    if (!document.body.contains(event.target as Node)) {\n      return;\n    }\n    if (this._element.nativeElement.contains(event.target)) {\n      return;\n    }\n    this.isPickerVisible = false;\n  }\n\n  get defaultLabel(): string {\n    return this.mode === 'clock' ? 'Select a time' : 'Stop Duration';\n  }\n\n  get defaultPlaceholder(): string {\n    if (this.placeholder) return this.placeholder;\n    return this.mode === 'clock' ? 'Select Time' : '0 min';\n  }\n\n  get hourSeparator(): string {\n    return this.mode === 'clock' ? ':' : 'hr';\n  }\n\n  get minuteSeparator(): string {\n    return this.mode === 'clock' ? ':' : 'min';\n  }\n\n  get secondSeparator(): string {\n    return this.mode === 'duration' ? 'sec' : '';\n  }\n\n  get formattedDisplayValue(): string {\n    if (!this.value) return '';\n\n    if (this.mode === 'clock') {\n      const h = this.formatNum(this.value.hours);\n      const m = this.formatNum(this.value.minutes);\n      if (this.showSeconds) {\n        const s = this.formatNum(this.value.seconds);\n        return `${h}.${m}.${s} ${this.value.period || 'AM'}`;\n      }\n      return `${h}.${m} ${this.value.period || 'AM'}`;\n    }\n\n    // Duration mode\n    const parts: string[] = [];\n    if (this.value.hours > 0) {\n      parts.push(`${this.value.hours} hr`);\n    }\n    if (this.value.minutes > 0) {\n      parts.push(`${this.value.minutes} min`);\n    }\n    if (this.showSeconds && this.value.seconds > 0) {\n      parts.push(`${this.value.seconds} sec`);\n    }\n    return parts.length > 0 ? parts.join(' ') : '0 min';\n  }\n\n  ngOnInit(): void {\n    this.buildRanges();\n    if (this.value) {\n      this.applyValue(this.value);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['mode']) {\n      this.buildRanges();\n    }\n    if (changes['value'] && this.value) {\n      this.applyValue(this.value);\n    }\n  }\n\n  togglePicker(): void {\n    if (this.disabled || this.readonly) return;\n    this.isPickerVisible = !this.isPickerVisible;\n    if (this.isPickerVisible) {\n      if (this.value) {\n        this.applyValue(this.value);\n      }\n      this.updatePlacement();\n    }\n  }\n\n  private updatePlacement(): void {\n    this.right = false;\n    this.bottom = false;\n    const el = this._element.nativeElement;\n    const rect = el.getBoundingClientRect();\n    if (rect.left > window.innerWidth / 2) {\n      this.right = true;\n    }\n    if (rect.top > window.innerHeight / 2) {\n      this.bottom = true;\n    }\n  }\n\n  private buildRanges(): void {\n    const maxHour = this.mode === 'clock' ? 12 : 23;\n    const startHour = this.mode === 'clock' ? 1 : 0;\n    this.hours = this.range(startHour, maxHour);\n    this.minutes = this.range(0, 59);\n    this.seconds = this.range(0, 59);\n  }\n\n  private applyValue(val: TimePickerValue): void {\n    this.selectedHours = val.hours;\n    this.selectedMinutes = val.minutes;\n    this.selectedSeconds = val.seconds;\n    if (val.period) {\n      this.selectedPeriod = val.period;\n    }\n  }\n\n  private range(start: number, end: number): number[] {\n    const arr: number[] = [];\n    for (let i = start; i <= end; i++) {\n      arr.push(i);\n    }\n    return arr;\n  }\n\n  formatNum(n: number): string {\n    return n < 10 ? '0' + n : '' + n;\n  }\n\n  selectHour(val: number): void {\n    this.selectedHours = val;\n  }\n\n  selectMinute(val: number): void {\n    this.selectedMinutes = val;\n  }\n\n  selectSecond(val: number): void {\n    this.selectedSeconds = val;\n  }\n\n  selectPeriod(period: 'AM' | 'PM'): void {\n    this.selectedPeriod = period;\n  }\n\n  onScroll(event: Event, type: 'hours' | 'minutes' | 'seconds'): void {\n    const el = event.target as HTMLElement;\n    const scrollTop = el.scrollTop;\n    const index = Math.round(scrollTop / this.ITEM_HEIGHT);\n\n    if (type === 'hours' && index >= 0 && index < this.hours.length) {\n      this.selectedHours = this.hours[index];\n    } else if (type === 'minutes' && index >= 0 && index < this.minutes.length) {\n      this.selectedMinutes = this.minutes[index];\n    } else if (type === 'seconds' && index >= 0 && index < this.seconds.length) {\n      this.selectedSeconds = this.seconds[index];\n    }\n  }\n\n  onMouseDown(event: MouseEvent, scrollEl: HTMLElement): void {\n    this.isDragging = true;\n    this.dragStartY = event.clientY;\n    this.dragStartScroll = scrollEl.scrollTop;\n    event.preventDefault();\n  }\n\n  onMouseMove(event: MouseEvent, scrollEl: HTMLElement): void {\n    if (!this.isDragging) return;\n    const delta = this.dragStartY - event.clientY;\n    scrollEl.scrollTop = this.dragStartScroll + delta;\n  }\n\n  onMouseUp(): void {\n    this.isDragging = false;\n  }\n\n  onApply(): void {\n    const val = this.getCurrentValue();\n    this.value = val;\n    this.valueChange.emit(val);\n    this.apply.emit(val);\n    this.isPickerVisible = false;\n  }\n\n  onClear(): void {\n    this.selectedHours = this.mode === 'clock' ? 12 : 0;\n    this.selectedMinutes = 0;\n    this.selectedSeconds = 0;\n    this.selectedPeriod = 'AM';\n    this.value = null;\n    this.valueChange.emit(null);\n    this.clear.emit();\n    this.isPickerVisible = false;\n  }\n\n  private getCurrentValue(): TimePickerValue {\n    const val: TimePickerValue = {\n      hours: this.selectedHours,\n      minutes: this.selectedMinutes,\n      seconds: this.selectedSeconds,\n    };\n    if (this.mode === 'clock') {\n      val.period = this.selectedPeriod;\n    }\n    return val;\n  }\n}\n","<div class=\"zen-tp\">\n  <!-- Input toggle button -->\n  <button class=\"zen-tp__toggle zen-tp__toggle--box\"\n          [class.zen-tp__toggle--active]=\"isPickerVisible\"\n          [class.zen-tp__toggle--disabled]=\"disabled\"\n          [class.zen-tp__toggle--readonly]=\"readonly\"\n          [style.width]=\"width || null\"\n          [disabled]=\"disabled || readonly\"\n          (click)=\"togglePicker()\">\n    <span class=\"zen-tp__display\" [class.zen-tp__display--placeholder]=\"!value\">\n      {{ value ? formattedDisplayValue : defaultPlaceholder }}\n    </span>\n    <zen-icon class=\"zen-tp__icon\"\n              [class.zen-tp__icon--filled]=\"value\"\n              src=\"assets/ng-zenduit/icons/time.svg\">\n    </zen-icon>\n  </button>\n\n  <!-- Picker dropdown -->\n  <div class=\"zen-tp__dropdown\"\n       #pickerPopup\n       *ngIf=\"isPickerVisible\"\n       [class.zen-tp__dropdown--right]=\"right\"\n       [class.zen-tp__dropdown--bottom]=\"bottom\">\n    <div class=\"zen-tp__popup\">\n      <!-- Header -->\n      <div class=\"zen-tp__popup-label\">{{ label || defaultLabel }}</div>\n\n      <!-- Scroll Columns -->\n      <div class=\"zen-tp__columns\">\n        <!-- Hours -->\n        <div class=\"zen-tp__scroll-group\">\n          <div class=\"zen-tp__scroll-col\"\n               #scrollCol\n               (scroll)=\"onScroll($event, 'hours')\"\n               (mousedown)=\"onMouseDown($event, scrollCol)\"\n               (mousemove)=\"onMouseMove($event, scrollCol)\"\n               (mouseup)=\"onMouseUp()\"\n               (mouseleave)=\"onMouseUp()\">\n            <div class=\"zen-tp__scroll-spacer\"></div>\n            <div *ngFor=\"let h of hours\"\n                 class=\"zen-tp__scroll-item\"\n                 [class.zen-tp__scroll-item--selected]=\"h === selectedHours\"\n                 (click)=\"selectHour(h)\">\n              {{ formatNum(h) }}\n            </div>\n            <div class=\"zen-tp__scroll-spacer\"></div>\n          </div>\n          <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n          <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n          <div class=\"zen-tp__highlight\"></div>\n        </div>\n\n        <span class=\"zen-tp__separator\">{{ hourSeparator }}</span>\n\n        <!-- Minutes -->\n        <div class=\"zen-tp__scroll-group\">\n          <div class=\"zen-tp__scroll-col\"\n               #scrollCol\n               (scroll)=\"onScroll($event, 'minutes')\"\n               (mousedown)=\"onMouseDown($event, scrollCol)\"\n               (mousemove)=\"onMouseMove($event, scrollCol)\"\n               (mouseup)=\"onMouseUp()\"\n               (mouseleave)=\"onMouseUp()\">\n            <div class=\"zen-tp__scroll-spacer\"></div>\n            <div *ngFor=\"let m of minutes\"\n                 class=\"zen-tp__scroll-item\"\n                 [class.zen-tp__scroll-item--selected]=\"m === selectedMinutes\"\n                 (click)=\"selectMinute(m)\">\n              {{ formatNum(m) }}\n            </div>\n            <div class=\"zen-tp__scroll-spacer\"></div>\n          </div>\n          <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n          <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n          <div class=\"zen-tp__highlight\"></div>\n        </div>\n\n        <span class=\"zen-tp__separator\" *ngIf=\"showSeconds && mode === 'clock'\">:</span>\n        <span class=\"zen-tp__separator zen-tp__separator--unit\" *ngIf=\"mode === 'duration'\">min</span>\n\n        <!-- Seconds -->\n        <div class=\"zen-tp__scroll-group\" *ngIf=\"showSeconds\">\n          <div class=\"zen-tp__scroll-col\"\n               #scrollCol\n               (scroll)=\"onScroll($event, 'seconds')\"\n               (mousedown)=\"onMouseDown($event, scrollCol)\"\n               (mousemove)=\"onMouseMove($event, scrollCol)\"\n               (mouseup)=\"onMouseUp()\"\n               (mouseleave)=\"onMouseUp()\">\n            <div class=\"zen-tp__scroll-spacer\"></div>\n            <div *ngFor=\"let s of seconds\"\n                 class=\"zen-tp__scroll-item\"\n                 [class.zen-tp__scroll-item--selected]=\"s === selectedSeconds\"\n                 (click)=\"selectSecond(s)\">\n              {{ formatNum(s) }}\n            </div>\n            <div class=\"zen-tp__scroll-spacer\"></div>\n          </div>\n          <div class=\"zen-tp__fade zen-tp__fade--top\"></div>\n          <div class=\"zen-tp__fade zen-tp__fade--bottom\"></div>\n          <div class=\"zen-tp__highlight\"></div>\n        </div>\n\n        <span class=\"zen-tp__separator zen-tp__separator--unit\"\n              *ngIf=\"mode === 'duration' && showSeconds\">\n          sec\n        </span>\n\n        <!-- AM/PM Toggle (Clock mode only) -->\n        <div class=\"zen-tp__period\" *ngIf=\"mode === 'clock'\">\n          <button class=\"zen-tp__period-btn\"\n                  [class.zen-tp__period-btn--active]=\"selectedPeriod === 'AM'\"\n                  (click)=\"selectPeriod('AM')\">\n            AM\n          </button>\n          <button class=\"zen-tp__period-btn\"\n                  [class.zen-tp__period-btn--active]=\"selectedPeriod === 'PM'\"\n                  (click)=\"selectPeriod('PM')\">\n            PM\n          </button>\n        </div>\n      </div>\n\n      <!-- Divider -->\n      <div class=\"zen-tp__divider\"></div>\n\n      <!-- Actions -->\n      <div class=\"zen-tp__actions\" [class.zen-tp__actions--full]=\"mode === 'duration'\">\n        <button class=\"zen-tp__btn zen-tp__btn--clear\" (click)=\"onClear()\">Clear</button>\n        <button class=\"zen-tp__btn zen-tp__btn--apply\" (click)=\"onApply()\">Apply</button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -44,4 +44,5 @@ export * from "./lib/file-upload/zendu-file-upload.component";
44
44
  export * from "./lib/progress/zendu-progress.component";
45
45
  export * from "./lib/location-search/zendu-location-search.component";
46
46
  export * from "./lib/live-view-player/live-view-player/live-view-player.component";
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLXplbmR1aXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUJBQXlCLENBQUM7QUFFeEM7O0dBRUc7QUFDSCxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLG1DQUFtQyxDQUFDO0FBRWxEOztHQUVHO0FBQ0gsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsaUVBQWlFLENBQUM7QUFDaEYsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyxvRUFBb0UsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIG9mIG5nLXplbmR1aXRcbiAqL1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NlcnZpY2VzL3plbmR1LW5vdGlmeS5zZXJ2aWNlXCI7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9uZy16ZW5kdWl0Lm1vZHVsZSc7XG5cbi8qKlxuICogVHlwZXNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmlsdGVyL2ZpbHRlcnNDb25maWcnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmlsdGVyL251bWJlclJhbmdlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbi1jb25maWd1cmF0aW9uL2NvbHVtblN0YXRlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21hcC9tYXAudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbG9jYXRpb24tc2VhcmNoL2xvY2F0aW9uLmFkZHJlc3MnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0ZXBpY2tlci9kYXRlcGlja2VyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGVwaWNrZXIvZGF0ZS1waWNrZXItaGludCc7XG5cbi8qKlxuICogQ29tcG9uZW50c1xuICovXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY2hlY2tib3gvemVuZHUtY2hlY2tib3guY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29sb3JwaWNrZXIvemVuZHUtY29sb3JwaWNrZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvY29sdW1uLWNvbmZpZ3VyYXRpb24vemVuZHUtY29sdW1uLWNvbmZpZ3VyYXRpb24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZGF0ZXBpY2tlci96ZW5kdS1kYXRlcGlja2VyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2ZpbHRlci96ZW5kdS1maWx0ZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZ3JvdXBzL3plbmR1LWdyb3Vwcy5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9wYWdpbmF0aW9uLWJhci96ZW5kdS1wYWdpbmF0aW9uLWJhci5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9waG9uZS1pbnB1dC96ZW5kdS1waG9uZS1pbnB1dC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9yYWRpby1idXR0b24vcmFkaW8tYnV0dG9uLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NlYXJjaC1ib3gvemVuZHUtc2VhcmNoLWJveC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9zZWxlY3QvemVuZHUtc2VsZWN0LmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NlbGVjdC90ZW1wbGF0ZXMvemVuZHUtc2VsZWN0LXZhbHVlLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NlbGVjdC90ZW1wbGF0ZXMvemVuZHUtc2VsZWN0LW9wdGlvbi5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9zZWxlY3QvdGVtcGxhdGVzL3plbmR1LXNlbGVjdC1idXR0b24uZGlyZWN0aXZlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc29ydC1oZWFkZXIvemVuZHUtc29ydC1oZWFkZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvdG9nZ2xlL3plbmR1LXRvZ2dsZS5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi90b2dnbGUtc2xpZGUvemVuZHUtdG9nZ2xlLXNsaWRlLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2ljb24vemVuZHUtaWNvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jYXJkLWJsb2NrL3plbmR1LWNhcmQtYmxvY2suY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvbWFwLXByZXZpZXcvemVuZHUtbWFwLXByZXZpZXcuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc3Bpbm5lci96ZW5kdS1zcGlubmVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2RvYy1zY2FubmVyL3plbmR1LWRvYy1zY2FubmVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2JyZWFkY3J1bWJzL3plbmR1LWJyZWFkY3J1bWJzLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL21hcC96ZW5kdS1tYXAuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZmlsZS11cGxvYWQvemVuZHUtZmlsZS11cGxvYWQuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvcHJvZ3Jlc3MvemVuZHUtcHJvZ3Jlc3MuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvbG9jYXRpb24tc2VhcmNoL3plbmR1LWxvY2F0aW9uLXNlYXJjaC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9saXZlLXZpZXctcGxheWVyL2xpdmUtdmlldy1wbGF5ZXIvbGl2ZS12aWV3LXBsYXllci5jb21wb25lbnRcIjtcbiJdfQ==
47
+ export * from "./lib/timepicker/zendu-timepicker.component";
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLXplbmR1aXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUJBQXlCLENBQUM7QUFFeEM7O0dBRUc7QUFDSCxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLG1DQUFtQyxDQUFDO0FBRWxEOztHQUVHO0FBQ0gsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsaUVBQWlFLENBQUM7QUFDaEYsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgb2YgbmctemVuZHVpdFxuICovXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2VydmljZXMvemVuZHUtbm90aWZ5LnNlcnZpY2VcIjtcbmV4cG9ydCAqIGZyb20gJy4vbGliL25nLXplbmR1aXQubW9kdWxlJztcblxuLyoqXG4gKiBUeXBlc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWx0ZXIvZmlsdGVyc0NvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWx0ZXIvbnVtYmVyUmFuZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1uLWNvbmZpZ3VyYXRpb24vY29sdW1uU3RhdGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWFwL21hcC50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2NhdGlvbi1zZWFyY2gvbG9jYXRpb24uYWRkcmVzcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlcGlja2VyL2RhdGVwaWNrZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0ZXBpY2tlci9kYXRlLXBpY2tlci1oaW50JztcblxuLyoqXG4gKiBDb21wb25lbnRzXG4gKi9cbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jaGVja2JveC96ZW5kdS1jaGVja2JveC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb2xvcnBpY2tlci96ZW5kdS1jb2xvcnBpY2tlci5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9jb2x1bW4tY29uZmlndXJhdGlvbi96ZW5kdS1jb2x1bW4tY29uZmlndXJhdGlvbi5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9kYXRlcGlja2VyL3plbmR1LWRhdGVwaWNrZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZmlsdGVyL3plbmR1LWZpbHRlci5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9ncm91cHMvemVuZHUtZ3JvdXBzLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3BhZ2luYXRpb24tYmFyL3plbmR1LXBhZ2luYXRpb24tYmFyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3Bob25lLWlucHV0L3plbmR1LXBob25lLWlucHV0LmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2VhcmNoLWJveC96ZW5kdS1zZWFyY2gtYm94LmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NlbGVjdC96ZW5kdS1zZWxlY3QuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2VsZWN0L3RlbXBsYXRlcy96ZW5kdS1zZWxlY3QtdmFsdWUuZGlyZWN0aXZlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvc2VsZWN0L3RlbXBsYXRlcy96ZW5kdS1zZWxlY3Qtb3B0aW9uLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3NlbGVjdC90ZW1wbGF0ZXMvemVuZHUtc2VsZWN0LWJ1dHRvbi5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9zb3J0LWhlYWRlci96ZW5kdS1zb3J0LWhlYWRlci5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi90b2dnbGUvemVuZHUtdG9nZ2xlLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3RvZ2dsZS1zbGlkZS96ZW5kdS10b2dnbGUtc2xpZGUuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvaWNvbi96ZW5kdS1pY29uLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2NhcmQtYmxvY2svemVuZHUtY2FyZC1ibG9jay5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9tYXAtcHJldmlldy96ZW5kdS1tYXAtcHJldmlldy5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9zcGlubmVyL3plbmR1LXNwaW5uZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvZG9jLXNjYW5uZXIvemVuZHUtZG9jLXNjYW5uZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvYnJlYWRjcnVtYnMvemVuZHUtYnJlYWRjcnVtYnMuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvbWFwL3plbmR1LW1hcC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9maWxlLXVwbG9hZC96ZW5kdS1maWxlLXVwbG9hZC5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9wcm9ncmVzcy96ZW5kdS1wcm9ncmVzcy5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9sb2NhdGlvbi1zZWFyY2gvemVuZHUtbG9jYXRpb24tc2VhcmNoLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2xpdmUtdmlldy1wbGF5ZXIvbGl2ZS12aWV3LXBsYXllci9saXZlLXZpZXctcGxheWVyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL3RpbWVwaWNrZXIvemVuZHUtdGltZXBpY2tlci5jb21wb25lbnRcIjtcbiJdfQ==