@alauda-fe/common 1.2.1 → 1.3.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/api/api-gateway.service.d.ts +1 -11
- package/api/public-api.d.ts +0 -1
- package/array-form-table/key-value-form/component.d.ts +3 -2
- package/async-data/async-data.module.d.ts +6 -0
- package/authorization/public-api.d.ts +1 -0
- package/authorization/state.service.d.ts +13 -20
- package/authorization/storage-token.d.ts +11 -0
- package/chart/common/tooltip/tooltip.component.d.ts +2 -1
- package/core/abstract/base-form-container.d.ts +1 -1
- package/core/constants/tokens.d.ts +0 -18
- package/core/module.d.ts +16 -15
- package/core/services/k8s-util.service.d.ts +0 -5
- package/core/types/k8s/crd.d.ts +2 -1
- package/core/utils/common.d.ts +2 -1
- package/esm2022/api/api-gateway.service.mjs +10 -20
- package/esm2022/api/product.service.mjs +4 -4
- package/esm2022/api/project-api.service.mjs +4 -4
- package/esm2022/api/public-api.mjs +1 -2
- package/esm2022/array-form-table/key-value-form/component.mjs +65 -43
- package/esm2022/async-data/async-data.module.mjs +17 -5
- package/esm2022/authorization/public-api.mjs +2 -1
- package/esm2022/authorization/state.service.mjs +86 -115
- package/esm2022/authorization/storage-token.mjs +82 -0
- package/esm2022/business/resource-select/exports/cluster-selector/component.mjs +2 -2
- package/esm2022/business/resource-select/exports/mesh-group-selector/component.mjs +2 -2
- package/esm2022/business/resource-select/exports/namespace-selector/component.mjs +2 -2
- package/esm2022/business/resource-select/exports/project-selector/component.mjs +2 -2
- package/esm2022/business/resource-select/module.mjs +9 -9
- package/esm2022/chart/chart.module.mjs +1 -1
- package/esm2022/chart/common/tooltip/tooltip.component.mjs +5 -2
- package/esm2022/core/abstract/base-form-container.mjs +1 -1
- package/esm2022/core/abstract/base-nested-form-control.mjs +2 -2
- package/esm2022/core/constants/tokens.mjs +1 -46
- package/esm2022/core/module.mjs +10 -3
- package/esm2022/core/pipes/page-env.pipe.mjs +6 -3
- package/esm2022/core/services/feature-gate.service.mjs +3 -3
- package/esm2022/core/services/k8s-util.service.mjs +1 -13
- package/esm2022/core/types/k8s/crd.mjs +1 -1
- package/esm2022/core/utils/common.mjs +11 -9
- package/esm2022/disabled-container/disabled-container.component.mjs +2 -2
- package/esm2022/form/validators/utils.mjs +37 -34
- package/esm2022/graph-canvas/graph-store.service.mjs +2 -2
- package/esm2022/help-document/service.mjs +3 -2
- package/esm2022/lazy-component/lazy-load-component.mjs +138 -0
- package/esm2022/lazy-component/public-api.mjs +14 -0
- package/esm2022/lazy-component/visibility.service.mjs +37 -0
- package/esm2022/list-display/component.mjs +159 -0
- package/esm2022/list-display/public-api.mjs +2 -0
- package/esm2022/metric-chart/metric-chart.component.mjs +2 -2
- package/esm2022/multi-search/action-input/component.mjs +2 -2
- package/esm2022/notification/feedback-notification/component.mjs +10 -4
- package/esm2022/notification/public-api.mjs +1 -2
- package/esm2022/page-scaffold/navigation/lottie-icons/animation-data.mjs +3 -1
- package/esm2022/page-scaffold/navigation/lottie-icons/animations/dashboard.json +1 -0
- package/esm2022/page-scaffold/navigation/nav-menu/nav-menu.types.mjs +1 -1
- package/esm2022/page-scaffold/page-header/common-layout/product-select/component.mjs +10 -13
- package/esm2022/page-scaffold/page-header/help-menu/component/component.mjs +3 -3
- package/esm2022/public-api.mjs +4 -4
- package/esm2022/table/component.mjs +5 -5
- package/esm2022/table/types.mjs +1 -1
- package/esm2022/translate/translate.service.mjs +7 -1
- package/esm2022/view-chart/view-chart.module.mjs +1 -1
- package/esm2022/view-zchart/custom-template/dropdown-legend.mjs +3 -3
- package/esm2022/view-zchart/legend/legend.component.mjs +8 -8
- package/esm2022/view-zchart/units.mjs +13 -1
- package/esm2022/view-zchart/view-zchart.component.mjs +2 -2
- package/esm2022/view-zchart/view-zchart.module.mjs +1 -1
- package/esm2022/widget/foldable-item-in-table/component.mjs +2 -2
- package/esm2022/widget/search-panel/component.mjs +4 -4
- package/esm2022/window-channel/plugin-window-channel.service.mjs +8 -3
- package/esm2022/xterm/xterm-terminal/xterm-terminal.component.mjs +66 -69
- package/esm2022/xterm/xterm.component.mjs +11 -3
- package/form/validators/utils.d.ts +7 -0
- package/lazy-component/lazy-load-component.d.ts +25 -0
- package/lazy-component/public-api.d.ts +9 -0
- package/lazy-component/visibility.service.d.ts +11 -0
- package/list-display/component.d.ts +15 -0
- package/list-display/public-api.d.ts +1 -0
- package/notification/feedback-notification/component.d.ts +1 -5
- package/notification/public-api.d.ts +0 -1
- package/package.json +1 -1
- package/page-scaffold/navigation/nav-menu/nav-menu.types.d.ts +1 -0
- package/page-scaffold/page-header/common-layout/product-select/component.d.ts +1 -2
- package/public-api.d.ts +3 -3
- package/styles/global.scss +6 -0
- package/styles/mixins.scss +20 -0
- package/styles/reset-browser.scss +4 -0
- package/styles/tailwind-preset.scss +1 -1
- package/table/types.d.ts +2 -0
- package/translate/translate.service.d.ts +2 -0
- package/view-zchart/custom-template/dropdown-legend.d.ts +1 -1
- package/view-zchart/units.d.ts +3 -0
- package/xterm/xterm-terminal/xterm-terminal.component.d.ts +4 -3
- package/xterm/xterm.component.d.ts +4 -2
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Injectable, ElementRef } from '@angular/core';
|
|
2
|
+
import { Subject, filter, map } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class VisibilityService {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.observer = new IntersectionObserver(entries => {
|
|
7
|
+
entries.forEach(entry => {
|
|
8
|
+
if (entry.isIntersecting) {
|
|
9
|
+
const target = entry.target;
|
|
10
|
+
this.visibilityChangeSubject.next({
|
|
11
|
+
element: new ElementRef(target),
|
|
12
|
+
isVisible: entry.isIntersecting,
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
}, {
|
|
17
|
+
threshold: 0.1,
|
|
18
|
+
});
|
|
19
|
+
this.visibilityChangeSubject = new Subject();
|
|
20
|
+
}
|
|
21
|
+
observe(element) {
|
|
22
|
+
this.observer.observe(element.nativeElement);
|
|
23
|
+
return this.visibilityChangeSubject.pipe(filter(({ element: el }) => el.nativeElement === element.nativeElement), map(({ isVisible }) => isVisible));
|
|
24
|
+
}
|
|
25
|
+
unobserve(element) {
|
|
26
|
+
this.observer.unobserve(element.nativeElement);
|
|
27
|
+
}
|
|
28
|
+
static { this.ɵfac = function VisibilityService_Factory(t) { return new (t || VisibilityService)(); }; }
|
|
29
|
+
static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: VisibilityService, factory: VisibilityService.ɵfac, providedIn: 'root' }); }
|
|
30
|
+
}
|
|
31
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(VisibilityService, [{
|
|
32
|
+
type: Injectable,
|
|
33
|
+
args: [{
|
|
34
|
+
providedIn: 'root',
|
|
35
|
+
}]
|
|
36
|
+
}], null, null); })();
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlzaWJpbGl0eS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL2xhenktY29tcG9uZW50L3Zpc2liaWxpdHkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RCxPQUFPLEVBQWMsT0FBTyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBS3hELE1BQU0sT0FBTyxpQkFBaUI7SUFIOUI7UUFJbUIsYUFBUSxHQUFHLElBQUksb0JBQW9CLENBQ2xELE9BQU8sQ0FBQyxFQUFFO1lBQ1IsT0FBTyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDdEIsSUFBSSxLQUFLLENBQUMsY0FBYyxFQUFFO29CQUN4QixNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBcUIsQ0FBQztvQkFDM0MsSUFBSSxDQUFDLHVCQUF1QixDQUFDLElBQUksQ0FBQzt3QkFDaEMsT0FBTyxFQUFFLElBQUksVUFBVSxDQUFDLE1BQU0sQ0FBQzt3QkFDL0IsU0FBUyxFQUFFLEtBQUssQ0FBQyxjQUFjO3FCQUNoQyxDQUFDLENBQUM7aUJBQ0o7WUFDSCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsRUFDRDtZQUNFLFNBQVMsRUFBRSxHQUFHO1NBQ2YsQ0FDRixDQUFDO1FBRWUsNEJBQXVCLEdBR25DLElBQUksT0FBTyxFQUFFLENBQUM7S0FhcEI7SUFYQyxPQUFPLENBQUMsT0FBbUI7UUFDekIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzdDLE9BQU8sSUFBSSxDQUFDLHVCQUF1QixDQUFDLElBQUksQ0FDdEMsTUFBTSxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxhQUFhLEtBQUssT0FBTyxDQUFDLGFBQWEsQ0FBQyxFQUN2RSxHQUFHLENBQUMsQ0FBQyxFQUFFLFNBQVMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FDbEMsQ0FBQztJQUNKLENBQUM7SUFFRCxTQUFTLENBQUMsT0FBbUI7UUFDM0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ2pELENBQUM7a0ZBakNVLGlCQUFpQjt1RUFBakIsaUJBQWlCLFdBQWpCLGlCQUFpQixtQkFGaEIsTUFBTTs7dUZBRVAsaUJBQWlCO2NBSDdCLFVBQVU7ZUFBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEVsZW1lbnRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QsIGZpbHRlciwgbWFwIH0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBWaXNpYmlsaXR5U2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgb2JzZXJ2ZXIgPSBuZXcgSW50ZXJzZWN0aW9uT2JzZXJ2ZXIoXG4gICAgZW50cmllcyA9PiB7XG4gICAgICBlbnRyaWVzLmZvckVhY2goZW50cnkgPT4ge1xuICAgICAgICBpZiAoZW50cnkuaXNJbnRlcnNlY3RpbmcpIHtcbiAgICAgICAgICBjb25zdCB0YXJnZXQgPSBlbnRyeS50YXJnZXQgYXMgSFRNTEVsZW1lbnQ7XG4gICAgICAgICAgdGhpcy52aXNpYmlsaXR5Q2hhbmdlU3ViamVjdC5uZXh0KHtcbiAgICAgICAgICAgIGVsZW1lbnQ6IG5ldyBFbGVtZW50UmVmKHRhcmdldCksXG4gICAgICAgICAgICBpc1Zpc2libGU6IGVudHJ5LmlzSW50ZXJzZWN0aW5nLFxuICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9LFxuICAgIHtcbiAgICAgIHRocmVzaG9sZDogMC4xLFxuICAgIH0sXG4gICk7XG5cbiAgcHJpdmF0ZSByZWFkb25seSB2aXNpYmlsaXR5Q2hhbmdlU3ViamVjdDogU3ViamVjdDx7XG4gICAgZWxlbWVudDogRWxlbWVudFJlZjtcbiAgICBpc1Zpc2libGU6IGJvb2xlYW47XG4gIH0+ID0gbmV3IFN1YmplY3QoKTtcblxuICBvYnNlcnZlKGVsZW1lbnQ6IEVsZW1lbnRSZWYpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICB0aGlzLm9ic2VydmVyLm9ic2VydmUoZWxlbWVudC5uYXRpdmVFbGVtZW50KTtcbiAgICByZXR1cm4gdGhpcy52aXNpYmlsaXR5Q2hhbmdlU3ViamVjdC5waXBlKFxuICAgICAgZmlsdGVyKCh7IGVsZW1lbnQ6IGVsIH0pID0+IGVsLm5hdGl2ZUVsZW1lbnQgPT09IGVsZW1lbnQubmF0aXZlRWxlbWVudCksXG4gICAgICBtYXAoKHsgaXNWaXNpYmxlIH0pID0+IGlzVmlzaWJsZSksXG4gICAgKTtcbiAgfVxuXG4gIHVub2JzZXJ2ZShlbGVtZW50OiBFbGVtZW50UmVmKSB7XG4gICAgdGhpcy5vYnNlcnZlci51bm9ic2VydmUoZWxlbWVudC5uYXRpdmVFbGVtZW50KTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import { TooltipModule } from '@alauda/ui';
|
|
2
|
+
import { NgFor, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, ContentChild, Input, TemplateRef, } from '@angular/core';
|
|
4
|
+
import { PurePipe } from '../core/public-api';
|
|
5
|
+
import { EffectDirectiveModule } from '../effect-directive/module';
|
|
6
|
+
import { TRANSLATE_MODULE } from '../translate/translate.module';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../translate/translate.pipe";
|
|
9
|
+
import * as i2 from "@alauda/ui";
|
|
10
|
+
import * as i3 from "../effect-directive/e2e-attribute-binding.directive";
|
|
11
|
+
function ListDisplayComponent_li_2_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
12
|
+
i0.ɵɵelementContainer(0);
|
|
13
|
+
} }
|
|
14
|
+
function ListDisplayComponent_li_2_Template(rf, ctx) { if (rf & 1) {
|
|
15
|
+
i0.ɵɵelementStart(0, "li");
|
|
16
|
+
i0.ɵɵtemplate(1, ListDisplayComponent_li_2_ng_container_1_Template, 1, 0, "ng-container", 5);
|
|
17
|
+
i0.ɵɵpipe(2, "pure");
|
|
18
|
+
i0.ɵɵelementEnd();
|
|
19
|
+
} if (rf & 2) {
|
|
20
|
+
const item_r6 = ctx.$implicit;
|
|
21
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
22
|
+
i0.ɵɵadvance(1);
|
|
23
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.childTemplate || ctx_r0.template)("ngTemplateOutletContext", i0.ɵɵpipeBind2(2, 2, item_r6, ctx_r0.templateContext));
|
|
24
|
+
} }
|
|
25
|
+
function ListDisplayComponent_div_3_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
26
|
+
i0.ɵɵelementContainerStart(0);
|
|
27
|
+
i0.ɵɵtext(1);
|
|
28
|
+
i0.ɵɵpipe(2, "translate");
|
|
29
|
+
i0.ɵɵelementStart(3, "a", 7);
|
|
30
|
+
i0.ɵɵtext(4);
|
|
31
|
+
i0.ɵɵelementEnd();
|
|
32
|
+
i0.ɵɵtext(5);
|
|
33
|
+
i0.ɵɵpipe(6, "translate");
|
|
34
|
+
i0.ɵɵelementContainerEnd();
|
|
35
|
+
} if (rf & 2) {
|
|
36
|
+
const ctx_r8 = i0.ɵɵnextContext(2);
|
|
37
|
+
const _r2 = i0.ɵɵreference(5);
|
|
38
|
+
i0.ɵɵadvance(1);
|
|
39
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 4, "in_total"), " ");
|
|
40
|
+
i0.ɵɵadvance(2);
|
|
41
|
+
i0.ɵɵproperty("auiTooltip", _r2);
|
|
42
|
+
i0.ɵɵadvance(1);
|
|
43
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r8.data.length, " ");
|
|
44
|
+
i0.ɵɵadvance(1);
|
|
45
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(6, 6, "ge"), " ");
|
|
46
|
+
} }
|
|
47
|
+
const _c0 = function (a0) { return { data: a0 }; };
|
|
48
|
+
function ListDisplayComponent_div_3_ng_container_2_Template(rf, ctx) { if (rf & 1) {
|
|
49
|
+
i0.ɵɵelementContainerStart(0);
|
|
50
|
+
i0.ɵɵtext(1);
|
|
51
|
+
i0.ɵɵpipe(2, "translate");
|
|
52
|
+
i0.ɵɵelementStart(3, "a", 8);
|
|
53
|
+
i0.ɵɵtext(4);
|
|
54
|
+
i0.ɵɵelementEnd();
|
|
55
|
+
i0.ɵɵtext(5);
|
|
56
|
+
i0.ɵɵpipe(6, "translate");
|
|
57
|
+
i0.ɵɵelementContainerEnd();
|
|
58
|
+
} if (rf & 2) {
|
|
59
|
+
const ctx_r9 = i0.ɵɵnextContext(2);
|
|
60
|
+
const _r4 = i0.ɵɵreference(7);
|
|
61
|
+
i0.ɵɵadvance(1);
|
|
62
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 5, "more"), " ");
|
|
63
|
+
i0.ɵɵadvance(2);
|
|
64
|
+
i0.ɵɵproperty("auiTooltip", _r4)("auiTooltipContext", i0.ɵɵpureFunction1(9, _c0, ctx_r9.data.slice(ctx_r9.threshold)));
|
|
65
|
+
i0.ɵɵadvance(1);
|
|
66
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r9.data.slice(ctx_r9.threshold).length, " ");
|
|
67
|
+
i0.ɵɵadvance(1);
|
|
68
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(6, 7, "tiao"), " ");
|
|
69
|
+
} }
|
|
70
|
+
const _c1 = function (a0) { return { "tw-ml-8": a0 }; };
|
|
71
|
+
function ListDisplayComponent_div_3_Template(rf, ctx) { if (rf & 1) {
|
|
72
|
+
i0.ɵɵelementStart(0, "div");
|
|
73
|
+
i0.ɵɵtemplate(1, ListDisplayComponent_div_3_ng_container_1_Template, 7, 8, "ng-container", 6);
|
|
74
|
+
i0.ɵɵtemplate(2, ListDisplayComponent_div_3_ng_container_2_Template, 7, 11, "ng-container", 6);
|
|
75
|
+
i0.ɵɵelementEnd();
|
|
76
|
+
} if (rf & 2) {
|
|
77
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
78
|
+
i0.ɵɵclassMap(i0.ɵɵpureFunction1(4, _c1, ctx_r1.direction === "row"));
|
|
79
|
+
i0.ɵɵadvance(1);
|
|
80
|
+
i0.ɵɵproperty("ngIf", ctx_r1.mode === "total");
|
|
81
|
+
i0.ɵɵadvance(1);
|
|
82
|
+
i0.ɵɵproperty("ngIf", ctx_r1.mode === "more");
|
|
83
|
+
} }
|
|
84
|
+
function ListDisplayComponent_ng_template_4_Template(rf, ctx) { if (rf & 1) {
|
|
85
|
+
i0.ɵɵelement(0, "acl-list-display", 9);
|
|
86
|
+
} if (rf & 2) {
|
|
87
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
88
|
+
i0.ɵɵproperty("data", ctx_r3.data)("template", ctx_r3.childTemplate || ctx_r3.template);
|
|
89
|
+
} }
|
|
90
|
+
function ListDisplayComponent_ng_template_6_Template(rf, ctx) { if (rf & 1) {
|
|
91
|
+
i0.ɵɵelement(0, "acl-list-display", 9);
|
|
92
|
+
} if (rf & 2) {
|
|
93
|
+
const data_r10 = ctx.data;
|
|
94
|
+
const ctx_r5 = i0.ɵɵnextContext();
|
|
95
|
+
i0.ɵɵproperty("data", data_r10)("template", ctx_r5.childTemplate || ctx_r5.template);
|
|
96
|
+
} }
|
|
97
|
+
const _c2 = function (a0) { return { "tw-flex-col": a0 }; };
|
|
98
|
+
export class ListDisplayComponent {
|
|
99
|
+
constructor() {
|
|
100
|
+
this.mode = 'total';
|
|
101
|
+
this.direction = 'column';
|
|
102
|
+
}
|
|
103
|
+
templateContext(item) {
|
|
104
|
+
return {
|
|
105
|
+
...item,
|
|
106
|
+
$implicit: item,
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
static { this.ɵfac = function ListDisplayComponent_Factory(t) { return new (t || ListDisplayComponent)(); }; }
|
|
110
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ListDisplayComponent, selectors: [["acl-list-display"]], contentQueries: function ListDisplayComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
111
|
+
i0.ɵɵcontentQuery(dirIndex, TemplateRef, 5);
|
|
112
|
+
} if (rf & 2) {
|
|
113
|
+
let _t;
|
|
114
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.childTemplate = _t.first);
|
|
115
|
+
} }, inputs: { data: "data", threshold: "threshold", mode: "mode", direction: "direction", template: "template" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 8, vars: 6, consts: [[1, "tw-flex"], [4, "ngFor", "ngForOf"], [3, "class", 4, "ngIf"], ["total", ""], ["more", ""], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], [4, "ngIf"], ["auiTooltipType", "info", "auiTooltipPosition", "bottom center", 3, "auiTooltip"], ["auiTooltipType", "info", "auiTooltipPosition", "bottom center", 3, "auiTooltip", "auiTooltipContext"], [3, "data", "template"]], template: function ListDisplayComponent_Template(rf, ctx) { if (rf & 1) {
|
|
116
|
+
i0.ɵɵelementStart(0, "div", 0)(1, "ul");
|
|
117
|
+
i0.ɵɵtemplate(2, ListDisplayComponent_li_2_Template, 3, 5, "li", 1);
|
|
118
|
+
i0.ɵɵelementEnd();
|
|
119
|
+
i0.ɵɵtemplate(3, ListDisplayComponent_div_3_Template, 3, 6, "div", 2);
|
|
120
|
+
i0.ɵɵelementEnd();
|
|
121
|
+
i0.ɵɵtemplate(4, ListDisplayComponent_ng_template_4_Template, 1, 2, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
|
|
122
|
+
i0.ɵɵtemplate(6, ListDisplayComponent_ng_template_6_Template, 1, 2, "ng-template", null, 4, i0.ɵɵtemplateRefExtractor);
|
|
123
|
+
} if (rf & 2) {
|
|
124
|
+
i0.ɵɵclassMap(i0.ɵɵpureFunction1(4, _c2, ctx.direction === "column"));
|
|
125
|
+
i0.ɵɵadvance(2);
|
|
126
|
+
i0.ɵɵproperty("ngForOf", ctx.threshold ? ctx.data.slice(0, ctx.threshold) : ctx.data);
|
|
127
|
+
i0.ɵɵadvance(1);
|
|
128
|
+
i0.ɵɵproperty("ngIf", ctx.threshold && ctx.data.length > ctx.threshold);
|
|
129
|
+
} }, dependencies: [ListDisplayComponent, NgFor,
|
|
130
|
+
NgIf,
|
|
131
|
+
NgTemplateOutlet,
|
|
132
|
+
PurePipe, i1.TranslatePipe, TooltipModule, i2.TooltipDirective, EffectDirectiveModule, i3.E2eAttributeBindingDirective], styles: ["li[_ngcontent-%COMP%]{line-height:20px}"], changeDetection: 0 }); }
|
|
133
|
+
}
|
|
134
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ListDisplayComponent, [{
|
|
135
|
+
type: Component,
|
|
136
|
+
args: [{ standalone: true, selector: 'acl-list-display', changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
137
|
+
NgFor,
|
|
138
|
+
NgIf,
|
|
139
|
+
NgTemplateOutlet,
|
|
140
|
+
PurePipe,
|
|
141
|
+
TRANSLATE_MODULE,
|
|
142
|
+
TooltipModule,
|
|
143
|
+
EffectDirectiveModule,
|
|
144
|
+
], template: "<div\n class=\"tw-flex\"\n [class]=\"{ 'tw-flex-col': direction === 'column' }\"\n>\n <ul>\n <li *ngFor=\"let item of threshold ? data.slice(0, threshold) : data\">\n <ng-container\n *ngTemplateOutlet=\"\n childTemplate || template;\n context: item | pure: templateContext\n \"\n ></ng-container>\n </li>\n </ul>\n <div\n [class]=\"{ 'tw-ml-8': direction === 'row' }\"\n *ngIf=\"threshold && data.length > threshold\"\n >\n <ng-container *ngIf=\"mode === 'total'\">\n {{ 'in_total' | translate }}\n <a\n [auiTooltip]=\"total\"\n auiTooltipType=\"info\"\n auiTooltipPosition=\"bottom center\"\n >\n {{ data.length }}\n </a>\n {{ 'ge' | translate }}\n </ng-container>\n\n <ng-container *ngIf=\"mode === 'more'\">\n {{ 'more' | translate }}\n <a\n [auiTooltip]=\"more\"\n [auiTooltipContext]=\"{ data: data.slice(threshold) }\"\n auiTooltipType=\"info\"\n auiTooltipPosition=\"bottom center\"\n >\n {{ data.slice(threshold).length }}\n </a>\n {{ 'tiao' | translate }}\n </ng-container>\n </div>\n</div>\n\n<ng-template #total>\n <acl-list-display\n [data]=\"data\"\n [template]=\"childTemplate || template\"\n ></acl-list-display>\n</ng-template>\n\n<ng-template\n #more\n let-data=\"data\"\n>\n <acl-list-display\n [data]=\"data\"\n [template]=\"childTemplate || template\"\n ></acl-list-display>\n</ng-template>\n", styles: ["li{line-height:20px}\n"] }]
|
|
145
|
+
}], null, { data: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], threshold: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}], mode: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], direction: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], template: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], childTemplate: [{
|
|
156
|
+
type: ContentChild,
|
|
157
|
+
args: [TemplateRef]
|
|
158
|
+
}] }); })();
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL2xpc3QtZGlzcGxheS9jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9zcmMvbGlzdC1kaXNwbGF5L3RlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUMzQyxPQUFPLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2hFLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBQ0wsV0FBVyxHQUNaLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7Ozs7O0lDTjNELHdCQUtnQjs7O0lBTmxCLDBCQUFxRTtJQUNuRSw0RkFLZ0I7O0lBQ2xCLGlCQUFLOzs7O0lBTEEsZUFFWTtJQUZaLDBFQUVZLGtGQUFBOzs7SUFTakIsNkJBQXVDO0lBQ3JDLFlBQ0E7O0lBQUEsNEJBSUM7SUFDQyxZQUNGO0lBQUEsaUJBQUk7SUFDSixZQUNGOztJQUFBLDBCQUFlOzs7O0lBVGIsZUFDQTtJQURBLGlFQUNBO0lBQ0UsZUFBb0I7SUFBcEIsZ0NBQW9CO0lBSXBCLGVBQ0Y7SUFERSxtREFDRjtJQUNBLGVBQ0Y7SUFERSwyREFDRjs7OztJQUVBLDZCQUFzQztJQUNwQyxZQUNBOztJQUFBLDRCQUtDO0lBQ0MsWUFDRjtJQUFBLGlCQUFJO0lBQ0osWUFDRjs7SUFBQSwwQkFBZTs7OztJQVZiLGVBQ0E7SUFEQSw2REFDQTtJQUNFLGVBQW1CO0lBQW5CLGdDQUFtQixzRkFBQTtJQUtuQixlQUNGO0lBREUsMkVBQ0Y7SUFDQSxlQUNGO0lBREUsNkRBQ0Y7Ozs7SUEzQkYsMkJBR0M7SUFDQyw2RkFVZTtJQUVmLDhGQVdlO0lBQ2pCLGlCQUFNOzs7SUEzQkoscUVBQTRDO0lBRzdCLGVBQXNCO0lBQXRCLDhDQUFzQjtJQVl0QixlQUFxQjtJQUFyQiw2Q0FBcUI7OztJQWdCdEMsc0NBR29COzs7SUFGbEIsa0NBQWEscURBQUE7OztJQVNmLHNDQUdvQjs7OztJQUZsQiwrQkFBYSxxREFBQTs7O0FEckJqQixNQUFNLE9BQU8sb0JBQW9CO0lBdEJqQztRQThCRSxTQUFJLEdBQXFCLE9BQU8sQ0FBQztRQUdqQyxjQUFTLEdBQXFCLFFBQVEsQ0FBQztLQWN4QztJQU5DLGVBQWUsQ0FBQyxJQUFPO1FBQ3JCLE9BQU87WUFDTCxHQUFHLElBQUk7WUFDUCxTQUFTLEVBQUUsSUFBSTtTQUNoQixDQUFDO0lBQ0osQ0FBQztxRkF4QlUsb0JBQW9CO29FQUFwQixvQkFBb0I7d0NBZ0JqQixXQUFXOzs7OztZQ3BEM0IsOEJBR0MsU0FBQTtZQUVHLG1FQU9LO1lBQ1AsaUJBQUs7WUFDTCxxRUE0Qk07WUFDUixpQkFBTTtZQUVOLHNIQUtjO1lBRWQsc0hBUWM7O1lBMURaLHFFQUFtRDtZQUc1QixlQUE4QztZQUE5QyxxRkFBOEM7WUFXbEUsZUFBMEM7WUFBMUMsdUVBQTBDOzRCRG9CbEMsb0JBQW9CLEVBVDdCLEtBQUs7WUFDTCxJQUFJO1lBQ0osZ0JBQWdCO1lBQ2hCLFFBQVEsb0JBRVIsYUFBYSx1QkFDYixxQkFBcUI7O3VGQUdaLG9CQUFvQjtjQXRCaEMsU0FBUzs2QkFDSSxJQUFJLFlBQ04sa0JBQWtCLG1CQVNYLHVCQUF1QixDQUFDLE1BQU0sV0FDdEM7b0JBQ1AsS0FBSztvQkFDTCxJQUFJO29CQUNKLGdCQUFnQjtvQkFDaEIsUUFBUTtvQkFDUixnQkFBZ0I7b0JBQ2hCLGFBQWE7b0JBQ2IscUJBQXFCO2lCQUN0QjtnQkFJRCxJQUFJO2tCQURILEtBQUs7WUFJTixTQUFTO2tCQURSLEtBQUs7WUFJTixJQUFJO2tCQURILEtBQUs7WUFJTixTQUFTO2tCQURSLEtBQUs7WUFJTixRQUFRO2tCQURQLEtBQUs7WUFJTixhQUFhO2tCQURaLFlBQVk7bUJBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYWxhdWRhL3VpJztcbmltcG9ydCB7IE5nRm9yLCBOZ0lmLCBOZ1RlbXBsYXRlT3V0bGV0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZCxcbiAgSW5wdXQsXG4gIFRlbXBsYXRlUmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgUHVyZVBpcGUgfSBmcm9tICcuLi9jb3JlL3B1YmxpYy1hcGknO1xuaW1wb3J0IHsgRWZmZWN0RGlyZWN0aXZlTW9kdWxlIH0gZnJvbSAnLi4vZWZmZWN0LWRpcmVjdGl2ZS9tb2R1bGUnO1xuaW1wb3J0IHsgVFJBTlNMQVRFX01PRFVMRSB9IGZyb20gJy4uL3RyYW5zbGF0ZS90cmFuc2xhdGUubW9kdWxlJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnYWNsLWxpc3QtZGlzcGxheScsXG4gIHRlbXBsYXRlVXJsOiAndGVtcGxhdGUuaHRtbCcsXG4gIHN0eWxlczogW1xuICAgIGBcbiAgICAgIGxpIHtcbiAgICAgICAgbGluZS1oZWlnaHQ6IDIwcHg7XG4gICAgICB9XG4gICAgYCxcbiAgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGltcG9ydHM6IFtcbiAgICBOZ0ZvcixcbiAgICBOZ0lmLFxuICAgIE5nVGVtcGxhdGVPdXRsZXQsXG4gICAgUHVyZVBpcGUsXG4gICAgVFJBTlNMQVRFX01PRFVMRSxcbiAgICBUb29sdGlwTW9kdWxlLFxuICAgIEVmZmVjdERpcmVjdGl2ZU1vZHVsZSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTGlzdERpc3BsYXlDb21wb25lbnQ8VD4ge1xuICBASW5wdXQoKVxuICBkYXRhOiBUW107XG5cbiAgQElucHV0KClcbiAgdGhyZXNob2xkOiBudW1iZXI7XG5cbiAgQElucHV0KClcbiAgbW9kZTogJ3RvdGFsJyB8ICdtb3JlJyA9ICd0b3RhbCc7XG5cbiAgQElucHV0KClcbiAgZGlyZWN0aW9uOiAncm93JyB8ICdjb2x1bW4nID0gJ2NvbHVtbic7XG5cbiAgQElucHV0KClcbiAgdGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgQENvbnRlbnRDaGlsZChUZW1wbGF0ZVJlZilcbiAgY2hpbGRUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcblxuICB0ZW1wbGF0ZUNvbnRleHQoaXRlbTogVCkge1xuICAgIHJldHVybiB7XG4gICAgICAuLi5pdGVtLFxuICAgICAgJGltcGxpY2l0OiBpdGVtLFxuICAgIH07XG4gIH1cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJ0dy1mbGV4XCJcbiAgW2NsYXNzXT1cInsgJ3R3LWZsZXgtY29sJzogZGlyZWN0aW9uID09PSAnY29sdW1uJyB9XCJcbj5cbiAgPHVsPlxuICAgIDxsaSAqbmdGb3I9XCJsZXQgaXRlbSBvZiB0aHJlc2hvbGQgPyBkYXRhLnNsaWNlKDAsIHRocmVzaG9sZCkgOiBkYXRhXCI+XG4gICAgICA8bmctY29udGFpbmVyXG4gICAgICAgICpuZ1RlbXBsYXRlT3V0bGV0PVwiXG4gICAgICAgICAgY2hpbGRUZW1wbGF0ZSB8fCB0ZW1wbGF0ZTtcbiAgICAgICAgICBjb250ZXh0OiBpdGVtIHwgcHVyZTogdGVtcGxhdGVDb250ZXh0XG4gICAgICAgIFwiXG4gICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgPC9saT5cbiAgPC91bD5cbiAgPGRpdlxuICAgIFtjbGFzc109XCJ7ICd0dy1tbC04JzogZGlyZWN0aW9uID09PSAncm93JyB9XCJcbiAgICAqbmdJZj1cInRocmVzaG9sZCAmJiBkYXRhLmxlbmd0aCA+IHRocmVzaG9sZFwiXG4gID5cbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwibW9kZSA9PT0gJ3RvdGFsJ1wiPlxuICAgICAge3sgJ2luX3RvdGFsJyB8IHRyYW5zbGF0ZSB9fVxuICAgICAgPGFcbiAgICAgICAgW2F1aVRvb2x0aXBdPVwidG90YWxcIlxuICAgICAgICBhdWlUb29sdGlwVHlwZT1cImluZm9cIlxuICAgICAgICBhdWlUb29sdGlwUG9zaXRpb249XCJib3R0b20gY2VudGVyXCJcbiAgICAgID5cbiAgICAgICAge3sgZGF0YS5sZW5ndGggfX1cbiAgICAgIDwvYT5cbiAgICAgIHt7ICdnZScgfCB0cmFuc2xhdGUgfX1cbiAgICA8L25nLWNvbnRhaW5lcj5cblxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJtb2RlID09PSAnbW9yZSdcIj5cbiAgICAgIHt7ICdtb3JlJyB8IHRyYW5zbGF0ZSB9fVxuICAgICAgPGFcbiAgICAgICAgW2F1aVRvb2x0aXBdPVwibW9yZVwiXG4gICAgICAgIFthdWlUb29sdGlwQ29udGV4dF09XCJ7IGRhdGE6IGRhdGEuc2xpY2UodGhyZXNob2xkKSB9XCJcbiAgICAgICAgYXVpVG9vbHRpcFR5cGU9XCJpbmZvXCJcbiAgICAgICAgYXVpVG9vbHRpcFBvc2l0aW9uPVwiYm90dG9tIGNlbnRlclwiXG4gICAgICA+XG4gICAgICAgIHt7IGRhdGEuc2xpY2UodGhyZXNob2xkKS5sZW5ndGggfX1cbiAgICAgIDwvYT5cbiAgICAgIHt7ICd0aWFvJyB8IHRyYW5zbGF0ZSB9fVxuICAgIDwvbmctY29udGFpbmVyPlxuICA8L2Rpdj5cbjwvZGl2PlxuXG48bmctdGVtcGxhdGUgI3RvdGFsPlxuICA8YWNsLWxpc3QtZGlzcGxheVxuICAgIFtkYXRhXT1cImRhdGFcIlxuICAgIFt0ZW1wbGF0ZV09XCJjaGlsZFRlbXBsYXRlIHx8IHRlbXBsYXRlXCJcbiAgPjwvYWNsLWxpc3QtZGlzcGxheT5cbjwvbmctdGVtcGxhdGU+XG5cbjxuZy10ZW1wbGF0ZVxuICAjbW9yZVxuICBsZXQtZGF0YT1cImRhdGFcIlxuPlxuICA8YWNsLWxpc3QtZGlzcGxheVxuICAgIFtkYXRhXT1cImRhdGFcIlxuICAgIFt0ZW1wbGF0ZV09XCJjaGlsZFRlbXBsYXRlIHx8IHRlbXBsYXRlXCJcbiAgPjwvYWNsLWxpc3QtZGlzcGxheT5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9saXN0LWRpc3BsYXkvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50JztcbiJdfQ==
|
|
@@ -46,7 +46,7 @@ export class MetricChartComponent {
|
|
|
46
46
|
}
|
|
47
47
|
}), map(percent => (d) => {
|
|
48
48
|
// prometheus 可能出现 Infinity情况,处理为 null
|
|
49
|
-
if (!Number.isFinite(d.y) || String(d.y)
|
|
49
|
+
if (!Number.isFinite(d.y) || String(d.y).includes('Inf')) {
|
|
50
50
|
return null;
|
|
51
51
|
}
|
|
52
52
|
return percent && d.y ? +d.y * 100 : d.y === null ? d.y : +d.y;
|
|
@@ -343,4 +343,4 @@ __decorate([
|
|
|
343
343
|
}], dataCompleted: [{
|
|
344
344
|
type: Output
|
|
345
345
|
}] }); })();
|
|
346
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metric-chart.component.js","sourceRoot":"","sources":["../../../../../libs/common/src/metric-chart/metric-chart.component.ts","../../../../../libs/common/src/metric-chart/metric-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { TooltipContext } from '@alauda/chart';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n} from '@angular/core';\nimport { CurveFactory, CurveFactoryLineOnly } from 'd3';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  merge,\n  of,\n  pipe,\n  BehaviorSubject,\n  catchError,\n  filter,\n  map,\n  switchMap,\n  tap,\n  withLatestFrom,\n} from 'rxjs';\nimport { Chart, TooltipValue } from 'zz-chart';\n\nimport {\n  AreaPosition,\n  ContextItem,\n  DATE_TIME_FORMAT_X_AXIS,\n} from '../chart/public-api';\nimport { StringMap, ObservableInput, publishRef } from '../core/public-api';\nimport {\n  ChartData,\n  ChartDataItem,\n  ChartStatus,\n  XPlotLines,\n} from '../view-chart/public-api';\n\nimport { CommonChartService } from './common-chart.service';\nimport { MatchUnitParams, PICKER_TIME_RANGES } from './helpers';\nimport { Indicator, MetricApiParams, MetricResult } from './types';\nimport { checkInterval, fillNullChartData, hasNoData } from './utils';\n\n@Component({\n  selector: 'acl-metric-chart',\n  templateUrl: './metric-chart.component.html',\n  styleUrls: ['./metric-chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MetricChartComponent implements OnInit {\n  @Input() contextCallbackFunction: (context: Chart) => void;\n\n  @Input() backgroundColor: string;\n\n  @Input() hideHeader: boolean;\n\n  @Input() title: string | TemplateRef<unknown>;\n\n  @Input() hideTitle: boolean;\n\n  @Input() chartType: 'line' | 'area' | 'bar' | 'point' | 'stat' = 'area';\n\n  @Input() titleDescription: string | TemplateRef<unknown>;\n\n  @Input() titleDescriptionContext: StringMap;\n\n  @Input() unit: string;\n\n  @Input() tooltipAppendToBody = true;\n\n  @HostBinding('style.overflow')\n  get overflow() {\n    return !this.tooltipAppendToBody && 'unset';\n  }\n\n  @ObservableInput()\n  unit$!: Observable<string>;\n\n  @Input() indicator: Indicator[];\n\n  @Input() gridOffsetTop = 0;\n\n  @Input() yAxisMinStep?: number;\n\n  @Input() rotated: boolean;\n\n  @Input() barType: 'standard' | 'stacked' = 'standard';\n\n  @ObservableInput()\n  indicator$!: Observable<Indicator[]>;\n\n  @Input() metricApiParams: MetricApiParams;\n\n  @ObservableInput()\n  metricApiParams$!: Observable<MetricApiParams>;\n\n  @Input() tooltipPointNameTemplate: TemplateRef<unknown>;\n\n  @Input() tooltipPointTemplate: TemplateRef<unknown>;\n\n  @Input() legendTemplate: TemplateRef<unknown> | string;\n\n  @Input() legendSelectAllOperation = false;\n\n  @Input() legendSelectAllName: string;\n\n  @Input() tooltipHide: boolean;\n\n  @Input() tooltipPointFormat: (d: ContextItem) => number | string;\n\n  @Input() tooltipPointTemplateContext: { [key: string]: any };\n\n  @Input() tooltipColumnLayout: boolean;\n\n  @Input() hideLegend = false;\n\n  @Input() tooltipAutoSort: boolean;\n\n  @Input() tooltipSortMethod: (a: TooltipValue, b: TooltipValue) => number;\n\n  @Input() hideTooltipUnit: boolean;\n\n  @Input() leftOperation: TemplateRef<unknown>;\n\n  @Input() leftOperationContext: StringMap;\n\n  @Input() rightOperation: TemplateRef<unknown>;\n\n  @Input() mode: 'card' | 'default' = 'default';\n\n  @Input()\n  adaptUnit: boolean | MatchUnitParams;\n\n  @ObservableInput()\n  adaptUnit$!: Observable<boolean | MatchUnitParams>;\n\n  @Input()\n  percent: boolean;\n\n  @ObservableInput()\n  percent$!: Observable<boolean>;\n\n  @Input() dependOnData: boolean;\n\n  @Input() customNoDataTitle: TemplateRef<unknown> | string;\n\n  @Input() dataFormat: (\n    d: MetricResult[],\n    indicator: Indicator[],\n  ) => ChartData[];\n\n  @Input() customSeries!: MetricResult[];\n  @ObservableInput() customSeries$!: Observable<MetricResult[]>;\n\n  @Input() isCustomSeries: boolean;\n\n  series$: Observable<ChartData[]>;\n\n  @Input() chartStatus: ChartStatus;\n  @ObservableInput()\n  chartStatus$!: Observable<ChartStatus>;\n\n  @Input() tooltipTranslation = true;\n\n  @Input() xPlotLines: XPlotLines;\n\n  @Input() xPlotEmpty: boolean;\n\n  @Input() yPlotLines: TooltipContext;\n\n  @Input() yPlotLinesTooltip: TemplateRef<unknown>;\n\n  @Input() yPlotLinesTooltipContext: StringMap;\n\n  @Input() yPlotLinesHide = false;\n\n  @Input() enableZoom: boolean;\n\n  @Input() stepLine: boolean;\n\n  @Input() tooltipTitleTemplate: TemplateRef<unknown>;\n\n  @Input() yAccessor: (d: ChartDataItem) => number;\n\n  @Input() curveType: CurveFactory | CurveFactoryLineOnly;\n\n  @Output() mouseUpEvent = new EventEmitter<AreaPosition>();\n\n  @Output() markClickEvent = new EventEmitter<TooltipContext>();\n\n  @Output() refreshEvent = new EventEmitter();\n\n  @Output() dataCompleted = new EventEmitter<void>();\n\n  reload$ = new BehaviorSubject(null);\n\n  _chartStatus$$ = new Subject<ChartStatus>();\n  _status: ChartStatus = {};\n  status$ = merge(this.chartStatus$, this._chartStatus$$).pipe(\n    map(status => ({\n      ...this._status,\n      ...status,\n    })),\n    tap(status => (this._status = status)),\n    publishRef(),\n  );\n\n  noData: boolean;\n\n  dateAxisLabelFormats = DATE_TIME_FORMAT_X_AXIS;\n\n  dateXAxisLabelFormats = '%H:%M';\n\n  get xAccessor() {\n    return (d: ChartDataItem<{ x: number; y: number }>) => d.x * 1000;\n  }\n\n  yAccessor$ = this.percent$.pipe(\n    tap(percent => {\n      if (percent) {\n        this.unit = '%';\n      }\n    }),\n    map(percent => (d: ChartDataItem<{ x: number; y: number }>) => {\n      // prometheus 可能出现 Infinity情况，处理为 null\n      if (!Number.isFinite(d.y) || String(d.y) === '+Inf') {\n        return null;\n      }\n      return percent && d.y ? +d.y * 100 : d.y === null ? d.y : +d.y;\n    }),\n  );\n\n  _cacheTime: MetricApiParams = {\n    start: PICKER_TIME_RANGES[1].startTime(),\n    end: PICKER_TIME_RANGES[1].endTime(),\n    step: PICKER_TIME_RANGES[1].step,\n  };\n\n  private chartParams: MetricApiParams;\n\n  constructor(\n    private readonly service: CommonChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit() {\n    if (this.metricApiParams) {\n      this._cacheTime = this.metricApiParams;\n    }\n\n    this.series$ = (\n      this.isCustomSeries ? this.customSeries$ : this.defaultSeries$\n    ).pipe(this.handleMetricDataPipe());\n  }\n\n  defaultSeries$: Observable<MetricResult[]> = combineLatest([\n    this.metricApiParams$,\n    this.indicator$,\n    this.reload$,\n  ]).pipe(\n    tap(([, indicator]) => {\n      this.handleTimeParams();\n      this.handleDateAxisLabelFormats(this.chartParams);\n      this.handelChartStatus({\n        loading: !!indicator?.length,\n        failed: false,\n        noData: !indicator?.length,\n      });\n    }),\n    switchMap(([_, indicator]) =>\n      indicator?.length && this.chartParams\n        ? this.service.requestChartData(this.chartParams, indicator).pipe(\n            catchError(() => {\n              this.handelChartStatus({ loading: false, failed: true });\n              return of(null);\n            }),\n          )\n        : of(null),\n    ),\n  );\n\n  handleTimeParams() {\n    let timeParams = this.metricApiParams;\n    if (timeParams) {\n      if (checkInterval(this.metricApiParams, this._cacheTime)) {\n        this._cacheTime = this.metricApiParams;\n      } else {\n        timeParams = this._cacheTime;\n      }\n      this.chartParams = {\n        ...this.metricApiParams,\n        ...timeParams,\n      };\n    }\n  }\n\n  handleMetricDataPipe() {\n    return pipe(\n      tap(() => {\n        if (this.isCustomSeries) {\n          this.handleTimeParams();\n        }\n      }),\n      filter(\n        (res: MetricResult[]) =>\n          !!this.chartParams && (!!res || !this.indicator?.length),\n      ),\n      map((res: MetricResult[]) => {\n        const format = this.dataFormat || this.service.handelChartData;\n        // `fillNullChartData` prometheus 存在某个时间点未采集到数据的情况，这里为区分 未采集到数据为0的情况，这里前端根据时间段自动填充数据\n        // 后端 需要和 Prometheus API 保持兼容，还是在前端做处理填充\n        return format(res, this.indicator || [], this.dependOnData)?.map(\n          item => ({\n            ...item,\n            unit: this.unit,\n            values: fillNullChartData(\n              this.chartParams,\n              item.values as Array<ChartDataItem<{ x: number; y: number }>>,\n              this.stepLine,\n            ),\n          }),\n        );\n      }),\n      tap(res => {\n        this.handleDateAxisLabelFormats(this.chartParams);\n        this.handelChartStatus({\n          loading: false,\n          noData: hasNoData(res),\n        });\n        this.cdr.markForCheck();\n      }),\n      map(res =>\n        res?.length\n          ? res\n          : [\n              {\n                values: fillNullChartData(this.chartParams, [], this.stepLine),\n              },\n            ],\n      ),\n      withLatestFrom(this.adaptUnit$),\n      map(([res, _adaptUnit]) => {\n        if (_adaptUnit && !this.noData) {\n          const { base, unit } = this.service.adaptChartUnit(res, _adaptUnit);\n          this.unit = `unit_${unit}`;\n          if (typeof _adaptUnit === 'object') {\n            const { defaultPrefix = true, prefix } = _adaptUnit;\n            this.unit = defaultPrefix\n              ? `unit_${unit}`\n              : `${prefix || ''}${unit}`;\n          }\n          return (res as ChartData[]).map((item: ChartData) => ({\n            ...item,\n            unit: this.unit,\n            values: item.values.map(d => ({\n              ...d,\n              y: d.y ? d.y / base : d.y,\n            })),\n          }));\n        }\n        return res.map(item => ({ ...item, unit: this.unit })) as ChartData[];\n      }),\n      tap(() => {\n        this.dataCompleted.next();\n      }),\n      publishRef(),\n    );\n  }\n\n  refresh() {\n    this.reload$.next(null);\n    this.refreshEvent.next(null);\n  }\n\n  private handelChartStatus(status: ChartStatus) {\n    this._chartStatus$$.next({\n      ...status,\n    });\n  }\n\n  private handleDateAxisLabelFormats(params: MetricApiParams) {\n    if (params) {\n      const diff = params.end - params.start;\n      const m1 = 24 * 60 * 60;\n      const m3 = 3 * m1;\n      const m7 = 7 * m1;\n      const M_D_FORMAT = 'MM-DD';\n      const format =\n        diff >= m7\n          ? M_D_FORMAT\n          : diff < m7 && (diff >= m3 || diff > m1)\n          ? `${M_D_FORMAT} ${DATE_TIME_FORMAT_X_AXIS}`\n          : DATE_TIME_FORMAT_X_AXIS;\n      this.dateAxisLabelFormats = format;\n      // https://d3js.org.cn/document/d3-time-format/#api-reference\n      this.dateXAxisLabelFormats =\n        diff >= m7\n          ? '%m-%d'\n          : diff < m7 && (diff >= m3 || diff > m1)\n          ? `%m-%d %H:%M`\n          : '%H:%M';\n      this.cdr.detectChanges();\n    }\n  }\n}\n","<acl-view-zchart\n  [class.overflow-display]=\"!tooltipAppendToBody\"\n  [contextCallbackFunction]=\"contextCallbackFunction\"\n  [unit]=\"unit\"\n  [hideHeader]=\"hideHeader\"\n  [customNoDataTitle]=\"customNoDataTitle\"\n  [chartStatus]=\"status$ | async\"\n  [backgroundColor]=\"backgroundColor\"\n  [series]=\"series$ | async\"\n  [curveType]=\"curveType\"\n  [tooltipAppendToBody]=\"tooltipAppendToBody\"\n  [mode]=\"mode\"\n  [gridOffsetTop]=\"gridOffsetTop\"\n  [title]=\"title\"\n  [chartType]=\"chartType\"\n  [hideTitle]=\"hideTitle\"\n  [tooltipHide]=\"tooltipHide\"\n  [tooltipSortMethod]=\"tooltipSortMethod\"\n  [titleDescription]=\"titleDescription\"\n  [titleDescriptionContext]=\"titleDescriptionContext\"\n  [hideLegend]=\"(dependOnData && noData) || hideLegend\"\n  [dateAxisLabelFormats]=\"dateAxisLabelFormats\"\n  [enableZoom]=\"enableZoom\"\n  [stepLine]=\"stepLine\"\n  [rotated]=\"rotated\"\n  [rightOperation]=\"rightOperation\"\n  [leftOperation]=\"leftOperation\"\n  [leftOperationContext]=\"leftOperationContext\"\n  [legendTemplate]=\"legendTemplate\"\n  [legendSelectAllOperation]=\"legendSelectAllOperation\"\n  [legendSelectAllName]=\"legendSelectAllName\"\n  [yAccessor]=\"yAccessor || (yAccessor$ | async)\"\n  [xAccessor]=\"xAccessor\"\n  [yAxisMinStep]=\"yAxisMinStep\"\n  [hideTooltipUnit]=\"hideTooltipUnit\"\n  [tooltipTitleTemplate]=\"tooltipTitleTemplate\"\n  [tooltipAutoSort]=\"tooltipAutoSort\"\n  [tooltipTranslation]=\"tooltipTranslation\"\n  [tooltipPointNameTemplate]=\"tooltipPointNameTemplate\"\n  [tooltipPointTemplate]=\"tooltipPointTemplate\"\n  [tooltipPointTemplateContext]=\"tooltipPointTemplateContext\"\n  [xPlotLines]=\"xPlotLines\"\n  [xPlotEmpty]=\"xPlotEmpty\"\n  [yPlotLinesHide]=\"yPlotLinesHide\"\n  [yPlotLines]=\"yPlotLines\"\n  (mouseUpEvent)=\"mouseUpEvent.next($event)\"\n  (markClickEvent)=\"markClickEvent.next($event)\"\n  (refreshEvent)=\"refresh()\"\n>\n</acl-view-zchart>\n<!-- [tooltipPointFormat]=\"tooltipPointFormat\" -->\n"]}
|
|
346
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metric-chart.component.js","sourceRoot":"","sources":["../../../../../libs/common/src/metric-chart/metric-chart.component.ts","../../../../../libs/common/src/metric-chart/metric-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { TooltipContext } from '@alauda/chart';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n} from '@angular/core';\nimport { CurveFactory, CurveFactoryLineOnly } from 'd3';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  merge,\n  of,\n  pipe,\n  BehaviorSubject,\n  catchError,\n  filter,\n  map,\n  switchMap,\n  tap,\n  withLatestFrom,\n} from 'rxjs';\nimport { Chart, TooltipValue } from 'zz-chart';\n\nimport {\n  AreaPosition,\n  ContextItem,\n  DATE_TIME_FORMAT_X_AXIS,\n} from '../chart/public-api';\nimport { StringMap, ObservableInput, publishRef } from '../core/public-api';\nimport {\n  ChartData,\n  ChartDataItem,\n  ChartStatus,\n  XPlotLines,\n} from '../view-chart/public-api';\n\nimport { CommonChartService } from './common-chart.service';\nimport { MatchUnitParams, PICKER_TIME_RANGES } from './helpers';\nimport { Indicator, MetricApiParams, MetricResult } from './types';\nimport { checkInterval, fillNullChartData, hasNoData } from './utils';\n\n@Component({\n  selector: 'acl-metric-chart',\n  templateUrl: './metric-chart.component.html',\n  styleUrls: ['./metric-chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MetricChartComponent implements OnInit {\n  @Input() contextCallbackFunction: (context: Chart) => void;\n\n  @Input() backgroundColor: string;\n\n  @Input() hideHeader: boolean;\n\n  @Input() title: string | TemplateRef<unknown>;\n\n  @Input() hideTitle: boolean;\n\n  @Input() chartType: 'line' | 'area' | 'bar' | 'point' | 'stat' = 'area';\n\n  @Input() titleDescription: string | TemplateRef<unknown>;\n\n  @Input() titleDescriptionContext: StringMap;\n\n  @Input() unit: string;\n\n  @Input() tooltipAppendToBody = true;\n\n  @HostBinding('style.overflow')\n  get overflow() {\n    return !this.tooltipAppendToBody && 'unset';\n  }\n\n  @ObservableInput()\n  unit$!: Observable<string>;\n\n  @Input() indicator: Indicator[];\n\n  @Input() gridOffsetTop = 0;\n\n  @Input() yAxisMinStep?: number;\n\n  @Input() rotated: boolean;\n\n  @Input() barType: 'standard' | 'stacked' = 'standard';\n\n  @ObservableInput()\n  indicator$!: Observable<Indicator[]>;\n\n  @Input() metricApiParams: MetricApiParams;\n\n  @ObservableInput()\n  metricApiParams$!: Observable<MetricApiParams>;\n\n  @Input() tooltipPointNameTemplate: TemplateRef<unknown>;\n\n  @Input() tooltipPointTemplate: TemplateRef<unknown>;\n\n  @Input() legendTemplate: TemplateRef<unknown> | string;\n\n  @Input() legendSelectAllOperation = false;\n\n  @Input() legendSelectAllName: string;\n\n  @Input() tooltipHide: boolean;\n\n  @Input() tooltipPointFormat: (d: ContextItem) => number | string;\n\n  @Input() tooltipPointTemplateContext: { [key: string]: any };\n\n  @Input() tooltipColumnLayout: boolean;\n\n  @Input() hideLegend = false;\n\n  @Input() tooltipAutoSort: boolean;\n\n  @Input() tooltipSortMethod: (a: TooltipValue, b: TooltipValue) => number;\n\n  @Input() hideTooltipUnit: boolean;\n\n  @Input() leftOperation: TemplateRef<unknown>;\n\n  @Input() leftOperationContext: StringMap;\n\n  @Input() rightOperation: TemplateRef<unknown>;\n\n  @Input() mode: 'card' | 'default' = 'default';\n\n  @Input()\n  adaptUnit: boolean | MatchUnitParams;\n\n  @ObservableInput()\n  adaptUnit$!: Observable<boolean | MatchUnitParams>;\n\n  @Input()\n  percent: boolean;\n\n  @ObservableInput()\n  percent$!: Observable<boolean>;\n\n  @Input() dependOnData: boolean;\n\n  @Input() customNoDataTitle: TemplateRef<unknown> | string;\n\n  @Input() dataFormat: (\n    d: MetricResult[],\n    indicator: Indicator[],\n  ) => ChartData[];\n\n  @Input() customSeries!: MetricResult[];\n  @ObservableInput() customSeries$!: Observable<MetricResult[]>;\n\n  @Input() isCustomSeries: boolean;\n\n  series$: Observable<ChartData[]>;\n\n  @Input() chartStatus: ChartStatus;\n  @ObservableInput()\n  chartStatus$!: Observable<ChartStatus>;\n\n  @Input() tooltipTranslation = true;\n\n  @Input() xPlotLines: XPlotLines;\n\n  @Input() xPlotEmpty: boolean;\n\n  @Input() yPlotLines: TooltipContext;\n\n  @Input() yPlotLinesTooltip: TemplateRef<unknown>;\n\n  @Input() yPlotLinesTooltipContext: StringMap;\n\n  @Input() yPlotLinesHide = false;\n\n  @Input() enableZoom: boolean;\n\n  @Input() stepLine: boolean;\n\n  @Input() tooltipTitleTemplate: TemplateRef<unknown>;\n\n  @Input() yAccessor: (d: ChartDataItem) => number;\n\n  @Input() curveType: CurveFactory | CurveFactoryLineOnly;\n\n  @Output() mouseUpEvent = new EventEmitter<AreaPosition>();\n\n  @Output() markClickEvent = new EventEmitter<TooltipContext>();\n\n  @Output() refreshEvent = new EventEmitter();\n\n  @Output() dataCompleted = new EventEmitter<void>();\n\n  reload$ = new BehaviorSubject(null);\n\n  _chartStatus$$ = new Subject<ChartStatus>();\n  _status: ChartStatus = {};\n  status$ = merge(this.chartStatus$, this._chartStatus$$).pipe(\n    map(status => ({\n      ...this._status,\n      ...status,\n    })),\n    tap(status => (this._status = status)),\n    publishRef(),\n  );\n\n  noData: boolean;\n\n  dateAxisLabelFormats = DATE_TIME_FORMAT_X_AXIS;\n\n  dateXAxisLabelFormats = '%H:%M';\n\n  get xAccessor() {\n    return (d: ChartDataItem<{ x: number; y: number }>) => d.x * 1000;\n  }\n\n  yAccessor$ = this.percent$.pipe(\n    tap(percent => {\n      if (percent) {\n        this.unit = '%';\n      }\n    }),\n    map(percent => (d: ChartDataItem<{ x: number; y: number }>) => {\n      // prometheus 可能出现 Infinity情况，处理为 null\n      if (!Number.isFinite(d.y) || String(d.y).includes('Inf')) {\n        return null;\n      }\n      return percent && d.y ? +d.y * 100 : d.y === null ? d.y : +d.y;\n    }),\n  );\n\n  _cacheTime: MetricApiParams = {\n    start: PICKER_TIME_RANGES[1].startTime(),\n    end: PICKER_TIME_RANGES[1].endTime(),\n    step: PICKER_TIME_RANGES[1].step,\n  };\n\n  private chartParams: MetricApiParams;\n\n  constructor(\n    private readonly service: CommonChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit() {\n    if (this.metricApiParams) {\n      this._cacheTime = this.metricApiParams;\n    }\n\n    this.series$ = (\n      this.isCustomSeries ? this.customSeries$ : this.defaultSeries$\n    ).pipe(this.handleMetricDataPipe());\n  }\n\n  defaultSeries$: Observable<MetricResult[]> = combineLatest([\n    this.metricApiParams$,\n    this.indicator$,\n    this.reload$,\n  ]).pipe(\n    tap(([, indicator]) => {\n      this.handleTimeParams();\n      this.handleDateAxisLabelFormats(this.chartParams);\n      this.handelChartStatus({\n        loading: !!indicator?.length,\n        failed: false,\n        noData: !indicator?.length,\n      });\n    }),\n    switchMap(([_, indicator]) =>\n      indicator?.length && this.chartParams\n        ? this.service.requestChartData(this.chartParams, indicator).pipe(\n            catchError(() => {\n              this.handelChartStatus({ loading: false, failed: true });\n              return of(null);\n            }),\n          )\n        : of(null),\n    ),\n  );\n\n  handleTimeParams() {\n    let timeParams = this.metricApiParams;\n    if (timeParams) {\n      if (checkInterval(this.metricApiParams, this._cacheTime)) {\n        this._cacheTime = this.metricApiParams;\n      } else {\n        timeParams = this._cacheTime;\n      }\n      this.chartParams = {\n        ...this.metricApiParams,\n        ...timeParams,\n      };\n    }\n  }\n\n  handleMetricDataPipe() {\n    return pipe(\n      tap(() => {\n        if (this.isCustomSeries) {\n          this.handleTimeParams();\n        }\n      }),\n      filter(\n        (res: MetricResult[]) =>\n          !!this.chartParams && (!!res || !this.indicator?.length),\n      ),\n      map((res: MetricResult[]) => {\n        const format = this.dataFormat || this.service.handelChartData;\n        // `fillNullChartData` prometheus 存在某个时间点未采集到数据的情况，这里为区分 未采集到数据为0的情况，这里前端根据时间段自动填充数据\n        // 后端 需要和 Prometheus API 保持兼容，还是在前端做处理填充\n        return format(res, this.indicator || [], this.dependOnData)?.map(\n          item => ({\n            ...item,\n            unit: this.unit,\n            values: fillNullChartData(\n              this.chartParams,\n              item.values as Array<ChartDataItem<{ x: number; y: number }>>,\n              this.stepLine,\n            ),\n          }),\n        );\n      }),\n      tap(res => {\n        this.handleDateAxisLabelFormats(this.chartParams);\n        this.handelChartStatus({\n          loading: false,\n          noData: hasNoData(res),\n        });\n        this.cdr.markForCheck();\n      }),\n      map(res =>\n        res?.length\n          ? res\n          : [\n              {\n                values: fillNullChartData(this.chartParams, [], this.stepLine),\n              },\n            ],\n      ),\n      withLatestFrom(this.adaptUnit$),\n      map(([res, _adaptUnit]) => {\n        if (_adaptUnit && !this.noData) {\n          const { base, unit } = this.service.adaptChartUnit(res, _adaptUnit);\n          this.unit = `unit_${unit}`;\n          if (typeof _adaptUnit === 'object') {\n            const { defaultPrefix = true, prefix } = _adaptUnit;\n            this.unit = defaultPrefix\n              ? `unit_${unit}`\n              : `${prefix || ''}${unit}`;\n          }\n          return (res as ChartData[]).map((item: ChartData) => ({\n            ...item,\n            unit: this.unit,\n            values: item.values.map(d => ({\n              ...d,\n              y: d.y ? d.y / base : d.y,\n            })),\n          }));\n        }\n        return res.map(item => ({ ...item, unit: this.unit })) as ChartData[];\n      }),\n      tap(() => {\n        this.dataCompleted.next();\n      }),\n      publishRef(),\n    );\n  }\n\n  refresh() {\n    this.reload$.next(null);\n    this.refreshEvent.next(null);\n  }\n\n  private handelChartStatus(status: ChartStatus) {\n    this._chartStatus$$.next({\n      ...status,\n    });\n  }\n\n  private handleDateAxisLabelFormats(params: MetricApiParams) {\n    if (params) {\n      const diff = params.end - params.start;\n      const m1 = 24 * 60 * 60;\n      const m3 = 3 * m1;\n      const m7 = 7 * m1;\n      const M_D_FORMAT = 'MM-DD';\n      const format =\n        diff >= m7\n          ? M_D_FORMAT\n          : diff < m7 && (diff >= m3 || diff > m1)\n          ? `${M_D_FORMAT} ${DATE_TIME_FORMAT_X_AXIS}`\n          : DATE_TIME_FORMAT_X_AXIS;\n      this.dateAxisLabelFormats = format;\n      // https://d3js.org.cn/document/d3-time-format/#api-reference\n      this.dateXAxisLabelFormats =\n        diff >= m7\n          ? '%m-%d'\n          : diff < m7 && (diff >= m3 || diff > m1)\n          ? `%m-%d %H:%M`\n          : '%H:%M';\n      this.cdr.detectChanges();\n    }\n  }\n}\n","<acl-view-zchart\n  [class.overflow-display]=\"!tooltipAppendToBody\"\n  [contextCallbackFunction]=\"contextCallbackFunction\"\n  [unit]=\"unit\"\n  [hideHeader]=\"hideHeader\"\n  [customNoDataTitle]=\"customNoDataTitle\"\n  [chartStatus]=\"status$ | async\"\n  [backgroundColor]=\"backgroundColor\"\n  [series]=\"series$ | async\"\n  [curveType]=\"curveType\"\n  [tooltipAppendToBody]=\"tooltipAppendToBody\"\n  [mode]=\"mode\"\n  [gridOffsetTop]=\"gridOffsetTop\"\n  [title]=\"title\"\n  [chartType]=\"chartType\"\n  [hideTitle]=\"hideTitle\"\n  [tooltipHide]=\"tooltipHide\"\n  [tooltipSortMethod]=\"tooltipSortMethod\"\n  [titleDescription]=\"titleDescription\"\n  [titleDescriptionContext]=\"titleDescriptionContext\"\n  [hideLegend]=\"(dependOnData && noData) || hideLegend\"\n  [dateAxisLabelFormats]=\"dateAxisLabelFormats\"\n  [enableZoom]=\"enableZoom\"\n  [stepLine]=\"stepLine\"\n  [rotated]=\"rotated\"\n  [rightOperation]=\"rightOperation\"\n  [leftOperation]=\"leftOperation\"\n  [leftOperationContext]=\"leftOperationContext\"\n  [legendTemplate]=\"legendTemplate\"\n  [legendSelectAllOperation]=\"legendSelectAllOperation\"\n  [legendSelectAllName]=\"legendSelectAllName\"\n  [yAccessor]=\"yAccessor || (yAccessor$ | async)\"\n  [xAccessor]=\"xAccessor\"\n  [yAxisMinStep]=\"yAxisMinStep\"\n  [hideTooltipUnit]=\"hideTooltipUnit\"\n  [tooltipTitleTemplate]=\"tooltipTitleTemplate\"\n  [tooltipAutoSort]=\"tooltipAutoSort\"\n  [tooltipTranslation]=\"tooltipTranslation\"\n  [tooltipPointNameTemplate]=\"tooltipPointNameTemplate\"\n  [tooltipPointTemplate]=\"tooltipPointTemplate\"\n  [tooltipPointTemplateContext]=\"tooltipPointTemplateContext\"\n  [xPlotLines]=\"xPlotLines\"\n  [xPlotEmpty]=\"xPlotEmpty\"\n  [yPlotLinesHide]=\"yPlotLinesHide\"\n  [yPlotLines]=\"yPlotLines\"\n  (mouseUpEvent)=\"mouseUpEvent.next($event)\"\n  (markClickEvent)=\"markClickEvent.next($event)\"\n  (refreshEvent)=\"refresh()\"\n>\n</acl-view-zchart>\n<!-- [tooltipPointFormat]=\"tooltipPointFormat\" -->\n"]}
|
|
@@ -989,7 +989,7 @@ export class MultiSearchActionInputComponent extends BaseResourceFormComponent {
|
|
|
989
989
|
AsyncPipe,
|
|
990
990
|
TranslateModule, i1.TranslatePipe, CheckboxComponent,
|
|
991
991
|
NgTemplateOutlet,
|
|
992
|
-
FormsModule, i2.DefaultValueAccessor, i2.NgControlStatus, i2.MaxLengthValidator, i2.NgModel], styles: ["[_nghost-%COMP%]{display:block;padding-top:5px}.search-input[_ngcontent-%COMP%]{border:none;box-shadow:none!important;height:22px}.mock-input[_ngcontent-%COMP%]{width:1px!important;flex-shrink:0;padding:0;margin-left:7px} .multi-search-dropdown{padding:0!important;margin-top:8px!important;cursor:pointer;max-height:284px;overflow-y:auto} .multi-search-dropdown ul .dropdown-content:first-child{border:none;padding-top:0;margin-top:0} .multi-search-dropdown .cursor-light{background-color:rgb(var(--aui-color-p-6))} .multi-search-dropdown .is-multi-value-select{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-p-2))} .multi-search-dropdown .search-dropdown-item{padding:0 8px} .multi-search-dropdown .search-dropdown-item:hover{background-color:rgb(var(--aui-color-p-6))} .multi-search-dropdown .search-dropdown-item .multi-item{display:flex;height:28px;align-items:center} .multi-search-dropdown .search-dropdown-item .multi-item aui-checkbox{width:24px} .multi-search-dropdown .search-dropdown-item-label{height:28px;line-height:28px;white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis} .multi-search-dropdown .dropdown-group-label{font-size:12px;color:rgb(var(--aui-color-n-4));padding-bottom:8px;padding-top:12px;margin-top:12px;margin-left:8px;margin-right:8px;border-top:1px solid rgb(var(--aui-color-n-8));white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis} .multi-search-dropdown .no-match-categories-tip{text-align:center;font-size:12px;color:rgb(var(--aui-color-n-4));border-bottom:1px solid rgb(var(--aui-color-n-8));margin-left:8px;margin-right:8px;margin-bottom:8px;padding-top:4px;padding-bottom:12px} .multi-search-dropdown .select-all{border-bottom:1px solid rgb(var(--aui-color-n-8))!important;margin-bottom:8px}"], changeDetection: 0 }); }
|
|
992
|
+
FormsModule, i2.DefaultValueAccessor, i2.NgControlStatus, i2.MaxLengthValidator, i2.NgModel], styles: ["[_nghost-%COMP%]{display:block;padding-top:5px}.search-input[_ngcontent-%COMP%]{border:none;box-shadow:none!important;height:22px}.mock-input[_ngcontent-%COMP%]{width:1px!important;flex-shrink:0;padding:0;margin-left:7px} .multi-search-dropdown{padding:0!important;margin-top:8px!important;cursor:pointer;max-height:284px;overflow-y:auto} .multi-search-dropdown ul .dropdown-content:first-child{border:none;padding-top:0;margin-top:0} .multi-search-dropdown .cursor-light{background-color:rgb(var(--aui-color-p-6))} .multi-search-dropdown .is-multi-value-select{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-p-2))} .multi-search-dropdown .search-dropdown-item{padding:0 8px} .multi-search-dropdown .search-dropdown-item:hover{background-color:rgb(var(--aui-color-p-6))} .multi-search-dropdown .search-dropdown-item .multi-item{display:flex;height:28px;align-items:center} .multi-search-dropdown .search-dropdown-item .multi-item aui-checkbox{width:24px} .multi-search-dropdown .search-dropdown-item-label{height:28px;line-height:28px;white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis;font-size:var(--aui-font-size-m)} .multi-search-dropdown .dropdown-group-label{font-size:12px;color:rgb(var(--aui-color-n-4));padding-bottom:8px;padding-top:12px;margin-top:12px;margin-left:8px;margin-right:8px;border-top:1px solid rgb(var(--aui-color-n-8));white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis} .multi-search-dropdown .no-match-categories-tip{text-align:center;font-size:12px;color:rgb(var(--aui-color-n-4));border-bottom:1px solid rgb(var(--aui-color-n-8));margin-left:8px;margin-right:8px;margin-bottom:8px;padding-top:4px;padding-bottom:12px} .multi-search-dropdown .select-all{border-bottom:1px solid rgb(var(--aui-color-n-8))!important;margin-bottom:8px}"], changeDetection: 0 }); }
|
|
993
993
|
}
|
|
994
994
|
__decorate([
|
|
995
995
|
ObservableInput(),
|
|
@@ -1017,7 +1017,7 @@ __decorate([
|
|
|
1017
1017
|
CheckboxComponent,
|
|
1018
1018
|
NgTemplateOutlet,
|
|
1019
1019
|
FormsModule,
|
|
1020
|
-
], template: "<div class=\"tw-flex tw-items-center tw-text-m\">\n <ng-container *ngIf=\"form.value as activeCondition\">\n <span\n class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n (click)=\"activeConditionClick(); $event.stopPropagation()\"\n >\n {{ activeCondition | pure: getConditionLabel }}\n </span>\n <span\n *ngIf=\"activeCondition.operator\"\n class=\"tw-ml-6\"\n (click)=\"activeOperatorClick(); $event.stopPropagation()\"\n >\n {{ activeCondition.operator }}\n </span>\n <span\n *ngIf=\"!isEditing\"\n class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n (click)=\"activeValueClick(); $event.stopPropagation()\"\n >\n {{ getValueContent(activeCondition) }}\n </span>\n </ng-container>\n <input\n class=\"search-input\"\n [ngClass]=\"{\n 'mock-input': (!isEditing && !isConditionSelecting) || isOperatorSelecting,\n }\"\n [maxlength]=\"isOperatorSelecting ? 0 : MAX_SAFE_INTEGER\"\n aui-input\n #inputRef\n #toolTipRef=\"auiTooltip\"\n [placeholder]=\"isConditionSelecting ? placeholder : ''\"\n [(ngModel)]=\"conditionsModel\"\n (ngModelChange)=\"conditionsModel$$.next($event)\"\n (keydown)=\"inputKeydown($event)\"\n (focus)=\"inputFocus()\"\n [auiTooltip]=\"templateRef\"\n auiTooltipAnimType=\"none\"\n auiTooltipTrigger=\"manual\"\n auiTooltipType=\"info\"\n auiTooltipClass=\"multi-search-dropdown\"\n auiTooltipPosition=\"bottom start\"\n />\n</div>\n\n<ng-template #templateRef>\n <div\n class=\"tw-py-8\"\n (mousedown)=\"$event.preventDefault()\"\n (click)=\"$event.stopPropagation()\"\n >\n <!-- \u7C7B\u76EE\u9009\u62E9 -->\n <ng-container\n *ngIf=\"isConditionSelecting && (conditionsShouldShow$ | async)\"\n >\n <ul\n *ngIf=\"hasFilteredConditions$ | async; else nonFilteredCategories\"\n class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n >\n <ng-container\n [ngTemplateOutlet]=\"categoriesTemp\"\n [ngTemplateOutletContext]=\"{\n normal: (normalConditions$ | async),\n groups: groupConditions$ | async\n }\"\n ></ng-container>\n </ul>\n\n <ng-template #nonFilteredCategories>\n <ul class=\"tw-min-w-[260px] tw-max-w-[400px]\">\n <div class=\"no-match-categories-tip\">\n {{ 'no_match_categories_tip' | translate }}\n </div>\n <ng-container\n [ngTemplateOutlet]=\"categoriesTemp\"\n [ngTemplateOutletContext]=\"{\n normal: normalConditionsResource$ | async,\n groups: groupConditionsResource$ | async\n }\"\n ></ng-container>\n </ul>\n </ng-template>\n\n <ng-template\n #categoriesTemp\n let-normal=\"normal\"\n let-groups=\"groups\"\n >\n <ng-container\n [ngTemplateOutlet]=\"liConditionTemp\"\n [ngTemplateOutletContext]=\"{ conditions: normal }\"\n ></ng-container>\n\n <ng-container *ngFor=\"let group of groups\">\n <ng-container *ngIf=\"group.member?.length\">\n <div\n [title]=\"group.group\"\n class=\"dropdown-group-label dropdown-content\"\n >\n {{ group.group }}\n </div>\n\n <ng-container\n [ngTemplateOutlet]=\"liConditionTemp\"\n [ngTemplateOutletContext]=\"{ conditions: group.member }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"form.value as activeCondition\">\n <!-- operator\u9009\u62E9 -->\n <ng-container *ngIf=\"isOperatorSelecting\">\n <ul class=\"tw-min-w-[160px]\">\n <li\n (click)=\"selectActiveOperator($any(operator))\"\n *ngFor=\"\n let operator of activeCondition.operators || [DEFAULT_OPERATOR]\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect: operator === conditionsModel,\n label: operator\n }\"\n >\n </ng-container>\n </li>\n </ul>\n </ng-container>\n\n <!-- \u5177\u4F53\u6761\u4EF6\u9009\u62E9 -->\n <ng-container *ngIf=\"isValueSelecting\">\n <ul\n *ngIf=\"\n activeCondition\n | pure: hasFilteredValues:conditionsModel:activeCondition.isMulti\n \"\n class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n >\n <li\n *ngIf=\"activeCondition.allowSelectAll && activeCondition.isMulti\"\n class=\"dropdown-content select-all\"\n >\n <div\n class=\"search-dropdown-item\"\n [ngClass]=\"{\n 'tw-text-p-2': isSelectAll,\n 'tw-bg-p-6': isSelectAll\n }\"\n (click)=\"selectAllClick()\"\n >\n <div class=\"multi-item\">\n <aui-checkbox\n [value]=\"isSelectAll\"\n [indeterminate]=\"isIndeterminate\"\n ></aui-checkbox>\n <div class=\"search-dropdown-item-label\">\n {{ 'all' | translate }}\n </div>\n </div>\n </div>\n </li>\n <ng-container\n [ngTemplateOutlet]=\"liValueTemp\"\n [ngTemplateOutletContext]=\"{\n values:\n activeCondition\n | pure: getNormalValues:conditionsModel:activeCondition.isMulti,\n activeCondition: activeCondition\n }\"\n >\n </ng-container>\n\n <ng-container\n *ngFor=\"\n let group of activeCondition\n | pure: getValuesGroup:conditionsModel:activeCondition.isMulti\n \"\n >\n <ng-container *ngIf=\"group.member?.length\">\n <div\n [title]=\"group.group\"\n class=\"dropdown-group-label dropdown-content\"\n >\n {{ group.group }}\n </div>\n\n <ng-container\n [ngTemplateOutlet]=\"liValueTemp\"\n [ngTemplateOutletContext]=\"{\n values: group.member,\n activeCondition: activeCondition\n }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ul>\n </ng-container>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template\n #liConditionTemp\n let-conditions=\"conditions\"\n>\n <li\n class=\"dropdown-content\"\n *ngFor=\"let condition of conditions\"\n (click)=\"selectActiveCondition(condition)\"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect:\n condition\n | pure: getConditionLabel\n | pure: isConditionSelected:conditionsModel,\n label: condition | pure: getConditionLabel\n }\"\n >\n </ng-container>\n </li>\n</ng-template>\n\n<ng-template\n #liValueTemp\n let-values=\"values\"\n let-activeCondition=\"activeCondition\"\n>\n <li\n class=\"dropdown-content\"\n *ngFor=\"let value of values\"\n (click)=\"\n selectValue(value, activeCondition.isMulti);\n $event.stopPropagation();\n $event.preventDefault()\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect:\n value\n | pure: getValueLabel\n | pure\n : isValueSelected\n : conditionsModel || (form.value | pure: getValueContent)\n : activeCondition,\n label: value | pure: getValueLabel,\n isMulti: activeCondition.isMulti\n }\"\n >\n </ng-container>\n </li>\n</ng-template>\n\n<ng-template\n #basicLiContentTemp\n let-isSelect=\"isSelect\"\n let-label=\"label\"\n let-isMulti=\"isMulti\"\n>\n <div\n [class]=\"DROPDOWN_ITEM_CLASS\"\n [ngClass]=\"{\n 'is-multi-value-select': isSelect,\n }\"\n >\n <div\n class=\"multi-item\"\n *ngIf=\"isMulti\"\n >\n <aui-checkbox [value]=\"isSelect\"></aui-checkbox>\n <div\n [title]=\"label\"\n class=\"search-dropdown-item-label\"\n >\n {{ label }}\n </div>\n </div>\n <div\n [title]=\"label\"\n class=\"search-dropdown-item-label\"\n *ngIf=\"!isMulti\"\n >\n {{ label }}\n </div>\n </div>\n</ng-template>\n", styles: [":host{display:block;padding-top:5px}.search-input{border:none;box-shadow:none!important;height:22px}.mock-input{width:1px!important;flex-shrink:0;padding:0;margin-left:7px}::ng-deep .multi-search-dropdown{padding:0!important;margin-top:8px!important;cursor:pointer;max-height:284px;overflow-y:auto}::ng-deep .multi-search-dropdown ul .dropdown-content:first-child{border:none;padding-top:0;margin-top:0}::ng-deep .multi-search-dropdown .cursor-light{background-color:rgb(var(--aui-color-p-6))}::ng-deep .multi-search-dropdown .is-multi-value-select{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-p-2))}::ng-deep .multi-search-dropdown .search-dropdown-item{padding:0 8px}::ng-deep .multi-search-dropdown .search-dropdown-item:hover{background-color:rgb(var(--aui-color-p-6))}::ng-deep .multi-search-dropdown .search-dropdown-item .multi-item{display:flex;height:28px;align-items:center}::ng-deep .multi-search-dropdown .search-dropdown-item .multi-item aui-checkbox{width:24px}::ng-deep .multi-search-dropdown .search-dropdown-item-label{height:28px;line-height:28px;white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis}::ng-deep .multi-search-dropdown .dropdown-group-label{font-size:12px;color:rgb(var(--aui-color-n-4));padding-bottom:8px;padding-top:12px;margin-top:12px;margin-left:8px;margin-right:8px;border-top:1px solid rgb(var(--aui-color-n-8));white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis}::ng-deep .multi-search-dropdown .no-match-categories-tip{text-align:center;font-size:12px;color:rgb(var(--aui-color-n-4));border-bottom:1px solid rgb(var(--aui-color-n-8));margin-left:8px;margin-right:8px;margin-bottom:8px;padding-top:4px;padding-bottom:12px}::ng-deep .multi-search-dropdown .select-all{border-bottom:1px solid rgb(var(--aui-color-n-8))!important;margin-bottom:8px}\n"] }]
|
|
1020
|
+
], template: "<div class=\"tw-flex tw-items-center tw-text-m\">\n <ng-container *ngIf=\"form.value as activeCondition\">\n <span\n class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n (click)=\"activeConditionClick(); $event.stopPropagation()\"\n >\n {{ activeCondition | pure: getConditionLabel }}\n </span>\n <span\n *ngIf=\"activeCondition.operator\"\n class=\"tw-ml-6\"\n (click)=\"activeOperatorClick(); $event.stopPropagation()\"\n >\n {{ activeCondition.operator }}\n </span>\n <span\n *ngIf=\"!isEditing\"\n class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n (click)=\"activeValueClick(); $event.stopPropagation()\"\n >\n {{ getValueContent(activeCondition) }}\n </span>\n </ng-container>\n <input\n class=\"search-input\"\n [ngClass]=\"{\n 'mock-input': (!isEditing && !isConditionSelecting) || isOperatorSelecting,\n }\"\n [maxlength]=\"isOperatorSelecting ? 0 : MAX_SAFE_INTEGER\"\n aui-input\n #inputRef\n #toolTipRef=\"auiTooltip\"\n [placeholder]=\"isConditionSelecting ? placeholder : ''\"\n [(ngModel)]=\"conditionsModel\"\n (ngModelChange)=\"conditionsModel$$.next($event)\"\n (keydown)=\"inputKeydown($event)\"\n (focus)=\"inputFocus()\"\n [auiTooltip]=\"templateRef\"\n auiTooltipAnimType=\"none\"\n auiTooltipTrigger=\"manual\"\n auiTooltipType=\"info\"\n auiTooltipClass=\"multi-search-dropdown\"\n auiTooltipPosition=\"bottom start\"\n />\n</div>\n\n<ng-template #templateRef>\n <div\n class=\"tw-py-8\"\n (mousedown)=\"$event.preventDefault()\"\n (click)=\"$event.stopPropagation()\"\n >\n <!-- \u7C7B\u76EE\u9009\u62E9 -->\n <ng-container\n *ngIf=\"isConditionSelecting && (conditionsShouldShow$ | async)\"\n >\n <ul\n *ngIf=\"hasFilteredConditions$ | async; else nonFilteredCategories\"\n class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n >\n <ng-container\n [ngTemplateOutlet]=\"categoriesTemp\"\n [ngTemplateOutletContext]=\"{\n normal: (normalConditions$ | async),\n groups: groupConditions$ | async\n }\"\n ></ng-container>\n </ul>\n\n <ng-template #nonFilteredCategories>\n <ul class=\"tw-min-w-[260px] tw-max-w-[400px]\">\n <div class=\"no-match-categories-tip\">\n {{ 'no_match_categories_tip' | translate }}\n </div>\n <ng-container\n [ngTemplateOutlet]=\"categoriesTemp\"\n [ngTemplateOutletContext]=\"{\n normal: normalConditionsResource$ | async,\n groups: groupConditionsResource$ | async\n }\"\n ></ng-container>\n </ul>\n </ng-template>\n\n <ng-template\n #categoriesTemp\n let-normal=\"normal\"\n let-groups=\"groups\"\n >\n <ng-container\n [ngTemplateOutlet]=\"liConditionTemp\"\n [ngTemplateOutletContext]=\"{ conditions: normal }\"\n ></ng-container>\n\n <ng-container *ngFor=\"let group of groups\">\n <ng-container *ngIf=\"group.member?.length\">\n <div\n [title]=\"group.group\"\n class=\"dropdown-group-label dropdown-content\"\n >\n {{ group.group }}\n </div>\n\n <ng-container\n [ngTemplateOutlet]=\"liConditionTemp\"\n [ngTemplateOutletContext]=\"{ conditions: group.member }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"form.value as activeCondition\">\n <!-- operator\u9009\u62E9 -->\n <ng-container *ngIf=\"isOperatorSelecting\">\n <ul class=\"tw-min-w-[160px]\">\n <li\n (click)=\"selectActiveOperator($any(operator))\"\n *ngFor=\"\n let operator of activeCondition.operators || [DEFAULT_OPERATOR]\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect: operator === conditionsModel,\n label: operator\n }\"\n >\n </ng-container>\n </li>\n </ul>\n </ng-container>\n\n <!-- \u5177\u4F53\u6761\u4EF6\u9009\u62E9 -->\n <ng-container *ngIf=\"isValueSelecting\">\n <ul\n *ngIf=\"\n activeCondition\n | pure: hasFilteredValues:conditionsModel:activeCondition.isMulti\n \"\n class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n >\n <li\n *ngIf=\"activeCondition.allowSelectAll && activeCondition.isMulti\"\n class=\"dropdown-content select-all\"\n >\n <div\n class=\"search-dropdown-item\"\n [ngClass]=\"{\n 'tw-text-p-2': isSelectAll,\n 'tw-bg-p-6': isSelectAll\n }\"\n (click)=\"selectAllClick()\"\n >\n <div class=\"multi-item\">\n <aui-checkbox\n [value]=\"isSelectAll\"\n [indeterminate]=\"isIndeterminate\"\n ></aui-checkbox>\n <div class=\"search-dropdown-item-label\">\n {{ 'all' | translate }}\n </div>\n </div>\n </div>\n </li>\n <ng-container\n [ngTemplateOutlet]=\"liValueTemp\"\n [ngTemplateOutletContext]=\"{\n values:\n activeCondition\n | pure: getNormalValues:conditionsModel:activeCondition.isMulti,\n activeCondition: activeCondition\n }\"\n >\n </ng-container>\n\n <ng-container\n *ngFor=\"\n let group of activeCondition\n | pure: getValuesGroup:conditionsModel:activeCondition.isMulti\n \"\n >\n <ng-container *ngIf=\"group.member?.length\">\n <div\n [title]=\"group.group\"\n class=\"dropdown-group-label dropdown-content\"\n >\n {{ group.group }}\n </div>\n\n <ng-container\n [ngTemplateOutlet]=\"liValueTemp\"\n [ngTemplateOutletContext]=\"{\n values: group.member,\n activeCondition: activeCondition\n }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ul>\n </ng-container>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template\n #liConditionTemp\n let-conditions=\"conditions\"\n>\n <li\n class=\"dropdown-content\"\n *ngFor=\"let condition of conditions\"\n (click)=\"selectActiveCondition(condition)\"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect:\n condition\n | pure: getConditionLabel\n | pure: isConditionSelected:conditionsModel,\n label: condition | pure: getConditionLabel\n }\"\n >\n </ng-container>\n </li>\n</ng-template>\n\n<ng-template\n #liValueTemp\n let-values=\"values\"\n let-activeCondition=\"activeCondition\"\n>\n <li\n class=\"dropdown-content\"\n *ngFor=\"let value of values\"\n (click)=\"\n selectValue(value, activeCondition.isMulti);\n $event.stopPropagation();\n $event.preventDefault()\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect:\n value\n | pure: getValueLabel\n | pure\n : isValueSelected\n : conditionsModel || (form.value | pure: getValueContent)\n : activeCondition,\n label: value | pure: getValueLabel,\n isMulti: activeCondition.isMulti\n }\"\n >\n </ng-container>\n </li>\n</ng-template>\n\n<ng-template\n #basicLiContentTemp\n let-isSelect=\"isSelect\"\n let-label=\"label\"\n let-isMulti=\"isMulti\"\n>\n <div\n [class]=\"DROPDOWN_ITEM_CLASS\"\n [ngClass]=\"{\n 'is-multi-value-select': isSelect,\n }\"\n >\n <div\n class=\"multi-item\"\n *ngIf=\"isMulti\"\n >\n <aui-checkbox [value]=\"isSelect\"></aui-checkbox>\n <div\n [title]=\"label\"\n class=\"search-dropdown-item-label\"\n >\n {{ label }}\n </div>\n </div>\n <div\n [title]=\"label\"\n class=\"search-dropdown-item-label\"\n *ngIf=\"!isMulti\"\n >\n {{ label }}\n </div>\n </div>\n</ng-template>\n", styles: [":host{display:block;padding-top:5px}.search-input{border:none;box-shadow:none!important;height:22px}.mock-input{width:1px!important;flex-shrink:0;padding:0;margin-left:7px}::ng-deep .multi-search-dropdown{padding:0!important;margin-top:8px!important;cursor:pointer;max-height:284px;overflow-y:auto}::ng-deep .multi-search-dropdown ul .dropdown-content:first-child{border:none;padding-top:0;margin-top:0}::ng-deep .multi-search-dropdown .cursor-light{background-color:rgb(var(--aui-color-p-6))}::ng-deep .multi-search-dropdown .is-multi-value-select{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-p-2))}::ng-deep .multi-search-dropdown .search-dropdown-item{padding:0 8px}::ng-deep .multi-search-dropdown .search-dropdown-item:hover{background-color:rgb(var(--aui-color-p-6))}::ng-deep .multi-search-dropdown .search-dropdown-item .multi-item{display:flex;height:28px;align-items:center}::ng-deep .multi-search-dropdown .search-dropdown-item .multi-item aui-checkbox{width:24px}::ng-deep .multi-search-dropdown .search-dropdown-item-label{height:28px;line-height:28px;white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis;font-size:var(--aui-font-size-m)}::ng-deep .multi-search-dropdown .dropdown-group-label{font-size:12px;color:rgb(var(--aui-color-n-4));padding-bottom:8px;padding-top:12px;margin-top:12px;margin-left:8px;margin-right:8px;border-top:1px solid rgb(var(--aui-color-n-8));white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis}::ng-deep .multi-search-dropdown .no-match-categories-tip{text-align:center;font-size:12px;color:rgb(var(--aui-color-n-4));border-bottom:1px solid rgb(var(--aui-color-n-8));margin-left:8px;margin-right:8px;margin-bottom:8px;padding-top:4px;padding-bottom:12px}::ng-deep .multi-search-dropdown .select-all{border-bottom:1px solid rgb(var(--aui-color-n-8))!important;margin-bottom:8px}\n"] }]
|
|
1021
1021
|
}], function () { return [{ type: i0.Injector }, { type: i3.MultiSearchComponent, decorators: [{
|
|
1022
1022
|
type: Inject,
|
|
1023
1023
|
args: [forwardRef(() => MultiSearchComponent)]
|
|
@@ -2,8 +2,14 @@
|
|
|
2
2
|
* @packageDocumentation
|
|
3
3
|
* @module notification
|
|
4
4
|
*/
|
|
5
|
+
import { ButtonModule } from '@alauda/ui';
|
|
6
|
+
import { NgIf } from '@angular/common';
|
|
5
7
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
8
|
+
import { CodeModule } from '../../code/code.module';
|
|
9
|
+
import { TranslateModule } from '../../translate/translate.module';
|
|
6
10
|
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../../translate/translate.pipe";
|
|
12
|
+
import * as i2 from "@alauda/ui";
|
|
7
13
|
function FeedbackNotificationComponent_main_0_pre_1_Template(rf, ctx) { if (rf & 1) {
|
|
8
14
|
i0.ɵɵelement(0, "pre", 4);
|
|
9
15
|
} if (rf & 2) {
|
|
@@ -58,7 +64,7 @@ export class FeedbackNotificationComponent {
|
|
|
58
64
|
this.onSecondary = new EventEmitter();
|
|
59
65
|
}
|
|
60
66
|
static { this.ɵfac = function FeedbackNotificationComponent_Factory(t) { return new (t || FeedbackNotificationComponent)(); }; }
|
|
61
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FeedbackNotificationComponent, selectors: [["ng-component"]], inputs: { primary: "primary", secondary: "secondary", content: "content", pre: "pre" }, outputs: { onPrimary: "onPrimary", onSecondary: "onSecondary" }, decls: 4, vars: 3, consts: [[4, "ngIf"], ["aui-button", "primary", "type", "button", "size", "mini", 3, "click", 4, "ngIf"], ["aui-button", "default", "type", "button", "size", "mini", 3, "click", 4, "ngIf"], [3, "innerHTML", 4, "ngIf"], [3, "innerHTML"], ["aui-button", "primary", "type", "button", "size", "mini", 3, "click"], ["aui-button", "default", "type", "button", "size", "mini", 3, "click"]], template: function FeedbackNotificationComponent_Template(rf, ctx) { if (rf & 1) {
|
|
67
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FeedbackNotificationComponent, selectors: [["ng-component"]], inputs: { primary: "primary", secondary: "secondary", content: "content", pre: "pre" }, outputs: { onPrimary: "onPrimary", onSecondary: "onSecondary" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 4, vars: 3, consts: [[4, "ngIf"], ["aui-button", "primary", "type", "button", "size", "mini", 3, "click", 4, "ngIf"], ["aui-button", "default", "type", "button", "size", "mini", 3, "click", 4, "ngIf"], [3, "innerHTML", 4, "ngIf"], [3, "innerHTML"], ["aui-button", "primary", "type", "button", "size", "mini", 3, "click"], ["aui-button", "default", "type", "button", "size", "mini", 3, "click"]], template: function FeedbackNotificationComponent_Template(rf, ctx) { if (rf & 1) {
|
|
62
68
|
i0.ɵɵtemplate(0, FeedbackNotificationComponent_main_0_Template, 3, 2, "main", 0);
|
|
63
69
|
i0.ɵɵelementStart(1, "footer");
|
|
64
70
|
i0.ɵɵtemplate(2, FeedbackNotificationComponent_button_2_Template, 3, 3, "button", 1);
|
|
@@ -70,11 +76,11 @@ export class FeedbackNotificationComponent {
|
|
|
70
76
|
i0.ɵɵproperty("ngIf", ctx.primary);
|
|
71
77
|
i0.ɵɵadvance(1);
|
|
72
78
|
i0.ɵɵproperty("ngIf", ctx.secondary);
|
|
73
|
-
} }, styles: ["[_nghost-%COMP%]{display:flex;flex-direction:column;max-height:150px}main[_ngcontent-%COMP%]{display:flex;flex:1;overflow:hidden}main[_ngcontent-%COMP%] > *[_ngcontent-%COMP%]{flex:1;overflow:auto}footer[_ngcontent-%COMP%]{padding-top:12px}"], changeDetection: 0 }); }
|
|
79
|
+
} }, dependencies: [NgIf, TranslateModule, i1.TranslatePipe, ButtonModule, i2.ButtonComponent, CodeModule], styles: ["[_nghost-%COMP%]{display:flex;flex-direction:column;max-height:150px}main[_ngcontent-%COMP%]{display:flex;flex:1;overflow:hidden}main[_ngcontent-%COMP%] > *[_ngcontent-%COMP%]{flex:1;overflow:auto}footer[_ngcontent-%COMP%]{padding-top:12px}"], changeDetection: 0 }); }
|
|
74
80
|
}
|
|
75
81
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FeedbackNotificationComponent, [{
|
|
76
82
|
type: Component,
|
|
77
|
-
args: [{ preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, template: "<main *ngIf=\"content\">\n <pre\n *ngIf=\"pre\"\n [innerHTML]=\"content\"\n ></pre>\n <div\n *ngIf=\"!pre\"\n [innerHTML]=\"content\"\n ></div>\n</main>\n<footer>\n <button\n *ngIf=\"primary\"\n aui-button=\"primary\"\n type=\"button\"\n size=\"mini\"\n (click)=\"onPrimary.emit()\"\n >\n {{ primary | translate }}\n </button>\n <button\n *ngIf=\"secondary\"\n aui-button=\"default\"\n type=\"button\"\n size=\"mini\"\n (click)=\"onSecondary.emit()\"\n >\n {{ secondary | translate }}\n </button>\n</footer>\n", styles: [":host{display:flex;flex-direction:column;max-height:150px}main{display:flex;flex:1;overflow:hidden}main>*{flex:1;overflow:auto}footer{padding-top:12px}\n"] }]
|
|
83
|
+
args: [{ standalone: true, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, imports: [NgIf, TranslateModule, ButtonModule, CodeModule], template: "<main *ngIf=\"content\">\n <pre\n *ngIf=\"pre\"\n [innerHTML]=\"content\"\n ></pre>\n <div\n *ngIf=\"!pre\"\n [innerHTML]=\"content\"\n ></div>\n</main>\n<footer>\n <button\n *ngIf=\"primary\"\n aui-button=\"primary\"\n type=\"button\"\n size=\"mini\"\n (click)=\"onPrimary.emit()\"\n >\n {{ primary | translate }}\n </button>\n <button\n *ngIf=\"secondary\"\n aui-button=\"default\"\n type=\"button\"\n size=\"mini\"\n (click)=\"onSecondary.emit()\"\n >\n {{ secondary | translate }}\n </button>\n</footer>\n", styles: [":host{display:flex;flex-direction:column;max-height:150px}main{display:flex;flex:1;overflow:hidden}main>*{flex:1;overflow:auto}footer{padding-top:12px}\n"] }]
|
|
78
84
|
}], null, { primary: [{
|
|
79
85
|
type: Input
|
|
80
86
|
}], secondary: [{
|
|
@@ -92,4 +98,4 @@ export class FeedbackNotificationComponent {
|
|
|
92
98
|
onSecondary: [{
|
|
93
99
|
type: Output
|
|
94
100
|
}] }); })();
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL25vdGlmaWNhdGlvbi9mZWVkYmFjay1ub3RpZmljYXRpb24vY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL25vdGlmaWNhdGlvbi9mZWVkYmFjay1ub3RpZmljYXRpb24vdGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN2QyxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDcEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtDQUFrQyxDQUFDOzs7OztJQ2ZqRSx5QkFHTzs7O0lBREwsNkRBQXFCOzs7SUFFdkIseUJBR087OztJQURMLDZEQUFxQjs7O0lBUHpCLDRCQUFzQjtJQUNwQixxRkFHTztJQUNQLHFGQUdPO0lBQ1QsaUJBQU87OztJQVBGLGVBQVM7SUFBVCxpQ0FBUztJQUlULGVBQVU7SUFBVixrQ0FBVTs7OztJQUtiLGlDQU1DO0lBREMsNktBQVMsZUFBQSx1QkFBZ0IsQ0FBQSxJQUFDO0lBRTFCLFlBQ0Y7O0lBQUEsaUJBQVM7OztJQURQLGVBQ0Y7SUFERSxxRUFDRjs7OztJQUNBLGlDQU1DO0lBREMsNktBQVMsZUFBQSx5QkFBa0IsQ0FBQSxJQUFDO0lBRTVCLFlBQ0Y7O0lBQUEsaUJBQVM7OztJQURQLGVBQ0Y7SUFERSx1RUFDRjs7QURGRixNQUFNLE9BQU8sNkJBQTZCO0lBUjFDO1FBdUJFLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBSXJDLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztLQUN4Qzs4RkFwQlksNkJBQTZCO29FQUE3Qiw2QkFBNkI7WUMxQjFDLGdGQVNPO1lBQ1AsOEJBQVE7WUFDTixvRkFRUztZQUNULG9GQVFTO1lBQ1gsaUJBQVM7O1lBN0JGLGtDQUFhO1lBWWYsZUFBYTtZQUFiLGtDQUFhO1lBU2IsZUFBZTtZQUFmLG9DQUFlOzRCREdSLElBQUksRUFBRSxlQUFlLG9CQUFFLFlBQVksc0JBQUUsVUFBVTs7dUZBRTlDLDZCQUE2QjtjQVJ6QyxTQUFTOzZCQUdJLElBQUksdUJBQ0ssS0FBSyxtQkFDVCx1QkFBdUIsQ0FBQyxNQUFNLFdBQ3RDLENBQUMsSUFBSSxFQUFFLGVBQWUsRUFBRSxZQUFZLEVBQUUsVUFBVSxDQUFDO2dCQUkxRCxPQUFPO2tCQUROLEtBQUs7WUFJTixTQUFTO2tCQURSLEtBQUs7WUFJTixPQUFPO2tCQUROLEtBQUs7WUFJTixHQUFHO2tCQURGLEtBQUs7O0lBSU4sK0RBQStEO0lBQy9ELFNBQVM7a0JBRlIsTUFBTTs7SUFLUCwrREFBK0Q7SUFDL0QsV0FBVztrQkFGVixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqIEBtb2R1bGUgbm90aWZpY2F0aW9uXG4gKi9cblxuaW1wb3J0IHsgQnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFsYXVkYS91aSc7XG5pbXBvcnQgeyBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IENvZGVNb2R1bGUgfSBmcm9tICcuLi8uLi9jb2RlL2NvZGUubW9kdWxlJztcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJy4uLy4uL3RyYW5zbGF0ZS90cmFuc2xhdGUubW9kdWxlJztcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlVXJsOiAndGVtcGxhdGUuaHRtbCcsXG4gIHN0eWxlVXJsczogWydzdHlsZXMuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGltcG9ydHM6IFtOZ0lmLCBUcmFuc2xhdGVNb2R1bGUsIEJ1dHRvbk1vZHVsZSwgQ29kZU1vZHVsZV0sXG59KVxuZXhwb3J0IGNsYXNzIEZlZWRiYWNrTm90aWZpY2F0aW9uQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgcHJpbWFyeTogc3RyaW5nO1xuXG4gIEBJbnB1dCgpXG4gIHNlY29uZGFyeTogc3RyaW5nO1xuXG4gIEBJbnB1dCgpXG4gIGNvbnRlbnQ/OiBzdHJpbmc7XG5cbiAgQElucHV0KClcbiAgcHJlOiBib29sZWFuO1xuXG4gIEBPdXRwdXQoKVxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L25vLW91dHB1dC1vbi1wcmVmaXhcbiAgb25QcmltYXJ5ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIEBPdXRwdXQoKVxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L25vLW91dHB1dC1vbi1wcmVmaXhcbiAgb25TZWNvbmRhcnkgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG59XG5cbmV4cG9ydCB0eXBlIEZlZWRiYWNrTm90aWZpY2F0aW9uUHJvcHMgPSBQYXJ0aWFsPFxuICBQaWNrPFxuICAgIEZlZWRiYWNrTm90aWZpY2F0aW9uQ29tcG9uZW50LFxuICAgICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ2NvbnRlbnQnIHwgJ3ByZSdcbiAgPlxuPjtcbiIsIjxtYWluICpuZ0lmPVwiY29udGVudFwiPlxuICA8cHJlXG4gICAgKm5nSWY9XCJwcmVcIlxuICAgIFtpbm5lckhUTUxdPVwiY29udGVudFwiXG4gID48L3ByZT5cbiAgPGRpdlxuICAgICpuZ0lmPVwiIXByZVwiXG4gICAgW2lubmVySFRNTF09XCJjb250ZW50XCJcbiAgPjwvZGl2PlxuPC9tYWluPlxuPGZvb3Rlcj5cbiAgPGJ1dHRvblxuICAgICpuZ0lmPVwicHJpbWFyeVwiXG4gICAgYXVpLWJ1dHRvbj1cInByaW1hcnlcIlxuICAgIHR5cGU9XCJidXR0b25cIlxuICAgIHNpemU9XCJtaW5pXCJcbiAgICAoY2xpY2spPVwib25QcmltYXJ5LmVtaXQoKVwiXG4gID5cbiAgICB7eyBwcmltYXJ5IHwgdHJhbnNsYXRlIH19XG4gIDwvYnV0dG9uPlxuICA8YnV0dG9uXG4gICAgKm5nSWY9XCJzZWNvbmRhcnlcIlxuICAgIGF1aS1idXR0b249XCJkZWZhdWx0XCJcbiAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICBzaXplPVwibWluaVwiXG4gICAgKGNsaWNrKT1cIm9uU2Vjb25kYXJ5LmVtaXQoKVwiXG4gID5cbiAgICB7eyBzZWNvbmRhcnkgfCB0cmFuc2xhdGUgfX1cbiAgPC9idXR0b24+XG48L2Zvb3Rlcj5cbiJdfQ==
|
|
@@ -7,7 +7,6 @@
|
|
|
7
7
|
export * from './errors-mapper';
|
|
8
8
|
export * from './feedback-notification/component';
|
|
9
9
|
export * from './helpers';
|
|
10
|
-
export * from './notification-util.module';
|
|
11
10
|
export * from './notification-util.service';
|
|
12
11
|
export * from './resource-error.interceptor';
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9ub3RpZmljYXRpb24vcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBQ0gsY0FBYztBQUNkLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsOEJBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFtbaW5jbHVkZTpub3RpZmljYXRpb24vUkVBRE1FLm1kXV1cbiAqIEBtb2R1bGUgbm90aWZpY2F0aW9uXG4gKiBAcHJlZmVycmVkXG4gKi9cbi8qKiBpbXBvcnRzICovXG5leHBvcnQgKiBmcm9tICcuL2Vycm9ycy1tYXBwZXInO1xuZXhwb3J0ICogZnJvbSAnLi9mZWVkYmFjay1ub3RpZmljYXRpb24vY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaGVscGVycyc7XG5leHBvcnQgKiBmcm9tICcuL25vdGlmaWNhdGlvbi11dGlsLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9yZXNvdXJjZS1lcnJvci5pbnRlcmNlcHRvcic7XG4iXX0=
|
|
@@ -11,6 +11,7 @@ import catalog from './animations/catalog.json';
|
|
|
11
11
|
import certificate from './animations/certificate.json';
|
|
12
12
|
import ci from './animations/ci.json';
|
|
13
13
|
import code from './animations/code.json';
|
|
14
|
+
import dashboard from './animations/dashboard.json';
|
|
14
15
|
import data_service from './animations/data_service.json';
|
|
15
16
|
import devops from './animations/devops.json';
|
|
16
17
|
import devops_tools from './animations/devops_tools.json';
|
|
@@ -109,5 +110,6 @@ export default {
|
|
|
109
110
|
params_template,
|
|
110
111
|
gitops,
|
|
111
112
|
events,
|
|
113
|
+
dashboard,
|
|
112
114
|
};
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animation-data.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/page-scaffold/navigation/lottie-icons/animation-data.ts"],"names":[],"mappings":"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","sourcesContent":["import alarm from './animations/alarm.json';\nimport app from './animations/app.json';\nimport application from './animations/application.json';\nimport artifactory from './animations/artifactory.json';\nimport audit from './animations/audit.json';\nimport auxiliary_function from './animations/auxiliary_function.json';\nimport backup from './animations/backup.json';\nimport bar_chart from './animations/bar_chart.json';\nimport bill from './animations/bill.json';\nimport catalog from './animations/catalog.json';\nimport certificate from './animations/certificate.json';\nimport ci from './animations/ci.json';\nimport code from './animations/code.json';\nimport dashboard from './animations/dashboard.json';\nimport data_service from './animations/data_service.json';\nimport devops from './animations/devops.json';\nimport devops_tools from './animations/devops_tools.json';\nimport events from './animations/events.json';\nimport file from './animations/file.json';\nimport gateway from './animations/gateway.json';\nimport gitops from './animations/gitops.json';\nimport inspection from './animations/inspection.json';\nimport internet from './animations/internet.json';\nimport kafka from './animations/kafka.json';\nimport log from './animations/log.json';\nimport member from './animations/member.json';\nimport mongodb from './animations/mongodb.json';\nimport monitor from './animations/monitor.json';\nimport mysql from './animations/mysql.json';\nimport namespace from './animations/namespace.json';\nimport notice from './animations/notice.json';\nimport oam from './animations/oam.json';\nimport operation_center from './animations/operation_center.json';\nimport params_template from './animations/params_template.json';\nimport pipeline from './animations/pipeline.json';\nimport platform_settings from './animations/platform_settings.json';\nimport postgresql from './animations/postgresql.json';\nimport product from './animations/product.json';\nimport project from './animations/proj.json';\nimport rabbitmq from './animations/rabbitmq.json';\nimport redis from './animations/redis.json';\nimport resource_list from './animations/resource_list.json';\nimport rocketmq from './animations/rocketmq.json';\nimport scrum from './animations/scrum.json';\nimport secrets from './animations/secrets.json';\nimport security from './animations/security.json';\nimport server from './animations/server.json';\nimport service_mesh from './animations/service_mesh.json';\nimport sitemap from './animations/sitemap.json';\nimport sliders_up from './animations/sliders_up.json';\nimport storage from './animations/storage.json';\nimport test_management from './animations/test_management.json';\nimport topology from './animations/topology.json';\nimport user_role from './animations/user_role.json';\nimport view_jaeger from './animations/view_jaeger.json';\nimport virtualization from './animations/virtualization.json';\n\nexport default {\n  alarm,\n  app,\n  application,\n  artifactory,\n  audit,\n  auxiliary_function,\n  backup,\n  bar_chart,\n  bill,\n  catalog,\n  certificate,\n  ci,\n  code,\n  data_service,\n  devops_tools,\n  devops,\n  file,\n  gateway,\n  sliders_up,\n  internet,\n  log,\n  member,\n  monitor,\n  namespace,\n  notice,\n  operation_center,\n  pipeline,\n  platform_settings,\n  product,\n  project,\n  resource_list,\n  rocketmq,\n  scrum,\n  secrets,\n  security,\n  server,\n  service_mesh,\n  sitemap,\n  storage,\n  topology,\n  user_role,\n  view_jaeger,\n  virtualization,\n  oam,\n  kafka,\n  redis,\n  mysql,\n  mongodb,\n  rabbitmq,\n  postgresql,\n  inspection,\n  test_management,\n  params_template,\n  gitops,\n  events,\n  dashboard,\n} as Record<string, any>;\n"]}
|