ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
331 lines • 25 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
/**
* @license
* Copyright Alibaba.com All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
*/
import { EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { InputBoolean } from 'ng-zorro-antd/core';
import { CandyDate } from './lib/candy-date/candy-date';
import { NzPickerComponent } from './picker.component';
/** @type {?} */
const 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
*/
export class AbstractPickerComponent {
/**
* @param {?} i18n
* @param {?} cdr
* @param {?} dateHelper
* @param {?=} noAnimation
*/
constructor(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 {?}
*/
() => void 0);
this.onTouchedFn = (/**
* @return {?}
*/
() => void 0);
}
// Indicate whether the value is a range value
/**
* @return {?}
*/
get realOpenState() {
return this.picker.animationOpenState;
} // Use picker's real open state to let re-render the picker's content when shown up
// Use picker's real open state to let re-render the picker's content when shown up
/**
* @return {?}
*/
initValue() {
this.nzValue = this.isRange ? [] : null;
}
/**
* @return {?}
*/
ngOnInit() {
// 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 {?}
*/
() => this.setLocale()));
}
// Default value
this.initValue();
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes.nzPopupStyle) {
// Always assign the popup style patch
this.nzPopupStyle = this.nzPopupStyle ? Object.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 {?}
*/
ngOnDestroy() {
this.destroyed$.next();
this.destroyed$.complete();
}
/**
* @return {?}
*/
closeOverlay() {
this.picker.hideOverlay();
}
/**
* Common handle for value changes
* @param {?} value changed value
* @return {?}
*/
onValueChange(value) {
this.nzValue = value;
if (this.isRange) {
/** @type {?} */
const vAsRange = (/** @type {?} */ (this.nzValue));
if (vAsRange.length) {
this.onChangeFn([vAsRange[0].nativeDate, vAsRange[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
* @return {?}
*/
onOpenChange(open) {
this.nzOnOpenChange.emit(open);
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
this.setValue(value);
this.cdr.markForCheck();
}
// tslint:disable-next-line:no-any
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.onChangeFn = fn;
}
// tslint:disable-next-line:no-any
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.onTouchedFn = fn;
}
/**
* @param {?} disabled
* @return {?}
*/
setDisabledState(disabled) {
this.nzDisabled = disabled;
this.cdr.markForCheck();
}
// ------------------------------------------------------------------------
// | Internal methods
// ------------------------------------------------------------------------
// Reload locale from i18n with side effects
/**
* @private
* @return {?}
*/
setLocale() {
this.nzLocale = this.i18n.getLocaleData('DatePicker', {});
this.setDefaultPlaceHolder();
this.cdr.markForCheck();
}
/**
* @private
* @return {?}
*/
setDefaultPlaceHolder() {
if (!this.isCustomPlaceHolder && this.nzLocale) {
this.nzPlaceHolder = this.isRange ? this.nzLocale.lang.rangePlaceholder : this.nzLocale.lang.placeholder;
}
}
// Safe way of setting value with default
/**
* @private
* @param {?} value
* @return {?}
*/
setValue(value) {
if (this.isRange) {
this.nzValue = value ? ((/** @type {?} */ (value))).map((/**
* @param {?} val
* @return {?}
*/
val => 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 }],
nzFormat: [{ type: Input }],
nzValue: [{ type: Input }],
nzOnOpenChange: [{ type: Output }],
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);
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.nzFormat;
/** @type {?} */
AbstractPickerComponent.prototype.nzValue;
/** @type {?} */
AbstractPickerComponent.prototype.nzOnOpenChange;
/**
* @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/date-picker/","sources":["abstract-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport {\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';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { InputBoolean, NzNoAnimationDirective } from 'ng-zorro-antd/core';\nimport { DateHelperService, NzDatePickerI18nInterface, NzI18nService } from 'ng-zorro-antd/i18n';\n\nimport { CandyDate } from './lib/candy-date/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  @Input() nzFormat: string;\n  @Input() nzValue: CompatibleValue | null;\n\n  @Output() readonly nzOnOpenChange = new EventEmitter<boolean>();\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(\n    protected i18n: NzI18nService,\n    protected cdr: ChangeDetectorRef,\n    protected dateHelper: DateHelperService,\n    public noAnimation?: NzNoAnimationDirective\n  ) {}\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.pipe(takeUntil(this.destroyed$)).subscribe(() => this.setLocale());\n    }\n\n    // Default value\n    this.initValue();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzPopupStyle) {\n      // 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) {\n      // 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      const vAsRange = this.nzValue as CandyDate[];\n      if (vAsRange.length) {\n        this.onChangeFn([vAsRange[0].nativeDate, vAsRange[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 | null) => 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  // tslint:disable-next-line:no-any\n  registerOnChange(fn: any): void {\n    this.onChangeFn = fn;\n  }\n\n  // tslint:disable-next-line:no-any\n  registerOnTouched(fn: any): void {\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"]}