ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
217 lines • 18.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Input, Output, Component, forwardRef, HostBinding, EventEmitter, ViewEncapsulation } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { DatePickerComponent } from '../date-picker/date-picker.component';
export class DatePickerViewComponent extends DatePickerComponent {
constructor() {
super(...arguments);
this.mode = 'date';
this.minDate = new Date(2000, 5, 1, 0, 0, 0);
this.maxDate = new Date(2030, 1, 1, 23, 59, 59);
this.value = new Date();
this.disabled = false;
this.indicatorStyle = {};
this.showErrorToast = true;
this.showErrorToastInterval = 2000;
this.onValueChange = new EventEmitter();
this.amPicker = true;
}
/**
* @return {?}
*/
get locale() {
return this.options.locale;
}
/**
* @param {?} value
* @return {?}
*/
set locale(value) {
this.options.locale = value;
this.unsubscribe$.next();
this.unsubscribe$.complete();
}
/**
* @return {?}
*/
reloadPicker() {
if (this.currentPicker) {
/** @type {?} */
const self = this;
setTimeout((/**
* @return {?}
*/
() => {
self.selectedTarget.forEach((/**
* @param {?} item
* @param {?} i
* @return {?}
*/
(item, i) => {
self.currentPicker.children[i].children[2].style.transition = 'transform .3s';
/** @type {?} */
const index = parseInt(item.currentY, 0);
self.currentPicker.children[i].children[2].style.transform = `translateY(${index * self.lineHeight}px)`;
}));
}), 0);
}
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
if (value) {
this.value = value;
this.optionInit();
this.init();
}
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.ngModelOnChange = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.ngModelOnTouched = fn;
}
/**
* @param {?} isDisabled
* @return {?}
*/
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
/**
* @return {?}
*/
optionInit() {
this.options.mode = this.mode;
this.options.minDate = this.minDate;
this.options.maxDate = this.maxDate;
this.options.disabled = this.disabled;
this.options.locale = this.locale;
this.options.value = this.value;
this.options.showErrorToast = this.showErrorToast;
this.options.showErrorToastInterval = this.showErrorToastInterval;
this.options.onValueChange = this.onValueChange;
this.checkMode(this.options.mode);
/** @type {?} */
const value = this.transformDateFormat(this.options.value).split('-');
if (value.length > 0) {
this.currentTime = value.map((/**
* @param {?} item
* @return {?}
*/
item => {
return parseInt(item, 0);
}));
}
}
/**
* @return {?}
*/
ngOnInit() {
this.optionInit();
this.localeProvider();
}
/**
* @return {?}
*/
ngAfterViewInit() {
this.currentPicker = this.elementRef.nativeElement;
this.reloadPicker();
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes.value) {
this.options.value = changes.value.currentValue;
/** @type {?} */
const value = this.transformDateFormat(this.options.value).split('-');
if (value.length > 0) {
this.currentTime = value.map((/**
* @param {?} item
* @return {?}
*/
item => {
return parseInt(item, 0);
}));
}
if (!this.judgeEqualArray(this.currentTime, this.resultArr, this.resultArr.length) ||
this.judgeEqualArray(this.currentTime, this.min_date, this.currentTime.length) ||
this.judgeTime(this.currentTime, this.max_date)) {
this.optionInit();
this.init();
}
}
if (changes.mode || changes.minDate || changes.maxDate || changes.disabled || changes.locale) {
this.optionInit();
this.init();
}
}
}
DatePickerViewComponent.decorators = [
{ type: Component, args: [{
selector: 'DatePickerView, nzm-date-picker-view',
template: "<div *ngFor=\"let item of dataWithStr; let i = index\" class=\"am-picker-col\">\n <div class=\"am-picker-col-indicator \" style=\"top: 102px;\" [ngStyle]=\"indicatorStyle\"></div>\n <div id=\"{{ i }}\" class=\"am-picker-col-mask\" style=\"background-size: 100% 102px;\"></div>\n <div class=\"am-picker-col-content\">\n <div id=\"{{ i }}\" *ngFor=\"let val of item; let i = index\" class=\"am-picker-col-item\">\n {{ val.label ? val.label : val }}\n </div>\n </div>\n</div>\n",
encapsulation: ViewEncapsulation.None,
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
() => DatePickerViewComponent)),
multi: true
}
]
}] }
];
DatePickerViewComponent.propDecorators = {
mode: [{ type: Input }],
minDate: [{ type: Input }],
maxDate: [{ type: Input }],
value: [{ type: Input }],
disabled: [{ type: Input }],
indicatorStyle: [{ type: Input }],
locale: [{ type: Input }],
showErrorToast: [{ type: Input }],
showErrorToastInterval: [{ type: Input }],
onValueChange: [{ type: Output }],
amPicker: [{ type: HostBinding, args: ['class.am-picker',] }]
};
if (false) {
/** @type {?} */
DatePickerViewComponent.prototype.mode;
/** @type {?} */
DatePickerViewComponent.prototype.minDate;
/** @type {?} */
DatePickerViewComponent.prototype.maxDate;
/** @type {?} */
DatePickerViewComponent.prototype.value;
/** @type {?} */
DatePickerViewComponent.prototype.disabled;
/** @type {?} */
DatePickerViewComponent.prototype.indicatorStyle;
/** @type {?} */
DatePickerViewComponent.prototype.showErrorToast;
/** @type {?} */
DatePickerViewComponent.prototype.showErrorToastInterval;
/** @type {?} */
DatePickerViewComponent.prototype.onValueChange;
/** @type {?} */
DatePickerViewComponent.prototype.amPicker;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-view.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["date-picker-view/date-picker-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  OnInit,\n  Output,\n  Component,\n  OnChanges,\n  forwardRef,\n  HostBinding,\n  EventEmitter,\n  SimpleChanges,\n  AfterViewInit,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DatePickerComponent } from '../date-picker/date-picker.component';\n\n@Component({\n  selector: 'DatePickerView, nzm-date-picker-view',\n  templateUrl: './date-picker-view.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerViewComponent),\n      multi: true\n    }\n  ]\n})\nexport class DatePickerViewComponent extends DatePickerComponent\n  implements OnInit, AfterViewInit, OnChanges, ControlValueAccessor {\n  @Input()\n  mode: string = 'date';\n  @Input()\n  minDate: Date = new Date(2000, 5, 1, 0, 0, 0);\n  @Input()\n  maxDate: Date = new Date(2030, 1, 1, 23, 59, 59);\n  @Input()\n  value: Date = new Date();\n  @Input()\n  disabled: boolean = false;\n  @Input()\n  indicatorStyle: object = {};\n  @Input()\n  get locale() {\n    return this.options.locale;\n  }\n  set locale(value) {\n    this.options.locale = value;\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n  }\n  @Input()\n  showErrorToast: boolean = true;\n  @Input()\n  showErrorToastInterval: number = 2000;\n  @Output()\n  onValueChange: EventEmitter<any> = new EventEmitter();\n\n  @HostBinding('class.am-picker')\n  amPicker = true;\n\n  reloadPicker() {\n    if (this.currentPicker) {\n      const self = this;\n      setTimeout(() => {\n        self.selectedTarget.forEach((item, i) => {\n          self.currentPicker.children[i].children[2].style.transition = 'transform .3s';\n          const index = parseInt(item.currentY, 0);\n          self.currentPicker.children[i].children[2].style.transform = `translateY(${index * self.lineHeight}px)`;\n        });\n      }, 0);\n    }\n  }\n\n  writeValue(value: Date): void {\n    if (value) {\n      this.value = value;\n      this.optionInit();\n      this.init();\n    }\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  optionInit() {\n    this.options.mode = this.mode;\n    this.options.minDate = this.minDate;\n    this.options.maxDate = this.maxDate;\n    this.options.disabled = this.disabled;\n    this.options.locale = this.locale;\n    this.options.value = this.value;\n    this.options.showErrorToast = this.showErrorToast;\n    this.options.showErrorToastInterval = this.showErrorToastInterval;\n    this.options.onValueChange = this.onValueChange;\n    this.checkMode(this.options.mode);\n    const value = this.transformDateFormat(this.options.value).split('-');\n    if (value.length > 0) {\n      this.currentTime = value.map(item => {\n        return parseInt(item, 0);\n      });\n    }\n  }\n\n  ngOnInit() {\n    this.optionInit();\n    this.localeProvider();\n  }\n\n  ngAfterViewInit() {\n    this.currentPicker = this.elementRef.nativeElement;\n    this.reloadPicker();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.value) {\n      this.options.value = changes.value.currentValue;\n      const value = this.transformDateFormat(this.options.value).split('-');\n      if (value.length > 0) {\n        this.currentTime = value.map(item => {\n          return parseInt(item, 0);\n        });\n      }\n      if (\n        !this.judgeEqualArray(this.currentTime, this.resultArr, this.resultArr.length) ||\n        this.judgeEqualArray(this.currentTime, this.min_date, this.currentTime.length) ||\n        this.judgeTime(this.currentTime, this.max_date)\n      ) {\n        this.optionInit();\n        this.init();\n      }\n    }\n\n    if (changes.mode || changes.minDate || changes.maxDate || changes.disabled || changes.locale) {\n      this.optionInit();\n      this.init();\n    }\n  }\n}\n"]}