@ohayojp.com/components
Version:
Common business components of ohayojp.
325 lines • 24.1 kB
JavaScript
/**
* @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"]}