UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

131 lines (130 loc) 14 kB
import * as tslib_1 from "tslib"; var DatepickerComponent_1; /** * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company. * @link https://truedirective.com/ * @license MIT */ import { Component, Input, Renderer2, ElementRef, ViewChild, forwardRef } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { CalendarComponent } from './calendar.component'; import { DropdownBaseComponent } from './dropdown-base.component'; import { MaskDateDirective } from '../mask/mask-date.directive'; import { InternationalizationService } from '../internationalization/internationalization.service'; import { Mask } from '@true-directive/base'; import { Keys } from '@true-directive/base'; /** * Datepicker component */ let DatepickerComponent = DatepickerComponent_1 = class DatepickerComponent extends DropdownBaseComponent { constructor(intl, _elementRef, _renderer) { super(_elementRef, _renderer); this.intl = intl; this._elementRef = _elementRef; this._renderer = _renderer; this._pattern = ''; this.showError = true; this.inputClass = ''; } get pattern() { return this._pattern; } set pattern(s) { this._pattern = s; this.checkPattern(); } checkPattern() { let hasDateComponents = false; const mask = Mask.maskWithPattern(this.intl, this._pattern); mask.sections.forEach(section => { if (section.sectionType.datePart === 'd' || section.sectionType.datePart === 'm' || section.sectionType.datePart === 'y' || section.sectionType.datePart === 'yy' || section.sectionType.datePart === 'yyyy') { hasDateComponents = true; } }); this.usePopup = hasDateComponents; } getIcon() { if (!this.usePopup) { return ''; } return 'true-icon-calendar-empty'; } dateClick(e) { this.popup.closePopup(); } escape(e) { this.popup.closePopup(); } // Overriding this method to send focus in the calendar focusPopup() { this.calendar.setFocus(); } acceptKey(e) { this.maskDateDirective.keyDown(Keys.generateEvent(this.input.nativeElement, -1, Keys.keyChar(e), e.shiftKey, e.ctrlKey)); } }; tslib_1.__decorate([ Input('pattern'), tslib_1.__metadata("design:type", String), tslib_1.__metadata("design:paramtypes", [String]) ], DatepickerComponent.prototype, "pattern", null); tslib_1.__decorate([ Input('error'), tslib_1.__metadata("design:type", String) ], DatepickerComponent.prototype, "error", void 0); tslib_1.__decorate([ Input('showError'), tslib_1.__metadata("design:type", Boolean) ], DatepickerComponent.prototype, "showError", void 0); tslib_1.__decorate([ Input('inputClass'), tslib_1.__metadata("design:type", String) ], DatepickerComponent.prototype, "inputClass", void 0); tslib_1.__decorate([ ViewChild('calendar', { static: false }), tslib_1.__metadata("design:type", CalendarComponent) ], DatepickerComponent.prototype, "calendar", void 0); tslib_1.__decorate([ ViewChild('input', { static: true }), tslib_1.__metadata("design:type", Object) ], DatepickerComponent.prototype, "input", void 0); tslib_1.__decorate([ ViewChild('input', { static: true, read: MaskDateDirective }), tslib_1.__metadata("design:type", MaskDateDirective) ], DatepickerComponent.prototype, "maskDateDirective", void 0); DatepickerComponent = DatepickerComponent_1 = tslib_1.__decorate([ Component({ selector: 'true-datepicker', template: "<true-input-wrapper\r\n (btnClick)=\"btnClick($event)\"\r\n class=\"true-datepicker__input\"\r\n [class.true-input_popup-visible]=\"popupVisible\"\r\n [disabled]=\"disabled\"\r\n [error]=\"error\"\r\n [showError]=\"showError\"\r\n [icon]=\"getIcon()\"><input #input\r\n [ngClass]=\"inputClass\"\r\n [true-mask-date]=\"pattern\"\r\n [readonly]=\"disableTextEditor\"\r\n [attr.disabled]=\"disabled\"\r\n [(ngModel)]=\"value\"\r\n (blur)=\"inputBlur($event)\"\r\n (focus)=\"inputFocus($event)\"\r\n (mousedown)=\"$event.stopPropagation()\"\r\n (keydown)=\"inputKeyDown($event)\" />\r\n</true-input-wrapper><true-popup #popup (close)=\"popupClose($event)\">\r\n <true-calendar #calendar\r\n *ngIf=\"popupVisible\"\r\n [(ngModel)]=\"value\"\r\n (escape)=\"escape($event)\"\r\n (dateClick)=\"dateClick($event)\">\r\n </true-calendar>\r\n</true-popup>\r\n", providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DatepickerComponent_1), multi: true }], styles: [` :host { padding: 0; } .true-datepicker__input { width: 100%; height: 100%; padding: 0; margin: 0; } input { box-sizing: border-box; width: 100%; margin: 0; } `] }), tslib_1.__metadata("design:paramtypes", [InternationalizationService, ElementRef, Renderer2]) ], DatepickerComponent); export { DatepickerComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/controls/datepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { Component, Input, Output, HostBinding, EventEmitter, Renderer2, ElementRef,\r\n         ChangeDetectorRef,\r\n         ViewChild, forwardRef } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nimport { PopupComponent } from './popup.component';\r\nimport { CalendarComponent } from './calendar.component';\r\nimport { DropdownBaseComponent } from './dropdown-base.component';\r\n\r\nimport { MaskDateDirective } from '../mask/mask-date.directive';\r\nimport { InternationalizationService } from '../internationalization/internationalization.service';\r\n\r\nimport { Mask } from '@true-directive/base';\r\nimport { Keys } from '@true-directive/base';\r\n\r\n/**\r\n * Datepicker component\r\n */\r\n@Component({\r\n  selector: 'true-datepicker',\r\n  templateUrl: './datepicker.component.html',\r\n  /* removed:  :host { display: inline-block; } - invalid iOS render */\r\n  styles: [`\r\n    :host {\r\n      padding: 0;\r\n    }\r\n    .true-datepicker__input {\r\n      width: 100%;\r\n      height: 100%;\r\n      padding: 0;\r\n      margin: 0;\r\n    }\r\n\r\n    input {\r\n      box-sizing: border-box;\r\n      width: 100%;\r\n      margin: 0;\r\n    }\r\n  `],\r\n  providers: [{\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => DatepickerComponent),\r\n      multi: true}]\r\n  })\r\nexport class DatepickerComponent extends DropdownBaseComponent {\r\n\r\n  _pattern = '';\r\n\r\n  @Input('pattern')\r\n  get pattern(): string {\r\n    return this._pattern;\r\n  }\r\n\r\n  set pattern(s: string) {\r\n    this._pattern = s;\r\n    this.checkPattern();\r\n  }\r\n\r\n  @Input('error')\r\n  error: string;\r\n\r\n  @Input('showError')\r\n  showError: boolean = true;\r\n\r\n  @Input('inputClass')\r\n  inputClass: string = '';\r\n\r\n  @ViewChild('calendar', {static: false})\r\n  calendar: CalendarComponent;\r\n\r\n  @ViewChild('input', {static: true})\r\n  input: any;\r\n\r\n  @ViewChild('input', { static: true, read: MaskDateDirective })\r\n  maskDateDirective: MaskDateDirective;\r\n\r\n  checkPattern() {\r\n\r\n    let hasDateComponents = false;\r\n    const mask: Mask = Mask.maskWithPattern(this.intl, this._pattern);\r\n\r\n    mask.sections.forEach(section => {\r\n      if (section.sectionType.datePart === 'd' ||\r\n          section.sectionType.datePart === 'm' ||\r\n          section.sectionType.datePart === 'y' ||\r\n          section.sectionType.datePart === 'yy' ||\r\n          section.sectionType.datePart === 'yyyy'\r\n        ) {\r\n        hasDateComponents = true;\r\n      }\r\n    });\r\n    this.usePopup = hasDateComponents;\r\n  }\r\n\r\n  getIcon(): string {\r\n    if (!this.usePopup) {\r\n      return '';\r\n    }\r\n    return 'true-icon-calendar-empty';\r\n  }\r\n\r\n  dateClick(e: any) {\r\n    this.popup.closePopup();\r\n  }\r\n\r\n  escape(e: any) {\r\n    this.popup.closePopup();\r\n  }\r\n\r\n  // Overriding this method to send focus in the calendar\r\n  focusPopup() {\r\n    this.calendar.setFocus();\r\n  }\r\n\r\n  acceptKey(e: any) {\r\n    this.maskDateDirective.keyDown(\r\n      Keys.generateEvent(this.input.nativeElement, -1, Keys.keyChar(e), e.shiftKey, e.ctrlKey)\r\n    );\r\n  }\r\n\r\n  constructor(\r\n    protected intl: InternationalizationService,\r\n    protected _elementRef: ElementRef,\r\n    protected _renderer: Renderer2) {\r\n      super(_elementRef, _renderer);\r\n  }\r\n}\r\n"]}