UNPKG

ngx-animating-datepicker

Version:

An Animating Datepicker for Angular 2+, for some smooth date picking :).

498 lines 35.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { ApplicationRef, ComponentFactoryResolver, Directive, EventEmitter, HostListener, Injector, Input, Optional, Output, Renderer2, ViewContainerRef } from '@angular/core'; import { NgControl } from '@angular/forms'; import { UtilitiesService } from '../../services/utilities.service'; import { AnimatepickerComponent } from '../animatepicker/animatepicker.component'; import { DatepickerComponent } from './datepicker.component'; import { DefaultDirectiveOptions } from './datepicker.options'; var DatepickerDirective = /** @class */ (function () { function DatepickerDirective(viewContainerRef, componentFactoryResolver, appRef, injector, renderer, formControl) { this.viewContainerRef = viewContainerRef; this.componentFactoryResolver = componentFactoryResolver; this.appRef = appRef; this.injector = injector; this.renderer = renderer; this.formControl = formControl; this.datepicker = null; // TODO: fix types: DatepickerComponent | AnimatepickerComponent this._options = DefaultDirectiveOptions; /** * Selected Dates: handles the selected dates array. Can be set both internally and externally */ this._selectedDates = []; this.selectedDatesChange = new EventEmitter(); } Object.defineProperty(DatepickerDirective.prototype, "options", { get: /** * @return {?} */ function () { return this._options; }, set: /** * @param {?} options * @return {?} */ function (options) { if (options === undefined || !options) { return; } // TODO: could be improved this._options = tslib_1.__assign({}, this._options, options); }, enumerable: true, configurable: true }); Object.defineProperty(DatepickerDirective.prototype, "datepickerOptions", { get: /** * @return {?} */ function () { return this._datepickerOptions; }, set: /** * @param {?} options * @return {?} */ function (options) { this._datepickerOptions = options; if (this.datepicker) { this.datepicker.options = options; } }, enumerable: true, configurable: true }); Object.defineProperty(DatepickerDirective.prototype, "language", { get: /** * @return {?} */ function () { return this._language; }, set: /** * @param {?} value * @return {?} */ function (value) { this._language = value; if (this.datepicker) { this.datepicker.language = value; } }, enumerable: true, configurable: true }); Object.defineProperty(DatepickerDirective.prototype, "minDate", { get: /** * @return {?} */ function () { return this._minDate; }, set: /** * @param {?} value * @return {?} */ function (value) { this._minDate = value; if (this.datepicker) { this.datepicker.minDate = value; } }, enumerable: true, configurable: true }); Object.defineProperty(DatepickerDirective.prototype, "maxDate", { get: /** * @return {?} */ function () { return this._minDate; }, set: /** * @param {?} value * @return {?} */ function (value) { this._maxDate = value; if (this.datepicker) { this.datepicker.maxDate = value; } }, enumerable: true, configurable: true }); Object.defineProperty(DatepickerDirective.prototype, "numberOfMonths", { get: /** * @return {?} */ function () { return this._numberOfMonths; }, set: /** * @param {?} value * @return {?} */ function (value) { this._numberOfMonths = value; if (this.datepicker) { this.datepicker.numberOfMonths = value; } }, enumerable: true, configurable: true }); Object.defineProperty(DatepickerDirective.prototype, "theme", { get: /** * @return {?} */ function () { return this._theme; }, set: /** * @param {?} value * @return {?} */ function (value) { if (this.datepicker) { this.datepicker.theme = value; } }, enumerable: true, configurable: true }); Object.defineProperty(DatepickerDirective.prototype, "isOpen", { get: /** * @return {?} */ function () { return this._isOpen; }, set: /** * @param {?} value * @return {?} */ function (value) { this._isOpen = value; if (this.datepicker) { this.datepicker.isOpen = value; } }, enumerable: true, configurable: true }); Object.defineProperty(DatepickerDirective.prototype, "selectedDates", { get: /** * @return {?} */ function () { return this._selectedDates; }, set: /** * @param {?} value * @return {?} */ function (value) { if (value === undefined || this._selectedDates === value) { return; } this._selectedDates = value; this.selectedDatesChange.emit(this._selectedDates); }, enumerable: true, configurable: true }); /** * @return {?} */ DatepickerDirective.prototype.onClick = /** * @return {?} */ function () { var _this = this; if (!this.datepicker) { this.datepicker = this.createDatepicker(); this.setDatepickerOptionsAndInputs(); this.subscribeToSelectedChanges(); } if (!this.datepicker.isOpen) { if (this.options.appendToBody) { this.setPosition(); } this.datepicker.open(); if (this.options.closeOnBlur) { setTimeout(function () { return (_this.clickListener = _this.renderer.listen('document', 'click', _this.onBlurHandler.bind(_this))); }); } } }; /** * Add selected changes */ /** * Add selected changes * @return {?} */ DatepickerDirective.prototype.subscribeToSelectedChanges = /** * Add selected changes * @return {?} */ function () { var _this = this; this.datepicker.selectedDatesChange.subscribe(function (date) { if (_this.formControl) { _this.formControl.control.setValue(date); } else { _this.selectedDates = date; } }); }; /** * Set all the options and inputs of the datepicker */ /** * Set all the options and inputs of the datepicker * @return {?} */ DatepickerDirective.prototype.setDatepickerOptionsAndInputs = /** * Set all the options and inputs of the datepicker * @return {?} */ function () { this.datepicker.options = this.datepickerOptions; this.datepicker.isOpen = this.isOpen || false; this.datepicker.asDirective = true; this.datepicker.numberOfMonths = this.numberOfMonths; this.datepicker.theme = this.theme; this.datepicker._selectedDates = this.selectedDates; this.datepicker.language = this.language; this.datepicker.minDate = this.minDate; this.datepicker.minDate = this.maxDate; }; /** * Handles the (faked) blur event * * @param event */ /** * Handles the (faked) blur event * * @param {?} event * @return {?} */ DatepickerDirective.prototype.onBlurHandler = /** * Handles the (faked) blur event * * @param {?} event * @return {?} */ function (event) { if (event.target !== this.datepicker.element.nativeElement && !this.datepicker.element.nativeElement.contains(event.target)) { // check click origin this.clickListener(); this.datepicker.close(true); } }; /** * Returns a create DatepickerComponent method */ /** * Returns a create DatepickerComponent method * @return {?} */ DatepickerDirective.prototype.createDatepicker = /** * Returns a create DatepickerComponent method * @return {?} */ function () { return this.options.appendToBody ? this.appendToBody() : this.appendToContainer(); }; /** * Sets the position of the datepicker */ /** * Sets the position of the datepicker * @return {?} */ DatepickerDirective.prototype.setPosition = /** * Sets the position of the datepicker * @return {?} */ function () { /** @type {?} */ var position = UtilitiesService.getPageOffset(this.viewContainerRef.element.nativeElement); if (this.options.openDirection === 'bottom') { this.datepicker.topPosition = position.bottom; this.datepicker.leftPosition = position.left; } if (this.options.openDirection === 'left') { this.datepicker.topPosition = position.top; this.datepicker.rightPosition = position.forRight; } if (this.options.openDirection === 'right') { this.datepicker.topPosition = position.top; this.datepicker.leftPosition = position.right; } if (this.options.openDirection === 'top') { this.datepicker.bottomPosition = position.forBottom; this.datepicker.leftPosition = position.left; } }; /** * Appends the DatepickerComponent to the body and returns the instance */ /** * Appends the DatepickerComponent to the body and returns the instance * @return {?} */ DatepickerDirective.prototype.appendToBody = /** * Appends the DatepickerComponent to the body and returns the instance * @return {?} */ function () { /** @type {?} */ var datepickerComponent = this.options.useAnimatePicker ? AnimatepickerComponent : DatepickerComponent; /** @type {?} */ var componentRef = this.componentFactoryResolver .resolveComponentFactory(datepickerComponent) .create(this.injector); this.appRef.attachView(componentRef.hostView); /** @type {?} */ var domElem = (/** @type {?} */ (((/** @type {?} */ (componentRef.hostView))).rootNodes[0])); document.body.appendChild(domElem); return componentRef.instance; }; /** * Appends the DatepickerComponent to the container and returns the instance */ /** * Appends the DatepickerComponent to the container and returns the instance * @return {?} */ DatepickerDirective.prototype.appendToContainer = /** * Appends the DatepickerComponent to the container and returns the instance * @return {?} */ function () { /** @type {?} */ var datepickerComponent = this.options.useAnimatePicker ? AnimatepickerComponent : DatepickerComponent; /** @type {?} */ var componentRef = this.componentFactoryResolver.resolveComponentFactory(datepickerComponent); return this.viewContainerRef.createComponent(componentRef).instance; }; DatepickerDirective.decorators = [ { type: Directive, args: [{ selector: '[aaDatepicker]' },] }, ]; DatepickerDirective.ctorParameters = function () { return [ { type: ViewContainerRef }, { type: ComponentFactoryResolver }, { type: ApplicationRef }, { type: Injector }, { type: Renderer2 }, { type: NgControl, decorators: [{ type: Optional }] } ]; }; DatepickerDirective.propDecorators = { options: [{ type: Input, args: ['aaDatepicker',] }], datepickerOptions: [{ type: Input, args: ['options',] }], language: [{ type: Input }], minDate: [{ type: Input }], maxDate: [{ type: Input }], numberOfMonths: [{ type: Input }], theme: [{ type: Input }], isOpen: [{ type: Input }], selectedDatesChange: [{ type: Output }], selectedDates: [{ type: Input }], onClick: [{ type: HostListener, args: ['click', ['$event.target'],] }] }; return DatepickerDirective; }()); export { DatepickerDirective }; if (false) { /** @type {?} */ DatepickerDirective.prototype.datepicker; /** @type {?} */ DatepickerDirective.prototype.clickListener; /** @type {?} */ DatepickerDirective.prototype._options; /** * @type {?} * @private */ DatepickerDirective.prototype._datepickerOptions; /** * Set the the language manualy. A string with a BCP 47 language tag * \@example nl-NL * @type {?} * @private */ DatepickerDirective.prototype._language; /** * Minimal Date: If set the dates before it will be disabled * @type {?} * @private */ DatepickerDirective.prototype._minDate; /** * Maximal Date: If set the dates after it will be disabled * @type {?} * @private */ DatepickerDirective.prototype._maxDate; /** * Number of months: the number of months displayed * @type {?} * @private */ DatepickerDirective.prototype._numberOfMonths; /** * Theme string is added to the host * @type {?} * @private */ DatepickerDirective.prototype._theme; /** * The open state * @type {?} * @private */ DatepickerDirective.prototype._isOpen; /** * Selected Dates: handles the selected dates array. Can be set both internally and externally * @type {?} * @private */ DatepickerDirective.prototype._selectedDates; /** @type {?} */ DatepickerDirective.prototype.selectedDatesChange; /** @type {?} */ DatepickerDirective.prototype.viewContainerRef; /** @type {?} */ DatepickerDirective.prototype.componentFactoryResolver; /** * @type {?} * @private */ DatepickerDirective.prototype.appRef; /** * @type {?} * @private */ DatepickerDirective.prototype.injector; /** * @type {?} * @private */ DatepickerDirective.prototype.renderer; /** @type {?} */ DatepickerDirective.prototype.formControl; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.directive.js","sourceRoot":"ng://ngx-animating-datepicker/","sources":["lib/components/datepicker/datepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tApplicationRef,\n\tComponentFactoryResolver,\n\tDirective,\n\tEmbeddedViewRef,\n\tEventEmitter,\n\tHostListener,\n\tInjector,\n\tInput,\n\tOptional,\n\tOutput,\n\tRenderer2,\n\tViewContainerRef\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {Options} from '../../models/datepicker-options.model';\nimport {DirectiveOptions} from '../../models/directive-options.model';\nimport {UtilitiesService} from '../../services/utilities.service';\nimport {AnimatepickerComponent} from '../animatepicker/animatepicker.component';\nimport {DatepickerComponent} from './datepicker.component';\nimport {DefaultDirectiveOptions} from './datepicker.options';\n\n@Directive({\n\tselector: '[aaDatepicker]'\n})\nexport class DatepickerDirective {\n\tdatepicker: any = null; // TODO: fix types: DatepickerComponent | AnimatepickerComponent\n\tclickListener;\n\n\t_options = DefaultDirectiveOptions;\n\n\t@Input('aaDatepicker')\n\tset options(options: DirectiveOptions) {\n\t\tif (options === undefined || !options) {\n\t\t\treturn;\n\t\t}\n\t\t// TODO: could be improved\n\t\tthis._options = {...this._options, ...options};\n\t}\n\n\tget options(): DirectiveOptions {\n\t\treturn this._options;\n\t}\n\n\tprivate _datepickerOptions;\n\t@Input('options')\n\tset datepickerOptions(options: Options) {\n\t\tthis._datepickerOptions = options;\n\n\t\tif (this.datepicker) {\n\t\t\tthis.datepicker.options = options;\n\t\t}\n\t}\n\n\tget datepickerOptions() {\n\t\treturn this._datepickerOptions;\n\t}\n\n\t/**\n\t * Set the the language manualy. A string with a BCP 47 language tag\n\t * @example nl-NL\n\t */\n\tprivate _language;\n\t@Input()\n\tset language(value: string) {\n\t\tthis._language = value;\n\n\t\tif (this.datepicker) {\n\t\t\tthis.datepicker.language = value;\n\t\t}\n\t}\n\n\tget language() {\n\t\treturn this._language;\n\t}\n\n\t/**\n\t * Minimal Date: If set the dates before it will be disabled\n\t */\n\tprivate _minDate;\n\t@Input()\n\tset minDate(value: Date) {\n\t\tthis._minDate = value;\n\n\t\tif (this.datepicker) {\n\t\t\tthis.datepicker.minDate = value;\n\t\t}\n\t}\n\n\tget minDate() {\n\t\treturn this._minDate;\n\t}\n\n\t/**\n\t * Maximal Date: If set the dates after it will be disabled\n\t */\n\tprivate _maxDate;\n\t@Input()\n\tset maxDate(value: Date) {\n\t\tthis._maxDate = value;\n\n\t\tif (this.datepicker) {\n\t\t\tthis.datepicker.maxDate = value;\n\t\t}\n\t}\n\n\tget maxDate() {\n\t\treturn this._minDate;\n\t}\n\n\t/**\n\t * Number of months: the number of months displayed\n\t */\n\tprivate _numberOfMonths;\n\t@Input()\n\tset numberOfMonths(value) {\n\t\tthis._numberOfMonths = value;\n\n\t\tif (this.datepicker) {\n\t\t\tthis.datepicker.numberOfMonths = value;\n\t\t}\n\t}\n\n\tget numberOfMonths() {\n\t\treturn this._numberOfMonths;\n\t}\n\n\t/**\n\t * Theme string is added to the host\n\t */\n\tprivate _theme;\n\t@Input()\n\tset theme(value) {\n\t\tif (this.datepicker) {\n\t\t\tthis.datepicker.theme = value;\n\t\t}\n\t}\n\n\tget theme() {\n\t\treturn this._theme;\n\t}\n\n\t/**\n\t * The open state\n\t */\n\tprivate _isOpen;\n\t@Input()\n\tset isOpen(value) {\n\t\tthis._isOpen = value;\n\n\t\tif (this.datepicker) {\n\t\t\tthis.datepicker.isOpen = value;\n\t\t}\n\t}\n\n\tget isOpen() {\n\t\treturn this._isOpen;\n\t}\n\n\t/**\n\t * Selected Dates: handles the selected dates array. Can be set both internally and externally\n\t */\n\tprivate _selectedDates: Date[] = [];\n\t@Output() selectedDatesChange = new EventEmitter();\n\n\t@Input()\n\tset selectedDates(value: Date[]) {\n\t\tif (value === undefined || this._selectedDates === value) {\n\t\t\treturn;\n\t\t}\n\t\tthis._selectedDates = value;\n\t\tthis.selectedDatesChange.emit(this._selectedDates);\n\t}\n\n\tget selectedDates(): Date[] {\n\t\treturn this._selectedDates;\n\t}\n\n\t@HostListener('click', ['$event.target'])\n\tonClick() {\n\t\tif (!this.datepicker) {\n\t\t\tthis.datepicker = this.createDatepicker();\n\n\t\t\tthis.setDatepickerOptionsAndInputs();\n\t\t\tthis.subscribeToSelectedChanges();\n\t\t}\n\n\t\tif (!this.datepicker.isOpen) {\n\t\t\tif (this.options.appendToBody) {\n\t\t\t\tthis.setPosition();\n\t\t\t}\n\t\t\tthis.datepicker.open();\n\n\t\t\tif (this.options.closeOnBlur) {\n\t\t\t\tsetTimeout(\n\t\t\t\t\t() =>\n\t\t\t\t\t\t(this.clickListener = this.renderer.listen('document', 'click', this.onBlurHandler.bind(this)))\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\tconstructor(\n\t\tpublic viewContainerRef: ViewContainerRef,\n\t\tpublic componentFactoryResolver: ComponentFactoryResolver,\n\t\tprivate appRef: ApplicationRef,\n\t\tprivate injector: Injector,\n\t\tprivate renderer: Renderer2,\n\t\t@Optional() public formControl: NgControl\n\t) {\n\t}\n\n\t/**\n\t * Add selected changes\n\t */\n\tsubscribeToSelectedChanges(): void {\n\t\tthis.datepicker.selectedDatesChange.subscribe(date => {\n\t\t\tif (this.formControl) {\n\t\t\t\tthis.formControl.control.setValue(date);\n\t\t\t} else {\n\t\t\t\tthis.selectedDates = date;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Set all the options and inputs of the datepicker\n\t */\n\tsetDatepickerOptionsAndInputs(): void {\n\t\tthis.datepicker.options = this.datepickerOptions;\n\t\tthis.datepicker.isOpen = this.isOpen || false;\n\t\tthis.datepicker.asDirective = true;\n\t\tthis.datepicker.numberOfMonths = this.numberOfMonths;\n\t\tthis.datepicker.theme = this.theme;\n\t\tthis.datepicker._selectedDates = this.selectedDates;\n\t\tthis.datepicker.language = this.language;\n\t\tthis.datepicker.minDate = this.minDate;\n\t\tthis.datepicker.minDate = this.maxDate;\n\t}\n\n\t/**\n\t * Handles the (faked) blur event\n\t *\n\t * @param event\n\t */\n\tonBlurHandler(event: Event): void {\n\t\tif (\n\t\t\tevent.target !== this.datepicker.element.nativeElement &&\n\t\t\t!this.datepicker.element.nativeElement.contains(event.target)\n\t\t) {\n\t\t\t// check click origin\n\t\t\tthis.clickListener();\n\t\t\tthis.datepicker.close(true);\n\t\t}\n\t}\n\n\t/**\n\t * Returns a create DatepickerComponent method\n\t */\n\tcreateDatepicker(): any {\n\t\treturn this.options.appendToBody ? this.appendToBody() : this.appendToContainer();\n\t}\n\n\t/**\n\t * Sets the position of the datepicker\n\t */\n\tsetPosition() {\n\t\tconst position = UtilitiesService.getPageOffset(this.viewContainerRef.element.nativeElement);\n\n\t\tif (this.options.openDirection === 'bottom') {\n\t\t\tthis.datepicker.topPosition = position.bottom;\n\t\t\tthis.datepicker.leftPosition = position.left;\n\t\t}\n\n\t\tif (this.options.openDirection === 'left') {\n\t\t\tthis.datepicker.topPosition = position.top;\n\t\t\tthis.datepicker.rightPosition = position.forRight;\n\t\t}\n\n\t\tif (this.options.openDirection === 'right') {\n\t\t\tthis.datepicker.topPosition = position.top;\n\t\t\tthis.datepicker.leftPosition = position.right;\n\t\t}\n\n\t\tif (this.options.openDirection === 'top') {\n\t\t\tthis.datepicker.bottomPosition = position.forBottom;\n\t\t\tthis.datepicker.leftPosition = position.left;\n\t\t}\n\t}\n\n\t/**\n\t * Appends the DatepickerComponent to the body and returns the instance\n\t */\n\tappendToBody(): any {\n\t\tconst datepickerComponent = this.options.useAnimatePicker ? AnimatepickerComponent : DatepickerComponent;\n\t\tconst componentRef = this.componentFactoryResolver\n\t\t\t.resolveComponentFactory(datepickerComponent)\n\t\t\t.create(this.injector);\n\n\t\tthis.appRef.attachView(componentRef.hostView);\n\n\t\tconst domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n\n\t\tdocument.body.appendChild(domElem);\n\n\t\treturn componentRef.instance;\n\t}\n\n\t/**\n\t * Appends the DatepickerComponent to the container and returns the instance\n\t */\n\tappendToContainer(): any {\n\t\tconst datepickerComponent = this.options.useAnimatePicker ? AnimatepickerComponent : DatepickerComponent;\n\t\tconst componentRef = this.componentFactoryResolver.resolveComponentFactory(datepickerComponent);\n\t\treturn this.viewContainerRef.createComponent(componentRef).instance;\n\t}\n}\n"]}