angular-bootstrap-datetimepicker
Version:
Native Angular (8+) datetime picker component styled by Twitter Bootstrap 4.
210 lines • 23.1 kB
JavaScript
import * as tslib_1 from "tslib";
import { Directive, ElementRef, EventEmitter, HostListener, Inject, Input, Output, Renderer2 } from '@angular/core';
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, Validators, } from '@angular/forms';
import * as _moment from 'moment';
import { DL_DATE_TIME_DISPLAY_FORMAT, DL_DATE_TIME_INPUT_FORMATS, DlDateAdapter } from '../core/public-api';
import { DlDateTimeInputChange } from './dl-date-time-input-change';
/**
* @internal
*/
var moment = _moment;
/**
* This directive allows the user to enter dates, using the keyboard, into an input box and
* angular will then store a date value in the model.
*
* The input format(s), display format, and model format are independent and fully customizable.
*/
var DlDateTimeInputDirective = /** @class */ (function () {
/**
* Constructs a new instance of this directive.
* @param _renderer
* reference to the renderer.
* @param _elementRef
* reference to this element.
* @param _dateAdapter
* date adapter for the date type in the model.
* @param _displayFormat
* from `DL_DATE_TIME_DISPLAY_FORMAT`, which defines the format to use for a valid date/time value.
* @param _inputFormats
* from `DL_DATE_TIME_INPUT_FORMATS`, which defines the input formats that allowed as valid date/time values.
* NB: moment is always in strict parse mode for this directive.
*/
function DlDateTimeInputDirective(_renderer, _elementRef, _dateAdapter, _displayFormat, _inputFormats) {
var _this = this;
this._renderer = _renderer;
this._elementRef = _elementRef;
this._dateAdapter = _dateAdapter;
this._displayFormat = _displayFormat;
this._inputFormats = _inputFormats;
/* tslint:disable:member-ordering */
this._filterValidator = function (control) {
// @ts-ignore
return (_this._inputFilter || (function () { return true; }))(_this._value) ?
null : { 'dlDateTimeInputFilter': { 'value': control.value } };
};
this._inputFilter = function () { return true; };
this._isValid = true;
this._parseValidator = function () {
return _this._isValid ?
null : { 'dlDateTimeInputParse': { 'text': _this._elementRef.nativeElement.value } };
};
this._changed = [];
this._touched = [];
this._validator = Validators.compose([this._parseValidator, this._filterValidator]);
this._onValidatorChange = function () { };
this._value = undefined;
/**
* Emits when a `change` event when date/time is selected or
* the value of the date/time picker changes.
**/
this.dateChange = new EventEmitter();
}
DlDateTimeInputDirective_1 = DlDateTimeInputDirective;
Object.defineProperty(DlDateTimeInputDirective.prototype, "dlDateTimeInputFilter", {
/**
* Set a function used to determine whether or not the `value` entered by the user is allowed.
* @param inputFilterFunction
* a function that returns `true` if the `value` entered by the user is allowed, otherwise `false`.
*/
set: function (inputFilterFunction) {
this._inputFilter = inputFilterFunction || (function () { return true; });
this._onValidatorChange();
},
enumerable: true,
configurable: true
});
Object.defineProperty(DlDateTimeInputDirective.prototype, "value", {
/* tslint:enable:member-ordering */
/**
* Returns `D` value of the date/time input or `undefined` | `null` if no value is set.
**/
get: function () {
return this._value;
},
/**
* Set the value of the date/time input to a value of `D` | `undefined` | `null`;
* @param newValue
* the new value of the date/time input
*/
set: function (newValue) {
var _this = this;
if (newValue !== this._value) {
this._value = newValue;
this._changed.forEach(function (onChanged) { return onChanged(_this._value); });
}
},
enumerable: true,
configurable: true
});
/**
* Emit a `change` event when the value of the input changes.
*/
DlDateTimeInputDirective.prototype._onChange = function () {
this.dateChange.emit(new DlDateTimeInputChange(this._value));
};
/**
* Format the input text using {@link DL_DATE_TIME_DISPLAY_FORMAT} and mark the control as touched.
*/
DlDateTimeInputDirective.prototype._onBlur = function () {
if (this._value) {
this._setElementValue(this._value);
}
this._touched.forEach(function (onTouched) { return onTouched(); });
};
/**
* Parse the user input into a possibly valid date.
* The model value is not set if the input is NOT one of the {@link DL_DATE_TIME_INPUT_FORMATS}.
* @param value
* Value of the input control.
*/
DlDateTimeInputDirective.prototype._onInput = function (value) {
var testDate = value === null || value === undefined || value === ''
? undefined
: moment(value, this._inputFormats, true);
this._isValid = testDate && testDate.isValid();
this.value = this._isValid ? this._dateAdapter.fromMilliseconds(testDate.valueOf()) : undefined;
};
/**
* @internal
*/
DlDateTimeInputDirective.prototype._setElementValue = function (value) {
if (value !== null && value !== undefined) {
this._renderer.setProperty(this._elementRef.nativeElement, 'value', moment(value).format(this._displayFormat));
}
};
/**
* @internal
*/
DlDateTimeInputDirective.prototype.registerOnChange = function (onChange) {
this._changed.push(onChange);
};
/**
* @internal
*/
DlDateTimeInputDirective.prototype.registerOnTouched = function (onTouched) {
this._touched.push(onTouched);
};
/**
* @internal
*/
DlDateTimeInputDirective.prototype.registerOnValidatorChange = function (validatorOnChange) {
this._onValidatorChange = validatorOnChange;
};
/**
* @internal
*/
DlDateTimeInputDirective.prototype.setDisabledState = function (isDisabled) {
this._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);
};
/**
* @internal
*/
DlDateTimeInputDirective.prototype.validate = function (control) {
return this._validator(control);
};
/**
* @internal
*/
DlDateTimeInputDirective.prototype.writeValue = function (value) {
this._isValid = true;
this.value = value;
this._setElementValue(value);
};
var DlDateTimeInputDirective_1;
DlDateTimeInputDirective.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: ElementRef },
{ type: DlDateAdapter },
{ type: String, decorators: [{ type: Inject, args: [DL_DATE_TIME_DISPLAY_FORMAT,] }] },
{ type: Array, decorators: [{ type: Inject, args: [DL_DATE_TIME_INPUT_FORMATS,] }] }
]; };
tslib_1.__decorate([
Output()
], DlDateTimeInputDirective.prototype, "dateChange", void 0);
tslib_1.__decorate([
Input()
], DlDateTimeInputDirective.prototype, "dlDateTimeInputFilter", null);
tslib_1.__decorate([
HostListener('change')
], DlDateTimeInputDirective.prototype, "_onChange", null);
tslib_1.__decorate([
HostListener('blur')
], DlDateTimeInputDirective.prototype, "_onBlur", null);
tslib_1.__decorate([
HostListener('input', ['$event.target.value'])
], DlDateTimeInputDirective.prototype, "_onInput", null);
DlDateTimeInputDirective = DlDateTimeInputDirective_1 = tslib_1.__decorate([
Directive({
selector: 'input[dlDateTimeInput]',
providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: DlDateTimeInputDirective_1, multi: true },
{ provide: NG_VALIDATORS, useExisting: DlDateTimeInputDirective_1, multi: true }
]
}),
tslib_1.__param(3, Inject(DL_DATE_TIME_DISPLAY_FORMAT)),
tslib_1.__param(4, Inject(DL_DATE_TIME_INPUT_FORMATS))
], DlDateTimeInputDirective);
return DlDateTimeInputDirective;
}());
export { DlDateTimeInputDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dl-date-time-input.directive.js","sourceRoot":"ng://angular-bootstrap-datetimepicker/","sources":["dl-date-time-input/dl-date-time-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, EventEmitter, HostListener, Inject, Input, Output, Renderer2} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport * as _moment from 'moment';\nimport {DL_DATE_TIME_DISPLAY_FORMAT, DL_DATE_TIME_INPUT_FORMATS, DlDateAdapter} from '../core/public-api';\nimport {DlDateTimeInputChange} from './dl-date-time-input-change';\n\n/**\n * @internal\n */\nconst moment = _moment;\n\n/**\n *  This directive allows the user to enter dates, using the keyboard, into an input box and\n *  angular will then store a date value in the model.\n *\n *  The input format(s), display format, and model format are independent and fully customizable.\n */\n@Directive({\n  selector: 'input[dlDateTimeInput]',\n  providers: [\n    {provide: NG_VALUE_ACCESSOR, useExisting:  DlDateTimeInputDirective, multi: true},\n    {provide: NG_VALIDATORS, useExisting:  DlDateTimeInputDirective, multi: true}\n  ]\n})\nexport class DlDateTimeInputDirective<D> implements ControlValueAccessor, Validator {\n\n  /* tslint:disable:member-ordering */\n  private _filterValidator: ValidatorFn = (control: AbstractControl): ValidationErrors | null => {\n    // @ts-ignore\n    return (this._inputFilter || (() => true))(this._value) ?\n      null : {'dlDateTimeInputFilter': {'value': control.value}};\n  }\n  private _inputFilter: (value: (D | null)) => boolean = () => true;\n  private _isValid = true;\n  private _parseValidator: ValidatorFn = (): ValidationErrors | null => {\n    return this._isValid ?\n      null : {'dlDateTimeInputParse': {'text': this._elementRef.nativeElement.value}};\n  }\n  private _changed: ((value: D) => void)[] = [];\n  private _touched: (() => void)[] = [];\n  private _validator = Validators.compose([this._parseValidator, this._filterValidator]);\n  private _onValidatorChange: () => void = () => {};\n  private _value: D | undefined = undefined;\n\n  /**\n   * Emits when a `change` event when date/time is selected or\n   * the value of the date/time picker changes.\n   **/\n  @Output()\n  readonly dateChange = new EventEmitter<DlDateTimeInputChange<D>>();\n\n  /**\n   * Constructs a new instance of this directive.\n   * @param _renderer\n   *  reference to the renderer.\n   * @param _elementRef\n   *  reference to this element.\n   * @param _dateAdapter\n   *  date adapter for the date type in the model.\n   * @param _displayFormat\n   *  from `DL_DATE_TIME_DISPLAY_FORMAT`, which defines the format to use for a valid date/time value.\n   * @param _inputFormats\n   *  from `DL_DATE_TIME_INPUT_FORMATS`, which defines the input formats that allowed as valid date/time values.\n   *  NB: moment is always in strict parse mode for this directive.\n   */\n  constructor(\n    private _renderer: Renderer2,\n    private _elementRef: ElementRef,\n    private _dateAdapter: DlDateAdapter<D>,\n    @Inject(DL_DATE_TIME_DISPLAY_FORMAT) private readonly _displayFormat: string,\n    @Inject(DL_DATE_TIME_INPUT_FORMATS) private readonly _inputFormats: string[]\n  ) {}\n\n  /**\n   * Set a function used to determine whether or not the `value` entered by the user is allowed.\n   * @param inputFilterFunction\n   *   a function that returns `true` if the `value` entered by the user is allowed, otherwise `false`.\n   */\n  @Input()\n  set dlDateTimeInputFilter(inputFilterFunction: (value: D | null) => boolean) {\n    this._inputFilter = inputFilterFunction || (() => true);\n    this._onValidatorChange();\n  }\n\n  /* tslint:enable:member-ordering */\n\n  /**\n   * Returns `D` value of the date/time input or `undefined` | `null` if no value is set.\n   **/\n  get value(): D {\n    return this._value;\n  }\n\n  /**\n   * Set the value of the date/time input to a value of `D` | `undefined` | `null`;\n   * @param newValue\n   *  the new value of the date/time input\n   */\n\n  set value(newValue: D | null | undefined) {\n    if (newValue !== this._value) {\n      this._value = newValue;\n      this._changed.forEach(onChanged => onChanged(this._value));\n    }\n  }\n\n  /**\n   * Emit a `change` event when the value of the input changes.\n   */\n  @HostListener('change') _onChange() {\n    this.dateChange.emit(new DlDateTimeInputChange(this._value));\n  }\n\n  /**\n   * Format the input text using {@link DL_DATE_TIME_DISPLAY_FORMAT} and mark the control as touched.\n   */\n  @HostListener('blur') _onBlur() {\n    if (this._value) {\n      this._setElementValue(this._value);\n    }\n    this._touched.forEach(onTouched => onTouched());\n  }\n\n  /**\n   * Parse the user input into a possibly valid date.\n   * The model value is not set if the input is NOT one of the {@link DL_DATE_TIME_INPUT_FORMATS}.\n   * @param value\n   *   Value of the input control.\n   */\n  @HostListener('input', ['$event.target.value']) _onInput(value: string | null | undefined): void {\n    const testDate = value === null || value === undefined || value === ''\n      ? undefined\n      : moment(value, this._inputFormats, true);\n\n    this._isValid = testDate && testDate.isValid();\n    this.value = this._isValid ? this._dateAdapter.fromMilliseconds(testDate.valueOf()) : undefined;\n  }\n\n  /**\n   * @internal\n   */\n  private _setElementValue(value: D) {\n    if (value !== null && value !== undefined) {\n      this._renderer.setProperty(this._elementRef.nativeElement, 'value', moment(value).format(this._displayFormat));\n    }\n  }\n\n  /**\n   * @internal\n   */\n  registerOnChange(onChange: (value: any) => void): void {\n    this._changed.push(onChange);\n  }\n\n  /**\n   * @internal\n   */\n  registerOnTouched(onTouched: () => void): void {\n    this._touched.push(onTouched);\n  }\n\n  /**\n   * @internal\n   */\n  registerOnValidatorChange(validatorOnChange: () => void): void {\n    this._onValidatorChange = validatorOnChange;\n  }\n\n  /**\n   * @internal\n   */\n  setDisabledState(isDisabled: boolean): void {\n    this._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n  }\n\n  /**\n   * @internal\n   */\n  validate(control: AbstractControl): ValidationErrors | null {\n    return this._validator(control);\n  }\n\n  /**\n   * @internal\n   */\n  writeValue(value: D): void {\n    this._isValid = true;\n    this.value = value;\n    this._setElementValue(value);\n  }\n}\n"]}