UNPKG

ngx-datetime-16

Version:

Update of ng2-datetime that is compatible with Angular v16+

331 lines 34.2 kB
import { Component, Input, HostListener, HostBinding, forwardRef, } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/forms"; const CUSTOM_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgxDatetimeComponent), multi: true, }; export class NgxDatetimeComponent { constructor() { this.timepickerOptions = {}; this.datepickerOptions = {}; this.idDatePicker = uniqueId('q-datepicker_'); this.idTimePicker = uniqueId('q-timepicker_'); this.onChange = (_) => { }; this.onTouched = () => { }; } get tabindexAttr() { return this.tabindex === undefined ? '-1' : undefined; } ngAfterViewInit() { this.init(); } ngOnDestroy() { if (this.datepicker) { this.datepicker.datepicker('destroy'); } if (this.timepicker) { this.timepicker.timepicker('remove'); } } ngOnChanges(changes) { if (changes) { if (changes['datepickerOptions'] && this.datepicker) { this.datepicker.datepicker('destroy'); if (changes['datepickerOptions'].currentValue) { this.datepicker = null; this.init(); } else if (changes['datepickerOptions'].currentValue === false) { this.datepicker.remove(); } } if (changes['timepickerOptions'] && this.timepicker) { this.timepicker.timepicker('remove'); if (changes['timepickerOptions'].currentValue) { this.timepicker = null; this.init(); } else if (changes['timepickerOptions'].currentValue === false) { this.timepicker.parent().remove(); } } } } writeValue(value) { this.date = value; if (isDate(this.date)) { setTimeout(() => { this.updateModel(this.date); }, 0); } else { this.clearModels(); } } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } checkEmptyValue(e) { const value = e.target.value; if (value === '' && (this.timepickerOptions === false || this.datepickerOptions === false || (this.timeModel === '' && this.dateModel === ''))) { this.onChange(undefined); } } clearModels() { this.onChange(undefined); if (this.timepicker) { this.timepicker.timepicker('setTime', null); } this.updateDatepicker(null); } showTimepicker() { this.timepicker.timepicker('showWidget'); } showDatepicker() { this.datepicker.datepicker('show'); } ////////////////////////////////// init() { if (!this.datepicker && this.datepickerOptions !== false) { let options = jQuery.extend({ enableOnReadonly: !this.readonly }, this.datepickerOptions); this.datepicker = $('#' + this.idDatePicker).datepicker(options); this.datepicker.on('changeDate', (e) => { let newDate = e.date; if (isDate(this.date) && isDate(newDate)) { // get hours/minutes newDate.setHours(this.date.getHours()); newDate.setMinutes(this.date.getMinutes()); newDate.setSeconds(this.date.getSeconds()); } this.date = newDate; this.onChange(newDate); }); } else if (this.datepickerOptions === false) { $('#' + this.idDatePicker).remove(); } if (!this.timepicker && this.timepickerOptions !== false) { let options = jQuery.extend({ defaultTime: false }, this.timepickerOptions); this.timepicker = $('#' + this.idTimePicker).timepicker(options); this.timepicker.on('changeTime.timepicker', (e) => { let { meridian, hours } = e.time; if (meridian) { // has meridian -> convert 12 to 24h if (meridian === 'PM' && hours < 12) { hours = hours + 12; } if (meridian === 'AM' && hours === 12) { hours = hours - 12; } hours = parseInt(this.pad(hours), 10); } if (!isDate(this.date)) { this.date = new Date(); this.updateDatepicker(this.date); } this.date.setHours(hours); this.date.setMinutes(e.time.minutes); this.date.setSeconds(e.time.seconds); this.onChange(this.date); }); } else if (this.timepickerOptions === false) { $('#' + this.idTimePicker).parent().remove(); } this.updateModel(this.date); } updateModel(date) { this.updateDatepicker(date); // update timepicker if (this.timepicker !== undefined && isDate(date)) { let hours = date.getHours(); if (this.timepickerOptions.showMeridian) { // Convert 24 to 12 hour system hours = hours === 0 || hours === 12 ? 12 : hours % 12; } const meridian = date.getHours() >= 12 ? ' PM' : ' AM'; const time = this.pad(hours) + ':' + this.pad(this.date.getMinutes()) + ':' + this.pad(this.date.getSeconds()) + (this.timepickerOptions.showMeridian || this.timepickerOptions.showMeridian === undefined ? meridian : ''); this.timepicker.timepicker('setTime', time); this.timeModel = time; // fix initial empty timeModel bug } } updateDatepicker(date) { if (this.datepicker !== undefined) { this.datepicker.datepicker('update', date); } } pad(value) { return value.toString().length < 2 ? '0' + value : value.toString(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgxDatetimeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: NgxDatetimeComponent, selector: "ngx-datetime", inputs: { timepickerOptions: ["timepicker", "timepickerOptions"], datepickerOptions: ["datepicker", "datepickerOptions"], hasClearButton: "hasClearButton", readonly: "readonly", required: "required", tabindex: "tabindex" }, host: { listeners: { "blur": "onTouched()" }, properties: { "attr.tabindex": "this.tabindexAttr" } }, providers: [CUSTOM_ACCESSOR], usesOnChanges: true, ngImport: i0, template: ` <div class="ng2-datetime"> <div [ngClass]="{ 'input-group': !datepickerOptions.hideIcon, date: true }" > <input id="{{ idDatePicker }}" type="text" class="form-control" [attr.readonly]="readonly" [attr.required]="required" [attr.placeholder]="datepickerOptions.placeholder || 'Choose date'" [attr.tabindex]="tabindex" [(ngModel)]="dateModel" (blur)="onTouched()" (keyup)="checkEmptyValue($event)" /> <div [hidden]="datepickerOptions.hideIcon || datepickerOptions === false" (click)="showDatepicker()" class="input-group-addon" > <span [ngClass]="datepickerOptions.icon || 'glyphicon glyphicon-th'" ></span> </div> </div> <div [ngClass]="{ 'input-group': !timepickerOptions.hideIcon, 'bootstrap-timepicker timepicker': true }" > <input id="{{ idTimePicker }}" type="text" class="form-control input-small" [attr.readonly]="readonly" [attr.required]="required" [attr.placeholder]="timepickerOptions.placeholder || 'Set time'" [attr.tabindex]="tabindex" [(ngModel)]="timeModel" (focus)="showTimepicker()" (blur)="onTouched()" (keyup)="checkEmptyValue($event)" /> <span [hidden]="timepickerOptions.hideIcon || false" class="input-group-addon" > <i [ngClass]="timepickerOptions.icon || 'glyphicon glyphicon-time'" ></i> </span> </div> <button *ngIf="hasClearButton" type="button" (click)="clearModels()"> Clear </button> </div> `, isInline: true, styles: [".ng2-datetime *[hidden]{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: NgxDatetimeComponent, decorators: [{ type: Component, args: [{ selector: 'ngx-datetime', providers: [CUSTOM_ACCESSOR], template: ` <div class="ng2-datetime"> <div [ngClass]="{ 'input-group': !datepickerOptions.hideIcon, date: true }" > <input id="{{ idDatePicker }}" type="text" class="form-control" [attr.readonly]="readonly" [attr.required]="required" [attr.placeholder]="datepickerOptions.placeholder || 'Choose date'" [attr.tabindex]="tabindex" [(ngModel)]="dateModel" (blur)="onTouched()" (keyup)="checkEmptyValue($event)" /> <div [hidden]="datepickerOptions.hideIcon || datepickerOptions === false" (click)="showDatepicker()" class="input-group-addon" > <span [ngClass]="datepickerOptions.icon || 'glyphicon glyphicon-th'" ></span> </div> </div> <div [ngClass]="{ 'input-group': !timepickerOptions.hideIcon, 'bootstrap-timepicker timepicker': true }" > <input id="{{ idTimePicker }}" type="text" class="form-control input-small" [attr.readonly]="readonly" [attr.required]="required" [attr.placeholder]="timepickerOptions.placeholder || 'Set time'" [attr.tabindex]="tabindex" [(ngModel)]="timeModel" (focus)="showTimepicker()" (blur)="onTouched()" (keyup)="checkEmptyValue($event)" /> <span [hidden]="timepickerOptions.hideIcon || false" class="input-group-addon" > <i [ngClass]="timepickerOptions.icon || 'glyphicon glyphicon-time'" ></i> </span> </div> <button *ngIf="hasClearButton" type="button" (click)="clearModels()"> Clear </button> </div> `, styles: [".ng2-datetime *[hidden]{display:none}\n"] }] }], propDecorators: { timepickerOptions: [{ type: Input, args: ['timepicker'] }], datepickerOptions: [{ type: Input, args: ['datepicker'] }], hasClearButton: [{ type: Input, args: ['hasClearButton'] }], readonly: [{ type: Input }], required: [{ type: Input }], tabindex: [{ type: Input }], onTouched: [{ type: HostListener, args: ['blur'] }], tabindexAttr: [{ type: HostBinding, args: ['attr.tabindex'] }] } }); let id = 0; function uniqueId(prefix) { return prefix + ++id; } function isDate(obj) { return Object.prototype.toString.call(obj) === '[object Date]'; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-datetime.component.js","sourceRoot":"","sources":["../../../../projects/ngx-datetime/src/lib/ngx-datetime.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  HostListener,\n  AfterViewInit,\n  OnDestroy,\n  SimpleChanges,\n  OnChanges,\n  HostBinding,\n  forwardRef,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ITimepickerEvent } from './ITimepickerEvent';\n\ndeclare var jQuery: any;\ndeclare var $: any;\n\nconst CUSTOM_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => NgxDatetimeComponent),\n  multi: true,\n};\n\n@Component({\n  selector: 'ngx-datetime',\n  providers: [CUSTOM_ACCESSOR],\n  template: `\n    <div class=\"ng2-datetime\">\n      <div\n        [ngClass]=\"{ 'input-group': !datepickerOptions.hideIcon, date: true }\"\n      >\n        <input\n          id=\"{{ idDatePicker }}\"\n          type=\"text\"\n          class=\"form-control\"\n          [attr.readonly]=\"readonly\"\n          [attr.required]=\"required\"\n          [attr.placeholder]=\"datepickerOptions.placeholder || 'Choose date'\"\n          [attr.tabindex]=\"tabindex\"\n          [(ngModel)]=\"dateModel\"\n          (blur)=\"onTouched()\"\n          (keyup)=\"checkEmptyValue($event)\"\n        />\n        <div\n          [hidden]=\"datepickerOptions.hideIcon || datepickerOptions === false\"\n          (click)=\"showDatepicker()\"\n          class=\"input-group-addon\"\n        >\n          <span\n            [ngClass]=\"datepickerOptions.icon || 'glyphicon glyphicon-th'\"\n          ></span>\n        </div>\n      </div>\n      <div\n        [ngClass]=\"{\n          'input-group': !timepickerOptions.hideIcon,\n          'bootstrap-timepicker timepicker': true\n        }\"\n      >\n        <input\n          id=\"{{ idTimePicker }}\"\n          type=\"text\"\n          class=\"form-control input-small\"\n          [attr.readonly]=\"readonly\"\n          [attr.required]=\"required\"\n          [attr.placeholder]=\"timepickerOptions.placeholder || 'Set time'\"\n          [attr.tabindex]=\"tabindex\"\n          [(ngModel)]=\"timeModel\"\n          (focus)=\"showTimepicker()\"\n          (blur)=\"onTouched()\"\n          (keyup)=\"checkEmptyValue($event)\"\n        />\n        <span\n          [hidden]=\"timepickerOptions.hideIcon || false\"\n          class=\"input-group-addon\"\n        >\n          <i\n            [ngClass]=\"timepickerOptions.icon || 'glyphicon glyphicon-time'\"\n          ></i>\n        </span>\n      </div>\n      <button *ngIf=\"hasClearButton\" type=\"button\" (click)=\"clearModels()\">\n        Clear\n      </button>\n    </div>\n  `,\n  styles: ['.ng2-datetime *[hidden] { display: none; }'],\n})\nexport class NgxDatetimeComponent\n  implements ControlValueAccessor, AfterViewInit, OnDestroy, OnChanges\n{\n  @Input('timepicker') timepickerOptions: any = {};\n  @Input('datepicker') datepickerOptions: any = {};\n  @Input('hasClearButton') hasClearButton?: boolean;\n  @Input() readonly?: boolean;\n  @Input() required?: boolean;\n  @Input() tabindex?: string;\n\n  date!: Date; // ngModel\n  dateModel?: string;\n  timeModel?: string;\n\n  // instances\n  datepicker: any;\n  timepicker: any;\n\n  idDatePicker: string = uniqueId('q-datepicker_');\n  idTimePicker: string = uniqueId('q-timepicker_');\n\n  onChange = (_: any) => {};\n\n  @HostListener('blur')\n  onTouched = () => {};\n\n  @HostBinding('attr.tabindex')\n  get tabindexAttr(): string | undefined {\n    return this.tabindex === undefined ? '-1' : undefined;\n  }\n\n  ngAfterViewInit() {\n    this.init();\n  }\n\n  ngOnDestroy() {\n    if (this.datepicker) {\n      this.datepicker.datepicker('destroy');\n    }\n    if (this.timepicker) {\n      this.timepicker.timepicker('remove');\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes) {\n      if (changes['datepickerOptions'] && this.datepicker) {\n        this.datepicker.datepicker('destroy');\n\n        if (changes['datepickerOptions'].currentValue) {\n          this.datepicker = null;\n          this.init();\n        } else if (changes['datepickerOptions'].currentValue === false) {\n          this.datepicker.remove();\n        }\n      }\n      if (changes['timepickerOptions'] && this.timepicker) {\n        this.timepicker.timepicker('remove');\n\n        if (changes['timepickerOptions'].currentValue) {\n          this.timepicker = null;\n          this.init();\n        } else if (changes['timepickerOptions'].currentValue === false) {\n          this.timepicker.parent().remove();\n        }\n      }\n    }\n  }\n\n  writeValue(value: any) {\n    this.date = value;\n    if (isDate(this.date)) {\n      setTimeout(() => {\n        this.updateModel(this.date);\n      }, 0);\n    } else {\n      this.clearModels();\n    }\n  }\n\n  registerOnChange(fn: (_: any) => void) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn;\n  }\n\n  checkEmptyValue(e: any) {\n    const value = e.target.value;\n    if (\n      value === '' &&\n      (this.timepickerOptions === false ||\n        this.datepickerOptions === false ||\n        (this.timeModel === '' && this.dateModel === ''))\n    ) {\n      this.onChange(undefined);\n    }\n  }\n\n  clearModels() {\n    this.onChange(undefined);\n    if (this.timepicker) {\n      this.timepicker.timepicker('setTime', null);\n    }\n    this.updateDatepicker(null);\n  }\n\n  showTimepicker() {\n    this.timepicker.timepicker('showWidget');\n  }\n\n  showDatepicker() {\n    this.datepicker.datepicker('show');\n  }\n\n  //////////////////////////////////\n\n  private init(): void {\n    if (!this.datepicker && this.datepickerOptions !== false) {\n      let options = jQuery.extend(\n        { enableOnReadonly: !this.readonly },\n        this.datepickerOptions\n      );\n      this.datepicker = (<any>$('#' + this.idDatePicker)).datepicker(options);\n      this.datepicker.on('changeDate', (e: any) => {\n        let newDate: Date = e.date;\n\n        if (isDate(this.date) && isDate(newDate)) {\n          // get hours/minutes\n          newDate.setHours(this.date.getHours());\n          newDate.setMinutes(this.date.getMinutes());\n          newDate.setSeconds(this.date.getSeconds());\n        }\n\n        this.date = newDate;\n        this.onChange(newDate);\n      });\n    } else if (this.datepickerOptions === false) {\n      (<any>$('#' + this.idDatePicker)).remove();\n    }\n\n    if (!this.timepicker && this.timepickerOptions !== false) {\n      let options = jQuery.extend(\n        { defaultTime: false },\n        this.timepickerOptions\n      );\n      this.timepicker = (<any>$('#' + this.idTimePicker)).timepicker(options);\n      this.timepicker.on('changeTime.timepicker', (e: ITimepickerEvent) => {\n        let { meridian, hours } = e.time;\n\n        if (meridian) {\n          // has meridian -> convert 12 to 24h\n          if (meridian === 'PM' && hours < 12) {\n            hours = hours + 12;\n          }\n          if (meridian === 'AM' && hours === 12) {\n            hours = hours - 12;\n          }\n          hours = parseInt(this.pad(hours), 10);\n        }\n\n        if (!isDate(this.date)) {\n          this.date = new Date();\n          this.updateDatepicker(this.date);\n        }\n\n        this.date.setHours(hours);\n        this.date.setMinutes(e.time.minutes);\n        this.date.setSeconds(e.time.seconds);\n        this.onChange(this.date);\n      });\n    } else if (this.timepickerOptions === false) {\n      (<any>$('#' + this.idTimePicker)).parent().remove();\n    }\n\n    this.updateModel(this.date);\n  }\n\n  private updateModel(date: Date): void {\n    this.updateDatepicker(date);\n\n    // update timepicker\n    if (this.timepicker !== undefined && isDate(date)) {\n      let hours = date.getHours();\n      if (this.timepickerOptions.showMeridian) {\n        // Convert 24 to 12 hour system\n        hours = hours === 0 || hours === 12 ? 12 : hours % 12;\n      }\n      const meridian = date.getHours() >= 12 ? ' PM' : ' AM';\n      const time =\n        this.pad(hours) +\n        ':' +\n        this.pad(this.date.getMinutes()) +\n        ':' +\n        this.pad(this.date.getSeconds()) +\n        (this.timepickerOptions.showMeridian ||\n        this.timepickerOptions.showMeridian === undefined\n          ? meridian\n          : '');\n      this.timepicker.timepicker('setTime', time);\n      this.timeModel = time; // fix initial empty timeModel bug\n    }\n  }\n\n  private updateDatepicker(date?: any) {\n    if (this.datepicker !== undefined) {\n      this.datepicker.datepicker('update', date);\n    }\n  }\n\n  private pad(value: any): string {\n    return value.toString().length < 2 ? '0' + value : value.toString();\n  }\n}\n\nlet id = 0;\nfunction uniqueId(prefix: string): string {\n  return prefix + ++id;\n}\n\nfunction isDate(obj: any) {\n  return Object.prototype.toString.call(obj) === '[object Date]';\n}\n"]}