UNPKG

ng-zorro-antd

Version:

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

266 lines 19.8 kB
/** * @fileoverview added by tsickle * Generated from: date-range-picker.component.ts * @suppress {checkTypes,constantProperty,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 { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core'; import { toBoolean, valueFunctionProp, InputBoolean, NzNoAnimationDirective } from 'ng-zorro-antd/core'; import { DateHelperService, NzI18nService } from 'ng-zorro-antd/i18n'; import { AbstractPickerComponent } from './abstract-picker.component'; var DateRangePickerComponent = /** @class */ (function (_super) { tslib_1.__extends(DateRangePickerComponent, _super); function DateRangePickerComponent(i18n, cdr, dateHelper, noAnimation) { var _this = _super.call(this, i18n, cdr, dateHelper, noAnimation) || this; _this.showWeek = false; // Should show as week picker _this.nzShowToday = true; _this.nzOnPanelChange = new EventEmitter(); _this.nzOnCalendarChange = new EventEmitter(); _this.nzOnOk = new EventEmitter(); return _this; } Object.defineProperty(DateRangePickerComponent.prototype, "nzShowTime", { get: /** * @return {?} */ function () { return this._showTime; }, set: /** * @param {?} value * @return {?} */ function (value) { this._showTime = typeof value === 'object' ? value : toBoolean(value); }, enumerable: true, configurable: true }); Object.defineProperty(DateRangePickerComponent.prototype, "realShowToday", { get: /** * @return {?} */ function () { // Range not support nzShowToday currently return !this.isRange && this.nzShowToday; }, enumerable: true, configurable: true }); /** * @return {?} */ DateRangePickerComponent.prototype.ngOnInit = /** * @return {?} */ function () { _super.prototype.ngOnInit.call(this); // Default format when it's empty if (!this.nzFormat) { if (this.showWeek) { this.nzFormat = this.dateHelper.relyOnDatePipe ? 'yyyy-ww' : 'YYYY-WW'; // Format for week } else { if (this.dateHelper.relyOnDatePipe) { this.nzFormat = this.nzShowTime ? 'yyyy-MM-dd HH:mm:ss' : 'yyyy-MM-dd'; } else { this.nzFormat = this.nzShowTime ? 'YYYY-MM-DD HH:mm:ss' : 'YYYY-MM-DD'; } } } }; /** * @param {?} changes * @return {?} */ DateRangePickerComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { _super.prototype.ngOnChanges.call(this, changes); if (changes.nzRenderExtraFooter) { this.extraFooter = valueFunctionProp(this.nzRenderExtraFooter); } if (changes.nzShowTime || changes.nzStyle) { this.setFixedPickerStyle(); } }; /** * If user press 'Enter' in input box or `nzShowTime` is false, overlay will close. */ /** * If user press 'Enter' in input box or `nzShowTime` is false, overlay will close. * @param {?} value * @param {?=} isEnter * @return {?} */ DateRangePickerComponent.prototype.onValueChange = /** * If user press 'Enter' in input box or `nzShowTime` is false, overlay will close. * @param {?} value * @param {?=} isEnter * @return {?} */ function (value, isEnter) { if (isEnter === void 0) { isEnter = false; } _super.prototype.onValueChange.call(this, value); if (!this.nzShowTime || isEnter) { this.closeOverlay(); } }; // Emit nzOnCalendarChange when select date by nz-range-picker // Emit nzOnCalendarChange when select date by nz-range-picker /** * @param {?} value * @return {?} */ DateRangePickerComponent.prototype.onCalendarChange = // Emit nzOnCalendarChange when select date by nz-range-picker /** * @param {?} value * @return {?} */ function (value) { if (this.isRange) { /** @type {?} */ var rangeValue = value.map((/** * @param {?} x * @return {?} */ function (x) { return x.nativeDate; })); this.nzOnCalendarChange.emit(rangeValue); } }; // Emitted when done with date selecting // Emitted when done with date selecting /** * @return {?} */ DateRangePickerComponent.prototype.onResultOk = // Emitted when done with date selecting /** * @return {?} */ function () { if (this.isRange) { /** @type {?} */ var value = (/** @type {?} */ (this.nzValue)); if (value.length) { this.nzOnOk.emit([value[0].nativeDate, value[1].nativeDate]); } else { this.nzOnOk.emit([]); } } else { if (this.nzValue) { this.nzOnOk.emit(((/** @type {?} */ (this.nzValue))).nativeDate); } else { this.nzOnOk.emit(null); } } this.closeOverlay(); }; /** * @param {?} open * @return {?} */ DateRangePickerComponent.prototype.onOpenChange = /** * @param {?} open * @return {?} */ function (open) { this.nzOnOpenChange.emit(open); }; // Setup fixed style for picker // Setup fixed style for picker /** * @private * @return {?} */ DateRangePickerComponent.prototype.setFixedPickerStyle = // Setup fixed style for picker /** * @private * @return {?} */ function () { /** @type {?} */ var showTimeFixes = {}; if (this.nzShowTime) { showTimeFixes.width = this.isRange ? '350px' : '195px'; } this.pickerStyle = tslib_1.__assign({}, showTimeFixes, this.nzStyle); }; DateRangePickerComponent.decorators = [ { type: Component, args: [{ template: "" // Just for rollup }] } ]; /** @nocollapse */ DateRangePickerComponent.ctorParameters = function () { return [ { type: NzI18nService }, { type: ChangeDetectorRef }, { type: DateHelperService }, { type: NzNoAnimationDirective } ]; }; DateRangePickerComponent.propDecorators = { nzDateRender: [{ type: Input }], nzDisabledTime: [{ type: Input }], nzRenderExtraFooter: [{ type: Input }], nzShowToday: [{ type: Input }], nzMode: [{ type: Input }], nzRanges: [{ type: Input }], nzOnPanelChange: [{ type: Output }], nzOnCalendarChange: [{ type: Output }], nzShowTime: [{ type: Input }], nzOnOk: [{ type: Output }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Boolean) ], DateRangePickerComponent.prototype, "nzShowToday", void 0); return DateRangePickerComponent; }(AbstractPickerComponent)); export { DateRangePickerComponent }; if (false) { /** @type {?} */ DateRangePickerComponent.prototype.showWeek; /** @type {?} */ DateRangePickerComponent.prototype.nzDateRender; /** @type {?} */ DateRangePickerComponent.prototype.nzDisabledTime; /** @type {?} */ DateRangePickerComponent.prototype.nzRenderExtraFooter; /** @type {?} */ DateRangePickerComponent.prototype.nzShowToday; /** @type {?} */ DateRangePickerComponent.prototype.nzMode; /** @type {?} */ DateRangePickerComponent.prototype.nzRanges; /** @type {?} */ DateRangePickerComponent.prototype.nzOnPanelChange; /** @type {?} */ DateRangePickerComponent.prototype.nzOnCalendarChange; /** * @type {?} * @private */ DateRangePickerComponent.prototype._showTime; /** @type {?} */ DateRangePickerComponent.prototype.nzOnOk; /** @type {?} */ DateRangePickerComponent.prototype.pickerStyle; /** @type {?} */ DateRangePickerComponent.prototype.extraFooter; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"ng://ng-zorro-antd/date-picker/","sources":["date-range-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  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef\n} from '@angular/core';\n\nimport {\n  toBoolean,\n  valueFunctionProp,\n  CandyDate,\n  FunctionProp,\n  InputBoolean,\n  NzNoAnimationDirective\n} from 'ng-zorro-antd/core';\nimport { DateHelperService, NzI18nService } from 'ng-zorro-antd/i18n';\n\nimport { AbstractPickerComponent } from './abstract-picker.component';\nimport { CompatibleDate, DisabledTimeFn, PanelMode, PresetRanges } from './standard-types';\n\n@Component({\n  template: `` // Just for rollup\n})\nexport class DateRangePickerComponent extends AbstractPickerComponent implements OnInit, OnChanges {\n  showWeek: boolean = false; // Should show as week picker\n\n  @Input() nzDateRender: FunctionProp<TemplateRef<Date> | string>;\n  @Input() nzDisabledTime: DisabledTimeFn;\n  @Input() nzRenderExtraFooter: FunctionProp<TemplateRef<void> | string>;\n  @Input() @InputBoolean() nzShowToday: boolean = true;\n  @Input() nzMode: PanelMode | PanelMode[];\n  @Input() nzRanges: PresetRanges;\n  @Output() readonly nzOnPanelChange = new EventEmitter<PanelMode | PanelMode[]>();\n  @Output() readonly nzOnCalendarChange = new EventEmitter<Date[]>();\n\n  private _showTime: object | boolean;\n  @Input() get nzShowTime(): object | boolean {\n    return this._showTime;\n  }\n  set nzShowTime(value: object | boolean) {\n    this._showTime = typeof value === 'object' ? value : toBoolean(value);\n  }\n\n  @Output() readonly nzOnOk = new EventEmitter<CompatibleDate | null>();\n\n  get realShowToday(): boolean {\n    // Range not support nzShowToday currently\n    return !this.isRange && this.nzShowToday;\n  }\n\n  pickerStyle: object; // Final picker style that contains width fix corrections etc.\n  extraFooter: TemplateRef<void> | string;\n\n  constructor(\n    i18n: NzI18nService,\n    cdr: ChangeDetectorRef,\n    dateHelper: DateHelperService,\n    noAnimation?: NzNoAnimationDirective\n  ) {\n    super(i18n, cdr, dateHelper, noAnimation);\n  }\n\n  ngOnInit(): void {\n    super.ngOnInit();\n\n    // Default format when it's empty\n    if (!this.nzFormat) {\n      if (this.showWeek) {\n        this.nzFormat = this.dateHelper.relyOnDatePipe ? 'yyyy-ww' : 'YYYY-WW'; // Format for week\n      } else {\n        if (this.dateHelper.relyOnDatePipe) {\n          this.nzFormat = this.nzShowTime ? 'yyyy-MM-dd HH:mm:ss' : 'yyyy-MM-dd';\n        } else {\n          this.nzFormat = this.nzShowTime ? 'YYYY-MM-DD HH:mm:ss' : 'YYYY-MM-DD';\n        }\n      }\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    super.ngOnChanges(changes);\n\n    if (changes.nzRenderExtraFooter) {\n      this.extraFooter = valueFunctionProp(this.nzRenderExtraFooter);\n    }\n\n    if (changes.nzShowTime || changes.nzStyle) {\n      this.setFixedPickerStyle();\n    }\n  }\n\n  /**\n   * If user press 'Enter' in input box or `nzShowTime` is false, overlay will close.\n   */\n  onValueChange(value: CandyDate, isEnter: boolean = false): void {\n    super.onValueChange(value);\n\n    if (!this.nzShowTime || isEnter) {\n      this.closeOverlay();\n    }\n  }\n\n  // Emit nzOnCalendarChange when select date by nz-range-picker\n  onCalendarChange(value: CandyDate[]): void {\n    if (this.isRange) {\n      const rangeValue = value.map(x => x.nativeDate);\n      this.nzOnCalendarChange.emit(rangeValue);\n    }\n  }\n\n  // Emitted when done with date selecting\n  onResultOk(): void {\n    if (this.isRange) {\n      const value = this.nzValue as CandyDate[];\n      if (value.length) {\n        this.nzOnOk.emit([value[0].nativeDate, value[1].nativeDate]);\n      } else {\n        this.nzOnOk.emit([]);\n      }\n    } else {\n      if (this.nzValue) {\n        this.nzOnOk.emit((this.nzValue as CandyDate).nativeDate);\n      } else {\n        this.nzOnOk.emit(null);\n      }\n    }\n    this.closeOverlay();\n  }\n\n  onOpenChange(open: boolean): void {\n    this.nzOnOpenChange.emit(open);\n  }\n\n  // Setup fixed style for picker\n  private setFixedPickerStyle(): void {\n    const showTimeFixes: { width?: string } = {};\n    if (this.nzShowTime) {\n      showTimeFixes.width = this.isRange ? '350px' : '195px';\n    }\n\n    this.pickerStyle = { ...showTimeFixes, ...this.nzStyle };\n  }\n}\n"]}