@alauda-fe/common
Version:
Alauda frontend team common codes.
318 lines • 45.7 kB
JavaScript
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"]}