@jermeo/ionic4-datepicker
Version:
ionic4-datepicker inspired by rajeshwar patlolla ionic1 datepicker
283 lines • 20.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/ionic4-datepicker.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, forwardRef, Input, ElementRef, Renderer2 } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { ModalController } from '@ionic/angular';
import { Ionic4DatepickerModalComponent } from './ionic4-datepicker-modal/ionic4-datepicker-modal.component';
import * as moment_ from 'moment';
/** @type {?} */
var moment = moment_;
/** @type {?} */
var noop = (/**
* @return {?}
*/
function () {
});
var ɵ0 = noop;
/** @type {?} */
export var CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return Ionic4DatepickerComponent; })),
multi: true
};
var Ionic4DatepickerComponent = /** @class */ (function () {
function Ionic4DatepickerComponent(modalCtrl, el, renderer2) {
this.modalCtrl = modalCtrl;
this.el = el;
this.renderer2 = renderer2;
this.selectedDate = {};
this.innerValue = '';
// Placeholders for the callbacks which are later provided
// by the Control Value Accessor
this.onTouchedCallback = noop;
this.onChangeCallback = noop;
}
/**
* @return {?}
*/
Ionic4DatepickerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
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 = '0px';
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 = '30%';
}
this.el.nativeElement.setAttribute('style', 'position: relative; width: 100%;');
this.el.nativeElement.appendChild(this.closeIcon);
this.renderer2.listen(this.closeIcon, 'click', (/**
* @param {?} event
* @return {?}
*/
function (event) {
// Do something with 'event'
// console.log('button clicks');
_this.selectedDate = new Date();
_this.value = '';
}));
}
};
/**
* @param {?} value
* @return {?}
*/
Ionic4DatepickerComponent.prototype.onChangeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
// console.log('onChangeValue =>' , value);
if (this.inputDateConfig.clearButton !== false) {
if (!value) {
this.closeIcon.style.visibility = 'hidden';
}
else {
this.closeIcon.style.visibility = 'visible';
}
}
};
/**
* @param {?} value
* @return {?}
*/
Ionic4DatepickerComponent.prototype.openDatePicker = /**
* @param {?} value
* @return {?}
*/
function (value) {
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');
if (value) {
this.selectedDate.date = value;
}
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) {
// console.log(data);
if (data.data && data.data.date && data.data.date !== 'Invalid date') {
_this.selectedDate.date = data.data.date;
_this.value = data.data.date;
}
}));
return [2 /*return*/];
}
});
});
};
Object.defineProperty(Ionic4DatepickerComponent.prototype, "value", {
// get accessor
get:
// get accessor
/**
* @return {?}
*/
function () {
return this.innerValue;
},
// set accessor including call the onchange callback
set:
// set accessor including call the onchange callback
/**
* @param {?} v
* @return {?}
*/
function (v) {
if (v !== this.innerValue) {
this.innerValue = v;
this.onChangeCallback(v);
}
this.onChangeValue(v);
},
enumerable: true,
configurable: true
});
// Set touched on blur
// Set touched on blur
/**
* @return {?}
*/
Ionic4DatepickerComponent.prototype.onBlur =
// Set touched on blur
/**
* @return {?}
*/
function () {
this.onTouchedCallback();
};
// From ControlValueAccessor interface
// From ControlValueAccessor interface
/**
* @param {?} value
* @return {?}
*/
Ionic4DatepickerComponent.prototype.writeValue =
// From ControlValueAccessor interface
/**
* @param {?} value
* @return {?}
*/
function (value) {
if (value !== this.innerValue) {
this.innerValue = value;
}
this.onChangeValue(value);
};
// From ControlValueAccessor interface
// From ControlValueAccessor interface
/**
* @param {?} fn
* @return {?}
*/
Ionic4DatepickerComponent.prototype.registerOnChange =
// From ControlValueAccessor interface
/**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChangeCallback = fn;
};
// From ControlValueAccessor interface
// From ControlValueAccessor interface
/**
* @param {?} fn
* @return {?}
*/
Ionic4DatepickerComponent.prototype.registerOnTouched =
// From ControlValueAccessor interface
/**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouchedCallback = fn;
};
Ionic4DatepickerComponent.decorators = [
{ type: Component, args: [{
selector: 'li-ionic4-datepicker',
template: "<input type=\"text\" class=\"li-dp-input\" (focus)=\"$event.preventDefault()\" (click)=\"openDatePicker(value)\" readonly\n [(ngModel)]=\"value\" start />",
providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR],
styles: [":host input{font-size:16px;margin:6px 0;border:0;border-bottom:1px solid #ccc;width:100%;padding:12px}@media (min-width:768px){:host input{font-size:18px}}:host input.has-focus,:host input:focus{outline:0;box-shadow:unset}"]
}] }
];
/** @nocollapse */
Ionic4DatepickerComponent.ctorParameters = function () { return [
{ type: ModalController },
{ type: ElementRef },
{ type: Renderer2 }
]; };
Ionic4DatepickerComponent.propDecorators = {
inputDateConfig: [{ type: Input }]
};
return Ionic4DatepickerComponent;
}());
export { Ionic4DatepickerComponent };
if (false) {
/** @type {?} */
Ionic4DatepickerComponent.prototype.inputDateConfig;
/** @type {?} */
Ionic4DatepickerComponent.prototype.closeIcon;
/** @type {?} */
Ionic4DatepickerComponent.prototype.selectedDate;
/**
* @type {?}
* @private
*/
Ionic4DatepickerComponent.prototype.innerValue;
/**
* @type {?}
* @private
*/
Ionic4DatepickerComponent.prototype.onTouchedCallback;
/**
* @type {?}
* @private
*/
Ionic4DatepickerComponent.prototype.onChangeCallback;
/**
* @type {?}
* @private
*/
Ionic4DatepickerComponent.prototype.modalCtrl;
/** @type {?} */
Ionic4DatepickerComponent.prototype.el;
/** @type {?} */
Ionic4DatepickerComponent.prototype.renderer2;
}
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ionic4-datepicker.component.js","sourceRoot":"ng://@jermeo/ionic4-datepicker/","sources":["lib/ionic4-datepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, forwardRef, Input, ElementRef, Renderer2 } from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, NgModel } from '@angular/forms';\nimport { ModalController } from '@ionic/angular';\nimport { Ionic4DatepickerModalComponent } from './ionic4-datepicker-modal/ionic4-datepicker-modal.component';\nimport * as moment_ from 'moment';\n\nconst moment = moment_;\n\nconst noop = () => {\n};\n\nexport const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => Ionic4DatepickerComponent),\n  multi: true\n};\n@Component({\n  selector: 'li-ionic4-datepicker',\n  templateUrl: './ionic4-datepicker.component.html',\n  styleUrls: ['./ionic4-datepicker.component.scss'],\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR]\n})\nexport class Ionic4DatepickerComponent implements OnInit, ControlValueAccessor {\n\n  @Input() inputDateConfig: any;\n\n  closeIcon;\n  selectedDate: any = {};\n  private innerValue: any = '';\n\n  // Placeholders for the callbacks which are later provided\n  // by the Control Value Accessor\n  private onTouchedCallback: () => void = noop;\n  private onChangeCallback: (_: any) => void = noop;\n\n  constructor(\n    private modalCtrl: ModalController,\n    public el: ElementRef,\n    public renderer2: Renderer2\n  ) { }\n\n  ngOnInit() {\n\n    if (this.inputDateConfig.clearButton !== false) {\n\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 = '0px';\n      this.closeIcon.style.fontSize = '18px';\n      this.closeIcon.style.color = '#A9A9A9';\n      this.closeIcon.style.zIndex = '5';\n\n      if (this.el.nativeElement.parentNode.nodeName === 'ION-ITEM') {\n        this.closeIcon.style.bottom = '30%';\n      }\n      this.el.nativeElement.setAttribute('style', 'position: relative; width: 100%;');\n      this.el.nativeElement.appendChild(this.closeIcon);\n\n      this.renderer2.listen(this.closeIcon, 'click', (event) => {\n        // Do something with 'event'\n        // console.log('button clicks');\n        this.selectedDate = new Date();\n        this.value = '';\n      });\n    }\n  }\n\n  onChangeValue(value) {\n    // console.log('onChangeValue =>' , 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  async openDatePicker(value) {\n    // console.log('openDatePicker');\n    if (value) {\n      this.selectedDate.date = value;\n    }\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        // console.log(data);\n        if (data.data && data.data.date && data.data.date !== 'Invalid date') {\n          this.selectedDate.date = data.data.date;\n          this.value = data.data.date;\n        }\n      });\n  }\n\n  // get accessor\n  get value(): any {\n    return this.innerValue;\n  }\n\n  // set accessor including call the onchange callback\n  set value(v: any) {\n    if (v !== this.innerValue) {\n      this.innerValue = v;\n      this.onChangeCallback(v);\n    }\n    this.onChangeValue(v);\n  }\n\n  // Set touched on blur\n  onBlur() {\n    this.onTouchedCallback();\n  }\n\n  // From ControlValueAccessor interface\n  writeValue(value: any) {\n    if (value !== this.innerValue) {\n      this.innerValue = value;\n    }\n    this.onChangeValue(value);\n  }\n\n  // From ControlValueAccessor interface\n  registerOnChange(fn: any) {\n    this.onChangeCallback = fn;\n  }\n\n  // From ControlValueAccessor interface\n  registerOnTouched(fn: any) {\n    this.onTouchedCallback = fn;\n  }\n}\n"]}