ngx-ui-hero
Version:
Simple, fast and reliable utilities for Angular.
115 lines • 19.7 kB
JavaScript
import { BsDatepickerDirective, BsLocaleService } from 'ngx-bootstrap/datepicker';
import { Component, EventEmitter, Inject, Input, Optional, Output, ViewChild } from '@angular/core';
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel } from '@angular/forms';
import { DomSanitizer } from '@angular/platform-browser';
import { ElementBase } from '../../base/element-base';
import { INPUT_FORMS_CONFIG } from '../../input-forms-config.constants';
import * as i0 from "@angular/core";
import * as i1 from "ngx-bootstrap/datepicker";
import * as i2 from "@angular/platform-browser";
import * as i3 from "@angular/common";
import * as i4 from "@angular/forms";
import * as i5 from "ngx-bootstrap/tooltip";
import * as i6 from "../input-validations/input-validations.component";
let identifier = 0;
export class InputDateComponent extends ElementBase {
constructor(validators, asyncValidators, config, localeService, domSanitizer) {
super(validators, asyncValidators, config);
this.config = config;
this.localeService = localeService;
this.domSanitizer = domSanitizer;
this.placeholder = '';
this.format = 'MM/dd/yyyy';
this.showInputGroup = true;
this.placement = 'bottom';
this.theme = 'theme-dark-blue';
this.onChange = new EventEmitter();
this.locale = 'en-gb';
this.bsConfig = {
containerClass: this.theme,
customTodayClass: 'today',
};
this.identifier = `input-date-${identifier++}`;
if (config.date) {
Object.assign(this, config.date);
}
}
ngOnInit() {
this.localeService.use(this.locale);
this.datepicker.setConfig();
if (!this.inputGroupText) {
this.inputGroupText = this.domSanitizer.bypassSecurityTrustHtml("<i class='fa fa-calendar' aria-hidden='true'></i>");
}
setTimeout(() => {
this.handleInitialValue();
});
}
ngDoCheck() {
this.handleInitialValue();
}
onValueChange(value) {
this.onChange.emit(value);
}
handleInitialValue() {
if (this.value && (typeof this.value == "string" || this.value instanceof String)) {
let data = new Date(this.value);
data.setHours(0);
data.setMinutes(0);
data.setSeconds(0);
data.setMilliseconds(0);
this.writeValue(data);
}
}
}
InputDateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: InputDateComponent, deps: [{ token: NG_VALIDATORS, optional: true }, { token: NG_ASYNC_VALIDATORS, optional: true }, { token: INPUT_FORMS_CONFIG }, { token: i1.BsLocaleService }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
InputDateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: InputDateComponent, selector: "input-date", inputs: { placeholder: "placeholder", minDate: "minDate", maxDate: "maxDate", format: "format", showInputGroup: "showInputGroup", inputGroupText: "inputGroupText", placement: "placement", theme: "theme" }, outputs: { onChange: "onChange" }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputDateComponent,
multi: true
}], viewQueries: [{ propertyName: "datepicker", first: true, predicate: ["dp"], descendants: true, static: true }, { propertyName: "model", first: true, predicate: NgModel, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<label *ngIf=\"label\" [attr.for]=\"identifier\">\n {{label}}\n <span class=\"required-symbol\" *ngIf=\"isRequired\"> *</span>\n <i class=\"fa fa-question-circle ml-2\" tooltip=\"{{help}}\" container=\"body\" *ngIf=\"help\"></i>\n</label>\n\n<div class=\"input-group\">\n <div class=\"input-group-prepend\" *ngIf=\"showInputGroup\">\n <span class=\"input-group-text\" [innerHtml]=\"inputGroupText\"></span>\n </div>\n\n <input type=\"text\" class=\"form-control\" [id]=\"identifier\" #dp=\"bsDatepicker\"\n bsDatepicker\n autocomplete=\"off\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [placement]=\"placement\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\" \n [bsConfig]=\"bsConfig\"\n [(ngModel)]=\"value\"\n (bsValueChange)=\"onValueChange($event)\"\n [ngClass]=\"{\n 'is-valid': showValidations && !disabled && touched && !(invalid | async),\n 'is-invalid': showValidations && !disabled && touched && (invalid | async)\n }\">\n</div>\n\n<small class=\"text-muted\" *ngIf=\"description\">{{description}}</small>\n\n<input-validations\n *ngIf=\"showValidations && !disabled && touched && (invalid | async)\"\n [messages]=\"failures | async\">\n</input-validations>\n", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.BsDatepickerDirective, selector: "[bsDatepicker]", inputs: ["placement", "triggers", "outsideClick", "container", "outsideEsc", "isOpen", "bsValue", "bsConfig", "isDisabled", "minDate", "maxDate", "minMode", "daysDisabled", "datesDisabled", "datesEnabled", "dateCustomClasses"], outputs: ["bsValueChange", "onShown", "onHidden"], exportAs: ["bsDatepicker"] }, { kind: "directive", type: i1.BsDatepickerInputDirective, selector: "input[bsDatepicker]" }, { kind: "directive", type: i5.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["containerClass", "tooltipAnimation", "tooltipFadeDuration", "isOpen", "tooltipHtml", "tooltip", "tooltipPlacement", "placement", "tooltipIsOpen", "tooltipEnable", "isDisabled", "tooltipAppendToBody", "container", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "delay", "tooltipTrigger", "triggers", "adaptivePosition"], outputs: ["tooltipChange", "tooltipStateChanged", "onShown", "onHidden"], exportAs: ["bs-tooltip"] }, { kind: "component", type: i6.InputValidationsComponent, selector: "input-validations", inputs: ["messages"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: InputDateComponent, decorators: [{
type: Component,
args: [{ selector: 'input-date', providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputDateComponent,
multi: true
}], template: "<label *ngIf=\"label\" [attr.for]=\"identifier\">\n {{label}}\n <span class=\"required-symbol\" *ngIf=\"isRequired\"> *</span>\n <i class=\"fa fa-question-circle ml-2\" tooltip=\"{{help}}\" container=\"body\" *ngIf=\"help\"></i>\n</label>\n\n<div class=\"input-group\">\n <div class=\"input-group-prepend\" *ngIf=\"showInputGroup\">\n <span class=\"input-group-text\" [innerHtml]=\"inputGroupText\"></span>\n </div>\n\n <input type=\"text\" class=\"form-control\" [id]=\"identifier\" #dp=\"bsDatepicker\"\n bsDatepicker\n autocomplete=\"off\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [placement]=\"placement\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\" \n [bsConfig]=\"bsConfig\"\n [(ngModel)]=\"value\"\n (bsValueChange)=\"onValueChange($event)\"\n [ngClass]=\"{\n 'is-valid': showValidations && !disabled && touched && !(invalid | async),\n 'is-invalid': showValidations && !disabled && touched && (invalid | async)\n }\">\n</div>\n\n<small class=\"text-muted\" *ngIf=\"description\">{{description}}</small>\n\n<input-validations\n *ngIf=\"showValidations && !disabled && touched && (invalid | async)\"\n [messages]=\"failures | async\">\n</input-validations>\n" }]
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [NG_VALIDATORS]
}] }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [NG_ASYNC_VALIDATORS]
}] }, { type: undefined, decorators: [{
type: Inject,
args: [INPUT_FORMS_CONFIG]
}] }, { type: i1.BsLocaleService }, { type: i2.DomSanitizer }]; }, propDecorators: { placeholder: [{
type: Input
}], minDate: [{
type: Input
}], maxDate: [{
type: Input
}], format: [{
type: Input
}], showInputGroup: [{
type: Input
}], inputGroupText: [{
type: Input
}], placement: [{
type: Input
}], theme: [{
type: Input
}], onChange: [{
type: Output
}], datepicker: [{
type: ViewChild,
args: ['dp', { static: true }]
}], model: [{
type: ViewChild,
args: [NgModel, { static: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-ui-hero/src/lib/input-forms/components/input-date/input-date.component.ts","../../../../../../../projects/ngx-ui-hero/src/lib/input-forms/components/input-date/input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BsDatepickerConfig, BsDatepickerDirective, BsLocaleService } from 'ngx-bootstrap/datepicker';\n\nimport { Component, DoCheck, EventEmitter, Inject, Input, OnInit, Optional, Output, ViewChild } from '@angular/core';\nimport { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel } from '@angular/forms';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\nimport { ElementBase } from '../../base/element-base';\nimport { AsyncValidatorArray, ValidatorArray } from '../../base/validate';\nimport { InputFormsConfig } from '../../input-forms-config';\nimport { INPUT_FORMS_CONFIG } from '../../input-forms-config.constants';\nimport { InputDateConfig } from './input-date-config';\n\nlet identifier = 0;\n\n@Component({\n  selector: 'input-date',\n  templateUrl: './input-date.component.html',\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputDateComponent,\n    multi: true\n  }]\n})\nexport class InputDateComponent extends ElementBase<Date> implements OnInit, DoCheck, InputDateConfig {\n  @Input() placeholder = '';\n  @Input() minDate?: Date;\n  @Input() maxDate?: Date;\n  @Input() format?: string = 'MM/dd/yyyy';\n  @Input() showInputGroup?: boolean = true;\n  @Input() inputGroupText?: string | SafeHtml;\n  @Input() placement?: string = 'bottom';\n  @Input() theme?: string = 'theme-dark-blue';\n  @Output() onChange = new EventEmitter<Date>();\n  @ViewChild('dp', {static: true}) datepicker: BsDatepickerDirective;\n  @ViewChild(NgModel, {static: true}) model: NgModel;\n\n  locale?: string = 'en-gb';\n  bsConfig: Partial<BsDatepickerConfig> = {\n    containerClass: this.theme,\n    customTodayClass: 'today',\n  };\n\n  public identifier = `input-date-${identifier++}`;\n\n  constructor(\n    @Optional() @Inject(NG_VALIDATORS) validators: ValidatorArray,\n    @Optional() @Inject(NG_ASYNC_VALIDATORS) asyncValidators: AsyncValidatorArray,\n    @Inject( INPUT_FORMS_CONFIG ) public config: InputFormsConfig,\n    private localeService: BsLocaleService,\n    private domSanitizer: DomSanitizer,\n  ) {\n    super(validators, asyncValidators, config);\n\n    if (config.date) {\n      Object.assign(this, config.date);\n    }\n  }\n\n  ngOnInit() {\n    this.localeService.use(this.locale);\n    this.datepicker.setConfig();\n\n    if (!this.inputGroupText) {\n      this.inputGroupText = this.domSanitizer.bypassSecurityTrustHtml(\"<i class='fa fa-calendar' aria-hidden='true'></i>\");\n    }\n\n    setTimeout(()=> {\n      this.handleInitialValue();\n    });\n  }\n  ngDoCheck(): void {\n    this.handleInitialValue();\n  }\n\n  onValueChange(value: any): void {\n    this.onChange.emit(value);  \n  }\n\n  private handleInitialValue(): void {\n    if (this.value && (typeof this.value == \"string\" || this.value instanceof String)) {\n      let data = new Date(this.value);\n      data.setHours(0);\n      data.setMinutes(0);\n      data.setSeconds(0);\n      data.setMilliseconds(0);\n      this.writeValue(data);\n    }\n  }\n}\n","<label *ngIf=\"label\" [attr.for]=\"identifier\">\n  {{label}}\n  <span class=\"required-symbol\" *ngIf=\"isRequired\"> *</span>\n  <i class=\"fa fa-question-circle ml-2\" tooltip=\"{{help}}\" container=\"body\" *ngIf=\"help\"></i>\n</label>\n\n<div class=\"input-group\">\n  <div class=\"input-group-prepend\" *ngIf=\"showInputGroup\">\n    <span class=\"input-group-text\" [innerHtml]=\"inputGroupText\"></span>\n  </div>\n\n  <input type=\"text\" class=\"form-control\" [id]=\"identifier\" #dp=\"bsDatepicker\"\n    bsDatepicker\n    autocomplete=\"off\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [placement]=\"placement\"\n    [placeholder]=\"placeholder\"\n    [disabled]=\"disabled\" \n    [bsConfig]=\"bsConfig\"\n    [(ngModel)]=\"value\"\n    (bsValueChange)=\"onValueChange($event)\"\n    [ngClass]=\"{\n      'is-valid': showValidations && !disabled && touched && !(invalid | async),\n      'is-invalid': showValidations && !disabled && touched && (invalid | async)\n    }\">\n</div>\n\n<small class=\"text-muted\" *ngIf=\"description\">{{description}}</small>\n\n<input-validations\n  *ngIf=\"showValidations && !disabled && touched && (invalid | async)\"\n  [messages]=\"failures | async\">\n</input-validations>\n"]}