ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
224 lines • 17.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';
import { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';
import { toBoolean, valueFunctionProp, InputBoolean } from '../core/util/convert';
import { NzI18nService } from '../i18n/nz-i18n.service';
import { DateHelperService } from '../i18n/date-helper.service';
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.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 () {
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 has no timepicker and the user select a date by date panel, then close picker
// If has no timepicker and the user select a date by date panel, then close picker
/**
* @param {?} value
* @return {?}
*/
DateRangePickerComponent.prototype.onValueChange =
// If has no timepicker and the user select a date by date panel, then close picker
/**
* @param {?} value
* @return {?}
*/
function (value) {
_super.prototype.onValueChange.call(this, value);
if (!this.nzShowTime) {
this.closeOverlay();
}
};
// 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) {
if (((/** @type {?} */ (this.nzValue))).length) {
this.nzOnOk.emit([this.nzValue[0].nativeDate, this.nzValue[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 }],
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 {?}
* @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/","sources":["date-picker/date-range-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef } from '@angular/core';\n\nimport { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';\nimport { FunctionProp } from '../core/types/common-wrap';\nimport { toBoolean, valueFunctionProp, InputBoolean } from '../core/util/convert';\nimport { NzI18nService } from '../i18n/nz-i18n.service';\nimport { CandyDate } from './lib/candy-date';\n\nimport { DateHelperService } from '../i18n/date-helper.service';\nimport { AbstractPickerComponent, CompatibleDate } from './abstract-picker.component';\nimport { DisabledTimeFn, PanelMode, PresetRanges } from './standard-types';\n\n@Component({\n  template: `` // Just for rollup\n})\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: FunctionProp<PresetRanges>;\n  @Output() readonly nzOnPanelChange = new EventEmitter<PanelMode | PanelMode[]>();\n\n  private _showTime: object | boolean;\n  @Input() get nzShowTime(): object | boolean { return this._showTime; }\n  set nzShowTime(value: object | boolean) {\n    this._showTime = typeof value === 'object' ? value : toBoolean(value);\n  }\n\n  @Output() readonly nzOnOk = new EventEmitter<CompatibleDate>();\n\n  get realShowToday(): boolean { // 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(i18n: NzI18nService, cdr: ChangeDetectorRef, dateHelper: DateHelperService, noAnimation?: NzNoAnimationDirective) {\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  // If has no timepicker and the user select a date by date panel, then close picker\n  onValueChange(value: CandyDate): void {\n    super.onValueChange(value);\n\n    if (!this.nzShowTime) {\n      this.closeOverlay();\n    }\n  }\n\n  // Emitted when done with date selecting\n  onResultOk(): void {\n    if (this.isRange) {\n      if ((this.nzValue as CandyDate[]).length) {\n        this.nzOnOk.emit([ this.nzValue[ 0 ].nativeDate, this.nzValue[ 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"]}