@ydalvik/ionic4-datepicker
Version:
ionic4-datepicker inspired by rajeshwar patlolla ionic1 datepicker
197 lines • 18.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/li-ionic4-datepicker.directive.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Directive, Input, HostListener, ElementRef, Renderer2 } from '@angular/core';
import { ModalController } from '@ionic/angular';
import { Ionic4DatepickerModalComponent } from './ionic4-datepicker-modal/ionic4-datepicker-modal.component';
import { NgModel, NgControl } from '@angular/forms';
import { Ionic4DatepickerService } from './ionic4-datepicker.service';
var LiIonic4DatepickerDirective = /** @class */ (function () {
function LiIonic4DatepickerDirective(modalCtrl, ngModel, control, el, renderer2, datePickerService) {
this.modalCtrl = modalCtrl;
this.ngModel = ngModel;
this.control = control;
this.el = el;
this.renderer2 = renderer2;
this.datePickerService = datePickerService;
this.selectedDate = {};
this.isModalOpen = false;
}
/**
* @return {?}
*/
LiIonic4DatepickerDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
// console.log('config.yearInAscending : ' + this.inputDateConfig.yearInAscending);
var _this = this;
if (this.inputDateConfig.clearButton !== false) {
this.closeIcon = document.createElement('ion-icon');
this.closeIcon.name = 'close-circle';
this.closeIcon.className = 'clearButton';
this.closeIcon.style.position = 'absolute';
this.closeIcon.style.right = '8px';
this.closeIcon.style.bottom = '30%';
this.closeIcon.style.fontSize = '18px';
this.closeIcon.style.color = '#A9A9A9';
this.closeIcon.style.zIndex = '5';
if (this.el.nativeElement.parentNode.nodeName === 'ION-ITEM') {
this.closeIcon.style.bottom = '12px';
}
this.el.nativeElement.parentNode.appendChild(this.closeIcon);
this.renderer2.listen(this.closeIcon, 'click', (/**
* @param {?} event
* @return {?}
*/
function (event) {
// Do something with 'event'
// console.log('button clicks');
_this.selectedDate.date = new Date();
_this.control.control.setValue('');
_this.ngModel.update.emit('');
}));
}
/** @type {?} */
var self = this;
this.ngModel.valueChanges.subscribe((/**
* @param {?} value
* @return {?}
*/
function (value) {
// console.log('ngModel value =>', value);
self.selectedDate.date = value;
if (_this.inputDateConfig.clearButton !== false) {
if (!value) {
_this.closeIcon.style.visibility = 'hidden';
}
else {
_this.closeIcon.style.visibility = 'visible';
}
}
}));
this.control.control.valueChanges.subscribe((/**
* @param {?} value
* @return {?}
*/
function (value) {
// console.log('formcontrol value =>', value);
self.selectedDate.date = value;
if (_this.inputDateConfig.clearButton !== false) {
if (!value) {
_this.closeIcon.style.visibility = 'hidden';
}
else {
_this.closeIcon.style.visibility = 'visible';
}
}
}));
if (this.control.control.value) {
this.selectedDate.date = this.control.control.value;
}
};
/**
* @return {?}
*/
LiIonic4DatepickerDirective.prototype.onFocus = /**
* @return {?}
*/
function () {
if (this.datePickerService.isModalOpen) {
return;
}
this.openDatePicker();
};
/**
* @return {?}
*/
LiIonic4DatepickerDirective.prototype.openDatePicker = /**
* @return {?}
*/
function () {
return tslib_1.__awaiter(this, void 0, void 0, function () {
var datePickerModal;
var _this = this;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0:
// console.log('openDatePicker');
return [4 /*yield*/, this.modalCtrl.create({
component: Ionic4DatepickerModalComponent,
cssClass: 'li-ionic4-datePicker',
componentProps: { 'objConfig': this.inputDateConfig, 'selectedDate': this.selectedDate.date }
})];
case 1:
datePickerModal = _a.sent();
return [4 /*yield*/, datePickerModal.present()];
case 2:
_a.sent();
datePickerModal.onDidDismiss()
.then((/**
* @param {?} data
* @return {?}
*/
function (data) {
if (data.data && data.data.date && data.data.date !== 'Invalid date') {
_this.selectedDate.date = data.data.date;
_this.control.control.setValue(data.data.date);
_this.ngModel.update.emit(data.data.date);
}
}));
return [2 /*return*/];
}
});
});
};
LiIonic4DatepickerDirective.decorators = [
{ type: Directive, args: [{
selector: '[liIonic4Datepicker]',
exportAs: 'liIonic4Datepicker',
providers: [NgModel],
},] }
];
/** @nocollapse */
LiIonic4DatepickerDirective.ctorParameters = function () { return [
{ type: ModalController },
{ type: NgModel },
{ type: NgControl },
{ type: ElementRef },
{ type: Renderer2 },
{ type: Ionic4DatepickerService }
]; };
LiIonic4DatepickerDirective.propDecorators = {
inputDateConfig: [{ type: Input, args: ['liIonic4Datepicker',] }],
onFocus: [{ type: HostListener, args: ['ionFocus',] }]
};
return LiIonic4DatepickerDirective;
}());
export { LiIonic4DatepickerDirective };
if (false) {
/** @type {?} */
LiIonic4DatepickerDirective.prototype.inputDateConfig;
/** @type {?} */
LiIonic4DatepickerDirective.prototype.closeIcon;
/** @type {?} */
LiIonic4DatepickerDirective.prototype.selectedDate;
/** @type {?} */
LiIonic4DatepickerDirective.prototype.isModalOpen;
/**
* @type {?}
* @private
*/
LiIonic4DatepickerDirective.prototype.modalCtrl;
/** @type {?} */
LiIonic4DatepickerDirective.prototype.ngModel;
/** @type {?} */
LiIonic4DatepickerDirective.prototype.control;
/** @type {?} */
LiIonic4DatepickerDirective.prototype.el;
/** @type {?} */
LiIonic4DatepickerDirective.prototype.renderer2;
/** @type {?} */
LiIonic4DatepickerDirective.prototype.datePickerService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"li-ionic4-datepicker.directive.js","sourceRoot":"ng://@ydalvik/ionic4-datepicker/","sources":["lib/li-ionic4-datepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnInit, HostListener, ElementRef, Renderer2 } from '@angular/core';\nimport { ModalController } from '@ionic/angular';\nimport { Ionic4DatepickerModalComponent } from './ionic4-datepicker-modal/ionic4-datepicker-modal.component';\nimport { NgModel, NgControl } from '@angular/forms';\n\nimport * as moment_ from 'moment';\nimport { Ionic4DatepickerService } from './ionic4-datepicker.service';\n\n@Directive({\n  selector: '[liIonic4Datepicker]',\n  exportAs: 'liIonic4Datepicker',\n  providers: [NgModel],\n})\nexport class LiIonic4DatepickerDirective implements OnInit {\n\n  @Input('liIonic4Datepicker') inputDateConfig: any;\n\n  closeIcon;\n  selectedDate: any = {};\n  isModalOpen: any = false;\n\n  constructor(\n    private modalCtrl: ModalController,\n    public ngModel: NgModel,\n    public control: NgControl,\n    public el: ElementRef,\n    public renderer2: Renderer2,\n    public datePickerService: Ionic4DatepickerService\n  ) { }\n\n  ngOnInit() {\n    // console.log('config.yearInAscending : ' + this.inputDateConfig.yearInAscending);\n\n    if (this.inputDateConfig.clearButton !== false) {\n      this.closeIcon = document.createElement('ion-icon');\n      this.closeIcon.name = 'close-circle';\n      this.closeIcon.className = 'clearButton';\n      this.closeIcon.style.position = 'absolute';\n      this.closeIcon.style.right = '8px';\n      this.closeIcon.style.bottom = '30%';\n      this.closeIcon.style.fontSize = '18px';\n      this.closeIcon.style.color = '#A9A9A9';\n      this.closeIcon.style.zIndex = '5';\n      if (this.el.nativeElement.parentNode.nodeName === 'ION-ITEM') {\n        this.closeIcon.style.bottom = '12px';\n      }\n      this.el.nativeElement.parentNode.appendChild(this.closeIcon);\n      this.renderer2.listen(this.closeIcon, 'click', (event) => {\n        // Do something with 'event'\n        // console.log('button clicks');\n        this.selectedDate.date = new Date();\n        this.control.control.setValue('');\n        this.ngModel.update.emit('');\n      });\n    }\n\n    const self = this;\n    this.ngModel.valueChanges.subscribe((value) => {\n      // console.log('ngModel value =>', value);\n      self.selectedDate.date = value;\n      if (this.inputDateConfig.clearButton !== false) {\n        if (!value) {\n          this.closeIcon.style.visibility = 'hidden';\n        } else {\n          this.closeIcon.style.visibility = 'visible';\n        }\n      }\n    });\n\n    this.control.control.valueChanges.subscribe((value) => {\n      // console.log('formcontrol value =>', value);\n      self.selectedDate.date = value;\n      if (this.inputDateConfig.clearButton !== false) {\n        if (!value) {\n          this.closeIcon.style.visibility = 'hidden';\n        } else {\n          this.closeIcon.style.visibility = 'visible';\n        }\n      }\n    });\n\n    if (this.control.control.value) {\n      this.selectedDate.date = this.control.control.value;\n    }\n  }\n\n  @HostListener('ionFocus')\n  public onFocus() {\n    if (this.datePickerService.isModalOpen) {\n      return;\n    }\n    this.openDatePicker();\n  }\n\n  async openDatePicker() {\n    // console.log('openDatePicker');\n\n    const datePickerModal = await this.modalCtrl.create({\n      component: Ionic4DatepickerModalComponent,\n      cssClass: 'li-ionic4-datePicker',\n      componentProps: { 'objConfig': this.inputDateConfig, 'selectedDate': this.selectedDate.date }\n    });\n    await datePickerModal.present();\n\n    datePickerModal.onDidDismiss()\n      .then((data) => {\n        if (data.data && data.data.date && data.data.date !== 'Invalid date') {\n          this.selectedDate.date = data.data.date;\n          this.control.control.setValue(data.data.date);\n          this.ngModel.update.emit(data.data.date);\n        }\n      });\n  }\n}\n\n"]}