@c8y/ngx-components 1021.73.3 → 1021.73.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/branding/shared/data/store-branding.service.d.ts.map +1 -1
  2. package/branding/shared/lazy/branding/branding.component.d.ts.map +1 -1
  3. package/core/beta-feature/beta-preview.service.d.ts +1 -1
  4. package/core/beta-feature/beta-preview.service.d.ts.map +1 -1
  5. package/core/date-time-picker/date-time-picker.component.d.ts +4 -1
  6. package/core/date-time-picker/date-time-picker.component.d.ts.map +1 -1
  7. package/esm2022/branding/shared/data/store-branding.service.mjs +13 -4
  8. package/esm2022/branding/shared/lazy/branding/branding.component.mjs +4 -5
  9. package/esm2022/core/beta-feature/beta-preview.service.mjs +10 -6
  10. package/esm2022/core/date-time-picker/date-time-picker.component.mjs +27 -14
  11. package/esm2022/datapoint-explorer/view/datapoint-explorer.component.mjs +3 -3
  12. package/esm2022/datapoint-selector/datapoint-selector.component.mjs +3 -3
  13. package/esm2022/ecosystem/packages/package-versions/packages-versions.component.mjs +3 -3
  14. package/esm2022/widgets/implementations/datapoints-graph/datapoints-graph-config/datapoints-graph-widget-config.component.mjs +3 -3
  15. package/esm2022/widgets/implementations/datapoints-graph/datapoints-graph-view/datapoints-graph-widget-view.component.mjs +3 -3
  16. package/fesm2022/c8y-ngx-components-branding-shared-data.mjs +12 -3
  17. package/fesm2022/c8y-ngx-components-branding-shared-data.mjs.map +1 -1
  18. package/fesm2022/c8y-ngx-components-branding-shared-lazy.mjs +3 -4
  19. package/fesm2022/c8y-ngx-components-branding-shared-lazy.mjs.map +1 -1
  20. package/fesm2022/c8y-ngx-components-datapoint-explorer-view.mjs +2 -2
  21. package/fesm2022/c8y-ngx-components-datapoint-explorer-view.mjs.map +1 -1
  22. package/fesm2022/c8y-ngx-components-datapoint-selector.mjs +2 -2
  23. package/fesm2022/c8y-ngx-components-datapoint-selector.mjs.map +1 -1
  24. package/fesm2022/c8y-ngx-components-ecosystem.mjs +2 -2
  25. package/fesm2022/c8y-ngx-components-ecosystem.mjs.map +1 -1
  26. package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-graph.mjs +4 -4
  27. package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-graph.mjs.map +1 -1
  28. package/fesm2022/c8y-ngx-components.mjs +35 -18
  29. package/fesm2022/c8y-ngx-components.mjs.map +1 -1
  30. package/locales/de.po +314 -41
  31. package/locales/es.po +315 -42
  32. package/locales/fr.po +315 -42
  33. package/locales/ja_JP.po +308 -47
  34. package/locales/ko.po +314 -42
  35. package/locales/locales.pot +5 -27
  36. package/locales/nl.po +312 -40
  37. package/locales/pl.po +315 -42
  38. package/locales/pt_BR.po +312 -39
  39. package/locales/zh_CN.po +312 -40
  40. package/locales/zh_TW.po +313 -42
  41. package/package.json +1 -1
@@ -80,14 +80,18 @@ export class PreviewService extends ExtensionPointForPlugins {
80
80
  this.reload$.next(this.toggledFeaturesWithReload.size > 0);
81
81
  }
82
82
  /**
83
- * Marks all features as seen by the user and updates the local storage.
83
+ * Marks all unseen features as seen by the user and updates the local storage.
84
84
  * This assumes all features are provided via the `items$` observable.
85
85
  */
86
86
  async markAllFeaturesAsSeen() {
87
- const features = await firstValueFrom(this.items$);
88
- const featureNames = features.map(feature => feature.label);
89
- localStorage.setItem(this.LOCAL_STORAGE_KEY, JSON.stringify(featureNames));
90
- this.seenFeatures$.next(featureNames);
87
+ const features = await firstValueFrom(this.getAvailableFeatures$());
88
+ const newFeatureNames = features.map(feature => feature.label);
89
+ const storedFeatures = localStorage.getItem(this.LOCAL_STORAGE_KEY);
90
+ const existingFeatureNames = storedFeatures ? JSON.parse(storedFeatures) : [];
91
+ // Update the local storage with unique feature names and remove duplicates
92
+ const updatedFeatureNames = Array.from(new Set([...existingFeatureNames, ...newFeatureNames]));
93
+ localStorage.setItem(this.LOCAL_STORAGE_KEY, JSON.stringify(updatedFeatureNames));
94
+ this.seenFeatures$.next(updatedFeatureNames);
91
95
  }
92
96
  /**
93
97
  * Filters the features to only include those that are available by checking the feature toggle API.
@@ -123,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
123
127
  type: Injectable,
124
128
  args: [{ providedIn: 'root' }]
125
129
  }], ctorParameters: () => [{ type: i0.Injector }, { type: i1.PluginsResolveService }] });
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"beta-preview.service.js","sourceRoot":"","sources":["../../../../core/beta-feature/beta-preview.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, InjectionToken, Injector } from '@angular/core';\nimport { BehaviorSubject, combineLatest, firstValueFrom, Observable, of } from 'rxjs';\nimport { distinctUntilChanged, map, shareReplay, switchMap } from 'rxjs/operators';\nimport {\n  GenericHookOptions,\n  GenericHookType,\n  hookGeneric,\n  getInjectedHooks,\n  ExtensionPointForPlugins,\n  fromTriggerOnce,\n  stateToFactory,\n  sortByPriority\n} from '../common/extension-hooks';\nimport { BetaFeature } from './beta-preview.model';\nimport { PluginsResolveService } from '../plugins/plugins-resolve.service';\nimport { FeatureService } from '@c8y/client';\nimport { FeatureCacheService } from './feature-cache.service';\nimport { OptionsService } from '../common/options.service';\n\nexport const HOOK_PREVIEW = new InjectionToken<BetaFeature[]>('HOOK_PREVIEW');\n\nexport function hookPreview(\n  preview: GenericHookType<BetaFeature>,\n  options?: Partial<GenericHookOptions>\n) {\n  return hookGeneric<BetaFeature>(preview, HOOK_PREVIEW, options);\n}\n\n@Injectable({ providedIn: 'root' })\nexport class PreviewService extends ExtensionPointForPlugins<BetaFeature> {\n  items$: Observable<BetaFeature[]> = this.setupItemsObservable();\n  reload$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n  private readonly LOCAL_STORAGE_KEY = 'c8y_beta_features_seen';\n  private seenFeatures$ = new BehaviorSubject<string[]>(this.getSeenFeatures());\n  hasUnseenFeatures$ = combineLatest([this.getAvailableFeatures$(), this.seenFeatures$]).pipe(\n    map(([features, seen]) => features.some(feature => !seen.includes(feature.label))),\n    distinctUntilChanged()\n  );\n  private readonly featureService = inject(FeatureService);\n  private readonly featureCacheService = inject(FeatureCacheService);\n  private readonly optionsService = inject(OptionsService);\n\n  private toggledFeaturesWithReload: Set<string> = new Set(); // track features with settings.reload = true\n\n  constructor(rootInjector: Injector, pluginService: PluginsResolveService) {\n    super(rootInjector, pluginService);\n  }\n\n  get state(): Set<BetaFeature> {\n    return this.state$.value;\n  }\n\n  /**\n   * Get the state of a specific feature.\n   * @param key The unique key for the feature.\n   * @returns Observable<boolean> representing the state of the feature.\n   */\n  getState$(key: string): Observable<boolean> {\n    return this.items$.pipe(\n      switchMap(features =>\n        this.optionsService.get$('enableAllBetaFeatures').pipe(\n          switchMap(enableAllBetaFeatures => {\n            if (enableAllBetaFeatures) {\n              return of(true);\n            }\n            const feature = features.find(f => f.key === key);\n            if (!feature) {\n              throw new Error(`Feature with key \"${key}\" does not exist.`);\n            }\n            if (feature.active$) {\n              return feature.active$;\n            }\n            return this.featureCacheService.getFeatureState(key).pipe(distinctUntilChanged());\n          })\n        )\n      ),\n      distinctUntilChanged()\n    );\n  }\n\n  /**\n   * Toggle the state of a specific feature.\n   * @param key The unique key or label for the feature. Label is used to find the custom features.\n   * @returns Promise<void> after toggling the state.\n   */\n  async setFeatureActiveState(key: string, toggleValue: boolean): Promise<void> {\n    const features = await firstValueFrom(this.items$);\n    const feature = features.find(f => f.key === key) || features.find(f => f.label === key);\n\n    if (!feature) {\n      throw new Error(`Feature with key \"${key}\" does not exist.`);\n    }\n\n    if (feature.onToggle) {\n      const success = await feature.onToggle(toggleValue);\n      if (!success) {\n        throw new Error(`Failed to toggle feature with key \"${key}\".`);\n      }\n      return;\n    }\n\n    const featureToUpdate = { key: feature.key, active: toggleValue };\n    await this.featureService.updateFeature(featureToUpdate);\n    await this.featureCacheService.resetFeatureState();\n\n    if (feature.settings?.reload) {\n      if (this.toggledFeaturesWithReload.has(key)) {\n        this.toggledFeaturesWithReload.delete(key);\n      } else {\n        this.toggledFeaturesWithReload.add(key);\n      }\n    }\n\n    this.reload$.next(this.toggledFeaturesWithReload.size > 0);\n  }\n\n  /**\n   * Marks all features as seen by the user and updates the local storage.\n   * This assumes all features are provided via the `items$` observable.\n   */\n  async markAllFeaturesAsSeen(): Promise<void> {\n    const features = await firstValueFrom(this.items$);\n    const featureNames = features.map(feature => feature.label);\n\n    localStorage.setItem(this.LOCAL_STORAGE_KEY, JSON.stringify(featureNames));\n    this.seenFeatures$.next(featureNames);\n  }\n\n  /**\n   * Filters the features to only include those that are available by checking the feature toggle API.\n   */\n  getAvailableFeatures$(): Observable<BetaFeature[]> {\n    return this.items$.pipe(\n      switchMap(features => {\n        return combineLatest(\n          features.map(feat =>\n            feat.key\n              ? this.featureCacheService\n                  .featureExists(feat.key)\n                  .pipe(map(exists => (exists ? feat : false)))\n              : of(feat)\n          )\n        ).pipe(map(features => features.filter(Boolean))) as Observable<BetaFeature[]>;\n      })\n    );\n  }\n\n  /**\n   *\n   * @returns An array of feature names that have been seen by the user. This is retrieved from local storage.\n   */\n  private getSeenFeatures(): string[] {\n    const seenFeatures = localStorage.getItem(this.LOCAL_STORAGE_KEY);\n    return seenFeatures ? JSON.parse(seenFeatures) : [];\n  }\n\n  protected setupItemsObservable(): Observable<BetaFeature[]> {\n    return fromTriggerOnce<BetaFeature>(undefined, this.refresh$, [\n      getInjectedHooks<BetaFeature>(HOOK_PREVIEW, this.injectors),\n      () => this.factories,\n      stateToFactory(this.state$)\n    ]).pipe(\n      distinctUntilChanged(),\n      map(features => sortByPriority(features)),\n      shareReplay(1)\n    );\n  }\n}\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"beta-preview.service.js","sourceRoot":"","sources":["../../../../core/beta-feature/beta-preview.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, InjectionToken, Injector } from '@angular/core';\nimport { BehaviorSubject, combineLatest, firstValueFrom, Observable, of } from 'rxjs';\nimport { distinctUntilChanged, map, shareReplay, switchMap } from 'rxjs/operators';\nimport {\n  GenericHookOptions,\n  GenericHookType,\n  hookGeneric,\n  getInjectedHooks,\n  ExtensionPointForPlugins,\n  fromTriggerOnce,\n  stateToFactory,\n  sortByPriority\n} from '../common/extension-hooks';\nimport { BetaFeature } from './beta-preview.model';\nimport { PluginsResolveService } from '../plugins/plugins-resolve.service';\nimport { FeatureService } from '@c8y/client';\nimport { FeatureCacheService } from './feature-cache.service';\nimport { OptionsService } from '../common/options.service';\n\nexport const HOOK_PREVIEW = new InjectionToken<BetaFeature[]>('HOOK_PREVIEW');\n\nexport function hookPreview(\n  preview: GenericHookType<BetaFeature>,\n  options?: Partial<GenericHookOptions>\n) {\n  return hookGeneric<BetaFeature>(preview, HOOK_PREVIEW, options);\n}\n\n@Injectable({ providedIn: 'root' })\nexport class PreviewService extends ExtensionPointForPlugins<BetaFeature> {\n  items$: Observable<BetaFeature[]> = this.setupItemsObservable();\n  reload$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n  private readonly LOCAL_STORAGE_KEY = 'c8y_beta_features_seen';\n  private seenFeatures$ = new BehaviorSubject<string[]>(this.getSeenFeatures());\n  hasUnseenFeatures$ = combineLatest([this.getAvailableFeatures$(), this.seenFeatures$]).pipe(\n    map(([features, seen]) => features.some(feature => !seen.includes(feature.label))),\n    distinctUntilChanged()\n  );\n  private readonly featureService = inject(FeatureService);\n  private readonly featureCacheService = inject(FeatureCacheService);\n  private readonly optionsService = inject(OptionsService);\n\n  private toggledFeaturesWithReload: Set<string> = new Set(); // track features with settings.reload = true\n\n  constructor(rootInjector: Injector, pluginService: PluginsResolveService) {\n    super(rootInjector, pluginService);\n  }\n\n  get state(): Set<BetaFeature> {\n    return this.state$.value;\n  }\n\n  /**\n   * Get the state of a specific feature.\n   * @param key The unique key for the feature.\n   * @returns Observable<boolean> representing the state of the feature.\n   */\n  getState$(key: string): Observable<boolean> {\n    return this.items$.pipe(\n      switchMap(features =>\n        this.optionsService.get$('enableAllBetaFeatures').pipe(\n          switchMap(enableAllBetaFeatures => {\n            if (enableAllBetaFeatures) {\n              return of(true);\n            }\n            const feature = features.find(f => f.key === key);\n            if (!feature) {\n              throw new Error(`Feature with key \"${key}\" does not exist.`);\n            }\n            if (feature.active$) {\n              return feature.active$;\n            }\n            return this.featureCacheService.getFeatureState(key).pipe(distinctUntilChanged());\n          })\n        )\n      ),\n      distinctUntilChanged()\n    );\n  }\n\n  /**\n   * Toggle the state of a specific feature.\n   * @param key The unique key or label for the feature. Label is used to find the custom features.\n   * @returns Promise<void> after toggling the state.\n   */\n  async setFeatureActiveState(key: string, toggleValue: boolean): Promise<void> {\n    const features = await firstValueFrom(this.items$);\n    const feature = features.find(f => f.key === key) || features.find(f => f.label === key);\n\n    if (!feature) {\n      throw new Error(`Feature with key \"${key}\" does not exist.`);\n    }\n\n    if (feature.onToggle) {\n      const success = await feature.onToggle(toggleValue);\n      if (!success) {\n        throw new Error(`Failed to toggle feature with key \"${key}\".`);\n      }\n      return;\n    }\n\n    const featureToUpdate = { key: feature.key, active: toggleValue };\n    await this.featureService.updateFeature(featureToUpdate);\n    await this.featureCacheService.resetFeatureState();\n\n    if (feature.settings?.reload) {\n      if (this.toggledFeaturesWithReload.has(key)) {\n        this.toggledFeaturesWithReload.delete(key);\n      } else {\n        this.toggledFeaturesWithReload.add(key);\n      }\n    }\n\n    this.reload$.next(this.toggledFeaturesWithReload.size > 0);\n  }\n\n  /**\n   * Marks all unseen features as seen by the user and updates the local storage.\n   * This assumes all features are provided via the `items$` observable.\n   */\n  async markAllFeaturesAsSeen(): Promise<void> {\n    const features = await firstValueFrom(this.getAvailableFeatures$());\n    const newFeatureNames = features.map(feature => feature.label);\n\n    const storedFeatures = localStorage.getItem(this.LOCAL_STORAGE_KEY);\n    const existingFeatureNames: string[] = storedFeatures ? JSON.parse(storedFeatures) : [];\n\n    // Update the local storage with unique feature names and remove duplicates\n    const updatedFeatureNames = Array.from(new Set([...existingFeatureNames, ...newFeatureNames]));\n\n    localStorage.setItem(this.LOCAL_STORAGE_KEY, JSON.stringify(updatedFeatureNames));\n    this.seenFeatures$.next(updatedFeatureNames);\n  }\n\n  /**\n   * Filters the features to only include those that are available by checking the feature toggle API.\n   */\n  getAvailableFeatures$(): Observable<BetaFeature[]> {\n    return this.items$.pipe(\n      switchMap(features => {\n        return combineLatest(\n          features.map(feat =>\n            feat.key\n              ? this.featureCacheService\n                  .featureExists(feat.key)\n                  .pipe(map(exists => (exists ? feat : false)))\n              : of(feat)\n          )\n        ).pipe(map(features => features.filter(Boolean))) as Observable<BetaFeature[]>;\n      })\n    );\n  }\n\n  /**\n   *\n   * @returns An array of feature names that have been seen by the user. This is retrieved from local storage.\n   */\n  private getSeenFeatures(): string[] {\n    const seenFeatures = localStorage.getItem(this.LOCAL_STORAGE_KEY);\n    return seenFeatures ? JSON.parse(seenFeatures) : [];\n  }\n\n  protected setupItemsObservable(): Observable<BetaFeature[]> {\n    return fromTriggerOnce<BetaFeature>(undefined, this.refresh$, [\n      getInjectedHooks<BetaFeature>(HOOK_PREVIEW, this.injectors),\n      () => this.factories,\n      stateToFactory(this.state$)\n    ]).pipe(\n      distinctUntilChanged(),\n      map(features => sortByPriority(features)),\n      shareReplay(1)\n    );\n  }\n}\n"]}
@@ -52,8 +52,8 @@ export class DateTimePickerComponent {
52
52
  // eslint-disable-next-line @typescript-eslint/no-empty-function
53
53
  this.onTouched = () => { };
54
54
  this.form = new FormGroup({});
55
- this.form.addControl('date', new FormControl(null));
56
- this.form.addControl('time', new FormControl(null));
55
+ this.form.addControl('date', new FormControl(undefined));
56
+ this.form.addControl('time', new FormControl(undefined));
57
57
  this.form.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {
58
58
  this.setDatetime(value);
59
59
  this.previousValue = value;
@@ -80,19 +80,26 @@ export class DateTimePickerComponent {
80
80
  ngAfterViewInit() {
81
81
  this.cd.detectChanges();
82
82
  }
83
+ onTimeChange(time) {
84
+ this.form.get('time').setValue(time, { emitEvent: true });
85
+ }
86
+ get dateControl() {
87
+ return this.form.get('date');
88
+ }
83
89
  /**
84
90
  * Control Value Accessor - If form value changes by external factor, update date property and internal form with new value.
85
91
  */
86
92
  writeValue(value) {
87
93
  if (typeof value === 'string' && value.length) {
88
94
  this.date = new Date(value);
95
+ this.time = this.date;
89
96
  this.form.setValue({
90
97
  date: new Date(value),
91
98
  time: this.date
92
99
  }, { emitEvent: false });
93
100
  }
94
101
  else {
95
- this.form.setValue({ date: null, time: null }, { emitEvent: false });
102
+ return;
96
103
  }
97
104
  this.previousValue = this.form.value;
98
105
  }
@@ -171,27 +178,33 @@ export class DateTimePickerComponent {
171
178
  // if date input is cleared from a previous correct value, clear form value:
172
179
  if (this.isInputCleared(dateTime)) {
173
180
  this.form.get('date').setValue(undefined, { emitEvent: false });
181
+ this.time = undefined;
174
182
  this.form.get('time').setValue(undefined, { emitEvent: false });
175
183
  this.onChange(null);
176
184
  return;
177
185
  }
186
+ const validTime = this.verifyDate(dateTime.time);
187
+ const validExistingTime = this.verifyDate(this.time);
188
+ const validDate = this.verifyDate(dateTime.date);
189
+ if (!validTime && !validExistingTime) {
190
+ // Ensure dateTime.date exists before using getFullYear:
191
+ if (dateTime.date) {
192
+ dateTime.time = new Date(dateTime.date.getFullYear(), dateTime.date.getMonth(), dateTime.date.getDate(), 0, 0, 0);
193
+ this.time = dateTime.time;
194
+ }
195
+ }
178
196
  // if both date and time is invalid, do set form value to null and stop:
179
- if (!this.verifyDate(dateTime.date) && !this.verifyDate(dateTime.time)) {
197
+ if (!validDate && !validTime) {
180
198
  this.onChange(null);
181
199
  return;
182
200
  }
183
201
  // If only time is provided, set Date to today:
184
- if (!this.verifyDate(dateTime.date) && this.verifyDate(dateTime.time)) {
202
+ if (!validDate && validTime) {
185
203
  dateTime.date = new Date(dateTime.time);
186
204
  }
187
- // If only date is provided, set time to 00:00:
188
- if (this.verifyDate(dateTime.date) && !this.verifyDate(dateTime.time)) {
189
- dateTime.time = new Date(dateTime.date.getFullYear(), dateTime.date.getMonth(), dateTime.date.getDate(), 0, 0, 0);
190
- this.form.get('time').setValue(dateTime.time, { emitEvent: false });
191
- }
192
205
  // Merge date and time, and emit as new form value:
193
206
  this.date = new Date(dateTime.date);
194
- this.date.setHours(dateTime.time.getHours(), dateTime.time.getMinutes());
207
+ this.date.setHours(this.time.getHours(), this.time.getMinutes());
195
208
  this.form.get('date').setValue(dateTime.date, { emitEvent: false });
196
209
  this.onChange(this.date.toISOString());
197
210
  }
@@ -214,7 +227,7 @@ export class DateTimePickerComponent {
214
227
  useExisting: forwardRef(() => DateTimePickerComponent),
215
228
  multi: true
216
229
  }
217
- ], viewQueries: [{ propertyName: "datepicker", first: true, predicate: BsDatepickerDirective, descendants: true }], ngImport: i0, template: "<div\n class=\"datetime-picker\"\n [ngSwitch]=\"dateType\"\n>\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateAndTime'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n data-cy=\"bootstrap-date-input\"\n style=\"min-width: 120px\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"form.get('date')\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [formControl]=\"form.get('time')\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Date'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"form.get('date')\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateRange'\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n placeholder=\"{{ 'Select a date range' | translate }}\"\n [formControl]=\"form.get('date')\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n adaptivePosition: true,\n rangeInputFormat: dateInputFormat\n }\"\n bsDaterangepicker\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Time'\"\n >\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [formControl]=\"form.get('time')\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div *ngSwitchCase=\"'SingleDateRequired'\">\n <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: CloseDatePickerDirective, selector: "[closeDatepicker]", inputs: ["closeDatepicker"] }, { kind: "ngmodule", type: BsDatepickerModule }, { kind: "directive", type: i2.BsDatepickerDirective, selector: "[bsDatepicker]", inputs: ["placement", "triggers", "outsideClick", "container", "outsideEsc", "isDisabled", "minDate", "maxDate", "minMode", "daysDisabled", "datesDisabled", "datesEnabled", "dateCustomClasses", "dateTooltipTexts", "isOpen", "bsValue", "bsConfig"], outputs: ["onShown", "onHidden", "bsValueChange"], exportAs: ["bsDatepicker"] }, { kind: "directive", type: i2.BsDatepickerInputDirective, selector: "input[bsDatepicker]" }, { kind: "directive", type: i2.BsDaterangepickerDirective, selector: "[bsDaterangepicker]", inputs: ["placement", "triggers", "outsideClick", "container", "outsideEsc", "isOpen", "bsValue", "bsConfig", "isDisabled", "minDate", "maxDate", "dateCustomClasses", "daysDisabled", "datesDisabled", "datesEnabled"], outputs: ["onShown", "onHidden", "bsValueChange"], exportAs: ["bsDaterangepicker"] }, { kind: "directive", type: i2.BsDaterangepickerInputDirective, selector: "input[bsDaterangepicker]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: TimepickerModule }, { kind: "component", type: i4.TimepickerComponent, selector: "timepicker", inputs: ["hourStep", "minuteStep", "secondsStep", "readonlyInput", "disabled", "mousewheel", "arrowkeys", "showSpinners", "showMeridian", "showMinutes", "showSeconds", "meridians", "min", "max", "hoursPlaceholder", "minutesPlaceholder", "secondsPlaceholder"], outputs: ["isValid", "meridianChange"] }, { kind: "component", type: DatePickerComponent, selector: "c8y-date-picker", inputs: ["placeholder", "dateInputFormat"], outputs: ["onDateSelected"] }, { kind: "pipe", type: C8yTranslatePipe, name: "translate" }] }); }
230
+ ], viewQueries: [{ propertyName: "datepicker", first: true, predicate: BsDatepickerDirective, descendants: true }], ngImport: i0, template: "<div\n class=\"datetime-picker\"\n [ngSwitch]=\"dateType\"\n>\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateAndTime'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n data-cy=\"bootstrap-date-input\"\n style=\"min-width: 120px\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"dateControl\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [(ngModel)]=\"time\"\n (ngModelChange)=\"onTimeChange($event)\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Date'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"dateControl\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateRange'\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n placeholder=\"{{ 'Select a date range' | translate }}\"\n [formControl]=\"dateControl\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n adaptivePosition: true,\n rangeInputFormat: dateInputFormat\n }\"\n bsDaterangepicker\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Time'\"\n >\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [(ngModel)]=\"time\"\n (ngModelChange)=\"onTimeChange($event)\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div *ngSwitchCase=\"'SingleDateRequired'\">\n <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: CloseDatePickerDirective, selector: "[closeDatepicker]", inputs: ["closeDatepicker"] }, { kind: "ngmodule", type: BsDatepickerModule }, { kind: "directive", type: i2.BsDatepickerDirective, selector: "[bsDatepicker]", inputs: ["placement", "triggers", "outsideClick", "container", "outsideEsc", "isDisabled", "minDate", "maxDate", "minMode", "daysDisabled", "datesDisabled", "datesEnabled", "dateCustomClasses", "dateTooltipTexts", "isOpen", "bsValue", "bsConfig"], outputs: ["onShown", "onHidden", "bsValueChange"], exportAs: ["bsDatepicker"] }, { kind: "directive", type: i2.BsDatepickerInputDirective, selector: "input[bsDatepicker]" }, { kind: "directive", type: i2.BsDaterangepickerDirective, selector: "[bsDaterangepicker]", inputs: ["placement", "triggers", "outsideClick", "container", "outsideEsc", "isOpen", "bsValue", "bsConfig", "isDisabled", "minDate", "maxDate", "dateCustomClasses", "daysDisabled", "datesDisabled", "datesEnabled"], outputs: ["onShown", "onHidden", "bsValueChange"], exportAs: ["bsDaterangepicker"] }, { kind: "directive", type: i2.BsDaterangepickerInputDirective, selector: "input[bsDaterangepicker]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: TimepickerModule }, { kind: "component", type: i4.TimepickerComponent, selector: "timepicker", inputs: ["hourStep", "minuteStep", "secondsStep", "readonlyInput", "disabled", "mousewheel", "arrowkeys", "showSpinners", "showMeridian", "showMinutes", "showSeconds", "meridians", "min", "max", "hoursPlaceholder", "minutesPlaceholder", "secondsPlaceholder"], outputs: ["isValid", "meridianChange"] }, { kind: "component", type: DatePickerComponent, selector: "c8y-date-picker", inputs: ["placeholder", "dateInputFormat"], outputs: ["onDateSelected"] }, { kind: "pipe", type: C8yTranslatePipe, name: "translate" }] }); }
218
231
  }
219
232
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DateTimePickerComponent, decorators: [{
220
233
  type: Component,
@@ -239,7 +252,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
239
252
  TimepickerModule,
240
253
  DatePickerComponent,
241
254
  C8yTranslatePipe
242
- ], template: "<div\n class=\"datetime-picker\"\n [ngSwitch]=\"dateType\"\n>\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateAndTime'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n data-cy=\"bootstrap-date-input\"\n style=\"min-width: 120px\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"form.get('date')\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [formControl]=\"form.get('time')\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Date'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"form.get('date')\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateRange'\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n placeholder=\"{{ 'Select a date range' | translate }}\"\n [formControl]=\"form.get('date')\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n adaptivePosition: true,\n rangeInputFormat: dateInputFormat\n }\"\n bsDaterangepicker\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Time'\"\n >\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [formControl]=\"form.get('time')\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div *ngSwitchCase=\"'SingleDateRequired'\">\n <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n </div>\n </div>\n</div>\n" }]
255
+ ], template: "<div\n class=\"datetime-picker\"\n [ngSwitch]=\"dateType\"\n>\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateAndTime'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n data-cy=\"bootstrap-date-input\"\n style=\"min-width: 120px\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"dateControl\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [(ngModel)]=\"time\"\n (ngModelChange)=\"onTimeChange($event)\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Date'\"\n [closeDatepicker]=\"datepicker\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n bsDatepicker\n [outsideClick]=\"false\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n dateInputFormat: dateInputFormat,\n adaptivePosition: adaptivePosition\n }\"\n [formControl]=\"dateControl\"\n (blur)=\"onTouched()\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'DateRange'\"\n >\n <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n <input\n class=\"form-control\"\n placeholder=\"{{ 'Select a date range' | translate }}\"\n [formControl]=\"dateControl\"\n [bsConfig]=\"{\n customTodayClass: 'today',\n adaptivePosition: true,\n rangeInputFormat: dateInputFormat\n }\"\n bsDaterangepicker\n />\n </div>\n </div>\n\n <div\n class=\"d-contents\"\n *ngSwitchCase=\"'Time'\"\n >\n <timepicker\n class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n [(ngModel)]=\"time\"\n (ngModelChange)=\"onTimeChange($event)\"\n [showSeconds]=\"config.showSeconds\"\n [showSpinners]=\"config.showSpinners\"\n [showMeridian]=\"config.showMeridian\"\n [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n (wheel)=\"handleMouseWheel($event)\"\n ></timepicker>\n </div>\n\n <div *ngSwitchCase=\"'SingleDateRequired'\">\n <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n </div>\n </div>\n</div>\n" }]
243
256
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.DateFormatService }], propDecorators: { _minDate: [{
244
257
  type: Input,
245
258
  args: ['minDate']
@@ -264,4 +277,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
264
277
  type: ViewChild,
265
278
  args: [BsDatepickerDirective]
266
279
  }] } });
267
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../core/date-time-picker/date-time-picker.component.ts","../../../../core/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  FormGroup,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n  FormsModule,\n  ReactiveFormsModule\n} from '@angular/forms';\nimport { first, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { gettext } from '../i18n';\nimport { BsDatepickerDirective, BsDatepickerModule } from 'ngx-bootstrap/datepicker';\nimport { PickedDates } from '../date-picker';\nimport { NgSwitch, NgSwitchCase } from '@angular/common';\nimport { CloseDatePickerDirective } from './close-date-picker.directive';\nimport { TimepickerModule } from 'ngx-bootstrap/timepicker';\nimport { DatePickerComponent } from '../date-picker/date-picker.component';\nimport { C8yTranslatePipe } from '../i18n/c8y-translate.pipe';\nimport { DateFormatService } from '../common/date-format.service';\n\ninterface DateAndTime {\n  date: Date;\n  time: Date;\n}\n\ninterface DateAndTimeOptions {\n  showSpinners?: boolean;\n  showMeridian?: boolean;\n  showMinutes?: boolean;\n  showSeconds?: boolean;\n}\n\nexport type DateType = 'DateAndTime' | 'Date' | 'DateRange' | 'SingleDateRequired' | 'Time';\n\n@Component({\n  selector: 'c8y-date-time-picker',\n  templateUrl: './date-time-picker.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateTimePickerComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DateTimePickerComponent),\n      multi: true\n    }\n  ],\n  standalone: true,\n  imports: [\n    NgSwitch,\n    NgSwitchCase,\n    CloseDatePickerDirective,\n    BsDatepickerModule,\n    FormsModule,\n    ReactiveFormsModule,\n    TimepickerModule,\n    DatePickerComponent,\n    C8yTranslatePipe\n  ]\n})\nexport class DateTimePickerComponent\n  implements ControlValueAccessor, Validator, OnInit, AfterViewInit, OnDestroy\n{\n  minDate: Date;\n\n  @Input('minDate')\n  set _minDate(value: string) {\n    this.minDate = value ? new Date(value) : undefined;\n  }\n\n  maxDate: Date;\n\n  @Input('maxDate')\n  set _maxDate(value: string) {\n    this.maxDate = value ? new Date(value) : undefined;\n  }\n\n  @Input()\n  placeholder: string;\n\n  @Input()\n  dateInputFormat: string;\n\n  @Input()\n  adaptivePosition = false;\n\n  @Input()\n  size: string;\n\n  /**\n   * Specifies the type of date input.\n   *\n   * @param DateAndTime - Display both date and time.\n   * @param Date - Display only the date without the time.\n   * @param DateRange - Specify a range of dates.\n   * @param SingleDateRequired - Require the selection of a single date.\n   * @param Time - Display only the time without the date.\n   *\n   * @defaultValue 'DateAndTime'\n   */\n  @Input()\n  dateType: DateType = 'DateAndTime';\n\n  @Input()\n  config: DateAndTimeOptions = {\n    showMinutes: true,\n    showSeconds: false,\n    showSpinners: false\n  };\n\n  @Output()\n  onDateSelected: EventEmitter<PickedDates> = new EventEmitter();\n\n  date: Date;\n  form: FormGroup;\n\n  defaultPlaceholder = gettext('Select a date…');\n\n  @ViewChild(BsDatepickerDirective) datepicker: BsDatepickerDirective;\n\n  private previousValue: DateAndTime;\n  private previousTimePickerValues: { hours?: number; minutes?: number } = {};\n  private destroy$: Subject<void> = new Subject();\n\n  constructor(\n    private cd: ChangeDetectorRef,\n    private dateFormatService: DateFormatService\n  ) {\n    this.form = new FormGroup({});\n    this.form.addControl('date', new FormControl(null));\n    this.form.addControl('time', new FormControl(null));\n    this.form.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value: DateAndTime) => {\n      this.setDatetime(value);\n      this.previousValue = value;\n    });\n    this.form.statusChanges\n      .pipe(first())\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        this.onTouched();\n      });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange: (value: string) => void = () => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched: () => void = () => {};\n\n  ngOnInit(): void {\n    if (!this.dateInputFormat) {\n      this.dateInputFormat = this.dateFormatService.getDateFormat();\n    }\n    if (!('showMeridian' in this.config)) {\n      this.config.showMeridian = this.dateFormatService.shouldUseMeridianFormat();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  ngAfterViewInit(): void {\n    this.cd.detectChanges();\n  }\n\n  /**\n   * Control Value Accessor - If form value changes by external factor, update date property and internal form with new value.\n   */\n  writeValue(value: string): void {\n    if (typeof value === 'string' && value.length) {\n      this.date = new Date(value);\n      this.form.setValue(\n        {\n          date: new Date(value),\n          time: this.date\n        },\n        { emitEvent: false }\n      );\n    } else {\n      this.form.setValue({ date: null, time: null }, { emitEvent: false });\n    }\n    this.previousValue = this.form.value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(onTouched: any) {\n    this.onTouched = onTouched;\n  }\n\n  setDisabledState(disabled: boolean) {\n    if (disabled === this.form?.disabled) {\n      return;\n    }\n    disabled ? this.form.disable() : this.form.enable();\n  }\n\n  validate(_control: AbstractControl): ValidationErrors | null {\n    if (this.date?.getTime() < new Date(this.minDate).getTime()) {\n      return { dateBeforeRangeMin: true };\n    } else if (this.date?.getTime() > new Date(this.maxDate).getTime()) {\n      return { dateAfterRangeMax: true };\n    } else if (this.form.invalid) {\n      return { invalidDateTime: true };\n    } else {\n      return null;\n    }\n  }\n\n  previousDay() {\n    const isOpen = this.datepicker.isOpen;\n    this.date.setDate(this.date.getDate() - 1);\n    this.setDatetime({ date: this.date, time: this.form.get('time').value });\n    if (isOpen) {\n      this.datepicker.show();\n    }\n  }\n\n  nextDay() {\n    const isOpen = this.datepicker.isOpen;\n    this.date.setDate(this.date.getDate() + 1);\n    this.setDatetime({ date: this.date, time: this.form.get('time').value });\n    if (isOpen) {\n      this.datepicker.show();\n    }\n  }\n\n  hide(): void {\n    this.datepicker.hide();\n  }\n\n  handleMouseWheel(event: WheelEvent): void {\n    const hours = this.form.get('time').value.getHours();\n    const minutes = this.form.get('time').value.getMinutes();\n    // down\n    event.preventDefault();\n    if (event.deltaY > 0) {\n      if (Number(hours) === 23 && this.previousTimePickerValues.hours !== 23) {\n        this.previousDay();\n      }\n    }\n\n    // up\n    if (event.deltaY < 0) {\n      if (this.previousTimePickerValues.hours === undefined) {\n        // scrolling up on empty form should not result in increasing day.\n      } else if (Number(hours) === 0 && this.previousTimePickerValues.hours !== 0) {\n        this.nextDay();\n      }\n    }\n    this.previousTimePickerValues = { hours, minutes };\n  }\n\n  /**\n   * If internal form changes its value, then combine date and time into one Date and pass its ISO string value to onChange method\n   * @param dateTime\n   * @private\n   */\n  private setDatetime(dateTime: DateAndTime) {\n    // if date input is cleared from a previous correct value, clear form value:\n    if (this.isInputCleared(dateTime)) {\n      this.form.get('date').setValue(undefined, { emitEvent: false });\n      this.form.get('time').setValue(undefined, { emitEvent: false });\n      this.onChange(null);\n      return;\n    }\n\n    // if both date and time is invalid, do set form value to null and stop:\n    if (!this.verifyDate(dateTime.date) && !this.verifyDate(dateTime.time)) {\n      this.onChange(null);\n      return;\n    }\n    // If only time is provided, set Date to today:\n    if (!this.verifyDate(dateTime.date) && this.verifyDate(dateTime.time)) {\n      dateTime.date = new Date(dateTime.time);\n    }\n\n    // If only date is provided, set time to 00:00:\n    if (this.verifyDate(dateTime.date) && !this.verifyDate(dateTime.time)) {\n      dateTime.time = new Date(\n        dateTime.date.getFullYear(),\n        dateTime.date.getMonth(),\n        dateTime.date.getDate(),\n        0,\n        0,\n        0\n      );\n      this.form.get('time').setValue(dateTime.time, { emitEvent: false });\n    }\n\n    // Merge date and time, and emit as new form value:\n    this.date = new Date(dateTime.date);\n    this.date.setHours(dateTime.time.getHours(), dateTime.time.getMinutes());\n    this.form.get('date').setValue(dateTime.date, { emitEvent: false });\n    this.onChange(this.date.toISOString());\n  }\n\n  private verifyDate(value: Date): boolean {\n    const date = value;\n    return date instanceof Date && !isNaN(date.getTime());\n  }\n\n  private isInputCleared(value: DateAndTime): boolean {\n    return this.previousValue?.date && value.date === undefined;\n  }\n}\n","<div\n  class=\"datetime-picker\"\n  [ngSwitch]=\"dateType\"\n>\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'DateAndTime'\"\n    [closeDatepicker]=\"datepicker\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        data-cy=\"bootstrap-date-input\"\n        style=\"min-width: 120px\"\n        [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n        bsDatepicker\n        [outsideClick]=\"false\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          dateInputFormat: dateInputFormat,\n          adaptivePosition: adaptivePosition\n        }\"\n        [formControl]=\"form.get('date')\"\n        (blur)=\"onTouched()\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\"\n      />\n    </div>\n    <timepicker\n      class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n      [formControl]=\"form.get('time')\"\n      [showSeconds]=\"config.showSeconds\"\n      [showSpinners]=\"config.showSpinners\"\n      [showMeridian]=\"config.showMeridian\"\n      (wheel)=\"handleMouseWheel($event)\"\n    ></timepicker>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'Date'\"\n    [closeDatepicker]=\"datepicker\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n        bsDatepicker\n        [outsideClick]=\"false\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          dateInputFormat: dateInputFormat,\n          adaptivePosition: adaptivePosition\n        }\"\n        [formControl]=\"form.get('date')\"\n        (blur)=\"onTouched()\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\"\n      />\n    </div>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'DateRange'\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        placeholder=\"{{ 'Select a date range' | translate }}\"\n        [formControl]=\"form.get('date')\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          adaptivePosition: true,\n          rangeInputFormat: dateInputFormat\n        }\"\n        bsDaterangepicker\n      />\n    </div>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'Time'\"\n  >\n    <timepicker\n      class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n      [formControl]=\"form.get('time')\"\n      [showSeconds]=\"config.showSeconds\"\n      [showSpinners]=\"config.showSpinners\"\n      [showMeridian]=\"config.showMeridian\"\n      [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n      [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n      [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n      (wheel)=\"handleMouseWheel($event)\"\n    ></timepicker>\n  </div>\n\n  <div *ngSwitchCase=\"'SingleDateRequired'\">\n    <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n      <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n    </div>\n  </div>\n</div>\n"]}
280
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../core/date-time-picker/date-time-picker.component.ts","../../../../core/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  FormGroup,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n  FormsModule,\n  ReactiveFormsModule\n} from '@angular/forms';\nimport { first, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { gettext } from '../i18n';\nimport { BsDatepickerDirective, BsDatepickerModule } from 'ngx-bootstrap/datepicker';\nimport { PickedDates } from '../date-picker';\nimport { NgSwitch, NgSwitchCase } from '@angular/common';\nimport { CloseDatePickerDirective } from './close-date-picker.directive';\nimport { TimepickerModule } from 'ngx-bootstrap/timepicker';\nimport { DatePickerComponent } from '../date-picker/date-picker.component';\nimport { C8yTranslatePipe } from '../i18n/c8y-translate.pipe';\nimport { DateFormatService } from '../common/date-format.service';\n\ninterface DateAndTime {\n  date: Date;\n  time: Date;\n}\n\ninterface DateAndTimeOptions {\n  showSpinners?: boolean;\n  showMeridian?: boolean;\n  showMinutes?: boolean;\n  showSeconds?: boolean;\n}\n\nexport type DateType = 'DateAndTime' | 'Date' | 'DateRange' | 'SingleDateRequired' | 'Time';\n\n@Component({\n  selector: 'c8y-date-time-picker',\n  templateUrl: './date-time-picker.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateTimePickerComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DateTimePickerComponent),\n      multi: true\n    }\n  ],\n  standalone: true,\n  imports: [\n    NgSwitch,\n    NgSwitchCase,\n    CloseDatePickerDirective,\n    BsDatepickerModule,\n    FormsModule,\n    ReactiveFormsModule,\n    TimepickerModule,\n    DatePickerComponent,\n    C8yTranslatePipe\n  ]\n})\nexport class DateTimePickerComponent\n  implements ControlValueAccessor, Validator, OnInit, AfterViewInit, OnDestroy\n{\n  minDate: Date;\n\n  @Input('minDate')\n  set _minDate(value: string) {\n    this.minDate = value ? new Date(value) : undefined;\n  }\n\n  maxDate: Date;\n\n  @Input('maxDate')\n  set _maxDate(value: string) {\n    this.maxDate = value ? new Date(value) : undefined;\n  }\n\n  @Input()\n  placeholder: string;\n\n  @Input()\n  dateInputFormat: string;\n\n  @Input()\n  adaptivePosition = false;\n\n  @Input()\n  size: string;\n\n  /**\n   * Specifies the type of date input.\n   *\n   * @param DateAndTime - Display both date and time.\n   * @param Date - Display only the date without the time.\n   * @param DateRange - Specify a range of dates.\n   * @param SingleDateRequired - Require the selection of a single date.\n   * @param Time - Display only the time without the date.\n   *\n   * @defaultValue 'DateAndTime'\n   */\n  @Input()\n  dateType: DateType = 'DateAndTime';\n\n  @Input()\n  config: DateAndTimeOptions = {\n    showMinutes: true,\n    showSeconds: false,\n    showSpinners: false\n  };\n\n  @Output()\n  onDateSelected: EventEmitter<PickedDates> = new EventEmitter();\n\n  date: Date;\n  time: Date | null;\n  form: FormGroup;\n\n  defaultPlaceholder = gettext('Select a date…');\n\n  @ViewChild(BsDatepickerDirective) datepicker: BsDatepickerDirective;\n\n  private previousValue: DateAndTime;\n  private previousTimePickerValues: { hours?: number; minutes?: number } = {};\n  private destroy$: Subject<void> = new Subject();\n\n  constructor(\n    private cd: ChangeDetectorRef,\n    private dateFormatService: DateFormatService\n  ) {\n    this.form = new FormGroup({});\n    this.form.addControl('date', new FormControl(undefined));\n    this.form.addControl('time', new FormControl(undefined));\n\n    this.form.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value: DateAndTime) => {\n      this.setDatetime(value);\n      this.previousValue = value;\n    });\n\n    this.form.statusChanges\n      .pipe(first())\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        this.onTouched();\n      });\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange: (value: string) => void = () => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched: () => void = () => {};\n\n  ngOnInit(): void {\n    if (!this.dateInputFormat) {\n      this.dateInputFormat = this.dateFormatService.getDateFormat();\n    }\n    if (!('showMeridian' in this.config)) {\n      this.config.showMeridian = this.dateFormatService.shouldUseMeridianFormat();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  ngAfterViewInit(): void {\n    this.cd.detectChanges();\n  }\n\n  onTimeChange(time: Date): void {\n    this.form.get('time').setValue(time, { emitEvent: true });\n  }\n\n  get dateControl(): FormControl {\n    return this.form.get('date') as FormControl;\n  }\n\n  /**\n   * Control Value Accessor - If form value changes by external factor, update date property and internal form with new value.\n   */\n  writeValue(value: string): void {\n    if (typeof value === 'string' && value.length) {\n      this.date = new Date(value);\n      this.time = this.date;\n      this.form.setValue(\n        {\n          date: new Date(value),\n          time: this.date\n        },\n        { emitEvent: false }\n      );\n    } else {\n      return;\n    }\n    this.previousValue = this.form.value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(onTouched: any) {\n    this.onTouched = onTouched;\n  }\n\n  setDisabledState(disabled: boolean) {\n    if (disabled === this.form?.disabled) {\n      return;\n    }\n    disabled ? this.form.disable() : this.form.enable();\n  }\n\n  validate(_control: AbstractControl): ValidationErrors | null {\n    if (this.date?.getTime() < new Date(this.minDate).getTime()) {\n      return { dateBeforeRangeMin: true };\n    } else if (this.date?.getTime() > new Date(this.maxDate).getTime()) {\n      return { dateAfterRangeMax: true };\n    } else if (this.form.invalid) {\n      return { invalidDateTime: true };\n    } else {\n      return null;\n    }\n  }\n\n  previousDay() {\n    const isOpen = this.datepicker.isOpen;\n    this.date.setDate(this.date.getDate() - 1);\n    this.setDatetime({ date: this.date, time: this.form.get('time').value });\n    if (isOpen) {\n      this.datepicker.show();\n    }\n  }\n\n  nextDay() {\n    const isOpen = this.datepicker.isOpen;\n    this.date.setDate(this.date.getDate() + 1);\n    this.setDatetime({ date: this.date, time: this.form.get('time').value });\n    if (isOpen) {\n      this.datepicker.show();\n    }\n  }\n\n  hide(): void {\n    this.datepicker.hide();\n  }\n\n  handleMouseWheel(event: WheelEvent): void {\n    const hours = this.form.get('time').value.getHours();\n    const minutes = this.form.get('time').value.getMinutes();\n    // down\n    event.preventDefault();\n    if (event.deltaY > 0) {\n      if (Number(hours) === 23 && this.previousTimePickerValues.hours !== 23) {\n        this.previousDay();\n      }\n    }\n\n    // up\n    if (event.deltaY < 0) {\n      if (this.previousTimePickerValues.hours === undefined) {\n        // scrolling up on empty form should not result in increasing day.\n      } else if (Number(hours) === 0 && this.previousTimePickerValues.hours !== 0) {\n        this.nextDay();\n      }\n    }\n    this.previousTimePickerValues = { hours, minutes };\n  }\n\n  /**\n   * If internal form changes its value, then combine date and time into one Date and pass its ISO string value to onChange method\n   * @param dateTime\n   * @private\n   */\n  private setDatetime(dateTime: DateAndTime) {\n    // if date input is cleared from a previous correct value, clear form value:\n    if (this.isInputCleared(dateTime)) {\n      this.form.get('date').setValue(undefined, { emitEvent: false });\n      this.time = undefined;\n      this.form.get('time').setValue(undefined, { emitEvent: false });\n      this.onChange(null);\n      return;\n    }\n\n    const validTime = this.verifyDate(dateTime.time);\n    const validExistingTime = this.verifyDate(this.time);\n    const validDate = this.verifyDate(dateTime.date);\n\n    if (!validTime && !validExistingTime) {\n      // Ensure dateTime.date exists before using getFullYear:\n      if (dateTime.date) {\n        dateTime.time = new Date(\n          dateTime.date.getFullYear(),\n          dateTime.date.getMonth(),\n          dateTime.date.getDate(),\n          0,\n          0,\n          0\n        );\n        this.time = dateTime.time;\n      }\n    }\n\n    // if both date and time is invalid, do set form value to null and stop:\n    if (!validDate && !validTime) {\n      this.onChange(null);\n      return;\n    }\n\n    // If only time is provided, set Date to today:\n    if (!validDate && validTime) {\n      dateTime.date = new Date(dateTime.time);\n    }\n\n    // Merge date and time, and emit as new form value:\n    this.date = new Date(dateTime.date);\n    this.date.setHours(this.time.getHours(), this.time.getMinutes());\n    this.form.get('date').setValue(dateTime.date, { emitEvent: false });\n    this.onChange(this.date.toISOString());\n  }\n\n  private verifyDate(value: Date): boolean {\n    const date = value;\n    return date instanceof Date && !isNaN(date.getTime());\n  }\n\n  private isInputCleared(value: DateAndTime): boolean {\n    return this.previousValue?.date && value.date === undefined;\n  }\n}\n","<div\n  class=\"datetime-picker\"\n  [ngSwitch]=\"dateType\"\n>\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'DateAndTime'\"\n    [closeDatepicker]=\"datepicker\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        data-cy=\"bootstrap-date-input\"\n        style=\"min-width: 120px\"\n        [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n        bsDatepicker\n        [outsideClick]=\"false\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          dateInputFormat: dateInputFormat,\n          adaptivePosition: adaptivePosition\n        }\"\n        [formControl]=\"dateControl\"\n        (blur)=\"onTouched()\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\"\n      />\n    </div>\n    <timepicker\n      class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n      [(ngModel)]=\"time\"\n      (ngModelChange)=\"onTimeChange($event)\"\n      [showSeconds]=\"config.showSeconds\"\n      [showSpinners]=\"config.showSpinners\"\n      [showMeridian]=\"config.showMeridian\"\n      (wheel)=\"handleMouseWheel($event)\"\n      ></timepicker>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'Date'\"\n    [closeDatepicker]=\"datepicker\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        [placeholder]=\"placeholder || defaultPlaceholder | translate\"\n        bsDatepicker\n        [outsideClick]=\"false\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          dateInputFormat: dateInputFormat,\n          adaptivePosition: adaptivePosition\n        }\"\n        [formControl]=\"dateControl\"\n        (blur)=\"onTouched()\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\"\n      />\n    </div>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'DateRange'\"\n  >\n    <div class=\"form-group datepicker {{ size ? 'form-group-' + size : '' }}\">\n      <input\n        class=\"form-control\"\n        placeholder=\"{{ 'Select a date range' | translate }}\"\n        [formControl]=\"dateControl\"\n        [bsConfig]=\"{\n          customTodayClass: 'today',\n          adaptivePosition: true,\n          rangeInputFormat: dateInputFormat\n        }\"\n        bsDaterangepicker\n      />\n    </div>\n  </div>\n\n  <div\n    class=\"d-contents\"\n    *ngSwitchCase=\"'Time'\"\n  >\n    <timepicker\n      class=\"form-group {{ size ? 'form-group-' + size : '' }}\"\n      [(ngModel)]=\"time\"\n      (ngModelChange)=\"onTimeChange($event)\"\n      [showSeconds]=\"config.showSeconds\"\n      [showSpinners]=\"config.showSpinners\"\n      [showMeridian]=\"config.showMeridian\"\n      [minutesPlaceholder]=\"'MM`MINUTES`' | translate\"\n      [hoursPlaceholder]=\"'HH`HOURS`' | translate\"\n      [secondsPlaceholder]=\"'SS`SECONDS`' | translate\"\n      (wheel)=\"handleMouseWheel($event)\"\n    ></timepicker>\n  </div>\n\n  <div *ngSwitchCase=\"'SingleDateRequired'\">\n    <div class=\"form-group {{ size ? 'form-group-' + size : '' }}\">\n      <c8y-date-picker (onDateSelected)=\"onDateSelected.emit($event)\"></c8y-date-picker>\n    </div>\n  </div>\n</div>\n"]}