UNPKG

ng-zorro-antd-mobile

Version:

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

147 lines 20 kB
import { Input, Output, Component, forwardRef, HostBinding, EventEmitter, ViewEncapsulation } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { DatePickerComponent, DatePickerOptions } from 'ng-zorro-antd-mobile/date-picker'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; 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; } get locale() { return this.options.locale; } set locale(value) { this.options.locale = value; this.unsubscribe$.next(); this.unsubscribe$.complete(); } reloadPicker() { if (this.currentPicker) { const self = this; setTimeout(() => { self.selectedTarget.forEach((item, i) => { self.currentPicker.children[i].children[2].style.transition = 'transform .3s'; const index = parseInt(item.currentY, 0); self.currentPicker.children[i].children[2].style.transform = `translateY(${index * self.lineHeight}px)`; }); }, 0); } } writeValue(value) { if (value) { this.value = value; this.optionInit(); this.init(); } } registerOnChange(fn) { this.ngModelOnChange = fn; } registerOnTouched(fn) { this.ngModelOnTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } 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); const value = this.transformDateFormat(this.options.value).split('-'); if (value.length > 0) { this.current_time = this.currentTime = value.map(item => { return parseInt(item, 0); }); } } ngOnInit() { this.optionInit(); this.localeProvider(); } ngAfterViewInit() { this.currentPicker = this.elementRef.nativeElement; this.reloadPicker(); } ngOnChanges(changes) { if (changes.value) { this.options.value = changes.value.currentValue; const value = this.transformDateFormat(this.options.value).split('-'); if (value.length > 0) { this.currentTime = value.map(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(); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DatePickerViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: DatePickerViewComponent, selector: "DatePickerView, nzm-date-picker-view", inputs: { mode: "mode", minDate: "minDate", maxDate: "maxDate", value: "value", disabled: "disabled", indicatorStyle: "indicatorStyle", locale: "locale", showErrorToast: "showErrorToast", showErrorToastInterval: "showErrorToastInterval" }, outputs: { onValueChange: "onValueChange" }, host: { properties: { "class.am-picker": "this.amPicker" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DatePickerViewComponent), multi: true }, DatePickerOptions ], usesInheritance: true, usesOnChanges: true, ngImport: i0, 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", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DatePickerViewComponent, decorators: [{ type: Component, args: [{ selector: 'DatePickerView, nzm-date-picker-view', encapsulation: ViewEncapsulation.None, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DatePickerViewComponent), multi: true }, DatePickerOptions ], 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" }] }], 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'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-view.component.js","sourceRoot":"","sources":["../../../components/date-picker-view/date-picker-view.component.ts","../../../components/date-picker-view/date-picker-view.component.html"],"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, DatePickerOptions } from 'ng-zorro-antd-mobile/date-picker';\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    DatePickerOptions\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.current_time = 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","<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"]}