UNPKG

ng-zorro-antd-mobile

Version:

An enterprise-class mobile UI components based on Ant Design and Angular

217 lines 18.8 kB
/** * @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"]}