@delon/abc
Version:
Common business components of ng-alain.
168 lines • 22.3 kB
JavaScript
import { Directive, EventEmitter, Input, Output, ViewContainerRef, inject } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';
import { fixEndTimeOfRange, getTimeDistance } from '@delon/util/date-time';
import { assert, deepMergeKey } from '@delon/util/other';
import { NzRangePickerComponent } from 'ng-zorro-antd/date-picker';
import { RangePickerShortcutTplComponent } from './range-shortcut.component';
import * as i0 from "@angular/core";
import * as i1 from "@delon/util/config";
export class RangePickerDirective {
set shortcut(val) {
const item = deepMergeKey({ list: [] }, true, this.defaultShortcuts, val == null ? {} : val);
if (typeof val !== 'object') {
item.enabled = val !== false;
}
(item.list || []).forEach(i => {
i._text = this.dom.bypassSecurityTrustHtml(i.text);
});
this._shortcut = item;
this.refreshShortcut();
}
get shortcut() {
return this._shortcut;
}
get dp() {
return this.nativeComp.datePicker;
}
get srv() {
return this.dp.datePickerService;
}
constructor(configSrv) {
this.dom = inject(DomSanitizer);
this.vcr = inject(ViewContainerRef);
this.nativeComp = inject(NzRangePickerComponent, { host: true, optional: true });
this._shortcut = null;
this.shortcutFactory = null;
this.start = null;
this.end = null;
this.ngModelEndChange = new EventEmitter();
if (typeof ngDevMode === 'undefined' || ngDevMode) {
assert(!!this.nativeComp, `It should be attached to nz-range-picker component, for example: '<nz-range-picker [(ngModel)]="i.start" extend [(ngModelEnd)]="i.end" shortcut></nz-range-picker>'`);
}
const cog = configSrv.merge('dataRange', {
nzFormat: 'yyyy-MM-dd',
nzAllowClear: true,
nzAutoFocus: false,
nzPopupStyle: { position: 'relative' },
nzShowToday: true,
shortcuts: {
enabled: false,
closed: true,
list: [
{
text: '今天',
fn: () => getTimeDistance('today')
},
{
text: '昨天',
fn: () => getTimeDistance('yesterday')
},
{
text: '近3天',
fn: () => getTimeDistance(-2)
},
{
text: '近7天',
fn: () => getTimeDistance(-6)
},
{
text: '本周',
fn: () => getTimeDistance('week')
},
{
text: '本月',
fn: () => getTimeDistance('month')
},
{
text: '全年',
fn: () => getTimeDistance('year')
}
]
}
});
this.defaultShortcuts = { ...cog.shortcuts };
Object.assign(this, cog);
}
cd() {
this.dp.cdr.markForCheck();
}
overrideNative() {
const dp = this.dp;
dp.writeValue = (value) => {
const dates = (value && this.ngModelEnd ? [value, this.ngModelEnd] : []).filter(w => !!w);
this.srv.setValue(this.srv.makeValue(dates));
this.start = dates.length > 0 ? dates[0] : null;
this.end = dates.length > 0 ? dates[1] : null;
this.cd();
};
const oldOnChangeFn = dp.onChangeFn;
dp.onChangeFn = (list) => {
let start = null;
let end = null;
if (list.length > 0 && list.filter(w => w != null).length === 2) {
[start, end] = fixEndTimeOfRange([list[0], list[1]]);
}
this.start = start;
this.end = end;
oldOnChangeFn(start);
this.ngModelEnd = end;
this.ngModelEndChange.emit(end);
};
}
refreshShortcut() {
if (!this._shortcut) {
return;
}
const { enabled, list } = this._shortcut;
let extraFooter;
if (!this.nativeComp || !enabled) {
extraFooter = undefined;
}
else {
if (!this.shortcutFactory) {
this.shortcutFactory = this.vcr.createComponent(RangePickerShortcutTplComponent);
}
const { instance } = this.shortcutFactory;
instance.list = list;
instance.click = (item) => {
const res = item.fn([this.start, this.end]);
this.srv.setValue(this.srv.makeValue(res));
this.dp.onChangeFn(res);
this.dp.close();
};
extraFooter = instance.tpl;
}
this.nativeComp.datePicker.extraFooter = extraFooter;
Promise.resolve().then(() => this.cd());
}
ngAfterViewInit() {
this.overrideNative();
this.refreshShortcut();
}
destoryShortcut() {
if (this.shortcutFactory != null) {
this.shortcutFactory.destroy();
}
}
ngOnDestroy() {
this.destoryShortcut();
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: RangePickerDirective, deps: [{ token: i1.AlainConfigService }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.5", type: RangePickerDirective, isStandalone: true, selector: "nz-range-picker[extend]", inputs: { shortcut: "shortcut", ngModelEnd: "ngModelEnd" }, outputs: { ngModelEndChange: "ngModelEndChange" }, exportAs: ["extendRangePicker"], ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: RangePickerDirective, decorators: [{
type: Directive,
args: [{
selector: 'nz-range-picker[extend]',
exportAs: 'extendRangePicker',
standalone: true
}]
}], ctorParameters: () => [{ type: i1.AlainConfigService }], propDecorators: { shortcut: [{
type: Input
}], ngModelEnd: [{
type: Input,
args: [{ required: true }]
}], ngModelEndChange: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range.directive.js","sourceRoot":"","sources":["../../../../../packages/abc/date-picker/range.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ComponentRef,\n  Directive,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  TemplateRef,\n  ViewContainerRef,\n  inject\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { AlainConfigService, AlainDateRangePickerShortcut, AlainDateRangePickerShortcutItem } from '@delon/util/config';\nimport { fixEndTimeOfRange, getTimeDistance } from '@delon/util/date-time';\nimport { assert, deepMergeKey } from '@delon/util/other';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { NzDatePickerComponent, NzRangePickerComponent } from 'ng-zorro-antd/date-picker';\nimport { DatePickerService } from 'ng-zorro-antd/date-picker/date-picker.service';\n\nimport { RangePickerShortcutTplComponent } from './range-shortcut.component';\n\n@Directive({\n  selector: 'nz-range-picker[extend]',\n  exportAs: 'extendRangePicker',\n  standalone: true\n})\nexport class RangePickerDirective implements OnDestroy, AfterViewInit {\n  static ngAcceptInputType_shortcut: AlainDateRangePickerShortcut | string | null;\n\n  private readonly dom = inject(DomSanitizer);\n  private readonly vcr = inject(ViewContainerRef);\n  private readonly nativeComp = inject(NzRangePickerComponent, { host: true, optional: true });\n\n  private defaultShortcuts: AlainDateRangePickerShortcut;\n  private _shortcut: AlainDateRangePickerShortcut | null = null;\n  private shortcutFactory: ComponentRef<RangePickerShortcutTplComponent> | null = null;\n  start: Date | null = null;\n  end: Date | null = null;\n\n  @Input()\n  set shortcut(val: AlainDateRangePickerShortcut | null) {\n    const item = deepMergeKey(\n      { list: [] },\n      true,\n      this.defaultShortcuts,\n      val == null ? {} : val\n    ) as AlainDateRangePickerShortcut;\n    if (typeof val !== 'object') {\n      item.enabled = val !== false;\n    }\n    (item.list || []).forEach(i => {\n      i._text = this.dom.bypassSecurityTrustHtml(i.text);\n    });\n    this._shortcut = item;\n    this.refreshShortcut();\n  }\n  get shortcut(): AlainDateRangePickerShortcut | null {\n    return this._shortcut;\n  }\n  @Input({ required: true }) ngModelEnd: NzSafeAny;\n  @Output() readonly ngModelEndChange = new EventEmitter<NzSafeAny>();\n\n  private get dp(): NzDatePickerComponent {\n    return this.nativeComp!.datePicker;\n  }\n\n  private get srv(): DatePickerService {\n    return this.dp.datePickerService;\n  }\n\n  constructor(configSrv: AlainConfigService) {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      assert(\n        !!this.nativeComp,\n        `It should be attached to nz-range-picker component, for example: '<nz-range-picker [(ngModel)]=\"i.start\" extend [(ngModelEnd)]=\"i.end\" shortcut></nz-range-picker>'`\n      );\n    }\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 AlainDateRangePickerShortcut;\n    Object.assign(this, cog);\n  }\n\n  private cd(): void {\n    (this.dp as NzSafeAny).cdr.markForCheck();\n  }\n\n  private overrideNative(): void {\n    const dp = this.dp;\n    dp.writeValue = (value: Date) => {\n      const dates = (value && this.ngModelEnd ? [value, this.ngModelEnd] : []).filter(w => !!w);\n      this.srv.setValue(this.srv.makeValue(dates));\n      this.start = dates.length > 0 ? dates[0] : null;\n      this.end = dates.length > 0 ? dates[1] : null;\n      this.cd();\n    };\n\n    const oldOnChangeFn = dp.onChangeFn;\n    dp.onChangeFn = (list: Array<Date | null>) => {\n      let start: Date | null = null;\n      let end: Date | null = null;\n      if (list.length > 0 && list.filter(w => w != null).length === 2) {\n        [start, end] = fixEndTimeOfRange([list[0]!, list[1]!]);\n      }\n      this.start = start;\n      this.end = end;\n      oldOnChangeFn(start);\n      this.ngModelEnd = end;\n      this.ngModelEndChange.emit(end);\n    };\n  }\n\n  private refreshShortcut(): void {\n    if (!this._shortcut) {\n      return;\n    }\n    const { enabled, list } = this._shortcut;\n    let extraFooter: TemplateRef<NzSafeAny> | undefined;\n    if (!this.nativeComp || !enabled) {\n      extraFooter = undefined;\n    } else {\n      if (!this.shortcutFactory) {\n        this.shortcutFactory = this.vcr.createComponent(RangePickerShortcutTplComponent);\n      }\n      const { instance } = this.shortcutFactory;\n      instance.list = list!;\n      instance.click = (item: AlainDateRangePickerShortcutItem) => {\n        const res = item.fn([this.start, this.end]);\n        this.srv.setValue(this.srv.makeValue(res as Date[]));\n        this.dp.onChangeFn(res);\n        this.dp.close();\n      };\n      extraFooter = instance.tpl;\n    }\n    this.nativeComp!.datePicker.extraFooter = extraFooter;\n    Promise.resolve().then(() => this.cd());\n  }\n\n  ngAfterViewInit(): void {\n    this.overrideNative();\n    this.refreshShortcut();\n  }\n\n  private destoryShortcut(): void {\n    if (this.shortcutFactory != null) {\n      this.shortcutFactory.destroy();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destoryShortcut();\n  }\n}\n"]}