UNPKG

ng-zorro-antd

Version:

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

400 lines 27.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { EventEmitter, Input, Output, ViewChild } from '@angular/core'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { InputBoolean } from '../core/util/convert'; import { CandyDate } from './lib/candy-date'; import { NzPickerComponent } from './picker.component'; /** @type {?} */ var POPUP_STYLE_PATCH = { 'position': 'relative' }; // Aim to override antd's style to support overlay's position strategy (position:absolute will cause it not working beacuse the overlay can't get the height/width of it's content) /** * The base picker for all common APIs * @abstract */ var AbstractPickerComponent = /** @class */ (function () { function AbstractPickerComponent(i18n, cdr, dateHelper, noAnimation) { this.i18n = i18n; this.cdr = cdr; this.dateHelper = dateHelper; this.noAnimation = noAnimation; // --- Common API this.nzAllowClear = true; this.nzAutoFocus = false; this.nzDisabled = false; this.nzPopupStyle = POPUP_STYLE_PATCH; this.nzOnOpenChange = new EventEmitter(); this.isRange = false; // Indicate whether the value is a range value this.destroyed$ = new Subject(); this.isCustomPlaceHolder = false; // ------------------------------------------------------------------------ // | Control value accessor implements // ------------------------------------------------------------------------ // NOTE: onChangeFn/onTouchedFn will not be assigned if user not use as ngModel this.onChangeFn = (/** * @return {?} */ function () { return void 0; }); this.onTouchedFn = (/** * @return {?} */ function () { return void 0; }); } Object.defineProperty(AbstractPickerComponent.prototype, "realOpenState", { get: // Indicate whether the value is a range value /** * @return {?} */ function () { return this.picker.animationOpenState; } // Use picker's real open state to let re-render the picker's content when shown up , enumerable: true, configurable: true }); // Use picker's real open state to let re-render the picker's content when shown up /** * @return {?} */ AbstractPickerComponent.prototype.initValue = // Use picker's real open state to let re-render the picker's content when shown up /** * @return {?} */ function () { this.nzValue = this.isRange ? [] : null; }; /** * @return {?} */ AbstractPickerComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; // Subscribe the every locale change if the nzLocale is not handled by user if (!this.nzLocale) { this.i18n.localeChange .pipe(takeUntil(this.destroyed$)) .subscribe((/** * @return {?} */ function () { return _this.setLocale(); })); } // Default value this.initValue(); }; /** * @param {?} changes * @return {?} */ AbstractPickerComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.nzPopupStyle) { // Always assign the popup style patch this.nzPopupStyle = this.nzPopupStyle ? tslib_1.__assign({}, this.nzPopupStyle, POPUP_STYLE_PATCH) : POPUP_STYLE_PATCH; } // Mark as customized placeholder by user once nzPlaceHolder assigned at the first time if (changes.nzPlaceHolder && changes.nzPlaceHolder.firstChange && typeof this.nzPlaceHolder !== 'undefined') { this.isCustomPlaceHolder = true; } if (changes.nzLocale) { // The nzLocale is currently handled by user this.setDefaultPlaceHolder(); } }; /** * @return {?} */ AbstractPickerComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroyed$.next(); this.destroyed$.complete(); }; /** * @return {?} */ AbstractPickerComponent.prototype.closeOverlay = /** * @return {?} */ function () { this.picker.hideOverlay(); }; /** * Common handle for value changes * @param value changed value */ /** * Common handle for value changes * @param {?} value changed value * @return {?} */ AbstractPickerComponent.prototype.onValueChange = /** * Common handle for value changes * @param {?} value changed value * @return {?} */ function (value) { this.nzValue = value; if (this.isRange) { if (((/** @type {?} */ (this.nzValue))).length) { this.onChangeFn([this.nzValue[0].nativeDate, this.nzValue[1].nativeDate]); } else { this.onChangeFn([]); } } else { if (this.nzValue) { this.onChangeFn(((/** @type {?} */ (this.nzValue))).nativeDate); } else { this.onChangeFn(null); } } this.onTouchedFn(); }; /** * Triggered when overlayOpen changes (different with realOpenState) * @param open The overlayOpen in picker component */ /** * Triggered when overlayOpen changes (different with realOpenState) * @param {?} open The overlayOpen in picker component * @return {?} */ AbstractPickerComponent.prototype.onOpenChange = /** * Triggered when overlayOpen changes (different with realOpenState) * @param {?} open The overlayOpen in picker component * @return {?} */ function (open) { this.nzOnOpenChange.emit(open); }; /** * @param {?} value * @return {?} */ AbstractPickerComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this.setValue(value); this.cdr.markForCheck(); }; /** * @param {?} fn * @return {?} */ AbstractPickerComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChangeFn = fn; }; /** * @param {?} fn * @return {?} */ AbstractPickerComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouchedFn = fn; }; /** * @param {?} disabled * @return {?} */ AbstractPickerComponent.prototype.setDisabledState = /** * @param {?} disabled * @return {?} */ function (disabled) { this.nzDisabled = disabled; this.cdr.markForCheck(); }; // ------------------------------------------------------------------------ // | Internal methods // ------------------------------------------------------------------------ // Reload locale from i18n with side effects // ------------------------------------------------------------------------ // | Internal methods // ------------------------------------------------------------------------ // Reload locale from i18n with side effects /** * @private * @return {?} */ AbstractPickerComponent.prototype.setLocale = // ------------------------------------------------------------------------ // | Internal methods // ------------------------------------------------------------------------ // Reload locale from i18n with side effects /** * @private * @return {?} */ function () { this.nzLocale = this.i18n.getLocaleData('DatePicker', {}); this.setDefaultPlaceHolder(); this.cdr.markForCheck(); }; /** * @private * @return {?} */ AbstractPickerComponent.prototype.setDefaultPlaceHolder = /** * @private * @return {?} */ function () { if (!this.isCustomPlaceHolder && this.nzLocale) { this.nzPlaceHolder = this.isRange ? this.nzLocale.lang.rangePlaceholder : this.nzLocale.lang.placeholder; } }; // Safe way of setting value with default // Safe way of setting value with default /** * @private * @param {?} value * @return {?} */ AbstractPickerComponent.prototype.setValue = // Safe way of setting value with default /** * @private * @param {?} value * @return {?} */ function (value) { if (this.isRange) { this.nzValue = value ? ((/** @type {?} */ (value))).map((/** * @param {?} val * @return {?} */ function (val) { return new CandyDate(val); })) : []; } else { this.nzValue = value ? new CandyDate((/** @type {?} */ (value))) : null; } }; AbstractPickerComponent.propDecorators = { nzAllowClear: [{ type: Input }], nzAutoFocus: [{ type: Input }], nzDisabled: [{ type: Input }], nzOpen: [{ type: Input }], nzClassName: [{ type: Input }], nzDisabledDate: [{ type: Input }], nzLocale: [{ type: Input }], nzPlaceHolder: [{ type: Input }], nzPopupStyle: [{ type: Input }], nzDropdownClassName: [{ type: Input }], nzSize: [{ type: Input }], nzStyle: [{ type: Input }], nzOnOpenChange: [{ type: Output }], nzFormat: [{ type: Input }], nzValue: [{ type: Input }], picker: [{ type: ViewChild, args: [NzPickerComponent,] }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Boolean) ], AbstractPickerComponent.prototype, "nzAllowClear", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Boolean) ], AbstractPickerComponent.prototype, "nzAutoFocus", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Boolean) ], AbstractPickerComponent.prototype, "nzDisabled", void 0); tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Boolean) ], AbstractPickerComponent.prototype, "nzOpen", void 0); return AbstractPickerComponent; }()); export { AbstractPickerComponent }; if (false) { /** @type {?} */ AbstractPickerComponent.prototype.nzAllowClear; /** @type {?} */ AbstractPickerComponent.prototype.nzAutoFocus; /** @type {?} */ AbstractPickerComponent.prototype.nzDisabled; /** @type {?} */ AbstractPickerComponent.prototype.nzOpen; /** @type {?} */ AbstractPickerComponent.prototype.nzClassName; /** @type {?} */ AbstractPickerComponent.prototype.nzDisabledDate; /** @type {?} */ AbstractPickerComponent.prototype.nzLocale; /** @type {?} */ AbstractPickerComponent.prototype.nzPlaceHolder; /** @type {?} */ AbstractPickerComponent.prototype.nzPopupStyle; /** @type {?} */ AbstractPickerComponent.prototype.nzDropdownClassName; /** @type {?} */ AbstractPickerComponent.prototype.nzSize; /** @type {?} */ AbstractPickerComponent.prototype.nzStyle; /** @type {?} */ AbstractPickerComponent.prototype.nzOnOpenChange; /** @type {?} */ AbstractPickerComponent.prototype.nzFormat; /** @type {?} */ AbstractPickerComponent.prototype.nzValue; /** * @type {?} * @protected */ AbstractPickerComponent.prototype.picker; /** @type {?} */ AbstractPickerComponent.prototype.isRange; /** * @type {?} * @protected */ AbstractPickerComponent.prototype.destroyed$; /** * @type {?} * @protected */ AbstractPickerComponent.prototype.isCustomPlaceHolder; /** @type {?} */ AbstractPickerComponent.prototype.onChangeFn; /** @type {?} */ AbstractPickerComponent.prototype.onTouchedFn; /** * @type {?} * @protected */ AbstractPickerComponent.prototype.i18n; /** * @type {?} * @protected */ AbstractPickerComponent.prototype.cdr; /** * @type {?} * @protected */ AbstractPickerComponent.prototype.dateHelper; /** @type {?} */ AbstractPickerComponent.prototype.noAnimation; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-picker.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["date-picker/abstract-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor } from '@angular/forms';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';\nimport { InputBoolean } from '../core/util/convert';\nimport { DateHelperService } from '../i18n/date-helper.service';\nimport { NzDatePickerI18nInterface } from '../i18n/nz-i18n.interface';\nimport { NzI18nService } from '../i18n/nz-i18n.service';\nimport { CandyDate } from './lib/candy-date';\nimport { NzPickerComponent } from './picker.component';\n\nconst POPUP_STYLE_PATCH = { 'position': 'relative' }; // Aim to override antd's style to support overlay's position strategy (position:absolute will cause it not working beacuse the overlay can't get the height/width of it's content)\n\n/**\n * The base picker for all common APIs\n */\nexport abstract class AbstractPickerComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor {\n  // --- Common API\n  @Input() @InputBoolean() nzAllowClear: boolean = true;\n  @Input() @InputBoolean() nzAutoFocus: boolean = false;\n  @Input() @InputBoolean() nzDisabled: boolean = false;\n  @Input() @InputBoolean() nzOpen: boolean;\n  @Input() nzClassName: string;\n  @Input() nzDisabledDate: (d: Date) => boolean;\n  @Input() nzLocale: NzDatePickerI18nInterface;\n  @Input() nzPlaceHolder: string | string[];\n  @Input() nzPopupStyle: object = POPUP_STYLE_PATCH;\n  @Input() nzDropdownClassName: string;\n  @Input() nzSize: 'large' | 'small';\n  @Input() nzStyle: object;\n  @Output() readonly nzOnOpenChange = new EventEmitter<boolean>();\n\n  @Input() nzFormat: string;\n\n  @Input() nzValue: CompatibleValue;\n\n  @ViewChild(NzPickerComponent) protected picker: NzPickerComponent;\n\n  isRange: boolean = false; // Indicate whether the value is a range value\n\n  get realOpenState(): boolean {\n    return this.picker.animationOpenState;\n  } // Use picker's real open state to let re-render the picker's content when shown up\n\n  initValue(): void {\n    this.nzValue = this.isRange ? [] : null;\n  }\n\n  protected destroyed$: Subject<void> = new Subject();\n  protected isCustomPlaceHolder: boolean = false;\n\n  constructor(protected i18n: NzI18nService, protected cdr: ChangeDetectorRef, protected dateHelper: DateHelperService, public noAnimation?: NzNoAnimationDirective) { }\n\n  ngOnInit(): void {\n    // Subscribe the every locale change if the nzLocale is not handled by user\n    if (!this.nzLocale) {\n      this.i18n.localeChange\n        .pipe(takeUntil(this.destroyed$))\n        .subscribe(() => this.setLocale());\n    }\n\n    // Default value\n    this.initValue();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzPopupStyle) { // Always assign the popup style patch\n      this.nzPopupStyle = this.nzPopupStyle ? { ...this.nzPopupStyle, ...POPUP_STYLE_PATCH } : POPUP_STYLE_PATCH;\n    }\n\n    // Mark as customized placeholder by user once nzPlaceHolder assigned at the first time\n    if (changes.nzPlaceHolder && changes.nzPlaceHolder.firstChange && typeof this.nzPlaceHolder !== 'undefined') {\n      this.isCustomPlaceHolder = true;\n    }\n\n    if (changes.nzLocale) { // The nzLocale is currently handled by user\n      this.setDefaultPlaceHolder();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroyed$.next();\n    this.destroyed$.complete();\n  }\n\n  closeOverlay(): void {\n    this.picker.hideOverlay();\n  }\n\n  /**\n   * Common handle for value changes\n   * @param value changed value\n   */\n  onValueChange(value: CompatibleValue): void {\n    this.nzValue = value;\n    if (this.isRange) {\n      if ((this.nzValue as CandyDate[]).length) {\n        this.onChangeFn([ this.nzValue[ 0 ].nativeDate, this.nzValue[ 1 ].nativeDate ]);\n      } else {\n        this.onChangeFn([]);\n      }\n    } else {\n      if (this.nzValue) {\n        this.onChangeFn((this.nzValue as CandyDate).nativeDate);\n      } else {\n        this.onChangeFn(null);\n      }\n    }\n    this.onTouchedFn();\n  }\n\n  /**\n   * Triggered when overlayOpen changes (different with realOpenState)\n   * @param open The overlayOpen in picker component\n   */\n  onOpenChange(open: boolean): void {\n    this.nzOnOpenChange.emit(open);\n  }\n\n  // ------------------------------------------------------------------------\n  // | Control value accessor implements\n  // ------------------------------------------------------------------------\n\n  // NOTE: onChangeFn/onTouchedFn will not be assigned if user not use as ngModel\n  onChangeFn: (val: CompatibleDate) => void = () => void 0;\n  onTouchedFn: () => void = () => void 0;\n\n  writeValue(value: CompatibleDate): void {\n    this.setValue(value);\n    this.cdr.markForCheck();\n  }\n\n  registerOnChange(fn: any): void { // tslint:disable-line:no-any\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(fn: any): void { // tslint:disable-line:no-any\n    this.onTouchedFn = fn;\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.nzDisabled = disabled;\n    this.cdr.markForCheck();\n  }\n\n  // ------------------------------------------------------------------------\n  // | Internal methods\n  // ------------------------------------------------------------------------\n\n  // Reload locale from i18n with side effects\n  private setLocale(): void {\n    this.nzLocale = this.i18n.getLocaleData('DatePicker', {});\n    this.setDefaultPlaceHolder();\n    this.cdr.markForCheck();\n  }\n\n  private setDefaultPlaceHolder(): void {\n    if (!this.isCustomPlaceHolder && this.nzLocale) {\n      this.nzPlaceHolder = this.isRange ? this.nzLocale.lang.rangePlaceholder : this.nzLocale.lang.placeholder;\n    }\n  }\n\n  // Safe way of setting value with default\n  private setValue(value: CompatibleDate): void {\n    if (this.isRange) {\n      this.nzValue = value ? (value as Date[]).map(val => new CandyDate(val)) : [];\n    } else {\n      this.nzValue = value ? new CandyDate(value as Date) : null;\n    }\n  }\n}\n\nexport type CompatibleValue = CandyDate | CandyDate[];\n\nexport type CompatibleDate = Date | Date[];\n"]}