UNPKG

ng-zorro-antd

Version:

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

320 lines 23 kB
/** * @fileoverview added by tsickle * @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 { forwardRef, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, HostBinding, Input, Output, TemplateRef, ViewEncapsulation } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { toBoolean, warnDeprecation, CandyDate, InputBoolean } from 'ng-zorro-antd/core'; import { NzDateCellDirective as DateCell, NzDateFullCellDirective as DateFullCell, NzMonthCellDirective as MonthCell, NzMonthFullCellDirective as MonthFullCell } from './nz-calendar-cells'; var NzCalendarComponent = /** @class */ (function () { function NzCalendarComponent(cdr) { this.cdr = cdr; this.activeDate = new CandyDate(); this.prefixCls = 'ant-fullcalendar'; this.onChangeFn = (/** * @return {?} */ function () { }); this.onTouchFn = (/** * @return {?} */ function () { }); this.nzMode = 'month'; this.nzModeChange = new EventEmitter(); this.nzPanelChange = new EventEmitter(); this.nzSelectChange = new EventEmitter(); this.nzValueChange = new EventEmitter(); this.nzFullscreen = true; } Object.defineProperty(NzCalendarComponent.prototype, "nzValue", { set: /** * @param {?} value * @return {?} */ function (value) { this.updateDate(new CandyDate(value), false); }, enumerable: true, configurable: true }); Object.defineProperty(NzCalendarComponent.prototype, "dateCell", { get: /** * @return {?} */ function () { return this.nzDateCell || this.nzDateCellChild; }, enumerable: true, configurable: true }); Object.defineProperty(NzCalendarComponent.prototype, "dateFullCell", { get: /** * @return {?} */ function () { return this.nzDateFullCell || this.nzDateFullCellChild; }, enumerable: true, configurable: true }); Object.defineProperty(NzCalendarComponent.prototype, "monthCell", { get: /** * @return {?} */ function () { return this.nzMonthCell || this.nzMonthCellChild; }, enumerable: true, configurable: true }); Object.defineProperty(NzCalendarComponent.prototype, "monthFullCell", { get: /** * @return {?} */ function () { return this.nzMonthFullCell || this.nzMonthFullCellChild; }, enumerable: true, configurable: true }); Object.defineProperty(NzCalendarComponent.prototype, "nzCard", { get: /** * @return {?} */ function () { return !this.nzFullscreen; }, /** * @deprecated use `[nzFullscreen]` instead. */ set: /** * @deprecated use `[nzFullscreen]` instead. * @param {?} value * @return {?} */ function (value) { warnDeprecation("'nzCard' is going to be removed in 9.0.0. Please use 'nzFullscreen' instead."); this.nzFullscreen = !toBoolean(value); }, enumerable: true, configurable: true }); /** * @return {?} */ NzCalendarComponent.prototype.ngOnInit = /** * @return {?} */ function () { }; /** * @param {?} mode * @return {?} */ NzCalendarComponent.prototype.onModeChange = /** * @param {?} mode * @return {?} */ function (mode) { this.nzModeChange.emit(mode); this.nzPanelChange.emit({ date: this.activeDate.nativeDate, mode: mode }); }; /** * @param {?} year * @return {?} */ NzCalendarComponent.prototype.onYearSelect = /** * @param {?} year * @return {?} */ function (year) { /** @type {?} */ var date = this.activeDate.setYear(year); this.updateDate(date); }; /** * @param {?} month * @return {?} */ NzCalendarComponent.prototype.onMonthSelect = /** * @param {?} month * @return {?} */ function (month) { /** @type {?} */ var date = this.activeDate.setMonth(month); this.updateDate(date); }; /** * @param {?} date * @return {?} */ NzCalendarComponent.prototype.onDateSelect = /** * @param {?} date * @return {?} */ function (date) { // Only activeDate is enough in calendar // this.value = date; this.updateDate(date); }; /** * @param {?} value * @return {?} */ NzCalendarComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this.updateDate(new CandyDate((/** @type {?} */ (value))), false); this.cdr.markForCheck(); }; /** * @param {?} fn * @return {?} */ NzCalendarComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChangeFn = fn; }; /** * @param {?} fn * @return {?} */ NzCalendarComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouchFn = fn; }; /** * @private * @param {?} date * @param {?=} touched * @return {?} */ NzCalendarComponent.prototype.updateDate = /** * @private * @param {?} date * @param {?=} touched * @return {?} */ function (date, touched) { if (touched === void 0) { touched = true; } this.activeDate = date; if (touched) { this.onChangeFn(date.nativeDate); this.onTouchFn(); this.nzSelectChange.emit(date.nativeDate); this.nzValueChange.emit(date.nativeDate); } }; NzCalendarComponent.decorators = [ { type: Component, args: [{ encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, selector: 'nz-calendar', exportAs: 'nzCalendar', template: "<nz-calendar-header [fullscreen]=\"nzFullscreen\" [activeDate]=\"activeDate\" [(mode)]=\"nzMode\"\n (modeChange)=\"onModeChange($event)\" (yearChange)=\"onYearSelect($event)\" (monthChange)=\"onMonthSelect($event)\">\n</nz-calendar-header>\n\n<div class=\"{{prefixCls}} {{prefixCls}}-full\" [class.ant-fullcalendar-fullscreen]=\"nzFullscreen\">\n <div class=\"{{prefixCls}}-calendar-body\">\n <ng-container *ngIf=\"nzMode === 'month' then monthModeTable else yearModeTable\"></ng-container>\n </div>\n</div>\n\n<ng-template #monthModeTable>\n <date-table [prefixCls]=\"prefixCls\" [value]=\"activeDate\" [dateCellRender]=\"dateCell\"\n [dateFullCellRender]=\"dateFullCell\" (valueChange)=\"onDateSelect($event)\"></date-table>\n</ng-template>\n\n<ng-template #yearModeTable>\n <month-table [prefixCls]=\"prefixCls\" [value]=\"activeDate\" [monthCellRender]=\"monthCell\"\n [monthFullCellRender]=\"monthFullCell\" (valueChange)=\"onDateSelect($event)\"></month-table>\n</ng-template>", providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return NzCalendarComponent; })), multi: true }] }] } ]; /** @nocollapse */ NzCalendarComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef } ]; }; NzCalendarComponent.propDecorators = { nzMode: [{ type: Input }], nzModeChange: [{ type: Output }], nzPanelChange: [{ type: Output }], nzSelectChange: [{ type: Output }], nzValue: [{ type: Input }], nzValueChange: [{ type: Output }], nzDateCell: [{ type: Input }], nzDateCellChild: [{ type: ContentChild, args: [DateCell, { static: false, read: TemplateRef },] }], nzDateFullCell: [{ type: Input }], nzDateFullCellChild: [{ type: ContentChild, args: [DateFullCell, { static: false, read: TemplateRef },] }], nzMonthCell: [{ type: Input }], nzMonthCellChild: [{ type: ContentChild, args: [MonthCell, { static: false, read: TemplateRef },] }], nzMonthFullCell: [{ type: Input }], nzMonthFullCellChild: [{ type: ContentChild, args: [MonthFullCell, { static: false, read: TemplateRef },] }], nzFullscreen: [{ type: Input }, { type: HostBinding, args: ['class.ant-fullcalendar--fullscreen',] }], nzCard: [{ type: Input }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Boolean) ], NzCalendarComponent.prototype, "nzFullscreen", void 0); return NzCalendarComponent; }()); export { NzCalendarComponent }; if (false) { /** @type {?} */ NzCalendarComponent.prototype.activeDate; /** @type {?} */ NzCalendarComponent.prototype.prefixCls; /** * @type {?} * @private */ NzCalendarComponent.prototype.onChangeFn; /** * @type {?} * @private */ NzCalendarComponent.prototype.onTouchFn; /** @type {?} */ NzCalendarComponent.prototype.nzMode; /** @type {?} */ NzCalendarComponent.prototype.nzModeChange; /** @type {?} */ NzCalendarComponent.prototype.nzPanelChange; /** @type {?} */ NzCalendarComponent.prototype.nzSelectChange; /** @type {?} */ NzCalendarComponent.prototype.nzValueChange; /** * Cannot use \@Input and \@ContentChild on one variable * because { static: false } will make \@Input property get delayed * * @type {?} */ NzCalendarComponent.prototype.nzDateCell; /** @type {?} */ NzCalendarComponent.prototype.nzDateCellChild; /** @type {?} */ NzCalendarComponent.prototype.nzDateFullCell; /** @type {?} */ NzCalendarComponent.prototype.nzDateFullCellChild; /** @type {?} */ NzCalendarComponent.prototype.nzMonthCell; /** @type {?} */ NzCalendarComponent.prototype.nzMonthCellChild; /** @type {?} */ NzCalendarComponent.prototype.nzMonthFullCell; /** @type {?} */ NzCalendarComponent.prototype.nzMonthFullCellChild; /** @type {?} */ NzCalendarComponent.prototype.nzFullscreen; /** * @type {?} * @private */ NzCalendarComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-calendar.component.js","sourceRoot":"ng://ng-zorro-antd/calendar/","sources":["nz-calendar.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  forwardRef,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { toBoolean, warnDeprecation, CandyDate, InputBoolean } from 'ng-zorro-antd/core';\nimport {\n  NzDateCellDirective as DateCell,\n  NzDateFullCellDirective as DateFullCell,\n  NzMonthCellDirective as MonthCell,\n  NzMonthFullCellDirective as MonthFullCell\n} from './nz-calendar-cells';\n\nexport type ModeType = 'month' | 'year';\nexport type DateTemplate = TemplateRef<{ $implicit: Date }>;\n\n@Component({\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'nz-calendar',\n  exportAs: 'nzCalendar',\n  templateUrl: './nz-calendar.component.html',\n  providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NzCalendarComponent), multi: true }]\n})\nexport class NzCalendarComponent implements ControlValueAccessor, OnInit {\n  activeDate: CandyDate = new CandyDate();\n  prefixCls: string = 'ant-fullcalendar';\n\n  private onChangeFn: (date: Date) => void = () => {};\n  private onTouchFn: () => void = () => {};\n\n  @Input() nzMode: ModeType = 'month';\n\n  @Output() readonly nzModeChange: EventEmitter<ModeType> = new EventEmitter();\n  @Output() readonly nzPanelChange: EventEmitter<{ date: Date; mode: ModeType }> = new EventEmitter();\n  @Output() readonly nzSelectChange: EventEmitter<Date> = new EventEmitter();\n\n  @Input() set nzValue(value: Date) {\n    this.updateDate(new CandyDate(value), false);\n  }\n  @Output() readonly nzValueChange: EventEmitter<Date> = new EventEmitter();\n\n  /**\n   * Cannot use @Input and @ContentChild on one variable\n   * because { static: false } will make @Input property get delayed\n   **/\n  @Input() nzDateCell: DateTemplate;\n  @ContentChild(DateCell, { static: false, read: TemplateRef }) nzDateCellChild: DateTemplate;\n  get dateCell(): DateTemplate {\n    return this.nzDateCell || this.nzDateCellChild;\n  }\n\n  @Input() nzDateFullCell: DateTemplate;\n  @ContentChild(DateFullCell, { static: false, read: TemplateRef }) nzDateFullCellChild: DateTemplate;\n  get dateFullCell(): DateTemplate {\n    return this.nzDateFullCell || this.nzDateFullCellChild;\n  }\n\n  @Input() nzMonthCell: DateTemplate;\n  @ContentChild(MonthCell, { static: false, read: TemplateRef }) nzMonthCellChild: DateTemplate;\n  get monthCell(): DateTemplate {\n    return this.nzMonthCell || this.nzMonthCellChild;\n  }\n\n  @Input() nzMonthFullCell: DateTemplate;\n  @ContentChild(MonthFullCell, { static: false, read: TemplateRef }) nzMonthFullCellChild: DateTemplate;\n  get monthFullCell(): DateTemplate {\n    return this.nzMonthFullCell || this.nzMonthFullCellChild;\n  }\n\n  @Input()\n  @InputBoolean()\n  @HostBinding('class.ant-fullcalendar--fullscreen')\n  nzFullscreen: boolean = true;\n\n  /**\n   * @deprecated use `[nzFullscreen]` instead.\n   */\n  @Input()\n  set nzCard(value: boolean) {\n    warnDeprecation(`'nzCard' is going to be removed in 9.0.0. Please use 'nzFullscreen' instead.`);\n    this.nzFullscreen = !toBoolean(value);\n  }\n  get nzCard(): boolean {\n    return !this.nzFullscreen;\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {}\n\n  onModeChange(mode: ModeType): void {\n    this.nzModeChange.emit(mode);\n    this.nzPanelChange.emit({ date: this.activeDate.nativeDate, mode });\n  }\n\n  onYearSelect(year: number): void {\n    const date = this.activeDate.setYear(year);\n    this.updateDate(date);\n  }\n\n  onMonthSelect(month: number): void {\n    const date = this.activeDate.setMonth(month);\n    this.updateDate(date);\n  }\n\n  onDateSelect(date: CandyDate): void {\n    // Only activeDate is enough in calendar\n    // this.value = date;\n    this.updateDate(date);\n  }\n\n  writeValue(value: Date | null): void {\n    this.updateDate(new CandyDate(value as Date), false);\n    this.cdr.markForCheck();\n  }\n\n  registerOnChange(fn: (date: Date) => void): void {\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouchFn = fn;\n  }\n\n  private updateDate(date: CandyDate, touched: boolean = true): void {\n    this.activeDate = date;\n\n    if (touched) {\n      this.onChangeFn(date.nativeDate);\n      this.onTouchFn();\n      this.nzSelectChange.emit(date.nativeDate);\n      this.nzValueChange.emit(date.nativeDate);\n    }\n  }\n}\n"]}