ngx-animating-datepicker
Version:
An Animating Datepicker for Angular 2+, for some smooth date picking :).
498 lines • 35.5 kB
JavaScript
/**
* @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"]}