UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

318 lines 45.7 kB
import { DateNavRange, TooltipDirective, InputGroupComponent, InputComponent, IconComponent, TagComponent, DateRangePickerPanelComponent, InputSuffixDirective, } from '@alauda/ui'; import { AsyncPipe, NgForOf, NgIf } from '@angular/common'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild, forwardRef, } from '@angular/core'; import { FormsModule, NG_VALUE_ACCESSOR, } from '@angular/forms'; import dayjs from 'dayjs'; import { range } from 'lodash-es'; import { PurePipe } from '../../core/public-api'; import { EFFECT_DIRECTIVE_MODULE } from '../../effect-directive/module'; import { TranslateModule, TranslateService } from '../../translate/public-api'; import { CUSTOM, CUSTOM_RANGE, DEFAULT_OPTIONS } from './util'; import * as i0 from "@angular/core"; import * as i1 from "../../translate/public-api"; import * as i2 from "../../translate/translate.pipe"; import * as i3 from "@angular/forms"; import * as i4 from "../../effect-directive/e2e-attribute-binding.directive"; const _c0 = ["tip"]; const _c1 = (a0, a1) => ({ "tw-text-center": a0, "!tw-text-s": a1, "date-range-picker": true }); function DateRangePickerComponent_aui_input_group_0_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "aui-input-group", 4, 1); i0.ɵɵelement(2, "input", 5); i0.ɵɵpipe(3, "async"); i0.ɵɵpipe(4, "pure"); i0.ɵɵpipe(5, "async"); i0.ɵɵpipe(6, "pure"); i0.ɵɵelement(7, "aui-icon", 6); i0.ɵɵelementEnd(); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(); const tooltip_r2 = i0.ɵɵreference(3); i0.ɵɵstyleProp("width", ctx_r0.inputWidth); i0.ɵɵproperty("auiTooltip", tooltip_r2); i0.ɵɵadvance(2); i0.ɵɵclassMap(i0.ɵɵpureFunction2(20, _c1, ctx_r0.mode === "dropdown", ctx_r0.mode === "dropdown")); i0.ɵɵproperty("title", i0.ɵɵpipeBind3(4, 10, ctx_r0.value, ctx_r0.formatValue, i0.ɵɵpipeBind1(3, 8, ctx_r0.translate.locale$)))("value", i0.ɵɵpipeBind3(6, 16, ctx_r0.value, ctx_r0.formatValue, i0.ɵɵpipeBind1(5, 14, ctx_r0.translate.locale$))); i0.ɵɵadvance(5); i0.ɵɵproperty("icon", ctx_r0.mode === "dropdown" ? "calendar" : "caret_down_s"); } } function DateRangePickerComponent_aui_tag_1_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "aui-tag", 7, 1); i0.ɵɵelement(2, "aui-icon", 8); i0.ɵɵtext(3); i0.ɵɵpipe(4, "translate"); i0.ɵɵpipe(5, "async"); i0.ɵɵpipe(6, "pure"); i0.ɵɵelement(7, "aui-icon", 9); i0.ɵɵelementEnd(); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(); const tooltip_r2 = i0.ɵɵreference(3); i0.ɵɵproperty("type", ctx_r0.tagActive ? "primary" : "info")("solid", ctx_r0.tagActive)("auiTooltip", tooltip_r2); i0.ɵɵadvance(3); i0.ɵɵtextInterpolate1(" ", !ctx_r0.value ? i0.ɵɵpipeBind1(4, 4, "more") : i0.ɵɵpipeBind3(6, 8, ctx_r0.value, ctx_r0.formatValue, i0.ɵɵpipeBind1(5, 6, ctx_r0.translate.locale$)), " "); } } function DateRangePickerComponent_ng_template_2_span_2_Template(rf, ctx) { if (rf & 1) { const _r3 = i0.ɵɵgetCurrentView(); i0.ɵɵelementStart(0, "span", 14); i0.ɵɵlistener("click", function DateRangePickerComponent_ng_template_2_span_2_Template_span_click_0_listener() { const range_r4 = i0.ɵɵrestoreView(_r3).$implicit; const ctx_r0 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r0.selectRange(range_r4)); }); i0.ɵɵtext(1); i0.ɵɵpipe(2, "translate"); i0.ɵɵpipe(3, "translate"); i0.ɵɵelementEnd(); } if (rf & 2) { const range_r4 = ctx.$implicit; const ctx_r0 = i0.ɵɵnextContext(2); i0.ɵɵclassProp("active", range_r4.label === (ctx_r0.selectedRange == null ? null : ctx_r0.selectedRange.label)); i0.ɵɵadvance(); i0.ɵɵtextInterpolate1(" ", range_r4.display ? i0.ɵɵpipeBind2(2, 3, range_r4.display, range_r4.displayCtx) : i0.ɵɵpipeBind1(3, 6, range_r4.label), " "); } } function DateRangePickerComponent_ng_template_2_div_3_Template(rf, ctx) { if (rf & 1) { const _r5 = i0.ɵɵgetCurrentView(); i0.ɵɵelementStart(0, "div", 15)(1, "aui-date-range-picker-panel", 16); i0.ɵɵpipe(2, "pure"); i0.ɵɵtwoWayListener("ngModelChange", function DateRangePickerComponent_ng_template_2_div_3_Template_aui_date_range_picker_panel_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r0 = i0.ɵɵnextContext(2); i0.ɵɵtwoWayBindingSet(ctx_r0.rangeValue, $event) || (ctx_r0.rangeValue = $event); return i0.ɵɵresetView($event); }); i0.ɵɵlistener("confirm", function DateRangePickerComponent_ng_template_2_div_3_Template_aui_date_range_picker_panel_confirm_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r0 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r0.submitRange(ctx_r0.CUSTOM_RANGE, ctx_r0.rangeValue)); })("clear", function DateRangePickerComponent_ng_template_2_div_3_Template_aui_date_range_picker_panel_clear_1_listener() { i0.ɵɵrestoreView(_r5); const ctx_r0 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r0.rangeValue = []); })("click", function DateRangePickerComponent_ng_template_2_div_3_Template_aui_date_range_picker_panel_click_1_listener($event) { i0.ɵɵrestoreView(_r5); return i0.ɵɵresetView($event.stopImmediatePropagation()); }); i0.ɵɵelementEnd()(); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(2); i0.ɵɵadvance(); i0.ɵɵproperty("disabledDate", i0.ɵɵpipeBind2(2, 4, ctx_r0.options, ctx_r0.getDisabledDate)); i0.ɵɵtwoWayProperty("ngModel", ctx_r0.rangeValue); i0.ɵɵproperty("showTime", ctx_r0.finalOptions.timePicker)("disabledTime", ctx_r0.enableDisableTime && ctx_r0.disabledTime()); } } function DateRangePickerComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "div", 10)(1, "div", 11); i0.ɵɵtemplate(2, DateRangePickerComponent_ng_template_2_span_2_Template, 4, 8, "span", 12); i0.ɵɵelementEnd(); i0.ɵɵtemplate(3, DateRangePickerComponent_ng_template_2_div_3_Template, 3, 7, "div", 13); i0.ɵɵelementEnd(); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(); i0.ɵɵadvance(2); i0.ɵɵproperty("ngForOf", ctx_r0.ranges); i0.ɵɵadvance(); i0.ɵɵproperty("ngIf", ctx_r0.isCustom); } } export class DateRangePickerComponent { get isCustom() { return this.selectedRange?.label === 'custom'; } get ranges() { return [...(this.options.timeRange || []), CUSTOM_RANGE]; } constructor(translate, cdr) { this.translate = translate; this.cdr = cdr; this.options = {}; this.format = 'YYYY-MM-DD HH:mm:ss'; this.mode = 'input'; this.customInputWidth = '315px'; this.rangeValue = null; this.finalOptions = this.options; this.CUSTOM = CUSTOM; this.CUSTOM_RANGE = CUSTOM_RANGE; this.inputWidth = ''; this.getDisabledDate = (options) => (date, navType, startDate) => { let result = false; const { minValue, maxValue } = this.getMinMaxDate(startDate); if (navType === DateNavRange.Month) { if (options.minDate) { result = result || date.isBefore(minValue, 'date'); } if (options.maxDate) { result = result || date.isAfter(maxValue, 'date'); } } return result; }; this.getMinMaxDate = (startDate) => { const { minDate, maxDate } = this.options; const minValue = typeof minDate === 'function' ? minDate(startDate)?.valueOf() : minDate?.valueOf(); const maxValue = typeof maxDate === 'function' ? maxDate(startDate)?.valueOf() : maxDate?.valueOf(); return { minValue: minValue || 0, maxValue: maxValue || 0, }; }; /** * 禁用时间存在 bug 具体查看 https://jira.alauda.cn/browse/AIT-52471 描述 * 可通过 enableDisableTime 开启 默认关闭,如果选择的 end 比 start 会对调 */ this.disabledTime = () => ({ left: (value) => { const { minValue } = this.getMinMaxDate(); const minDate = dayjs(minValue); const sameDay = minDate?.day() === value?.day(); return (minValue && sameDay && { hours: () => range(0, minDate.hour() - 1), minutes: () => range(0, minDate.minute()), seconds: () => range(0, minDate.second()), }); }, right: (value) => { const { maxValue } = this.getMinMaxDate(); const minDate = this.rangeValue?.[0]; const sameHour = minDate?.isSame(value, 'hour'); const sameDay = this.rangeValue?.[0]?.isSame(value, 'day'); return (maxValue && sameDay && { hours: () => range(minDate.hour()), minutes: sameHour ? () => range(minDate.minute()) : () => [], seconds: sameHour ? () => range(minDate.second()) : () => [], }); }, }); this.submitRange = this.submitRange.bind(this); this.formatValue = this.formatValue.bind(this); this.formatCustomValue = this.formatCustomValue.bind(this); } writeValue(obj) { if (obj) { this.value = obj; this.selectedRange = obj; this.setInputWidth(obj.label); this.cdr.markForCheck(); } } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onBlur = fn; } ngOnInit() { const { timePicker, ...reset } = this.options; this.finalOptions = { ...DEFAULT_OPTIONS, timePicker: timePicker !== false, ...reset, }; } cancel() { this.tip.hide(); this.selectedRange = this.value; } submitRange(range, rangeValue) { if (!rangeValue?.length && range.label === CUSTOM) { this.tip.hide(); return; } range = range.label === CUSTOM ? { label: range.label, start: () => rangeValue[0] || this.value.start(), end: () => rangeValue[1] || dayjs(), } : range; this.value = range; this.selectedRange = range; this.setInputWidth(range.label); this.onChange?.(range); this.tip.hide(); } setInputWidth(label) { if (this.options?.widthAdaptive) { this.inputWidth = label === CUSTOM ? this.customInputWidth : ''; } } selectRange(range) { this.selectedRange = range; if (range.label === CUSTOM) { requestAnimationFrame(() => this.tip.updatePosition()); } else { this.submitRange(range); } } formatValue(value, _locale) { if (!value) { return ''; } if (value.label !== CUSTOM) { return value.display ? this.translate.get(value.display, value.displayCtx) : this.translate.get(value.label); } return this.formatCustomValue([value.start(), value.end()]); } formatCustomValue(value) { return value?.map(i => i?.format(this.format)).join(' - '); } static { this.ɵfac = function DateRangePickerComponent_Factory(t) { return new (t || DateRangePickerComponent)(i0.ɵɵdirectiveInject(i1.TranslateService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DateRangePickerComponent, selectors: [["acl-date-range-picker"]], viewQuery: function DateRangePickerComponent_Query(rf, ctx) { if (rf & 1) { i0.ɵɵviewQuery(_c0, 5); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tip = _t.first); } }, inputs: { options: "options", format: "format", mode: "mode", tagActive: "tagActive", customInputWidth: "customInputWidth", enableDisableTime: "enableDisableTime" }, standalone: true, features: [i0.ɵɵProvidersFeature([ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateRangePickerComponent), multi: true, }, ]), i0.ɵɵStandaloneFeature], decls: 4, vars: 2, consts: [["tooltip", ""], ["tip", "auiTooltip"], ["auiTooltipClass", "acl-date-range-picker__panel", "auiTooltipTrigger", "click", "auiTooltipType", "info", "auiTooltipPosition", "bottom start", "auiTooltipAnimType", "none", 3, "auiTooltip", "width", 4, "ngIf"], ["size", "mini", "class", "tag", "auiTooltipClass", "acl-date-range-picker__panel", "auiTooltipTrigger", "click", "auiTooltipType", "info", "auiTooltipPosition", "bottom start", 3, "type", "solid", "auiTooltip", 4, "ngIf"], ["auiTooltipClass", "acl-date-range-picker__panel", "auiTooltipTrigger", "click", "auiTooltipType", "info", "auiTooltipPosition", "bottom start", "auiTooltipAnimType", "none", 3, "auiTooltip"], ["aui-input", "", "readonly", "", 3, "title", "value"], ["auiInputSuffix", "", 1, "tw-text-n-2", 3, "icon"], ["size", "mini", "auiTooltipClass", "acl-date-range-picker__panel", "auiTooltipTrigger", "click", "auiTooltipType", "info", "auiTooltipPosition", "bottom start", 1, "tag", 3, "type", "solid", "auiTooltip"], ["icon", "clock"], ["icon", "angle_down", "margin", "left", 1, "tw-ml-[-4px]"], [1, "range-picker-panel"], [1, "control"], ["class", "control-row", 3, "active", "click", 4, "ngFor", "ngForOf"], ["class", "range-picker-wrapper", 4, "ngIf"], [1, "control-row", 3, "click"], [1, "range-picker-wrapper"], [3, "ngModelChange", "confirm", "clear", "click", "disabledDate", "ngModel", "showTime", "disabledTime"]], template: function DateRangePickerComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵtemplate(0, DateRangePickerComponent_aui_input_group_0_Template, 8, 23, "aui-input-group", 2)(1, DateRangePickerComponent_aui_tag_1_Template, 8, 12, "aui-tag", 3)(2, DateRangePickerComponent_ng_template_2_Template, 4, 2, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor); } if (rf & 2) { i0.ɵɵproperty("ngIf", ctx.mode === "input" || ctx.mode === "dropdown"); i0.ɵɵadvance(); i0.ɵɵproperty("ngIf", ctx.mode === "tag"); } }, dependencies: [InputGroupComponent, NgIf, TooltipDirective, InputSuffixDirective, InputComponent, IconComponent, TagComponent, NgForOf, TranslateModule, i2.TranslatePipe, DateRangePickerPanelComponent, FormsModule, i3.NgControlStatus, i3.NgModel, PurePipe, AsyncPipe, i4.E2eAttributeBindingDirective], styles: [".range-picker-panel[_ngcontent-%COMP%]{display:inline-flex}.range-picker-footer[_ngcontent-%COMP%]{padding:9px;display:flex;justify-content:flex-end;box-sizing:content-box;border-top:1px solid rgb(var(--aui-color-divider))}.range-picker-footer[_ngcontent-%COMP%] .range-date-tip[_ngcontent-%COMP%]{display:flex;font-size:14px;align-items:center;margin-right:6px;color:rgb(var(--aui-color-main-text))}.date-range-picker[readonly][_ngcontent-%COMP%]{background-color:rgb(var(--aui-color-n-9));border-color:rgb(var(--aui-color-n-7))}aui-input-group[_ngcontent-%COMP%]{width:100%;display:inline-block}[_nghost-%COMP%] {display:flex}[_nghost-%COMP%] .aui-input{cursor:pointer!important} .acl-date-range-picker__panel{max-width:unset!important;padding:0!important;overflow:hidden} .acl-date-range-picker__panel .control{display:flex;min-width:120px;flex-direction:column;max-height:337px;overflow:auto} .acl-date-range-picker__panel .range-picker-wrapper{padding:8px;display:flex;flex-direction:column;border-left:1px solid rgb(var(--aui-color-divider))} .acl-date-range-picker__panel .control-row{padding:8px 12px;font-size:12px;color:rgb(var(--aui-color-main-text))} .acl-date-range-picker__panel .control-row:hover{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-primary));cursor:pointer} .acl-date-range-picker__panel .control-row.active{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-primary))}.tag[_ngcontent-%COMP%]{position:relative}.tag[_ngcontent-%COMP%] .aui-tag__content{overflow:inherit}.tag[_ngcontent-%COMP%] .aui-tag{max-width:unset!important}"], changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DateRangePickerComponent, [{ type: Component, args: [{ selector: 'acl-date-range-picker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateRangePickerComponent), multi: true, }, ], imports: [ InputGroupComponent, NgIf, TooltipDirective, InputSuffixDirective, InputComponent, IconComponent, TagComponent, NgForOf, TranslateModule, DateRangePickerPanelComponent, FormsModule, PurePipe, AsyncPipe, ...EFFECT_DIRECTIVE_MODULE, ], standalone: true, template: "<aui-input-group\n *ngIf=\"mode === 'input' || mode === 'dropdown'\"\n [auiTooltip]=\"tooltip\"\n auiTooltipClass=\"acl-date-range-picker__panel\"\n auiTooltipTrigger=\"click\"\n auiTooltipType=\"info\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipAnimType=\"none\"\n [style.width]=\"inputWidth\"\n #tip=\"auiTooltip\"\n>\n <input\n aui-input\n [class]=\"{\n 'tw-text-center': mode === 'dropdown',\n '!tw-text-s': mode === 'dropdown',\n 'date-range-picker': true,\n }\"\n [title]=\"value | pure: formatValue : (translate.locale$ | async)\"\n [value]=\"value | pure: formatValue : (translate.locale$ | async)\"\n readonly\n />\n <aui-icon\n auiInputSuffix\n class=\"tw-text-n-2\"\n [icon]=\"mode === 'dropdown' ? 'calendar' : 'caret_down_s'\"\n ></aui-icon>\n</aui-input-group>\n\n<aui-tag\n *ngIf=\"mode === 'tag'\"\n size=\"mini\"\n class=\"tag\"\n [type]=\"tagActive ? 'primary' : 'info'\"\n [solid]=\"tagActive\"\n [auiTooltip]=\"tooltip\"\n auiTooltipClass=\"acl-date-range-picker__panel\"\n auiTooltipTrigger=\"click\"\n auiTooltipType=\"info\"\n #tip=\"auiTooltip\"\n auiTooltipPosition=\"bottom start\"\n>\n <aui-icon icon=\"clock\"></aui-icon>\n {{\n !value\n ? ('more' | translate)\n : (value | pure: formatValue : (translate.locale$ | async))\n }}\n <aui-icon\n class=\"tw-ml-[-4px]\"\n icon=\"angle_down\"\n margin=\"left\"\n ></aui-icon>\n</aui-tag>\n\n<ng-template #tooltip>\n <div class=\"range-picker-panel\">\n <div class=\"control\">\n <span\n *ngFor=\"let range of ranges\"\n class=\"control-row\"\n [class.active]=\"range.label === selectedRange?.label\"\n (click)=\"selectRange(range)\"\n >\n {{\n range.display\n ? (range.display | translate: range.displayCtx)\n : (range.label | translate)\n }}\n </span>\n </div>\n <div\n class=\"range-picker-wrapper\"\n *ngIf=\"isCustom\"\n >\n <aui-date-range-picker-panel\n [disabledDate]=\"options | pure: getDisabledDate\"\n [(ngModel)]=\"rangeValue\"\n (confirm)=\"submitRange(CUSTOM_RANGE, rangeValue)\"\n (clear)=\"rangeValue = []\"\n (click)=\"$event.stopImmediatePropagation()\"\n [showTime]=\"finalOptions.timePicker\"\n [disabledTime]=\"enableDisableTime && disabledTime()\"\n ></aui-date-range-picker-panel>\n </div>\n </div>\n</ng-template>\n", styles: [".range-picker-panel{display:inline-flex}.range-picker-footer{padding:9px;display:flex;justify-content:flex-end;box-sizing:content-box;border-top:1px solid rgb(var(--aui-color-divider))}.range-picker-footer .range-date-tip{display:flex;font-size:14px;align-items:center;margin-right:6px;color:rgb(var(--aui-color-main-text))}.date-range-picker[readonly]{background-color:rgb(var(--aui-color-n-9));border-color:rgb(var(--aui-color-n-7))}aui-input-group{width:100%;display:inline-block}:host::ng-deep{display:flex}:host::ng-deep .aui-input{cursor:pointer!important}::ng-deep .acl-date-range-picker__panel{max-width:unset!important;padding:0!important;overflow:hidden}::ng-deep .acl-date-range-picker__panel .control{display:flex;min-width:120px;flex-direction:column;max-height:337px;overflow:auto}::ng-deep .acl-date-range-picker__panel .range-picker-wrapper{padding:8px;display:flex;flex-direction:column;border-left:1px solid rgb(var(--aui-color-divider))}::ng-deep .acl-date-range-picker__panel .control-row{padding:8px 12px;font-size:12px;color:rgb(var(--aui-color-main-text))}::ng-deep .acl-date-range-picker__panel .control-row:hover{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-primary));cursor:pointer}::ng-deep .acl-date-range-picker__panel .control-row.active{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-primary))}.tag{position:relative}.tag ::ng-deep .aui-tag__content{overflow:inherit}.tag ::ng-deep .aui-tag{max-width:unset!important}\n"] }] }], () => [{ type: i1.TranslateService }, { type: i0.ChangeDetectorRef }], { options: [{ type: Input }], format: [{ type: Input }], mode: [{ type: Input }], tagActive: [{ type: Input }], customInputWidth: [{ type: Input }], enableDisableTime: [{ type: Input }], tip: [{ type: ViewChild, args: ['tip', { static: false }] }] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DateRangePickerComponent, { className: "DateRangePickerComponent" }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/widget/date-range-picker/component.ts","../../../../../../libs/common/src/widget/date-range-picker/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  DateNavRange,\n  TooltipDirective,\n  DisabledTimeFn,\n  InputGroupComponent,\n  InputComponent,\n  IconComponent,\n  TagComponent,\n  DateRangePickerPanelComponent,\n  InputSuffixDirective,\n} from '@alauda/ui';\nimport { AsyncPipe, NgForOf, NgIf } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  forwardRef,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport dayjs, { Dayjs } from 'dayjs';\nimport { range } from 'lodash-es';\n\nimport { PurePipe } from '../../core/public-api';\nimport { EFFECT_DIRECTIVE_MODULE } from '../../effect-directive/module';\nimport { TranslateModule, TranslateService } from '../../translate/public-api';\n\nimport { Options, PickerTimeRange } from './type';\nimport { CUSTOM, CUSTOM_RANGE, DEFAULT_OPTIONS } from './util';\n\n@Component({\n  selector: 'acl-date-range-picker',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateRangePickerComponent),\n      multi: true,\n    },\n  ],\n  imports: [\n    InputGroupComponent,\n    NgIf,\n    TooltipDirective,\n    InputSuffixDirective,\n    InputComponent,\n    IconComponent,\n    TagComponent,\n    NgForOf,\n    TranslateModule,\n    DateRangePickerPanelComponent,\n    FormsModule,\n    PurePipe,\n    AsyncPipe,\n    ...EFFECT_DIRECTIVE_MODULE,\n  ],\n  standalone: true,\n})\nexport class DateRangePickerComponent implements OnInit, ControlValueAccessor {\n  @Input() options: Options = {};\n\n  @Input()\n  format = 'YYYY-MM-DD HH:mm:ss';\n\n  @Input() mode = 'input';\n\n  @Input()\n  tagActive: boolean;\n\n  @Input()\n  customInputWidth = '315px';\n\n  @Input() enableDisableTime: boolean;\n\n  @ViewChild('tip', { static: false })\n  tip: TooltipDirective;\n\n  rangeValue: Dayjs[] = null;\n\n  get isCustom() {\n    return this.selectedRange?.label === 'custom';\n  }\n\n  get ranges() {\n    return [...(this.options.timeRange || []), CUSTOM_RANGE];\n  }\n\n  finalOptions = this.options;\n  CUSTOM = CUSTOM;\n\n  selectedRange: PickerTimeRange;\n  CUSTOM_RANGE = CUSTOM_RANGE;\n  value: PickerTimeRange;\n\n  inputWidth = '';\n\n  private onChange: (value: PickerTimeRange) => void;\n  onBlur: (value: PickerTimeRange) => void;\n\n  constructor(\n    public readonly translate: TranslateService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    this.submitRange = this.submitRange.bind(this);\n    this.formatValue = this.formatValue.bind(this);\n    this.formatCustomValue = this.formatCustomValue.bind(this);\n  }\n\n  writeValue(obj: PickerTimeRange) {\n    if (obj) {\n      this.value = obj;\n      this.selectedRange = obj;\n      this.setInputWidth(obj.label);\n      this.cdr.markForCheck();\n    }\n  }\n\n  registerOnChange(fn: () => void) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onBlur = fn;\n  }\n\n  ngOnInit() {\n    const { timePicker, ...reset } = this.options;\n    this.finalOptions = {\n      ...DEFAULT_OPTIONS,\n      timePicker: timePicker !== false,\n      ...reset,\n    };\n  }\n\n  cancel() {\n    this.tip.hide();\n    this.selectedRange = this.value;\n  }\n\n  submitRange(range: PickerTimeRange, rangeValue?: Dayjs[]) {\n    if (!rangeValue?.length && range.label === CUSTOM) {\n      this.tip.hide();\n      return;\n    }\n    range =\n      range.label === CUSTOM\n        ? {\n            label: range.label,\n            start: () => rangeValue[0] || this.value.start(),\n            end: () => rangeValue[1] || dayjs(),\n          }\n        : range;\n    this.value = range;\n    this.selectedRange = range;\n    this.setInputWidth(range.label);\n    this.onChange?.(range);\n    this.tip.hide();\n  }\n\n  setInputWidth(label: string) {\n    if (this.options?.widthAdaptive) {\n      this.inputWidth = label === CUSTOM ? this.customInputWidth : '';\n    }\n  }\n\n  selectRange(range: PickerTimeRange) {\n    this.selectedRange = range;\n    if (range.label === CUSTOM) {\n      requestAnimationFrame(() => this.tip.updatePosition());\n    } else {\n      this.submitRange(range);\n    }\n  }\n\n  formatValue(value: PickerTimeRange, _locale: string) {\n    if (!value) {\n      return '';\n    }\n    if (value.label !== CUSTOM) {\n      return value.display\n        ? this.translate.get(value.display, value.displayCtx)\n        : this.translate.get(value.label);\n    }\n    return this.formatCustomValue([value.start(), value.end()]);\n  }\n\n  formatCustomValue(value: Dayjs[]) {\n    return value?.map(i => i?.format(this.format)).join(' - ');\n  }\n\n  getDisabledDate =\n    (options: Options) =>\n    (date: Dayjs, navType: DateNavRange, startDate: Dayjs) => {\n      let result = false;\n      const { minValue, maxValue } = this.getMinMaxDate(startDate);\n      if (navType === DateNavRange.Month) {\n        if (options.minDate) {\n          result = result || date.isBefore(minValue, 'date');\n        }\n        if (options.maxDate) {\n          result = result || date.isAfter(maxValue, 'date');\n        }\n      }\n      return result;\n    };\n\n  getMinMaxDate = (startDate?: Dayjs) => {\n    const { minDate, maxDate } = this.options;\n    const minValue =\n      typeof minDate === 'function'\n        ? minDate(startDate)?.valueOf()\n        : minDate?.valueOf();\n    const maxValue =\n      typeof maxDate === 'function'\n        ? maxDate(startDate)?.valueOf()\n        : maxDate?.valueOf();\n    return {\n      minValue: minValue || 0,\n      maxValue: maxValue || 0,\n    };\n  };\n\n  /**\n   * 禁用时间存在 bug 具体查看  https://jira.alauda.cn/browse/AIT-52471 描述\n   * 可通过 enableDisableTime 开启 默认关闭，如果选择的 end 比 start 会对调\n   */\n  disabledTime = (): { left: DisabledTimeFn; right: DisabledTimeFn } => ({\n    left: (value: Dayjs) => {\n      const { minValue } = this.getMinMaxDate();\n      const minDate = dayjs(minValue);\n      const sameDay = minDate?.day() === value?.day();\n      return (\n        minValue &&\n        sameDay && {\n          hours: () => range(0, minDate.hour() - 1),\n          minutes: () => range(0, minDate.minute()),\n          seconds: () => range(0, minDate.second()),\n        }\n      );\n    },\n    right: (value: Dayjs) => {\n      const { maxValue } = this.getMinMaxDate();\n      const minDate = this.rangeValue?.[0];\n      const sameHour = minDate?.isSame(value, 'hour');\n      const sameDay = this.rangeValue?.[0]?.isSame(value, 'day');\n      return (\n        maxValue &&\n        sameDay && {\n          hours: () => range(minDate.hour()),\n          minutes: sameHour ? () => range(minDate.minute()) : () => [],\n          seconds: sameHour ? () => range(minDate.second()) : () => [],\n        }\n      );\n    },\n  });\n}\n","<aui-input-group\n  *ngIf=\"mode === 'input' || mode === 'dropdown'\"\n  [auiTooltip]=\"tooltip\"\n  auiTooltipClass=\"acl-date-range-picker__panel\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipType=\"info\"\n  auiTooltipPosition=\"bottom start\"\n  auiTooltipAnimType=\"none\"\n  [style.width]=\"inputWidth\"\n  #tip=\"auiTooltip\"\n>\n  <input\n    aui-input\n    [class]=\"{\n      'tw-text-center': mode === 'dropdown',\n      '!tw-text-s': mode === 'dropdown',\n      'date-range-picker': true,\n    }\"\n    [title]=\"value | pure: formatValue : (translate.locale$ | async)\"\n    [value]=\"value | pure: formatValue : (translate.locale$ | async)\"\n    readonly\n  />\n  <aui-icon\n    auiInputSuffix\n    class=\"tw-text-n-2\"\n    [icon]=\"mode === 'dropdown' ? 'calendar' : 'caret_down_s'\"\n  ></aui-icon>\n</aui-input-group>\n\n<aui-tag\n  *ngIf=\"mode === 'tag'\"\n  size=\"mini\"\n  class=\"tag\"\n  [type]=\"tagActive ? 'primary' : 'info'\"\n  [solid]=\"tagActive\"\n  [auiTooltip]=\"tooltip\"\n  auiTooltipClass=\"acl-date-range-picker__panel\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipType=\"info\"\n  #tip=\"auiTooltip\"\n  auiTooltipPosition=\"bottom start\"\n>\n  <aui-icon icon=\"clock\"></aui-icon>\n  {{\n    !value\n      ? ('more' | translate)\n      : (value | pure: formatValue : (translate.locale$ | async))\n  }}\n  <aui-icon\n    class=\"tw-ml-[-4px]\"\n    icon=\"angle_down\"\n    margin=\"left\"\n  ></aui-icon>\n</aui-tag>\n\n<ng-template #tooltip>\n  <div class=\"range-picker-panel\">\n    <div class=\"control\">\n      <span\n        *ngFor=\"let range of ranges\"\n        class=\"control-row\"\n        [class.active]=\"range.label === selectedRange?.label\"\n        (click)=\"selectRange(range)\"\n      >\n        {{\n          range.display\n            ? (range.display | translate: range.displayCtx)\n            : (range.label | translate)\n        }}\n      </span>\n    </div>\n    <div\n      class=\"range-picker-wrapper\"\n      *ngIf=\"isCustom\"\n    >\n      <aui-date-range-picker-panel\n        [disabledDate]=\"options | pure: getDisabledDate\"\n        [(ngModel)]=\"rangeValue\"\n        (confirm)=\"submitRange(CUSTOM_RANGE, rangeValue)\"\n        (clear)=\"rangeValue = []\"\n        (click)=\"$event.stopImmediatePropagation()\"\n        [showTime]=\"finalOptions.timePicker\"\n        [disabledTime]=\"enableDisableTime && disabledTime()\"\n      ></aui-date-range-picker-panel>\n    </div>\n  </div>\n</ng-template>\n"]}