ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
337 lines • 22 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Input, Output, Injector, Directive, forwardRef, EventEmitter, HostListener, ViewContainerRef, ComponentFactoryResolver } from '@angular/core';
import { DatePickerComponent } from './date-picker.component';
import { DatePickerOptions } from './date-picker-options.provider';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
var DatePickerDirective = /** @class */ (function () {
function DatePickerDirective(_viewContainerRef, _defaultOptions, _cfr) {
this._viewContainerRef = _viewContainerRef;
this._defaultOptions = _defaultOptions;
this._cfr = _cfr;
this._eventListeners = [];
this.minuteStep = 1;
this.value = new Date();
this.onVisibleChange = new EventEmitter(true);
this.onValueChange = new EventEmitter();
this.onOk = new EventEmitter();
this.onDismiss = new EventEmitter();
}
/**
* @return {?}
*/
DatePickerDirective.prototype.togglePicker = /**
* @return {?}
*/
function () {
if (!this.picker) {
this.showPicker();
}
else {
this.hidePicker();
}
};
/**
* @return {?}
*/
DatePickerDirective.prototype.showPicker = /**
* @return {?}
*/
function () {
var _this = this;
if (!this.picker && !this.disabled) {
setTimeout((/**
* @return {?}
*/
function () {
_this._eventListeners = [];
}));
/** @type {?} */
var options_1 = new DatePickerOptions();
Object.assign(options_1, this._defaultOptions, {
hidePicker: (/**
* @param {?} event
* @return {?}
*/
function (event) {
_this.hidePicker();
}),
updateNgModel: (/**
* @param {?} value
* @return {?}
*/
function (value) {
if (_this._ngModelOnChange) {
_this.value = value;
_this._ngModelOnChange(value);
}
})
});
/** @type {?} */
var optionalParams = [
'mode',
'minDate',
'maxDate',
'minuteStep',
'value',
'mask',
'title',
'okText',
'dismissText',
'disabled',
'locale',
'appendToBody',
'showErrorToast',
'showErrorToastInterval',
'onOk',
'onDismiss',
'onValueChange'
];
optionalParams.forEach((/**
* @param {?} param
* @return {?}
*/
function (param) {
if (typeof _this[param] !== 'undefined') {
((/** @type {?} */ (options_1)))[param] = _this[param];
}
}));
/** @type {?} */
var componentFactory = this._cfr.resolveComponentFactory(DatePickerComponent);
/** @type {?} */
var childInjector = Injector.create([
{
provide: DatePickerOptions,
useValue: options_1
}
]);
this.picker = this._viewContainerRef.createComponent(componentFactory, this._viewContainerRef.length, childInjector);
if (options_1.appendToBody) {
document.body.appendChild(this.picker.location.nativeElement);
}
this.onVisibleChange.emit(true);
}
};
/**
* @return {?}
*/
DatePickerDirective.prototype.hidePicker = /**
* @return {?}
*/
function () {
if (this.picker) {
this.picker.destroy();
delete this.picker;
this.onVisibleChange.emit(false);
this._eventListeners.forEach((/**
* @param {?} fn
* @return {?}
*/
function (fn) { return fn(); }));
this._eventListeners = [];
}
};
/**
* @param {?} value
* @return {?}
*/
DatePickerDirective.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.value = value;
};
/**
* @param {?} fn
* @return {?}
*/
DatePickerDirective.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this._ngModelOnChange = fn;
};
/**
* @param {?} fn
* @return {?}
*/
DatePickerDirective.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this._ngModelOnTouched = fn;
};
/**
* @param {?} isDisabled
* @return {?}
*/
DatePickerDirective.prototype.setDisabledState = /**
* @param {?} isDisabled
* @return {?}
*/
function (isDisabled) {
this.disabled = isDisabled;
};
/**
* @return {?}
*/
DatePickerDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.onVisibleChange.emit(false);
};
/**
* @param {?} changes
* @return {?}
*/
DatePickerDirective.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes.isOpen) {
if (changes.isOpen.currentValue === true) {
this.showPicker();
}
else {
this.hidePicker();
}
}
};
/**
* @return {?}
*/
DatePickerDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.hidePicker();
};
DatePickerDirective.decorators = [
{ type: Directive, args: [{
selector: '[DatePicker]',
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return DatePickerDirective; })),
multi: true
}
]
},] }
];
/** @nocollapse */
DatePickerDirective.ctorParameters = function () { return [
{ type: ViewContainerRef },
{ type: DatePickerOptions },
{ type: ComponentFactoryResolver }
]; };
DatePickerDirective.propDecorators = {
isOpen: [{ type: Input }],
mode: [{ type: Input }],
minDate: [{ type: Input }],
maxDate: [{ type: Input }],
use12Hours: [{ type: Input }],
minuteStep: [{ type: Input }],
value: [{ type: Input }],
mask: [{ type: Input }],
title: [{ type: Input }],
okText: [{ type: Input }],
dismissText: [{ type: Input }],
disabled: [{ type: Input }],
locale: [{ type: Input }],
appendToBody: [{ type: Input }],
showErrorToast: [{ type: Input }],
showErrorToastInterval: [{ type: Input }],
onVisibleChange: [{ type: Output }],
onValueChange: [{ type: Output }],
onOk: [{ type: Output }],
onDismiss: [{ type: Output }],
togglePicker: [{ type: HostListener, args: ['click',] }]
};
return DatePickerDirective;
}());
export { DatePickerDirective };
if (false) {
/** @type {?} */
DatePickerDirective.prototype.picker;
/**
* @type {?}
* @private
*/
DatePickerDirective.prototype._eventListeners;
/**
* @type {?}
* @private
*/
DatePickerDirective.prototype._ngModelOnChange;
/**
* @type {?}
* @private
*/
DatePickerDirective.prototype._ngModelOnTouched;
/** @type {?} */
DatePickerDirective.prototype.isOpen;
/** @type {?} */
DatePickerDirective.prototype.mode;
/** @type {?} */
DatePickerDirective.prototype.minDate;
/** @type {?} */
DatePickerDirective.prototype.maxDate;
/** @type {?} */
DatePickerDirective.prototype.use12Hours;
/** @type {?} */
DatePickerDirective.prototype.minuteStep;
/** @type {?} */
DatePickerDirective.prototype.value;
/** @type {?} */
DatePickerDirective.prototype.mask;
/** @type {?} */
DatePickerDirective.prototype.title;
/** @type {?} */
DatePickerDirective.prototype.okText;
/** @type {?} */
DatePickerDirective.prototype.dismissText;
/** @type {?} */
DatePickerDirective.prototype.disabled;
/** @type {?} */
DatePickerDirective.prototype.locale;
/** @type {?} */
DatePickerDirective.prototype.appendToBody;
/** @type {?} */
DatePickerDirective.prototype.showErrorToast;
/** @type {?} */
DatePickerDirective.prototype.showErrorToastInterval;
/** @type {?} */
DatePickerDirective.prototype.onVisibleChange;
/** @type {?} */
DatePickerDirective.prototype.onValueChange;
/** @type {?} */
DatePickerDirective.prototype.onOk;
/** @type {?} */
DatePickerDirective.prototype.onDismiss;
/**
* @type {?}
* @private
*/
DatePickerDirective.prototype._viewContainerRef;
/**
* @type {?}
* @private
*/
DatePickerDirective.prototype._defaultOptions;
/**
* @type {?}
* @private
*/
DatePickerDirective.prototype._cfr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.directive.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["date-picker/date-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  Output,\n  OnInit,\n  Injector,\n  OnChanges,\n  OnDestroy,\n  Directive,\n  forwardRef,\n  EventEmitter,\n  HostListener,\n  ComponentRef,\n  SimpleChanges,\n  ComponentFactory,\n  ViewContainerRef,\n  ComponentFactoryResolver\n} from '@angular/core';\nimport { DatePickerComponent } from './date-picker.component';\nimport { DatePickerOptions } from './date-picker-options.provider';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n@Directive({\n  selector: '[DatePicker]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerDirective),\n      multi: true\n    }\n  ]\n})\nexport class DatePickerDirective implements OnDestroy, OnChanges, OnInit, ControlValueAccessor {\n  picker: ComponentRef<DatePickerComponent>;\n  private _eventListeners: Array<() => void> = [];\n  private _ngModelOnChange: (value: Date) => {};\n  private _ngModelOnTouched: () => {};\n\n  @Input()\n  isOpen: boolean;\n  @Input()\n  mode: string;\n  @Input()\n  minDate: string;\n  @Input()\n  maxDate: string;\n  @Input()\n  use12Hours: boolean;\n  @Input()\n  minuteStep: number = 1;\n  @Input()\n  value: Date = new Date();\n  @Input()\n  mask: boolean;\n  @Input()\n  title: string;\n  @Input()\n  okText: string;\n  @Input()\n  dismissText: string;\n  @Input()\n  disabled: boolean;\n  @Input()\n  locale: any;\n  @Input()\n  appendToBody: boolean;\n  @Input()\n  showErrorToast: boolean;\n  @Input()\n  showErrorToastInterval: number;\n  @Output()\n  onVisibleChange: EventEmitter<boolean> = new EventEmitter(true);\n  @Output()\n  onValueChange: EventEmitter<any> = new EventEmitter();\n  @Output()\n  onOk: EventEmitter<any> = new EventEmitter();\n  @Output()\n  onDismiss: EventEmitter<any> = new EventEmitter();\n\n  @HostListener('click')\n  togglePicker(): void {\n    if (!this.picker) {\n      this.showPicker();\n    } else {\n      this.hidePicker();\n    }\n  }\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _defaultOptions: DatePickerOptions,\n    private _cfr: ComponentFactoryResolver\n  ) {}\n\n  showPicker(): void {\n    if (!this.picker && !this.disabled) {\n      setTimeout(() => {\n        this._eventListeners = [];\n      });\n\n      const options = new DatePickerOptions();\n      Object.assign(options, this._defaultOptions, {\n        hidePicker: (event): void => {\n          this.hidePicker();\n        },\n        updateNgModel: (value: Date): void => {\n          if (this._ngModelOnChange) {\n            this.value = value;\n            this._ngModelOnChange(value);\n          }\n        }\n      });\n\n      const optionalParams: Array<keyof DatePickerDirective> = [\n        'mode',\n        'minDate',\n        'maxDate',\n        'minuteStep',\n        'value',\n        'mask',\n        'title',\n        'okText',\n        'dismissText',\n        'disabled',\n        'locale',\n        'appendToBody',\n        'showErrorToast',\n        'showErrorToastInterval',\n        'onOk',\n        'onDismiss',\n        'onValueChange'\n      ];\n      optionalParams.forEach(param => {\n        if (typeof this[param] !== 'undefined') {\n          (options as any)[param] = this[param];\n        }\n      });\n      const componentFactory: ComponentFactory<DatePickerComponent> = this._cfr.resolveComponentFactory(\n        DatePickerComponent\n      );\n      const childInjector = Injector.create([\n        {\n          provide: DatePickerOptions,\n          useValue: options\n        }\n      ]);\n      this.picker = this._viewContainerRef.createComponent(\n        componentFactory,\n        this._viewContainerRef.length,\n        childInjector\n      );\n      if (options.appendToBody) {\n        document.body.appendChild(this.picker.location.nativeElement);\n      }\n      this.onVisibleChange.emit(true);\n    }\n  }\n\n  hidePicker(): void {\n    if (this.picker) {\n      this.picker.destroy();\n      delete this.picker;\n      this.onVisibleChange.emit(false);\n      this._eventListeners.forEach(fn => fn());\n      this._eventListeners = [];\n    }\n  }\n\n  writeValue(value: Date): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: (_: Date) => {}): void {\n    this._ngModelOnChange = fn;\n  }\n\n  registerOnTouched(fn: () => {}): void {\n    this._ngModelOnTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  ngOnInit(): void {\n    this.onVisibleChange.emit(false);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.isOpen) {\n      if (changes.isOpen.currentValue === true) {\n        this.showPicker();\n      } else {\n        this.hidePicker();\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this.hidePicker();\n  }\n}\n"]}