@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
85 lines • 17.3 kB
JavaScript
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { BsDatepickerModule } from 'ngx-bootstrap/datepicker';
import { CommonModule } from '../common/common.module';
import { CUSTOM, INTERVAL_OPTIONS, LAST_HOUR } from './time-interval.model';
import * as i0 from "@angular/core";
import * as i1 from "../common/icon.directive";
import * as i2 from "@angular/common";
import * as i3 from "../i18n/c8y-translate.pipe";
import * as i4 from "@angular/forms";
import * as i5 from "ngx-bootstrap/datepicker";
export class TimeIntervalComponent {
constructor() {
this.intvervals = INTERVAL_OPTIONS;
this.CUSTOM = CUSTOM;
this.selectedInterval = LAST_HOUR;
this.interval = new EventEmitter();
}
ngAfterViewInit() {
this.changeInterval(this.selectedInterval);
}
changeInterval(intervalOption) {
if (intervalOption !== CUSTOM) {
const interval = {
dateFrom: intervalOption.getStartDate(),
dateTo: this.getEndDate()
};
this.emitInterval(interval);
}
}
changeCustomRange(range) {
this.emitInterval(this.rangeToInterval(range));
}
reload() {
if (this.selectedInterval === CUSTOM) {
this.emitInterval(this.rangeToInterval(this.customRange));
}
else {
this.changeInterval(this.selectedInterval);
}
}
getEndDate() {
const end = new Date();
end.setSeconds(end.getSeconds() + 1);
return end;
}
rangeToInterval(range) {
const dateFrom = new Date(range[0]);
const dateTo = new Date(range[1]);
dateFrom.setHours(0, 0, 0, 0);
if (!this.isToday(dateTo)) {
dateTo.setHours(23, 59, 59, 999);
}
return { dateFrom, dateTo };
}
isToday(date) {
const today = new Date();
return (date?.getDate() === today.getDate() &&
date.getMonth() === today.getMonth() &&
date.getFullYear() === today.getFullYear());
}
emitInterval(interval) {
// only emit valid intervals
if (!isNaN(interval?.dateFrom?.getTime()) && !isNaN(interval?.dateTo?.getTime())) {
this.interval.emit(interval);
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TimeIntervalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TimeIntervalComponent, isStandalone: true, selector: "c8y-time-interval", inputs: { minCustomDate: "minCustomDate", maxCustomDate: "maxCustomDate", dateRangePickerConfig: "dateRangePickerConfig", selectedInterval: "selectedInterval" }, outputs: { interval: "interval" }, ngImport: i0, template: "<form class=\"form-inline\">\n <div class=\"form-group\">\n <div class=\"c8y-select-wrapper\">\n <select\n class=\"form-control\"\n [attr.aria-label]=\"'Time interval' | translate\"\n name=\"interval\"\n [(ngModel)]=\"selectedInterval\"\n (ngModelChange)=\"changeInterval($event)\"\n data-cy=\"c8y-time-interval--select\"\n >\n <option\n *ngFor=\"let interval of intvervals\"\n [ngValue]=\"interval\"\n >\n {{ interval.label | translate }}\n </option>\n </select>\n </div>\n </div>\n\n <div\n class=\"form-group datepicker\"\n *ngIf=\"selectedInterval === CUSTOM\"\n >\n <input\n class=\"form-control\"\n [placeholder]=\"'Select date range' | translate\"\n bsDaterangepicker\n [bsConfig]=\"dateRangePickerConfig\"\n [minDate]=\"minCustomDate\"\n [maxDate]=\"maxCustomDate\"\n [(bsValue)]=\"customRange\"\n (bsValueChange)=\"changeCustomRange($event)\"\n />\n </div>\n\n <button\n class=\"btn btn-link\"\n [title]=\"'Reload' | translate\"\n type=\"button\"\n [disabled]=\"selectedInterval === CUSTOM && (!customRange || customRange.length === 0)\"\n (click)=\"reload()\"\n >\n <i c8yIcon=\"refresh\"></i>\n {{ 'Reload' | translate }}\n </button>\n</form>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.C8yTranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: BsDatepickerModule }, { kind: "directive", type: i5.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: i5.BsDaterangepickerInputDirective, selector: "input[bsDaterangepicker]" }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TimeIntervalComponent, decorators: [{
type: Component,
args: [{ standalone: true, selector: 'c8y-time-interval', imports: [CommonModule, FormsModule, BsDatepickerModule], template: "<form class=\"form-inline\">\n <div class=\"form-group\">\n <div class=\"c8y-select-wrapper\">\n <select\n class=\"form-control\"\n [attr.aria-label]=\"'Time interval' | translate\"\n name=\"interval\"\n [(ngModel)]=\"selectedInterval\"\n (ngModelChange)=\"changeInterval($event)\"\n data-cy=\"c8y-time-interval--select\"\n >\n <option\n *ngFor=\"let interval of intvervals\"\n [ngValue]=\"interval\"\n >\n {{ interval.label | translate }}\n </option>\n </select>\n </div>\n </div>\n\n <div\n class=\"form-group datepicker\"\n *ngIf=\"selectedInterval === CUSTOM\"\n >\n <input\n class=\"form-control\"\n [placeholder]=\"'Select date range' | translate\"\n bsDaterangepicker\n [bsConfig]=\"dateRangePickerConfig\"\n [minDate]=\"minCustomDate\"\n [maxDate]=\"maxCustomDate\"\n [(bsValue)]=\"customRange\"\n (bsValueChange)=\"changeCustomRange($event)\"\n />\n </div>\n\n <button\n class=\"btn btn-link\"\n [title]=\"'Reload' | translate\"\n type=\"button\"\n [disabled]=\"selectedInterval === CUSTOM && (!customRange || customRange.length === 0)\"\n (click)=\"reload()\"\n >\n <i c8yIcon=\"refresh\"></i>\n {{ 'Reload' | translate }}\n </button>\n</form>\n" }]
}], propDecorators: { minCustomDate: [{
type: Input
}], maxCustomDate: [{
type: Input
}], dateRangePickerConfig: [{
type: Input
}], selectedInterval: [{
type: Input
}], interval: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-interval.component.js","sourceRoot":"","sources":["../../../../core/time-interval/time-interval.component.ts","../../../../core/time-interval/time-interval.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { BsDatepickerModule } from 'ngx-bootstrap/datepicker';\nimport { CommonModule } from '../common/common.module';\nimport {\n  CUSTOM,\n  DateRangePickerConfig,\n  INTERVAL_OPTIONS,\n  LAST_HOUR,\n  TimeInterval,\n  TimeIntervalOption\n} from './time-interval.model';\n\n@Component({\n  standalone: true,\n  selector: 'c8y-time-interval',\n  templateUrl: './time-interval.component.html',\n  imports: [CommonModule, FormsModule, BsDatepickerModule]\n})\nexport class TimeIntervalComponent implements AfterViewInit {\n  intvervals = INTERVAL_OPTIONS;\n  CUSTOM = CUSTOM;\n\n  @Input()\n  minCustomDate: Date;\n\n  @Input()\n  maxCustomDate: Date;\n\n  @Input()\n  dateRangePickerConfig: DateRangePickerConfig;\n\n  @Input()\n  selectedInterval: TimeIntervalOption = LAST_HOUR;\n\n  @Output()\n  interval: EventEmitter<TimeInterval> = new EventEmitter();\n\n  customRange: Date[];\n\n  ngAfterViewInit(): void {\n    this.changeInterval(this.selectedInterval);\n  }\n\n  changeInterval(intervalOption: TimeIntervalOption) {\n    if (intervalOption !== CUSTOM) {\n      const interval: TimeInterval = {\n        dateFrom: intervalOption.getStartDate(),\n        dateTo: this.getEndDate()\n      };\n\n      this.emitInterval(interval);\n    }\n  }\n\n  changeCustomRange(range: Date[]) {\n    this.emitInterval(this.rangeToInterval(range));\n  }\n\n  reload() {\n    if (this.selectedInterval === CUSTOM) {\n      this.emitInterval(this.rangeToInterval(this.customRange));\n    } else {\n      this.changeInterval(this.selectedInterval);\n    }\n  }\n\n  private getEndDate(): Date {\n    const end = new Date();\n    end.setSeconds(end.getSeconds() + 1);\n    return end;\n  }\n\n  private rangeToInterval(range: Date[]): TimeInterval {\n    const dateFrom = new Date(range[0]);\n    const dateTo = new Date(range[1]);\n\n    dateFrom.setHours(0, 0, 0, 0);\n    if (!this.isToday(dateTo)) {\n      dateTo.setHours(23, 59, 59, 999);\n    }\n    return { dateFrom, dateTo };\n  }\n\n  private isToday(date: Date): boolean {\n    const today = new Date();\n    return (\n      date?.getDate() === today.getDate() &&\n      date.getMonth() === today.getMonth() &&\n      date.getFullYear() === today.getFullYear()\n    );\n  }\n\n  private emitInterval(interval: TimeInterval) {\n    // only emit valid intervals\n    if (!isNaN(interval?.dateFrom?.getTime()) && !isNaN(interval?.dateTo?.getTime())) {\n      this.interval.emit(interval);\n    }\n  }\n}\n","<form class=\"form-inline\">\n  <div class=\"form-group\">\n    <div class=\"c8y-select-wrapper\">\n      <select\n        class=\"form-control\"\n        [attr.aria-label]=\"'Time interval' | translate\"\n        name=\"interval\"\n        [(ngModel)]=\"selectedInterval\"\n        (ngModelChange)=\"changeInterval($event)\"\n        data-cy=\"c8y-time-interval--select\"\n      >\n        <option\n          *ngFor=\"let interval of intvervals\"\n          [ngValue]=\"interval\"\n        >\n          {{ interval.label | translate }}\n        </option>\n      </select>\n    </div>\n  </div>\n\n  <div\n    class=\"form-group datepicker\"\n    *ngIf=\"selectedInterval === CUSTOM\"\n  >\n    <input\n      class=\"form-control\"\n      [placeholder]=\"'Select date range' | translate\"\n      bsDaterangepicker\n      [bsConfig]=\"dateRangePickerConfig\"\n      [minDate]=\"minCustomDate\"\n      [maxDate]=\"maxCustomDate\"\n      [(bsValue)]=\"customRange\"\n      (bsValueChange)=\"changeCustomRange($event)\"\n    />\n  </div>\n\n  <button\n    class=\"btn btn-link\"\n    [title]=\"'Reload' | translate\"\n    type=\"button\"\n    [disabled]=\"selectedInterval === CUSTOM && (!customRange || customRange.length === 0)\"\n    (click)=\"reload()\"\n  >\n    <i c8yIcon=\"refresh\"></i>\n    {{ 'Reload' | translate }}\n  </button>\n</form>\n"]}