UNPKG

ng-zorro-antd-mobile

Version:

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

258 lines 20.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; 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'; var DatePickerViewComponent = /** @class */ (function (_super) { tslib_1.__extends(DatePickerViewComponent, _super); function DatePickerViewComponent() { var _this = _super !== null && _super.apply(this, arguments) || this; _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 _this; } Object.defineProperty(DatePickerViewComponent.prototype, "locale", { get: /** * @return {?} */ function () { return this.options.locale; }, set: /** * @param {?} value * @return {?} */ function (value) { this.options.locale = value; this.unsubscribe$.next(); this.unsubscribe$.complete(); }, enumerable: true, configurable: true }); /** * @return {?} */ DatePickerViewComponent.prototype.reloadPicker = /** * @return {?} */ function () { if (this.currentPicker) { /** @type {?} */ var self_1 = this; setTimeout((/** * @return {?} */ function () { self_1.selectedTarget.forEach((/** * @param {?} item * @param {?} i * @return {?} */ function (item, i) { self_1.currentPicker.children[i].children[2].style.transition = 'transform .3s'; /** @type {?} */ var index = parseInt(item.currentY, 0); self_1.currentPicker.children[i].children[2].style.transform = "translateY(" + index * self_1.lineHeight + "px)"; })); }), 0); } }; /** * @param {?} value * @return {?} */ DatePickerViewComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { if (value) { this.value = value; this.optionInit(); this.init(); } }; /** * @param {?} fn * @return {?} */ DatePickerViewComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.ngModelOnChange = fn; }; /** * @param {?} fn * @return {?} */ DatePickerViewComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.ngModelOnTouched = fn; }; /** * @param {?} isDisabled * @return {?} */ DatePickerViewComponent.prototype.setDisabledState = /** * @param {?} isDisabled * @return {?} */ function (isDisabled) { this.disabled = isDisabled; }; /** * @return {?} */ DatePickerViewComponent.prototype.optionInit = /** * @return {?} */ function () { 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 {?} */ var value = this.transformDateFormat(this.options.value).split('-'); if (value.length > 0) { this.currentTime = value.map((/** * @param {?} item * @return {?} */ function (item) { return parseInt(item, 0); })); } }; /** * @return {?} */ DatePickerViewComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.optionInit(); this.localeProvider(); }; /** * @return {?} */ DatePickerViewComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { this.currentPicker = this.elementRef.nativeElement; this.reloadPicker(); }; /** * @param {?} changes * @return {?} */ DatePickerViewComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.value) { this.options.value = changes.value.currentValue; /** @type {?} */ var value = this.transformDateFormat(this.options.value).split('-'); if (value.length > 0) { this.currentTime = value.map((/** * @param {?} item * @return {?} */ function (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 {?} */ function () { 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',] }] }; return DatePickerViewComponent; }(DatePickerComponent)); export { DatePickerViewComponent }; 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"]}