UNPKG

@ohayojp.com/components

Version:

Common business components of ohayojp.

325 lines 24.1 kB
/** * @fileoverview added by tsickle * Generated from: range.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { __decorate, __metadata } from "tslib"; import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { DomSanitizer } from '@angular/platform-browser'; import { OhayoConfigService, deepMergeKey, fixEndTimeOfRange, getTimeDistance, InputBoolean, } from '@ohayojp.com/util'; import { NzRangePickerComponent } from 'ng-zorro-antd/date-picker'; export class RangePickerComponent { // #endregion /** * @param {?} dom * @param {?} configSrv */ constructor(dom, configSrv) { this.dom = dom; this.value = []; this.ngModelEndChange = new EventEmitter(); // #region Native properties this.nzAllowClear = true; this.nzAutoFocus = false; this.nzOnOpenChange = new EventEmitter(); this.nzShowToday = true; this.nzOnPanelChange = new EventEmitter(); this.nzOnOk = new EventEmitter(); /** @type {?} */ const cog = (/** @type {?} */ (configSrv.merge('dataRange', { nzFormat: 'yyyy-MM-dd', nzAllowClear: true, nzAutoFocus: false, nzPopupStyle: { position: 'relative' }, nzShowToday: true, shortcuts: { enabled: false, closed: true, list: [ { text: '今天', fn: (/** * @return {?} */ () => getTimeDistance('today')), }, { text: '昨天', fn: (/** * @return {?} */ () => getTimeDistance('yesterday')), }, { text: '近3天', fn: (/** * @return {?} */ () => getTimeDistance(-2)), }, { text: '近7天', fn: (/** * @return {?} */ () => getTimeDistance(-6)), }, { text: '本周', fn: (/** * @return {?} */ () => getTimeDistance('week')), }, { text: '本月', fn: (/** * @return {?} */ () => getTimeDistance('month')), }, { text: '全年', fn: (/** * @return {?} */ () => getTimeDistance('year')), }, ], }, }))); this.defaultShortcuts = (/** @type {?} */ (Object.assign({}, cog.shortcuts))); Object.assign(this, cog); } /** * @param {?} val * @return {?} */ set shortcut(val) { /** @type {?} */ const item = (/** @type {?} */ (deepMergeKey({}, true, this.defaultShortcuts, val == null ? {} : val))); if (typeof val === 'boolean') { item.enabled = val; } (item.list || []).forEach((/** * @param {?} i * @return {?} */ i => { i._text = this.dom.bypassSecurityTrustHtml(i.text); })); this._shortcut = item; } /** * @return {?} */ get shortcut() { return this._shortcut; } /** * @param {?} e * @return {?} */ _nzOnOpenChange(e) { this.nzOnOpenChange.emit(e); } /** * @param {?} e * @return {?} */ _nzOnPanelChange(e) { this.nzOnPanelChange.emit(e); } /** * @param {?} e * @return {?} */ _nzOnOk(e) { this.nzOnOk.emit(e); } /** * @param {?} e * @return {?} */ valueChange(e) { e = fixEndTimeOfRange(e); this.onChangeFn(e[0]); this.ngModelEnd = e[1]; this.ngModelEndChange.emit(e[1]); } /** * @param {?} value * @return {?} */ writeValue(value) { this.value = value && this.ngModelEnd ? [value, this.ngModelEnd] : []; } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this.onChangeFn = fn; } /** * @param {?} _fn * @return {?} */ registerOnTouched(_fn) { // this.onTouchedFn = fn; } /** * @param {?} disabled * @return {?} */ setDisabledState(disabled) { this.nzDisabled = disabled; } /** * @param {?} item * @return {?} */ clickShortcut(item) { this.value = item.fn((/** @type {?} */ (this.value))); this.valueChange((/** @type {?} */ (this.value))); if (this._shortcut.closed) { // tslint:disable-next-line:no-string-literal ((/** @type {?} */ (this.comp)))['picker'].hideOverlay(); } } } RangePickerComponent.decorators = [ { type: Component, args: [{ selector: 'range-picker', exportAs: 'rangePicker', template: "<nz-range-picker\n #comp\n [ngModel]=\"value\"\n (ngModelChange)=\"valueChange($event)\"\n [nzAllowClear]=\"nzAllowClear\"\n [nzAutoFocus]=\"nzAutoFocus\"\n [ngClass]=\"nzClassName\"\n [nzDisabled]=\"nzDisabled\"\n [nzSize]=\"nzSize\"\n [nzDisabledDate]=\"nzDisabledDate\"\n [nzLocale]=\"nzLocale\"\n [nzPopupStyle]=\"nzPopupStyle\"\n [nzDropdownClassName]=\"nzDropdownClassName\"\n [ngStyle]=\"nzStyle\"\n [nzPlaceHolder]=\"nzPlaceHolder\"\n (nzOnOpenChange)=\"_nzOnOpenChange($event)\"\n [nzDateRender]=\"nzDateRender\"\n [nzDisabledTime]=\"nzDisabledTime\"\n [nzFormat]=\"nzFormat\"\n [nzRenderExtraFooter]=\"nzRenderExtraFooter || (shortcut?.enabled ? shortcutTpl : null)\"\n [nzShowTime]=\"nzShowTime\"\n [nzShowToday]=\"nzShowToday\"\n [nzMode]=\"nzMode\"\n [nzRanges]=\"nzRanges\"\n (nzOnPanelChange)=\"_nzOnPanelChange($event)\"\n (nzOnOk)=\"_nzOnOk($event)\"\n></nz-range-picker>\n<ng-template #shortcutTpl>\n <a *ngFor=\"let i of shortcut?.list; let first = first\" (click)=\"clickShortcut(i)\" [innerHTML]=\"i._text\" [ngClass]=\"{ 'ml-sm': !first }\"></a>\n</ng-template>\n", providers: [ { provide: NG_VALUE_ACCESSOR, multi: true, useExisting: forwardRef((/** * @return {?} */ () => RangePickerComponent)), }, ] }] } ]; /** @nocollapse */ RangePickerComponent.ctorParameters = () => [ { type: DomSanitizer }, { type: OhayoConfigService } ]; RangePickerComponent.propDecorators = { comp: [{ type: ViewChild, args: ['comp', { static: false },] }], ngModelEnd: [{ type: Input }], shortcut: [{ type: Input }], ngModelEndChange: [{ type: Output }], nzAllowClear: [{ type: Input }], nzAutoFocus: [{ type: Input }], nzClassName: [{ type: Input }], nzDisabled: [{ type: Input }], nzSize: [{ type: Input }], nzStyle: [{ type: Input }], nzDisabledDate: [{ type: Input }], nzLocale: [{ type: Input }], nzPopupStyle: [{ type: Input }], nzDropdownClassName: [{ type: Input }], nzPlaceHolder: [{ type: Input }], nzOnOpenChange: [{ type: Output }], nzDateRender: [{ type: Input }], nzFormat: [{ type: Input }], nzDisabledTime: [{ type: Input }], nzRenderExtraFooter: [{ type: Input }], nzShowTime: [{ type: Input }], nzShowToday: [{ type: Input }], nzMode: [{ type: Input }], nzRanges: [{ type: Input }], nzOnPanelChange: [{ type: Output }], nzOnOk: [{ type: Output }] }; __decorate([ InputBoolean(), __metadata("design:type", Boolean) ], RangePickerComponent.prototype, "nzShowToday", void 0); if (false) { /** * @type {?} * @private */ RangePickerComponent.prototype.onChangeFn; /** * @type {?} * @private */ RangePickerComponent.prototype._shortcut; /** * @type {?} * @private */ RangePickerComponent.prototype.defaultShortcuts; /** * @type {?} * @private */ RangePickerComponent.prototype.comp; /** @type {?} */ RangePickerComponent.prototype.value; /** @type {?} */ RangePickerComponent.prototype.ngModelEnd; /** @type {?} */ RangePickerComponent.prototype.ngModelEndChange; /** @type {?} */ RangePickerComponent.prototype.nzAllowClear; /** @type {?} */ RangePickerComponent.prototype.nzAutoFocus; /** @type {?} */ RangePickerComponent.prototype.nzClassName; /** @type {?} */ RangePickerComponent.prototype.nzDisabled; /** @type {?} */ RangePickerComponent.prototype.nzSize; /** @type {?} */ RangePickerComponent.prototype.nzStyle; /** @type {?} */ RangePickerComponent.prototype.nzDisabledDate; /** @type {?} */ RangePickerComponent.prototype.nzLocale; /** @type {?} */ RangePickerComponent.prototype.nzPopupStyle; /** @type {?} */ RangePickerComponent.prototype.nzDropdownClassName; /** @type {?} */ RangePickerComponent.prototype.nzPlaceHolder; /** @type {?} */ RangePickerComponent.prototype.nzOnOpenChange; /** @type {?} */ RangePickerComponent.prototype.nzDateRender; /** @type {?} */ RangePickerComponent.prototype.nzFormat; /** @type {?} */ RangePickerComponent.prototype.nzDisabledTime; /** @type {?} */ RangePickerComponent.prototype.nzRenderExtraFooter; /** @type {?} */ RangePickerComponent.prototype.nzShowTime; /** @type {?} */ RangePickerComponent.prototype.nzShowToday; /** @type {?} */ RangePickerComponent.prototype.nzMode; /** @type {?} */ RangePickerComponent.prototype.nzRanges; /** @type {?} */ RangePickerComponent.prototype.nzOnPanelChange; /** @type {?} */ RangePickerComponent.prototype.nzOnOk; /** * @type {?} * @private */ RangePickerComponent.prototype.dom; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range.component.js","sourceRoot":"C:/android/@ohayojp/packages/components/date-picker/","sources":["range.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, Output, TemplateRef, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport {\n  OhayoConfigService,\n  OhayoDateRangePickerShortcut,\n  OhayoDateRangePickerShortcutItem,\n  deepMergeKey,\n  fixEndTimeOfRange,\n  getTimeDistance,\n  InputBoolean,\n} from '@ohayo/util';\nimport { FunctionProp, NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { NzRangePickerComponent } from 'ng-zorro-antd/date-picker';\n\n@Component({\n  selector: 'range-picker',\n  exportAs: 'rangePicker',\n  templateUrl: './range.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: forwardRef(() => RangePickerComponent),\n    },\n  ],\n})\nexport class RangePickerComponent implements ControlValueAccessor {\n  private onChangeFn: (val: Date) => void;\n  private _shortcut: OhayoDateRangePickerShortcut;\n  private defaultShortcuts: OhayoDateRangePickerShortcut;\n  @ViewChild('comp', { static: false }) private comp: NzRangePickerComponent;\n  value: Date[] = [];\n\n  @Input() ngModelEnd: Date;\n  @Input()\n  set shortcut(val: OhayoDateRangePickerShortcut | null) {\n    const item = deepMergeKey({}, true, this.defaultShortcuts, val == null ? {} : val) as OhayoDateRangePickerShortcut;\n    if (typeof val === 'boolean') {\n      item.enabled = val;\n    }\n    (item.list || []).forEach(i => {\n      i._text = this.dom.bypassSecurityTrustHtml(i.text);\n    });\n    this._shortcut = item;\n  }\n  get shortcut(): OhayoDateRangePickerShortcut | null {\n    return this._shortcut;\n  }\n  @Output() readonly ngModelEndChange = new EventEmitter<Date>();\n\n  // #region Native properties\n\n  @Input() nzAllowClear = true;\n  @Input() nzAutoFocus = false;\n  @Input() nzClassName: string;\n  @Input() nzDisabled: boolean;\n  @Input() nzSize: string;\n  @Input() nzStyle: string;\n  @Input() nzDisabledDate: (d: Date) => boolean;\n  @Input() nzLocale: object;\n  @Input() nzPopupStyle: object;\n  @Input() nzDropdownClassName: string;\n  @Input() nzPlaceHolder: string | string[];\n  @Output() readonly nzOnOpenChange = new EventEmitter<boolean>();\n\n  // range\n  @Input() nzDateRender: any;\n  @Input() nzFormat: any;\n  @Input() nzDisabledTime: any;\n  @Input() nzRenderExtraFooter: FunctionProp<TemplateRef<void> | string>;\n  @Input() nzShowTime: any;\n  @Input() @InputBoolean() nzShowToday: boolean = true;\n  @Input() nzMode: any;\n  @Input() nzRanges: any;\n  @Output() readonly nzOnPanelChange = new EventEmitter<any>();\n  @Output() readonly nzOnOk = new EventEmitter<any>();\n\n  // #endregion\n\n  constructor(private dom: DomSanitizer, configSrv: OhayoConfigService) {\n    const cog = configSrv.merge('dataRange', {\n      nzFormat: 'yyyy-MM-dd',\n      nzAllowClear: true,\n      nzAutoFocus: false,\n      nzPopupStyle: { position: 'relative' },\n      nzShowToday: true,\n      shortcuts: {\n        enabled: false,\n        closed: true,\n        list: [\n          {\n            text: '今天',\n            fn: () => getTimeDistance('today'),\n          },\n          {\n            text: '昨天',\n            fn: () => getTimeDistance('yesterday'),\n          },\n          {\n            text: '近3天',\n            fn: () => getTimeDistance(-2),\n          },\n          {\n            text: '近7天',\n            fn: () => getTimeDistance(-6),\n          },\n          {\n            text: '本周',\n            fn: () => getTimeDistance('week'),\n          },\n          {\n            text: '本月',\n            fn: () => getTimeDistance('month'),\n          },\n          {\n            text: '全年',\n            fn: () => getTimeDistance('year'),\n          },\n        ],\n      },\n    })!;\n    this.defaultShortcuts = { ...cog.shortcuts } as OhayoDateRangePickerShortcut;\n    Object.assign(this, cog);\n  }\n\n  _nzOnOpenChange(e: any): void {\n    this.nzOnOpenChange.emit(e);\n  }\n\n  _nzOnPanelChange(e: any): void {\n    this.nzOnPanelChange.emit(e);\n  }\n\n  _nzOnOk(e: any): void {\n    this.nzOnOk.emit(e);\n  }\n\n  valueChange(e: [Date, Date]): void {\n    e = fixEndTimeOfRange(e);\n    this.onChangeFn(e[0]);\n    this.ngModelEnd = e[1];\n    this.ngModelEndChange.emit(e[1]);\n  }\n\n  writeValue(value: Date): void {\n    this.value = value && this.ngModelEnd ? [value, this.ngModelEnd] : [];\n  }\n\n  registerOnChange(fn: (val: Date) => void): void {\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(_fn: () => void): void {\n    // this.onTouchedFn = fn;\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.nzDisabled = disabled;\n  }\n\n  clickShortcut(item: OhayoDateRangePickerShortcutItem): void {\n    this.value = item.fn(this.value as any);\n    this.valueChange(this.value as [Date, Date]);\n    if (this._shortcut.closed) {\n      // tslint:disable-next-line:no-string-literal\n      (this.comp as NzSafeAny)['picker'].hideOverlay();\n    }\n  }\n}\n"]}