@alauda-fe/common 1.0.3 → 1.1.0
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/a-chart/base-chart.d.ts +2 -2
- package/a-chart/chart.component.d.ts +3 -2
- package/a-chart/types.d.ts +5 -0
- package/a-metric-chart/a-metric-chart.component.d.ts +45 -2
- package/a-metric-chart/a-metric-chart.module.d.ts +2 -2
- package/a-metric-chart/utils/util.d.ts +1 -1
- package/api/acp-common-api.service.d.ts +26 -0
- package/api/cluster-version.service.d.ts +0 -3
- package/api/project-api.service.d.ts +5 -0
- package/api/public-api.d.ts +1 -0
- package/assets/icons/prod-icons.js +1 -1
- package/core/constants/patterns.d.ts +5 -0
- package/core/constants/status-icons.d.ts +1 -0
- package/core/directives/aui-code-editor.directive.d.ts +13 -0
- package/core/directives/feature-gate.directive.d.ts +1 -1
- package/core/directives/public-api.d.ts +2 -0
- package/core/guards/feature.guard.d.ts +1 -1
- package/core/module.d.ts +10 -10
- package/core/pipes/k8s-util.pipe.d.ts +13 -13
- package/core/pipes/k8s-util.pipe.module.d.ts +6 -1
- package/core/pipes/public-api.d.ts +3 -0
- package/{scm/pure-pipe/module.d.ts → core/pipes/pure.pipe.module.d.ts} +3 -0
- package/core/services/context.service.d.ts +1 -1
- package/core/utils/unit.d.ts +1 -0
- package/disabled-container/disabled-container.component.d.ts +1 -1
- package/disabled-container/disabled-container.module.d.ts +4 -4
- package/effect-directive/module.d.ts +1 -1
- package/esm2022/a-chart/a-chart.module.mjs +1 -1
- package/esm2022/a-chart/base-chart.mjs +7 -7
- package/esm2022/a-chart/chart.component.mjs +11 -3
- package/esm2022/a-chart/types.mjs +7 -2
- package/esm2022/a-metric-chart/a-metric-chart.component.mjs +38 -13
- package/esm2022/a-metric-chart/a-metric-chart.module.mjs +6 -8
- package/esm2022/a-metric-chart/bar-gauge/bar-gauge.component.mjs +6 -5
- package/esm2022/a-metric-chart/stat-chart/stat-chart.component.mjs +26 -12
- package/esm2022/a-metric-chart/table-chart/table-chart.component.mjs +3 -3
- package/esm2022/a-metric-chart/utils/util.mjs +6 -5
- package/esm2022/api/acp-common-api.service.mjs +34 -0
- package/esm2022/api/cluster-version.service.mjs +1 -7
- package/esm2022/api/project-api.service.mjs +17 -4
- package/esm2022/api/public-api.mjs +2 -1
- package/esm2022/array-form-table/form/component.mjs +2 -2
- package/esm2022/array-form-table/key-value-table/component.mjs +2 -2
- package/esm2022/business/resource-select/module.mjs +2 -2
- package/esm2022/chart/chart.module.mjs +1 -1
- package/esm2022/core/constants/patterns.mjs +6 -1
- package/esm2022/core/constants/status-icons.mjs +2 -1
- package/esm2022/core/directives/aui-code-editor.directive.mjs +30 -0
- package/esm2022/core/directives/declare.directive.mjs +27 -0
- package/esm2022/core/directives/feature-gate.directive.mjs +3 -3
- package/esm2022/core/directives/public-api.mjs +3 -1
- package/esm2022/core/guards/feature.guard.mjs +3 -5
- package/esm2022/core/module.mjs +19 -17
- package/esm2022/core/pipes/calc.pipe.mjs +21 -0
- package/esm2022/core/pipes/k8s-util.pipe.mjs +27 -27
- package/esm2022/core/pipes/k8s-util.pipe.module.mjs +8 -5
- package/esm2022/core/pipes/public-api.mjs +4 -1
- package/esm2022/core/pipes/pure.pipe.mjs +26 -0
- package/esm2022/core/pipes/pure.pipe.module.mjs +21 -0
- package/esm2022/core/services/context.service.mjs +5 -3
- package/esm2022/core/utils/common.mjs +3 -3
- package/esm2022/core/utils/unit.mjs +5 -1
- package/esm2022/disabled-container/disabled-container.component.mjs +7 -5
- package/esm2022/disabled-container/disabled-container.module.mjs +7 -11
- package/esm2022/effect-directive/module.mjs +4 -5
- package/esm2022/exec/module.mjs +3 -4
- package/esm2022/form/errors-mapper/errors-mapper.module.mjs +13 -4
- package/esm2022/form/labels-editor/component.mjs +8 -8
- package/esm2022/form/taints-editor/component.mjs +4 -6
- package/esm2022/form/validators/strong-password/strong-password-validator.directive.mjs +9 -10
- package/esm2022/form/validators/utils.mjs +47 -2
- package/esm2022/graphql/graphql.module.mjs +62 -0
- package/esm2022/graphql/graphql.service.mjs +45 -0
- package/esm2022/graphql/public-api.mjs +4 -0
- package/esm2022/graphql/queries.mjs +29 -0
- package/esm2022/graphql/types.mjs +6 -0
- package/esm2022/grid-layout/utils/grid.utils.mjs +2 -20
- package/esm2022/help-document/directive.mjs +3 -2
- package/esm2022/help-document/module.mjs +6 -4
- package/esm2022/k8s-shared/update-key-value-dialog/component.mjs +3 -2
- package/esm2022/license/license-error/module.mjs +1 -1
- package/esm2022/multi-search/action-input/component.mjs +6 -7
- package/esm2022/multi-search/form/component.mjs +3 -4
- package/esm2022/multi-search/multi-search-tags/component.mjs +9 -9
- package/esm2022/overview-banner/overview-banner.component.mjs +5 -5
- package/esm2022/overview-banner/overview-banner.module.mjs +7 -7
- package/esm2022/page-guard/module.mjs +7 -4
- package/esm2022/page-scaffold/navigation/breadcrumb/breadcrumb-slot.directive.mjs +3 -2
- package/esm2022/page-scaffold/navigation/breadcrumb/breadcrumb.component.mjs +23 -5
- package/esm2022/page-scaffold/navigation/breadcrumb/module.mjs +16 -31
- package/esm2022/page-scaffold/navigation/lottie-icons/lottie-icon.directive.mjs +3 -2
- package/esm2022/page-scaffold/navigation/lottie-icons/module.mjs +6 -3
- package/esm2022/page-scaffold/navigation/nav-menu/nav-menu.module.mjs +4 -4
- package/esm2022/page-scaffold/page-header/common-layout/common-layout.module.mjs +5 -7
- package/esm2022/page-scaffold/page-header/header-notify/header-notify.module.mjs +4 -4
- package/esm2022/page-scaffold/page-header/help-menu/module.mjs +13 -14
- package/esm2022/pie-derivative-chart/pie-derivative-chart.module.mjs +2 -2
- package/esm2022/public-api.mjs +2 -2
- package/esm2022/searchable-selector/module.mjs +1 -1
- package/esm2022/skeleton/module.mjs +1 -1
- package/esm2022/table/module.mjs +5 -5
- package/esm2022/translate/en.json +44 -1
- package/esm2022/translate/translate.directive.mjs +7 -7
- package/esm2022/translate/translate.module.mjs +18 -17
- package/esm2022/translate/translate.pipe.mjs +4 -3
- package/esm2022/translate/zh.json +42 -1
- package/esm2022/widget/card-section/card-section.component.mjs +23 -6
- package/esm2022/widget/current-time/component.mjs +6 -4
- package/esm2022/widget/date-range-picker/component.mjs +12 -9
- package/esm2022/widget/foldable-item-in-table/component.mjs +28 -6
- package/esm2022/widget/password-input/component.mjs +283 -0
- package/esm2022/widget/public-api.mjs +8 -1
- package/esm2022/widget/resource-multi-select/component.mjs +211 -0
- package/esm2022/widget/resource-multi-select/util.mjs +24 -0
- package/esm2022/{scm → widget}/search-panel/component.mjs +1 -1
- package/esm2022/{scm → widget}/search-panel/helper.directive.mjs +1 -1
- package/esm2022/{scm → widget}/search-panel/search-item/component.mjs +1 -1
- package/esm2022/widget/status-icon/status-icon.component.mjs +2 -2
- package/esm2022/widget/tags-label/component.mjs +2 -3
- package/esm2022/widget/terminating-tag/component.mjs +7 -4
- package/esm2022/{scm → widget}/text-ellipsis/component.mjs +1 -1
- package/esm2022/widget/text-with-url/component.mjs +6 -4
- package/esm2022/widget/widget.module.mjs +54 -86
- package/esm2022/widget/zero-state/zero-state.component.mjs +6 -6
- package/esm2022/xterm/xterm-terminal/xterm-terminal.component.mjs +102 -65
- package/exec/module.d.ts +1 -1
- package/form/errors-mapper/errors-mapper.module.d.ts +6 -0
- package/form/validators/strong-password/strong-password-validator.directive.d.ts +3 -3
- package/form/validators/utils.d.ts +3 -0
- package/graphql/graphql.module.d.ts +12 -0
- package/graphql/graphql.service.d.ts +14 -0
- package/graphql/public-api.d.ts +3 -0
- package/graphql/queries.d.ts +5 -0
- package/graphql/types.d.ts +46 -0
- package/help-document/directive.d.ts +1 -1
- package/help-document/module.d.ts +7 -7
- package/overview-banner/overview-banner.component.d.ts +1 -1
- package/overview-banner/overview-banner.module.d.ts +4 -3
- package/package.json +1 -1
- package/page-guard/module.d.ts +4 -1
- package/page-scaffold/navigation/breadcrumb/breadcrumb-slot.directive.d.ts +1 -1
- package/page-scaffold/navigation/breadcrumb/breadcrumb.component.d.ts +1 -1
- package/page-scaffold/navigation/breadcrumb/module.d.ts +8 -6
- package/page-scaffold/navigation/lottie-icons/lottie-icon.directive.d.ts +1 -1
- package/page-scaffold/navigation/lottie-icons/module.d.ts +4 -1
- package/page-scaffold/page-header/common-layout/common-layout.module.d.ts +2 -2
- package/page-scaffold/page-header/help-menu/module.d.ts +6 -5
- package/public-api.d.ts +1 -1
- package/styles/tailwind-preset.scss +1 -1
- package/translate/translate.directive.d.ts +3 -3
- package/translate/translate.module.d.ts +97 -4
- package/translate/translate.pipe.d.ts +1 -1
- package/widget/card-section/card-section.component.d.ts +4 -2
- package/widget/current-time/component.d.ts +1 -1
- package/widget/foldable-item-in-table/component.d.ts +1 -1
- package/{scm → widget}/password-input/component.d.ts +1 -1
- package/widget/public-api.d.ts +7 -0
- package/widget/terminating-tag/component.d.ts +1 -1
- package/widget/text-with-url/component.d.ts +1 -1
- package/widget/widget.module.d.ts +37 -21
- package/xterm/xterm-terminal/xterm-terminal.component.d.ts +14 -1
- package/esm2022/scm/declare.directive.mjs +0 -27
- package/esm2022/scm/password-input/component.mjs +0 -261
- package/esm2022/scm/password-input/module.mjs +0 -67
- package/esm2022/scm/password-input/public-api.mjs +0 -3
- package/esm2022/scm/public-api.mjs +0 -10
- package/esm2022/scm/pure-pipe/calc.pipe.mjs +0 -21
- package/esm2022/scm/pure-pipe/module.mjs +0 -18
- package/esm2022/scm/pure-pipe/public-api.mjs +0 -4
- package/esm2022/scm/pure-pipe/pure.pipe.mjs +0 -26
- package/esm2022/scm/resource-multi-select/component.mjs +0 -212
- package/esm2022/scm/resource-multi-select/util.mjs +0 -24
- package/scm/password-input/module.d.ts +0 -14
- package/scm/password-input/public-api.d.ts +0 -2
- package/scm/public-api.d.ts +0 -9
- package/scm/pure-pipe/public-api.d.ts +0 -3
- /package/{scm → core/directives}/declare.directive.d.ts +0 -0
- /package/{scm/pure-pipe → core/pipes}/calc.pipe.d.ts +0 -0
- /package/{scm/pure-pipe → core/pipes}/pure.pipe.d.ts +0 -0
- /package/{scm → widget}/resource-multi-select/component.d.ts +0 -0
- /package/{scm → widget}/resource-multi-select/util.d.ts +0 -0
- /package/{scm → widget}/search-panel/component.d.ts +0 -0
- /package/{scm → widget}/search-panel/helper.directive.d.ts +0 -0
- /package/{scm → widget}/search-panel/search-item/component.d.ts +0 -0
- /package/{scm → widget}/text-ellipsis/component.d.ts +0 -0
|
@@ -60,9 +60,10 @@ function BarGaugeComponent_div_5_div_1_div_3_Template(rf, ctx) { if (rf & 1) {
|
|
|
60
60
|
i0.ɵɵelementEnd()();
|
|
61
61
|
} if (rf & 2) {
|
|
62
62
|
const item_r5 = ctx.$implicit;
|
|
63
|
-
const
|
|
63
|
+
const series_r2 = i0.ɵɵnextContext(2).ngIf;
|
|
64
|
+
const ctx_r4 = i0.ɵɵnextContext();
|
|
64
65
|
i0.ɵɵadvance(1);
|
|
65
|
-
i0.ɵɵproperty("ngIf", !i0.ɵɵpipeBind2(2, 8, ctx_r4.options.layout, ctx_r4.isVertical));
|
|
66
|
+
i0.ɵɵproperty("ngIf", !i0.ɵɵpipeBind2(2, 8, ctx_r4.options.layout, ctx_r4.isVertical) && (series_r2 == null ? null : series_r2.length) > 1);
|
|
66
67
|
i0.ɵɵadvance(2);
|
|
67
68
|
i0.ɵɵstyleProp("width", i0.ɵɵpipeBind2(5, 11, ctx_r4.containerWidth, ctx_r4.getWrapperWidth));
|
|
68
69
|
i0.ɵɵadvance(4);
|
|
@@ -120,7 +121,7 @@ export class BarGaugeComponent extends BaseComponentChart {
|
|
|
120
121
|
const key = isVertical(this.options.layout) ? 'height' : 'width';
|
|
121
122
|
return {
|
|
122
123
|
background: item.color,
|
|
123
|
-
[key]: `${(item.value / max || 0) * 100}%`,
|
|
124
|
+
[key]: `${(item.value / Math.max(item.value, max) || 0) * 100}%`,
|
|
124
125
|
};
|
|
125
126
|
};
|
|
126
127
|
this.getEmptyStyle = (item) => {
|
|
@@ -155,11 +156,11 @@ export class BarGaugeComponent extends BaseComponentChart {
|
|
|
155
156
|
}
|
|
156
157
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BarGaugeComponent, [{
|
|
157
158
|
type: Component,
|
|
158
|
-
args: [{ selector: 'a-bar-gauge', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"bar-gauge tw-h-full tw-w-full\"\n #barGauge\n aclResize\n (resized)=\"containerWidth = $event.width\"\n>\n <div class=\"tw-flex\">\n <div class=\"achart-title tw-flex-1 tw-break-all\">\n <ng-content select=\"a-title\"></ng-content>\n </div>\n </div>\n <div\n class=\"bar tw-h-full tw-w-full\"\n *ngIf=\"data$ | async as series\"\n >\n <div\n *ngIf=\"!status.noData\"\n class=\"body tw-h-full tw-w-full tw-flex\"\n [ngClass]=\"{\n 'vertical': options.layout | pure: isVertical,\n 'horizontal': !(options.layout | pure: isVertical),\n }\"\n >\n <div\n class=\"item tw-h-full tw-w-full\"\n *ngFor=\"let item of series\"\n >\n <div\n class=\"legend tw-text-center tw-text-overflow tw-mb-4\"\n *ngIf=\"!(options.layout | pure: isVertical)\"\n [ngClass]=\"{ 'tw-text-center': options.layout | pure: isVertical }\"\n >\n {{ $any(item).name }}\n </div>\n <div\n class=\"wrapper tw-flex tw-h-full\"\n #wrapper\n [style.width]=\"containerWidth | pure: getWrapperWidth\"\n >\n <div class=\"value tw-text-n-1 tw-text-xl tw-text-center\">\n {{ $any(item).displayName }}\n <ng-container *ngIf=\"$any(item).displayName | pure: showUnit\">{{\n $any(item)?.unit | translate: {} : true\n }}</ng-container>\n </div>\n <div\n class=\"empty-bar tw-flex tw-relative tw-bg-n-8\"\n [ngStyle]=\"item | pure: getEmptyStyle\"\n ></div>\n <div\n class=\"bar\"\n [ngStyle]=\"item | pure: getBarStyle\"\n ></div>\n <div\n class=\"legend tw-text-center tw-text-overflow\"\n *ngIf=\"options.layout | pure: isVertical\"\n [ngClass]=\"{ 'tw-text-center': options.layout | pure: isVertical }\"\n >\n {{ $any(item).name }}\n </div>\n </div>\n </div>\n </div>\n </div>\n <acl-chart-status\n [status]=\"status\"\n [customError]=\"customError\"\n (refresh)=\"refresh.next()\"\n ></acl-chart-status>\n</div>\n", styles: [":host{height:100%;width:100%;padding-top:16px}:host .vertical{justify-content:space-between;flex-direction:row}:host .vertical .wrapper{flex-direction:column;justify-content:flex-end}:host .vertical .bar{transition:height 1s ease 0s;margin-bottom:4px}:host .vertical .empty-bar{margin-top:4px}:host .vertical .value{height:25px;text-align:center}:host .vertical .legend{text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}:host .vertical .item:not(:last-child){margin-right:10px}:host .horizontal{display:flex;flex-direction:column}:host .horizontal .item{display:flex;flex-direction:column}:host .horizontal .item:not(:last-child){margin-bottom:20px}:host .horizontal .wrapper{flex-direction:row-reverse;justify-content:flex-end;align-items:stretch}:host .horizontal .bar{transition:width 1s ease 0s}:host .horizontal .empty-bar{margin-right:4px}:host .horizontal .legend{display:flex;align-items:center}:host .horizontal .value{width:40px;display:flex;align-items:center;white-space:nowrap}:host .empty-bar{border-radius:2px}:host .bar{border-radius:2px}:host .legend{color:rgb(var(--aui-color-n-1))}\n"] }]
|
|
159
|
+
args: [{ selector: 'a-bar-gauge', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"bar-gauge tw-h-full tw-w-full\"\n #barGauge\n aclResize\n (resized)=\"containerWidth = $event.width\"\n>\n <div class=\"tw-flex\">\n <div class=\"achart-title tw-flex-1 tw-break-all\">\n <ng-content select=\"a-title\"></ng-content>\n </div>\n </div>\n <div\n class=\"bar tw-h-full tw-w-full\"\n *ngIf=\"data$ | async as series\"\n >\n <div\n *ngIf=\"!status.noData\"\n class=\"body tw-h-full tw-w-full tw-flex\"\n [ngClass]=\"{\n 'vertical': options.layout | pure: isVertical,\n 'horizontal': !(options.layout | pure: isVertical),\n }\"\n >\n <div\n class=\"item tw-h-full tw-w-full\"\n *ngFor=\"let item of series\"\n >\n <div\n class=\"legend tw-text-center tw-text-overflow tw-mb-4\"\n *ngIf=\"!(options.layout | pure: isVertical) && series?.length > 1\"\n [ngClass]=\"{ 'tw-text-center': options.layout | pure: isVertical }\"\n >\n {{ $any(item).name }}\n </div>\n <div\n class=\"wrapper tw-flex tw-h-full\"\n #wrapper\n [style.width]=\"containerWidth | pure: getWrapperWidth\"\n >\n <div class=\"value tw-text-n-1 tw-text-xl tw-text-center\">\n {{ $any(item).displayName }}\n <ng-container *ngIf=\"$any(item).displayName | pure: showUnit\">{{\n $any(item)?.unit | translate: {} : true\n }}</ng-container>\n </div>\n <div\n class=\"empty-bar tw-flex tw-relative tw-bg-n-8\"\n [ngStyle]=\"item | pure: getEmptyStyle\"\n ></div>\n <div\n class=\"bar\"\n [ngStyle]=\"item | pure: getBarStyle\"\n ></div>\n <div\n class=\"legend tw-text-center tw-text-overflow\"\n *ngIf=\"options.layout | pure: isVertical\"\n [ngClass]=\"{ 'tw-text-center': options.layout | pure: isVertical }\"\n >\n {{ $any(item).name }}\n </div>\n </div>\n </div>\n </div>\n </div>\n <acl-chart-status\n [status]=\"status\"\n [customError]=\"customError\"\n (refresh)=\"refresh.next()\"\n ></acl-chart-status>\n</div>\n", styles: [":host{height:100%;width:100%;padding-top:16px}:host .vertical{justify-content:space-between;flex-direction:row}:host .vertical .wrapper{flex-direction:column;justify-content:flex-end}:host .vertical .bar{transition:height 1s ease 0s;margin-bottom:4px}:host .vertical .empty-bar{margin-top:4px}:host .vertical .value{height:25px;text-align:center}:host .vertical .legend{text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}:host .vertical .item:not(:last-child){margin-right:10px}:host .horizontal{display:flex;flex-direction:column}:host .horizontal .item{display:flex;flex-direction:column}:host .horizontal .item:not(:last-child){margin-bottom:20px}:host .horizontal .wrapper{flex-direction:row-reverse;justify-content:flex-end;align-items:stretch}:host .horizontal .bar{transition:width 1s ease 0s}:host .horizontal .empty-bar{margin-right:4px}:host .horizontal .legend{display:flex;align-items:center}:host .horizontal .value{width:40px;display:flex;align-items:center;white-space:nowrap}:host .empty-bar{border-radius:2px}:host .bar{border-radius:2px}:host .legend{color:rgb(var(--aui-color-n-1))}\n"] }]
|
|
159
160
|
}], null, { options: [{
|
|
160
161
|
type: Input
|
|
161
162
|
}] }); })();
|
|
162
163
|
function isVertical(orientation) {
|
|
163
164
|
return orientation === Orientation.VERTICAL;
|
|
164
165
|
}
|
|
165
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar-gauge.component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/a-metric-chart/bar-gauge/bar-gauge.component.ts","../../../../../../libs/common/src/a-metric-chart/bar-gauge/bar-gauge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport { isNumber } from 'lodash-es';\n\nimport { AChartData } from '../../a-chart/public-api';\nimport { BaseComponentChart } from '../base-chart.component';\nimport { Orientation } from '../types';\n\nexport interface BarGaugeOptions {\n  layout?: Orientation;\n}\n\n@Component({\n  selector: 'a-bar-gauge',\n  templateUrl: './bar-gauge.component.html',\n  styleUrls: ['./bar-gauge.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BarGaugeComponent extends BaseComponentChart {\n  @Input() options: BarGaugeOptions = {\n    layout: Orientation.VERTICAL,\n  };\n\n  containerWidth: number;\n\n  isVertical = isVertical;\n\n  showUnit(value: string | number) {\n    return isNumber(+value) && !Number.isNaN(+value);\n  }\n\n  getWrapperWidth = (width: number) => {\n    return this.data?.length &&\n      this.options.layout === Orientation.VERTICAL &&\n      width\n      ? `${width / this.data.length - 10}px`\n      : '100%';\n  };\n\n  getBarStyle = (item: AChartData) => {\n    const max = Math.max(...this.data.map(item => item.max || item.value || 0));\n    const key = isVertical(this.options.layout) ? 'height' : 'width';\n    return {\n      background: item.color,\n      [key]: `${(item.value / Math.max(item.value, max) || 0) * 100}%`,\n    };\n  };\n\n  getEmptyStyle = (item: AChartData) => {\n    const key = isVertical(this.options.layout) ? 'height' : 'width';\n    return {\n      [key]: `calc(100% - ${this.getBarStyle(item)[key]})`,\n    };\n  };\n}\n\nfunction isVertical(orientation: Orientation) {\n  return orientation === Orientation.VERTICAL;\n}\n","<div\n  class=\"bar-gauge tw-h-full tw-w-full\"\n  #barGauge\n  aclResize\n  (resized)=\"containerWidth = $event.width\"\n>\n  <div class=\"tw-flex\">\n    <div class=\"achart-title tw-flex-1 tw-break-all\">\n      <ng-content select=\"a-title\"></ng-content>\n    </div>\n  </div>\n  <div\n    class=\"bar tw-h-full tw-w-full\"\n    *ngIf=\"data$ | async as series\"\n  >\n    <div\n      *ngIf=\"!status.noData\"\n      class=\"body tw-h-full tw-w-full tw-flex\"\n      [ngClass]=\"{\n        'vertical': options.layout | pure: isVertical,\n        'horizontal': !(options.layout | pure: isVertical),\n      }\"\n    >\n      <div\n        class=\"item tw-h-full tw-w-full\"\n        *ngFor=\"let item of series\"\n      >\n        <div\n          class=\"legend tw-text-center tw-text-overflow tw-mb-4\"\n          *ngIf=\"!(options.layout | pure: isVertical) && series?.length > 1\"\n          [ngClass]=\"{ 'tw-text-center': options.layout | pure: isVertical }\"\n        >\n          {{ $any(item).name }}\n        </div>\n        <div\n          class=\"wrapper tw-flex tw-h-full\"\n          #wrapper\n          [style.width]=\"containerWidth | pure: getWrapperWidth\"\n        >\n          <div class=\"value tw-text-n-1 tw-text-xl tw-text-center\">\n            {{ $any(item).displayName }}\n            <ng-container *ngIf=\"$any(item).displayName | pure: showUnit\">{{\n              $any(item)?.unit | translate: {} : true\n            }}</ng-container>\n          </div>\n          <div\n            class=\"empty-bar tw-flex tw-relative tw-bg-n-8\"\n            [ngStyle]=\"item | pure: getEmptyStyle\"\n          ></div>\n          <div\n            class=\"bar\"\n            [ngStyle]=\"item | pure: getBarStyle\"\n          ></div>\n          <div\n            class=\"legend tw-text-center tw-text-overflow\"\n            *ngIf=\"options.layout | pure: isVertical\"\n            [ngClass]=\"{ 'tw-text-center': options.layout | pure: isVertical }\"\n          >\n            {{ $any(item).name }}\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <acl-chart-status\n    [status]=\"status\"\n    [customError]=\"customError\"\n    (refresh)=\"refresh.next()\"\n  ></acl-chart-status>\n</div>\n"]}
|
|
@@ -2,9 +2,18 @@ import { Component, ChangeDetectionStrategy } from '@angular/core';
|
|
|
2
2
|
import { isNumber } from 'lodash-es';
|
|
3
3
|
import { BaseComponentChart } from '../base-chart.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
+
function StatChartComponent_div_4_div_2_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
6
|
+
i0.ɵɵelementStart(0, "div", 11);
|
|
7
|
+
i0.ɵɵtext(1);
|
|
8
|
+
i0.ɵɵelementEnd();
|
|
9
|
+
} if (rf & 2) {
|
|
10
|
+
const item_r3 = i0.ɵɵnextContext().$implicit;
|
|
11
|
+
i0.ɵɵadvance(1);
|
|
12
|
+
i0.ɵɵtextInterpolate1(" ", item_r3.name, " ");
|
|
13
|
+
} }
|
|
5
14
|
const _c0 = function () { return {}; };
|
|
6
|
-
function
|
|
7
|
-
i0.ɵɵelementStart(0, "span",
|
|
15
|
+
function StatChartComponent_div_4_div_2_span_4_Template(rf, ctx) { if (rf & 1) {
|
|
16
|
+
i0.ɵɵelementStart(0, "span", 12);
|
|
8
17
|
i0.ɵɵtext(1);
|
|
9
18
|
i0.ɵɵpipe(2, "translate");
|
|
10
19
|
i0.ɵɵelementEnd();
|
|
@@ -15,24 +24,29 @@ function StatChartComponent_div_4_div_2_span_3_Template(rf, ctx) { if (rf & 1) {
|
|
|
15
24
|
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind3(2, 1, (tmp_0_0 = item_r3) == null ? null : tmp_0_0.unit, i0.ɵɵpureFunction0(5, _c0), true));
|
|
16
25
|
} }
|
|
17
26
|
function StatChartComponent_div_4_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
18
|
-
i0.ɵɵelementStart(0, "div", 7)
|
|
19
|
-
i0.ɵɵ
|
|
20
|
-
i0.ɵɵ
|
|
21
|
-
i0.ɵɵ
|
|
27
|
+
i0.ɵɵelementStart(0, "div", 7);
|
|
28
|
+
i0.ɵɵtemplate(1, StatChartComponent_div_4_div_2_div_1_Template, 2, 1, "div", 8);
|
|
29
|
+
i0.ɵɵelementStart(2, "div", 9);
|
|
30
|
+
i0.ɵɵtext(3);
|
|
31
|
+
i0.ɵɵtemplate(4, StatChartComponent_div_4_div_2_span_4_Template, 3, 6, "span", 10);
|
|
32
|
+
i0.ɵɵpipe(5, "pure");
|
|
22
33
|
i0.ɵɵelementEnd()();
|
|
23
34
|
} if (rf & 2) {
|
|
24
35
|
const item_r3 = ctx.$implicit;
|
|
25
|
-
const
|
|
36
|
+
const statSeries_r1 = i0.ɵɵnextContext().ngIf;
|
|
37
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
38
|
+
i0.ɵɵadvance(1);
|
|
39
|
+
i0.ɵɵproperty("ngIf", (statSeries_r1 == null ? null : statSeries_r1.length) > 1);
|
|
26
40
|
i0.ɵɵadvance(1);
|
|
27
41
|
i0.ɵɵstyleProp("color", item_r3 == null ? null : item_r3.color);
|
|
28
42
|
i0.ɵɵadvance(1);
|
|
29
43
|
i0.ɵɵtextInterpolate1(" ", item_r3.displayName, " ");
|
|
30
44
|
i0.ɵɵadvance(1);
|
|
31
|
-
i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(
|
|
45
|
+
i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind2(5, 5, item_r3.displayName, ctx_r2.showUnit));
|
|
32
46
|
} }
|
|
33
47
|
function StatChartComponent_div_4_Template(rf, ctx) { if (rf & 1) {
|
|
34
48
|
i0.ɵɵelementStart(0, "div", 0)(1, "div", 5);
|
|
35
|
-
i0.ɵɵtemplate(2, StatChartComponent_div_4_div_2_Template,
|
|
49
|
+
i0.ɵɵtemplate(2, StatChartComponent_div_4_div_2_Template, 6, 8, "div", 6);
|
|
36
50
|
i0.ɵɵelementEnd()();
|
|
37
51
|
} if (rf & 2) {
|
|
38
52
|
const statSeries_r1 = ctx.ngIf;
|
|
@@ -46,7 +60,7 @@ export class StatChartComponent extends BaseComponentChart {
|
|
|
46
60
|
return isNumber(+value) && !Number.isNaN(+value);
|
|
47
61
|
}
|
|
48
62
|
static { this.ɵfac = /*@__PURE__*/ function () { let ɵStatChartComponent_BaseFactory; return function StatChartComponent_Factory(t) { return (ɵStatChartComponent_BaseFactory || (ɵStatChartComponent_BaseFactory = i0.ɵɵgetInheritedFactory(StatChartComponent)))(t || StatChartComponent); }; }(); }
|
|
49
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: StatChartComponent, selectors: [["acl-stat-chart"]], features: [i0.ɵɵInheritDefinitionFeature], ngContentSelectors: _c2, decls: 7, vars: 5, consts: [[1, "stat"], [1, "tw-flex"], [1, "achart-title", "tw-flex-1", "tw-break-all"], ["class", "stat", 4, "ngIf"], [3, "status", "customError", "refresh"], [1, "body"], ["class", "item", 4, "ngFor", "ngForOf"], [1, "item"], [1, "value"], ["class", "tw-text-l tw-font-bold", 4, "ngIf"], [1, "tw-text-l", "tw-font-bold"]], template: function StatChartComponent_Template(rf, ctx) { if (rf & 1) {
|
|
63
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: StatChartComponent, selectors: [["acl-stat-chart"]], features: [i0.ɵɵInheritDefinitionFeature], ngContentSelectors: _c2, decls: 7, vars: 5, consts: [[1, "stat"], [1, "tw-flex"], [1, "achart-title", "tw-flex-1", "tw-break-all"], ["class", "stat", 4, "ngIf"], [3, "status", "customError", "refresh"], [1, "body"], ["class", "item", 4, "ngFor", "ngForOf"], [1, "item"], ["class", "name", 4, "ngIf"], [1, "value"], ["class", "tw-text-l tw-font-bold", 4, "ngIf"], [1, "name"], [1, "tw-text-l", "tw-font-bold"]], template: function StatChartComponent_Template(rf, ctx) { if (rf & 1) {
|
|
50
64
|
i0.ɵɵprojectionDef(_c1);
|
|
51
65
|
i0.ɵɵelementStart(0, "div", 0)(1, "div", 1)(2, "div", 2);
|
|
52
66
|
i0.ɵɵprojection(3);
|
|
@@ -65,6 +79,6 @@ export class StatChartComponent extends BaseComponentChart {
|
|
|
65
79
|
}
|
|
66
80
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(StatChartComponent, [{
|
|
67
81
|
type: Component,
|
|
68
|
-
args: [{ selector: 'acl-stat-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"stat\">\n <div class=\"tw-flex\">\n <div class=\"achart-title tw-flex-1 tw-break-all\">\n <ng-content select=\"a-title\"></ng-content>\n </div>\n </div>\n <div\n class=\"stat\"\n *ngIf=\"data$ | async as statSeries\"\n >\n <div class=\"body\">\n <div\n class=\"item\"\n *ngFor=\"let item of statSeries\"\n >\n
|
|
82
|
+
args: [{ selector: 'acl-stat-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"stat\">\n <div class=\"tw-flex\">\n <div class=\"achart-title tw-flex-1 tw-break-all\">\n <ng-content select=\"a-title\"></ng-content>\n </div>\n </div>\n <div\n class=\"stat\"\n *ngIf=\"data$ | async as statSeries\"\n >\n <div class=\"body\">\n <div\n class=\"item\"\n *ngFor=\"let item of statSeries\"\n >\n <div\n class=\"name\"\n *ngIf=\"statSeries?.length > 1\"\n >\n {{ $any(item).name }}\n </div>\n <div\n class=\"value\"\n [style.color]=\"item?.color\"\n >\n {{ $any(item).displayName }}\n <span\n class=\"tw-text-l tw-font-bold\"\n *ngIf=\"$any(item).displayName | pure: showUnit\"\n >{{ $any(item)?.unit | translate: {} : true}}</span\n >\n </div>\n </div>\n </div>\n </div>\n <acl-chart-status\n [status]=\"status\"\n [customError]=\"customError\"\n (refresh)=\"refresh.next()\"\n ></acl-chart-status>\n</div>\n", styles: [":host{position:relative}.stat{display:flex;flex-direction:column;width:100%;height:100%}.stat .body{display:flex;height:100%}.stat .item{flex:1;padding:12px;display:flex;align-items:center;justify-content:center;flex-direction:column}.stat .title{font-size:20px}.stat .value{font-size:60px;line-height:initial}\n"] }]
|
|
69
83
|
}], null, null); })();
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdC1jaGFydC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9zcmMvYS1tZXRyaWMtY2hhcnQvc3RhdC1jaGFydC9zdGF0LWNoYXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9hLW1ldHJpYy1jaGFydC9zdGF0LWNoYXJ0L3N0YXQtY2hhcnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRXJDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDOzs7SUNZckQsK0JBR0M7SUFDQyxZQUNGO0lBQUEsaUJBQU07OztJQURKLGVBQ0Y7SUFERSw2Q0FDRjs7OztJQU1FLGdDQUdHO0lBQUEsWUFBNEM7O0lBQUEsaUJBQzlDOzs7O0lBREUsZUFBNEM7SUFBNUMsK0hBQTRDOzs7SUFsQm5ELDhCQUdDO0lBQ0MsK0VBS007SUFDTiw4QkFHQztJQUNDLFlBQ0E7SUFBQSxrRkFJQzs7SUFDSCxpQkFBTSxFQUFBOzs7OztJQWRILGVBQTRCO0lBQTVCLGdGQUE0QjtJQU03QixlQUEyQjtJQUEzQiwrREFBMkI7SUFFM0IsZUFDQTtJQURBLG9EQUNBO0lBRUcsZUFBNkM7SUFBN0MsaUZBQTZDOzs7SUF0QnhELDhCQUdDLGFBQUE7SUFFRyx5RUFxQk07SUFDUixpQkFBTSxFQUFBOzs7SUFwQmUsZUFBYTtJQUFiLHVDQUFhOzs7O0FERnRDLE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxrQkFBa0I7SUFDeEQsUUFBUSxDQUFDLEtBQXNCO1FBQzdCLE9BQU8sUUFBUSxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbkQsQ0FBQztpUEFIVSxrQkFBa0IsU0FBbEIsa0JBQWtCO29FQUFsQixrQkFBa0I7O1lDWC9CLDhCQUFrQixhQUFBLGFBQUE7WUFHWixrQkFBMEM7WUFDNUMsaUJBQU0sRUFBQTtZQUVSLG1FQTRCTTs7WUFDTiwyQ0FJQztZQURDLDZHQUFXLGtCQUFjLElBQUM7WUFDM0IsaUJBQW1CLEVBQUE7O1lBL0JqQixlQUFvQjtZQUFwQixzREFBb0I7WUE0QnJCLGVBQWlCO1lBQWpCLG1DQUFpQixnQ0FBQTs7O3VGRHpCUixrQkFBa0I7Y0FOOUIsU0FBUzsyQkFDRSxnQkFBZ0IsbUJBR1QsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGlzTnVtYmVyIH0gZnJvbSAnbG9kYXNoLWVzJztcblxuaW1wb3J0IHsgQmFzZUNvbXBvbmVudENoYXJ0IH0gZnJvbSAnLi4vYmFzZS1jaGFydC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhY2wtc3RhdC1jaGFydCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9zdGF0LWNoYXJ0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3RhdC1jaGFydC5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgU3RhdENoYXJ0Q29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudENoYXJ0IHtcbiAgc2hvd1VuaXQodmFsdWU6IHN0cmluZyB8IG51bWJlcikge1xuICAgIHJldHVybiBpc051bWJlcigrdmFsdWUpICYmICFOdW1iZXIuaXNOYU4oK3ZhbHVlKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInN0YXRcIj5cbiAgPGRpdiBjbGFzcz1cInR3LWZsZXhcIj5cbiAgICA8ZGl2IGNsYXNzPVwiYWNoYXJ0LXRpdGxlIHR3LWZsZXgtMSB0dy1icmVhay1hbGxcIj5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImEtdGl0bGVcIj48L25nLWNvbnRlbnQ+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuICA8ZGl2XG4gICAgY2xhc3M9XCJzdGF0XCJcbiAgICAqbmdJZj1cImRhdGEkIHwgYXN5bmMgYXMgc3RhdFNlcmllc1wiXG4gID5cbiAgICA8ZGl2IGNsYXNzPVwiYm9keVwiPlxuICAgICAgPGRpdlxuICAgICAgICBjbGFzcz1cIml0ZW1cIlxuICAgICAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiBzdGF0U2VyaWVzXCJcbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNsYXNzPVwibmFtZVwiXG4gICAgICAgICAgKm5nSWY9XCJzdGF0U2VyaWVzPy5sZW5ndGggPiAxXCJcbiAgICAgICAgPlxuICAgICAgICAgIHt7ICRhbnkoaXRlbSkubmFtZSB9fVxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNsYXNzPVwidmFsdWVcIlxuICAgICAgICAgIFtzdHlsZS5jb2xvcl09XCJpdGVtPy5jb2xvclwiXG4gICAgICAgID5cbiAgICAgICAgICB7eyAkYW55KGl0ZW0pLmRpc3BsYXlOYW1lIH19XG4gICAgICAgICAgPHNwYW5cbiAgICAgICAgICAgIGNsYXNzPVwidHctdGV4dC1sIHR3LWZvbnQtYm9sZFwiXG4gICAgICAgICAgICAqbmdJZj1cIiRhbnkoaXRlbSkuZGlzcGxheU5hbWUgfCBwdXJlOiBzaG93VW5pdFwiXG4gICAgICAgICAgICA+e3sgJGFueShpdGVtKT8udW5pdCB8IHRyYW5zbGF0ZToge30gOiB0cnVlfX08L3NwYW5cbiAgICAgICAgICA+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuICA8YWNsLWNoYXJ0LXN0YXR1c1xuICAgIFtzdGF0dXNdPVwic3RhdHVzXCJcbiAgICBbY3VzdG9tRXJyb3JdPVwiY3VzdG9tRXJyb3JcIlxuICAgIChyZWZyZXNoKT1cInJlZnJlc2gubmV4dCgpXCJcbiAgPjwvYWNsLWNoYXJ0LXN0YXR1cz5cbjwvZGl2PlxuIl19
|
|
@@ -179,7 +179,7 @@ export class TableChartComponent extends BaseComponentChart {
|
|
|
179
179
|
i0.ɵɵelementEnd()();
|
|
180
180
|
} if (rf & 2) {
|
|
181
181
|
i0.ɵɵadvance(4);
|
|
182
|
-
i0.ɵɵproperty("ngIf", ctx.list);
|
|
182
|
+
i0.ɵɵproperty("ngIf", ctx.list == null ? null : ctx.list.length);
|
|
183
183
|
i0.ɵɵadvance(1);
|
|
184
184
|
i0.ɵɵproperty("status", ctx._status)("customError", ctx.customError);
|
|
185
185
|
} }, styles: ["[_nghost-%COMP%]{width:100%;height:100%}[_nghost-%COMP%] .aui-table{padding:0}[_nghost-%COMP%] .aui-table__row{min-width:auto}[_nghost-%COMP%] .aui-table__scroll-wrapper{padding-left:0}[_nghost-%COMP%] .aui-table__row:not(.aui-table__scroll-shadow .aui-table__row:last-child) .aui-table__cell, [_nghost-%COMP%] .aui-table__row .aui-table__cell:first-of-type{border-left:0}[_nghost-%COMP%] .aui-table__scroll-shadow .aui-table__row .aui-table__cell:first-of-type, [_nghost-%COMP%] .aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:first-of-type{padding-left:0}[_nghost-%COMP%] .aui-table__scroll-shadow.hasTableBottomShadow:after{display:none}[_nghost-%COMP%] .aui-table__row, [_nghost-%COMP%] .aui-table__cell, [_nghost-%COMP%] .aui-table__header-row{background-color:transparent}"], changeDetection: 0 }); }
|
|
@@ -190,7 +190,7 @@ __decorate([
|
|
|
190
190
|
], TableChartComponent.prototype, "list$", void 0);
|
|
191
191
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TableChartComponent, [{
|
|
192
192
|
type: Component,
|
|
193
|
-
args: [{ selector: 'a-table-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"tw-h-full\">\n <div class=\"tw-flex\">\n <div class=\"achart-title tw-flex-1 tw-break-all\">\n <ng-content select=\"a-title\"></ng-content>\n </div>\n </div>\n <div\n class=\"table tw-mt-8\"\n [ngStyle]=\"{ height: 'calc(100% - 15px)' }\"\n *ngIf=\"list\"\n >\n <div [auiTableScrollWrapper]=\"paginator ? 'calc(100% - 48px)' : '100%'\">\n <aui-table\n [dataSource]=\"columns.length ? (tableList$ | async) : []\"\n auiTableScrollable\n >\n <ng-container *ngFor=\"let column of columns\">\n <ng-container [auiTableColumnDef]=\"column\">\n <aui-table-header-cell\n [class]=\"alignment | pure: getAlignmentClass\"\n *auiTableHeaderCellDef\n >\n {{$any(list?.[0]?.[column]?.sourceName) === 'time' && !$any(list?.[0]?.[column]?.displayName) ? (column | translate) : column }}\n <ng-container\n *ngIf=\"$any(tableList$ | async)?.[0]?.[column]?.unit as unit\"\n >\n ({{ unit }})\n </ng-container>\n </aui-table-header-cell>\n <aui-table-cell\n [class]=\"alignment | pure: getAlignmentClass\"\n *auiTableCellDef=\"let item; let index = index\"\n >\n <span\n class=\"tw-text-ellipsis tw-overflow-hidden\"\n [ngStyle]=\"{ color: item?.[column]?.color }\"\n >\n {{ item?.[column]?.value | pure: format:item?.[column]?.sourceName: item?.[column]?.unit | aclFieldNotAvailable }}\n </span>\n </aui-table-cell>\n </ng-container>\n </ng-container>\n\n <aui-table-header-row\n *auiTableHeaderRowDef=\"columns; sticky: true\"\n ></aui-table-header-row>\n <aui-table-row\n *auiTableRowDef=\"let row; columns: columns\"\n ></aui-table-row>\n </aui-table>\n </div>\n <aui-paginator\n *ngIf=\"paginator\"\n layout=\"pager\"\n [currentPage]=\"(paginator$$ | async).currentPage\"\n [pageSize]=\"(paginator$$ | async).pageSize\"\n [total]=\"list.length || 0\"\n (currentPageChange)=\"onPageChange($event)\"\n ></aui-paginator>\n </div>\n <acl-chart-status\n [status]=\"_status\"\n [customError]=\"customError\"\n (refresh)=\"refresh.next()\"\n ></acl-chart-status>\n</div>\n", styles: [":host{width:100%;height:100%}:host ::ng-deep .aui-table{padding:0}:host ::ng-deep .aui-table__row{min-width:auto}:host ::ng-deep .aui-table__scroll-wrapper{padding-left:0}:host ::ng-deep .aui-table__row:not(.aui-table__scroll-shadow .aui-table__row:last-child) .aui-table__cell,:host ::ng-deep .aui-table__row .aui-table__cell:first-of-type{border-left:0}:host ::ng-deep .aui-table__scroll-shadow .aui-table__row .aui-table__cell:first-of-type,:host ::ng-deep .aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:first-of-type{padding-left:0}:host ::ng-deep .aui-table__scroll-shadow.hasTableBottomShadow:after{display:none}:host ::ng-deep .aui-table__row,:host ::ng-deep .aui-table__cell,:host ::ng-deep .aui-table__header-row{background-color:transparent}\n"] }]
|
|
193
|
+
args: [{ selector: 'a-table-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"tw-h-full\">\n <div class=\"tw-flex\">\n <div class=\"achart-title tw-flex-1 tw-break-all\">\n <ng-content select=\"a-title\"></ng-content>\n </div>\n </div>\n <div\n class=\"table tw-mt-8\"\n [ngStyle]=\"{ height: 'calc(100% - 15px)' }\"\n *ngIf=\"list?.length\"\n >\n <div [auiTableScrollWrapper]=\"paginator ? 'calc(100% - 48px)' : '100%'\">\n <aui-table\n [dataSource]=\"columns.length ? (tableList$ | async) : []\"\n auiTableScrollable\n >\n <ng-container *ngFor=\"let column of columns\">\n <ng-container [auiTableColumnDef]=\"column\">\n <aui-table-header-cell\n [class]=\"alignment | pure: getAlignmentClass\"\n *auiTableHeaderCellDef\n >\n {{$any(list?.[0]?.[column]?.sourceName) === 'time' && !$any(list?.[0]?.[column]?.displayName) ? (column | translate) : column }}\n <ng-container\n *ngIf=\"$any(tableList$ | async)?.[0]?.[column]?.unit as unit\"\n >\n ({{ unit }})\n </ng-container>\n </aui-table-header-cell>\n <aui-table-cell\n [class]=\"alignment | pure: getAlignmentClass\"\n *auiTableCellDef=\"let item; let index = index\"\n >\n <span\n class=\"tw-text-ellipsis tw-overflow-hidden\"\n [ngStyle]=\"{ color: item?.[column]?.color }\"\n >\n {{ item?.[column]?.value | pure: format:item?.[column]?.sourceName: item?.[column]?.unit | aclFieldNotAvailable }}\n </span>\n </aui-table-cell>\n </ng-container>\n </ng-container>\n\n <aui-table-header-row\n *auiTableHeaderRowDef=\"columns; sticky: true\"\n ></aui-table-header-row>\n <aui-table-row\n *auiTableRowDef=\"let row; columns: columns\"\n ></aui-table-row>\n </aui-table>\n </div>\n <aui-paginator\n *ngIf=\"paginator\"\n layout=\"pager\"\n [currentPage]=\"(paginator$$ | async).currentPage\"\n [pageSize]=\"(paginator$$ | async).pageSize\"\n [total]=\"list.length || 0\"\n (currentPageChange)=\"onPageChange($event)\"\n ></aui-paginator>\n </div>\n <acl-chart-status\n [status]=\"_status\"\n [customError]=\"customError\"\n (refresh)=\"refresh.next()\"\n ></acl-chart-status>\n</div>\n", styles: [":host{width:100%;height:100%}:host ::ng-deep .aui-table{padding:0}:host ::ng-deep .aui-table__row{min-width:auto}:host ::ng-deep .aui-table__scroll-wrapper{padding-left:0}:host ::ng-deep .aui-table__row:not(.aui-table__scroll-shadow .aui-table__row:last-child) .aui-table__cell,:host ::ng-deep .aui-table__row .aui-table__cell:first-of-type{border-left:0}:host ::ng-deep .aui-table__scroll-shadow .aui-table__row .aui-table__cell:first-of-type,:host ::ng-deep .aui-table__scroll-shadow .aui-table__header-row .aui-table__header-cell:first-of-type{padding-left:0}:host ::ng-deep .aui-table__scroll-shadow.hasTableBottomShadow:after{display:none}:host ::ng-deep .aui-table__row,:host ::ng-deep .aui-table__cell,:host ::ng-deep .aui-table__header-row{background-color:transparent}\n"] }]
|
|
194
194
|
}], null, { list: [{
|
|
195
195
|
type: Input
|
|
196
196
|
}], list$: [], alignment: [{
|
|
@@ -198,4 +198,4 @@ __decorate([
|
|
|
198
198
|
}], paginator: [{
|
|
199
199
|
type: Input
|
|
200
200
|
}] }); })();
|
|
201
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-chart.component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/a-metric-chart/table-chart/table-chart.component.ts","../../../../../../libs/common/src/a-metric-chart/table-chart/table-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport dayjs from 'dayjs';\nimport { get, uniq } from 'lodash-es';\nimport { BehaviorSubject, Observable, combineLatest, map } from 'rxjs';\n\nimport {\n  DATE_TIME_FORMAT,\n  ObservableInput,\n  publishRef,\n} from '../../core/public-api';\nimport { BaseComponentChart } from '../base-chart.component';\n\ntype TableItem = Record<string, Record<string, unknown>>;\n\n@Component({\n  selector: 'a-table-chart',\n  templateUrl: './table-chart.component.html',\n  styleUrls: ['./table-chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TableChartComponent extends BaseComponentChart {\n  @Input() list: TableItem[];\n  @ObservableInput() list$!: Observable<TableItem[]>;\n\n  @Input() alignment: 'left' | 'center' | 'right' = 'left';\n\n  @Input() paginator: {\n    layout: string | string[];\n    currentPage?: number;\n    pageIndex?: number;\n    pageSize?: number;\n    total?: number;\n  };\n\n  get columns() {\n    return this.list?.length\n      ? this.list.reduce(\n          (prev, item) => uniq([...prev, ...Object.keys(item)]),\n          [],\n        )\n      : [];\n  }\n\n  get _status() {\n    return this.columns.length ? this.status : { ...this.status, noData: true };\n  }\n\n  getAlignmentClass(type: 'left' | 'center' | 'right') {\n    return {\n      left: 'tw-justify-start',\n      center: 'tw-justify-center',\n      right: 'tw-justify-end',\n    }[type];\n  }\n\n  paginator$$ = new BehaviorSubject({\n    currentPage: 1,\n    pageSize: 5,\n  });\n\n  tableList$ = combineLatest([this.list$, this.paginator$$]).pipe(\n    map(([item, { currentPage, pageSize }]) => {\n      const list = get(item?.[0], ['time', 'value'])\n        ? item.sort(\n            (a, b) => (b.time.value as number) - (a.time.value as number),\n          )\n        : item;\n      if (!this.paginator) {\n        return list;\n      }\n      return list.slice((currentPage - 1) * pageSize, currentPage * pageSize);\n    }),\n    publishRef(),\n  );\n\n  format(value: string, type: string, unit: string) {\n    if (!value) {\n      return;\n    }\n    let data: string | number = value;\n    if (unit === '%') {\n      data = isNaN(+value) || !value ? value : +value * 100;\n    }\n    if (type.includes('value')) {\n      return isNaN(+data) || !data ? data : +(+data)?.toFixed(2);\n    }\n    switch (type) {\n      case 'time': {\n        return dayjs(+data * 1000).format(DATE_TIME_FORMAT);\n      }\n      default: {\n        return data;\n      }\n    }\n  }\n\n  onPageChange(currentPage: number) {\n    this.paginator$$.next({\n      currentPage,\n      pageSize: this.paginator.pageSize || 5,\n    });\n  }\n}\n","<div class=\"tw-h-full\">\n  <div class=\"tw-flex\">\n    <div class=\"achart-title tw-flex-1 tw-break-all\">\n      <ng-content select=\"a-title\"></ng-content>\n    </div>\n  </div>\n  <div\n    class=\"table tw-mt-8\"\n    [ngStyle]=\"{ height: 'calc(100% - 15px)' }\"\n    *ngIf=\"list\"\n  >\n    <div [auiTableScrollWrapper]=\"paginator ? 'calc(100% - 48px)' : '100%'\">\n      <aui-table\n        [dataSource]=\"columns.length ? (tableList$ | async) : []\"\n        auiTableScrollable\n      >\n        <ng-container *ngFor=\"let column of columns\">\n          <ng-container [auiTableColumnDef]=\"column\">\n            <aui-table-header-cell\n              [class]=\"alignment | pure: getAlignmentClass\"\n              *auiTableHeaderCellDef\n            >\n              {{$any(list?.[0]?.[column]?.sourceName) === 'time' && !$any(list?.[0]?.[column]?.displayName)  ?  (column | translate) : column }}\n              <ng-container\n                *ngIf=\"$any(tableList$ | async)?.[0]?.[column]?.unit as unit\"\n              >\n                ({{ unit }})\n              </ng-container>\n            </aui-table-header-cell>\n            <aui-table-cell\n              [class]=\"alignment | pure: getAlignmentClass\"\n              *auiTableCellDef=\"let item; let index = index\"\n            >\n              <span\n                class=\"tw-text-ellipsis tw-overflow-hidden\"\n                [ngStyle]=\"{ color: item?.[column]?.color }\"\n              >\n                {{ item?.[column]?.value | pure: format:item?.[column]?.sourceName: item?.[column]?.unit | aclFieldNotAvailable }}\n              </span>\n            </aui-table-cell>\n          </ng-container>\n        </ng-container>\n\n        <aui-table-header-row\n          *auiTableHeaderRowDef=\"columns; sticky: true\"\n        ></aui-table-header-row>\n        <aui-table-row\n          *auiTableRowDef=\"let row; columns: columns\"\n        ></aui-table-row>\n      </aui-table>\n    </div>\n    <aui-paginator\n      *ngIf=\"paginator\"\n      layout=\"pager\"\n      [currentPage]=\"(paginator$$ | async).currentPage\"\n      [pageSize]=\"(paginator$$ | async).pageSize\"\n      [total]=\"list.length || 0\"\n      (currentPageChange)=\"onPageChange($event)\"\n    ></aui-paginator>\n  </div>\n  <acl-chart-status\n    [status]=\"_status\"\n    [customError]=\"customError\"\n    (refresh)=\"refresh.next()\"\n  ></acl-chart-status>\n</div>\n"]}
|
|
201
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-chart.component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/a-metric-chart/table-chart/table-chart.component.ts","../../../../../../libs/common/src/a-metric-chart/table-chart/table-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core';\nimport dayjs from 'dayjs';\nimport { get, uniq } from 'lodash-es';\nimport { BehaviorSubject, Observable, combineLatest, map } from 'rxjs';\n\nimport {\n  DATE_TIME_FORMAT,\n  ObservableInput,\n  publishRef,\n} from '../../core/public-api';\nimport { BaseComponentChart } from '../base-chart.component';\n\ntype TableItem = Record<string, Record<string, unknown>>;\n\n@Component({\n  selector: 'a-table-chart',\n  templateUrl: './table-chart.component.html',\n  styleUrls: ['./table-chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TableChartComponent extends BaseComponentChart {\n  @Input() list: TableItem[];\n  @ObservableInput() list$!: Observable<TableItem[]>;\n\n  @Input() alignment: 'left' | 'center' | 'right' = 'left';\n\n  @Input() paginator: {\n    layout: string | string[];\n    currentPage?: number;\n    pageIndex?: number;\n    pageSize?: number;\n    total?: number;\n  };\n\n  get columns() {\n    return this.list?.length\n      ? this.list.reduce(\n          (prev, item) => uniq([...prev, ...Object.keys(item)]),\n          [],\n        )\n      : [];\n  }\n\n  get _status() {\n    return this.columns.length ? this.status : { ...this.status, noData: true };\n  }\n\n  getAlignmentClass(type: 'left' | 'center' | 'right') {\n    return {\n      left: 'tw-justify-start',\n      center: 'tw-justify-center',\n      right: 'tw-justify-end',\n    }[type];\n  }\n\n  paginator$$ = new BehaviorSubject({\n    currentPage: 1,\n    pageSize: 5,\n  });\n\n  tableList$ = combineLatest([this.list$, this.paginator$$]).pipe(\n    map(([item, { currentPage, pageSize }]) => {\n      const list = get(item?.[0], ['time', 'value'])\n        ? item.sort(\n            (a, b) => (b.time.value as number) - (a.time.value as number),\n          )\n        : item;\n      if (!this.paginator) {\n        return list;\n      }\n      return list.slice((currentPage - 1) * pageSize, currentPage * pageSize);\n    }),\n    publishRef(),\n  );\n\n  format(value: string, type: string, unit: string) {\n    if (!value) {\n      return;\n    }\n    let data: string | number = value;\n    if (unit === '%') {\n      data = isNaN(+value) || !value ? value : +value * 100;\n    }\n    if (type.includes('value')) {\n      return isNaN(+data) || !data ? data : +(+data)?.toFixed(2);\n    }\n    switch (type) {\n      case 'time': {\n        return dayjs(+data * 1000).format(DATE_TIME_FORMAT);\n      }\n      default: {\n        return data;\n      }\n    }\n  }\n\n  onPageChange(currentPage: number) {\n    this.paginator$$.next({\n      currentPage,\n      pageSize: this.paginator.pageSize || 5,\n    });\n  }\n}\n","<div class=\"tw-h-full\">\n  <div class=\"tw-flex\">\n    <div class=\"achart-title tw-flex-1 tw-break-all\">\n      <ng-content select=\"a-title\"></ng-content>\n    </div>\n  </div>\n  <div\n    class=\"table tw-mt-8\"\n    [ngStyle]=\"{ height: 'calc(100% - 15px)' }\"\n    *ngIf=\"list?.length\"\n  >\n    <div [auiTableScrollWrapper]=\"paginator ? 'calc(100% - 48px)' : '100%'\">\n      <aui-table\n        [dataSource]=\"columns.length ? (tableList$ | async) : []\"\n        auiTableScrollable\n      >\n        <ng-container *ngFor=\"let column of columns\">\n          <ng-container [auiTableColumnDef]=\"column\">\n            <aui-table-header-cell\n              [class]=\"alignment | pure: getAlignmentClass\"\n              *auiTableHeaderCellDef\n            >\n              {{$any(list?.[0]?.[column]?.sourceName) === 'time' && !$any(list?.[0]?.[column]?.displayName)  ?  (column | translate) : column }}\n              <ng-container\n                *ngIf=\"$any(tableList$ | async)?.[0]?.[column]?.unit as unit\"\n              >\n                ({{ unit }})\n              </ng-container>\n            </aui-table-header-cell>\n            <aui-table-cell\n              [class]=\"alignment | pure: getAlignmentClass\"\n              *auiTableCellDef=\"let item; let index = index\"\n            >\n              <span\n                class=\"tw-text-ellipsis tw-overflow-hidden\"\n                [ngStyle]=\"{ color: item?.[column]?.color }\"\n              >\n                {{ item?.[column]?.value | pure: format:item?.[column]?.sourceName: item?.[column]?.unit | aclFieldNotAvailable }}\n              </span>\n            </aui-table-cell>\n          </ng-container>\n        </ng-container>\n\n        <aui-table-header-row\n          *auiTableHeaderRowDef=\"columns; sticky: true\"\n        ></aui-table-header-row>\n        <aui-table-row\n          *auiTableRowDef=\"let row; columns: columns\"\n        ></aui-table-row>\n      </aui-table>\n    </div>\n    <aui-paginator\n      *ngIf=\"paginator\"\n      layout=\"pager\"\n      [currentPage]=\"(paginator$$ | async).currentPage\"\n      [pageSize]=\"(paginator$$ | async).pageSize\"\n      [total]=\"list.length || 0\"\n      (currentPageChange)=\"onPageChange($event)\"\n    ></aui-paginator>\n  </div>\n  <acl-chart-status\n    [status]=\"_status\"\n    [customError]=\"customError\"\n    (refresh)=\"refresh.next()\"\n  ></acl-chart-status>\n</div>\n"]}
|
|
@@ -117,12 +117,13 @@ function matchLegend(value) {
|
|
|
117
117
|
}
|
|
118
118
|
// 填充空数据
|
|
119
119
|
// eslint-disable-next-line sonarjs/cognitive-complexity
|
|
120
|
-
export function fillNullData({ start, end, step }, res = [], stepLine = false) {
|
|
120
|
+
export function fillNullData({ start, end, step }, res = [], isZero = false, stepLine = false) {
|
|
121
121
|
if (!+start || !+end) {
|
|
122
122
|
return res;
|
|
123
123
|
}
|
|
124
124
|
const _step = step || roundInterval(start, end);
|
|
125
125
|
const curStart = +start;
|
|
126
|
+
const nullValue = isZero ? 0 : null;
|
|
126
127
|
const curEnd = start + step * ((end - start) / step);
|
|
127
128
|
const preX = stepLine
|
|
128
129
|
? {
|
|
@@ -132,9 +133,9 @@ export function fillNullData({ start, end, step }, res = [], stepLine = false) {
|
|
|
132
133
|
}
|
|
133
134
|
: {};
|
|
134
135
|
const result = [
|
|
135
|
-
...(curStart === res[0]?.x ? [] : [{ x: curStart, y:
|
|
136
|
+
...(curStart === res[0]?.x ? [] : [{ x: curStart, y: nullValue, ...preX }]),
|
|
136
137
|
...res,
|
|
137
|
-
...(res.at(-1)?.x
|
|
138
|
+
...(res.at(-1)?.x >= curEnd ? [] : [{ x: curEnd, y: nullValue }]),
|
|
138
139
|
];
|
|
139
140
|
// query 返回数据可能存在某个时间段无数据情况,会导致前端bug
|
|
140
141
|
// 通过 step 计算出 总数据。
|
|
@@ -159,7 +160,7 @@ export function fillNullData({ start, end, step }, res = [], stepLine = false) {
|
|
|
159
160
|
...old,
|
|
160
161
|
{
|
|
161
162
|
x: x / 1000,
|
|
162
|
-
y:
|
|
163
|
+
y: nullValue,
|
|
163
164
|
...(stepLine
|
|
164
165
|
? { preX: i === 0 ? result[index].x : old[i - 1].x }
|
|
165
166
|
: {}),
|
|
@@ -221,4 +222,4 @@ export function findTimeRange(diff) {
|
|
|
221
222
|
});
|
|
222
223
|
return time ? { start: time.startTime(), end: time.endTime() } : null;
|
|
223
224
|
}
|
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../libs/common/src/a-metric-chart/utils/util.ts"],"names":[],"mappings":"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","sourcesContent":["import dayjs from 'dayjs';\nimport { get, isFunction, template } from 'lodash-es';\nimport { DataItem, TooltipValue } from 'zz-chart';\n\nimport { CHART_TIME_FORMAT, AChartData } from '../../a-chart/public-api';\nimport { MonitorMetric, MonitorMetricResult } from '../../api/public-api';\nimport {\n  Dictionary,\n  FIELD_NOT_AVAILABLE_PLACEHOLDER,\n  StringMap,\n} from '../../core/public-api';\nimport { PICKER_TIME_RANGES } from '../../metric-chart/public-api';\nimport { FetchParams, IndicatorParams, MetricParams } from '../types';\n\nimport { roundInterval } from './range';\n\nexport function handleMetricParams(\n  params: IndicatorParams[],\n  { variableSource, start, end, step, isIndex }: MetricParams,\n) {\n  // eslint-disable-next-line sonarjs/cognitive-complexity\n  const value = params.map((cur, index) => {\n    const v = Array.isArray(variableSource)\n      ? variableSource.filter(\n          (item, i) =>\n            Object.keys(item).length &&\n            ((isIndex\n              ? index === i\n              : cur?.variables?.every(v => Object.keys(item).includes(v))) ||\n              cur.expr),\n        )\n      : cur.variables?.length && variableSource\n      ? [variableSource]\n      : [];\n    const variable: StringMap[] = v.map(value => {\n      return cur.expr\n        ? value\n        : cur.variables?.reduce(\n            (pre, key) =>\n              value[key]\n                ? {\n                    ...pre,\n                    [key]: value[key],\n                  }\n                : pre,\n            {},\n          );\n    });\n    const indicators = cur.indicators || cur.expr;\n    return {\n      indicators: cur.indicators,\n      exprs: cur.expr ? [indicators] : [],\n      variables: variable,\n    };\n  });\n  return {\n    indicators: value,\n    start,\n    end,\n    step,\n  };\n}\n\nexport function handleChartData(\n  { indicatorParams, metricParams }: FetchParams,\n  data: MonitorMetric[],\n) {\n  if (!data) {\n    return [];\n  }\n  const { dependentData } = metricParams;\n  return dependentData\n    ? dependOnData(indicatorParams, data)\n    : dependOnIndicator(indicatorParams, data);\n}\n\nexport function dependOnIndicator(\n  indicatorParams: IndicatorParams[],\n  data: MonitorMetric[],\n): AChartData[] {\n  return indicatorParams.reduce((pre, params) => {\n    const metricData = data?.find(item => item.indicator === params.indicators);\n    return [...pre, handleDataResult(params, metricData?.result?.[0])];\n  }, []);\n}\n\nexport function dependOnData(\n  indicatorParams: IndicatorParams[],\n  data: MonitorMetric[],\n): AChartData[] {\n  const params = indicatorParams[0];\n  return data?.reduce((pre, res) => {\n    if (params.indicators === res.indicator || params.expr === res.query) {\n      return [\n        ...pre,\n        ...res.result.map(item => handleDataResult(params, item)),\n      ];\n    }\n    return pre;\n  }, []);\n}\n\nexport function handleDataResult(\n  params: IndicatorParams,\n  res: MonitorMetricResult,\n) {\n  return {\n    name: handleLegend(params, res),\n    values: res?.values?.map(d => ({\n      x: d[0],\n      y: d[1],\n    })),\n  };\n}\n\nexport function handleLegend(\n  params: IndicatorParams,\n  result: MonitorMetricResult,\n) {\n  return isFunction(params?.legend)\n    ? params.legend(params, result)\n    : getLegendName(params?.legend, result?.metric || {});\n}\nexport const LEGEND_TEMPLATE_OPTIONS = Object.freeze({\n  // eslint-disable-next-line regexp/match-any, regexp/strict\n  interpolate: /{{\\.([\\S\\s]+?)}}/g,\n});\n\nexport function getLegendName(metricKey: string, metric: StringMap) {\n  if (!metricKey && !Object.keys(metric || {})?.length) {\n    return FIELD_NOT_AVAILABLE_PLACEHOLDER;\n  }\n  if (!metricKey && metric) {\n    return JSON.stringify(metric);\n  }\n  const metricKeys = metricKey?.split(',').map(matchLegend);\n  if (metricKeys?.length > 1) {\n    const value = metric?.[metricKeys.find(item => metric[item])];\n    return value || metricKey;\n  }\n  return (\n    getLegendTemplate(metricKey, metric) ||\n    metric[matchLegend(metricKey)] ||\n    metricKey\n  );\n}\n\nfunction getLegendTemplate(str: string, obj: object) {\n  let name: string;\n  try {\n    name = get(obj, str) || template(str, LEGEND_TEMPLATE_OPTIONS)(obj);\n  } catch {\n    name = '';\n  }\n  return name;\n}\n\nfunction matchLegend(value: string) {\n  // eslint-disable-next-line unicorn/better-regex\n  return value.match(/\\{\\{\\.(.+?)\\}\\}/)?.[1] || value;\n}\n\n// 填充空数据\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport function fillNullData(\n  { start, end, step }: MetricParams,\n  res: DataItem['values'] = [],\n  stepLine = false,\n) {\n  if (!+start || !+end) {\n    return res;\n  }\n  const _step = step || roundInterval(start, end);\n  const curStart = +start;\n  const curEnd = start + step * ((end - start) / step);\n  const preX = stepLine\n    ? {\n        preX: dayjs(curStart)\n          .subtract((end - start) / 6, 's')\n          .valueOf(),\n      }\n    : {};\n  const result = [\n    ...(curStart === res[0]?.x ? [] : [{ x: curStart, y: null, ...preX }]),\n    ...res,\n    ...(res.at(-1)?.x === curEnd ? [] : [{ x: curEnd, y: null }]),\n  ];\n\n  // query 返回数据可能存在某个时间段无数据情况，会导致前端bug\n  // 通过 step 计算出 总数据。\n  // 在出现一开始数据缺失情况，先给数据添加开始时间数据，和结束时间数据。\n  // 在进行遍历，判读当前数据和下一跳数据事件差 是否是这个 step,\n  // 如果不是计算出两者相差 几条数据，然后进行填充\n  const data = result.reduce((acc, prev, index) => {\n    const diff =\n      result[index + 1] && result[index + 1].x * 1000 - prev.x * 1000;\n    const stepM = _step * 1000;\n    // 后端可能出现 +Ifn 导致成 NaN，设置为 null\n    const curValue = {\n      ...prev,\n      y: prev.y,\n    };\n    if (diff && diff !== stepM) {\n      const total = Math.ceil(diff / stepM - 1);\n      const data = Array.from<number>({ length: total || 0 })\n        .fill(0)\n        .reduce((old, _curr, i) => {\n          const x =\n            i === 0 ? prev.x * 1000 + stepM : old[i - 1].x * 1000 + stepM;\n          return [\n            ...old,\n            {\n              x: x / 1000,\n              y: null,\n              ...(stepLine\n                ? { preX: i === 0 ? result[index].x : old[i - 1].x }\n                : {}),\n            },\n          ];\n        }, []);\n      return [...acc, curValue, ...data];\n    }\n    return [...acc, curValue];\n  }, []);\n  return data.sort((a, b) => a.x - b.x);\n}\n\nexport function handleDateAxisLabelFormats(\n  params: MetricParams,\n  isRich?: boolean,\n) {\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 MD_HS_FORMAT = `${M_D_FORMAT} ${CHART_TIME_FORMAT}`;\n    return diff >= m7\n      ? isRich\n        ? MD_HS_FORMAT\n        : M_D_FORMAT\n      : diff < m7 && (diff >= m3 || diff > m1)\n      ? MD_HS_FORMAT\n      : CHART_TIME_FORMAT;\n  }\n}\n\nexport function limitMaxTooltipItem(context: TooltipValue[], limit = 15) {\n  return context.slice(0, limit);\n}\n\nexport const VARIABLE_KEY_CLUSTER = '$cluster';\nexport const VARIABLE_KEY_NAMESPACE = '$namespace';\n\nexport function replaceExprVariable(\n  expr: string | string[],\n  variable: Dictionary<any>,\n) {\n  let data = Array.isArray(expr) ? expr.join('|') : expr;\n  const variableKeys = Object.keys(variable || {});\n  const variableValues = Object.values(variable || {});\n  const vars: string[] =\n    data && typeof data.match === 'function' ? data.match(/\\$\\w+/g) : [];\n  if (\n    !variableKeys.length ||\n    !variableKeys.some(v => vars?.some(item => item.replace('$', '') === v))\n  ) {\n    return data;\n  }\n\n  vars\n    .sort((a, b) => b.length - a.length)\n    .forEach(key => {\n      const k = key.replace('$', '');\n      const index = variableKeys.indexOf(k);\n      if (index >= 0) {\n        const v = variableValues[index];\n        data = data?.replace(\n          new RegExp(`\\\\$${k}`, 'g'),\n          Array.isArray(v) ? v.join('|') : v,\n        );\n      }\n    });\n  return data;\n}\n\nexport function findTimeRange(diff: number) {\n  const time = PICKER_TIME_RANGES.find(item => {\n    return item.endTime() - item.startTime() === diff;\n  });\n  return time ? { start: time.startTime(), end: time.endTime() } : null;\n}\n"]}
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../libs/common/src/a-metric-chart/utils/util.ts"],"names":[],"mappings":"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","sourcesContent":["import dayjs from 'dayjs';\nimport { get, isFunction, template } from 'lodash-es';\nimport { DataItem, TooltipValue } from 'zz-chart';\n\nimport { CHART_TIME_FORMAT, AChartData } from '../../a-chart/public-api';\nimport { MonitorMetric, MonitorMetricResult } from '../../api/public-api';\nimport {\n  Dictionary,\n  FIELD_NOT_AVAILABLE_PLACEHOLDER,\n  StringMap,\n} from '../../core/public-api';\nimport { PICKER_TIME_RANGES } from '../../metric-chart/public-api';\nimport { FetchParams, IndicatorParams, MetricParams } from '../types';\n\nimport { roundInterval } from './range';\n\nexport function handleMetricParams(\n  params: IndicatorParams[],\n  { variableSource, start, end, step, isIndex }: MetricParams,\n) {\n  // eslint-disable-next-line sonarjs/cognitive-complexity\n  const value = params.map((cur, index) => {\n    const v = Array.isArray(variableSource)\n      ? variableSource.filter(\n          (item, i) =>\n            Object.keys(item).length &&\n            ((isIndex\n              ? index === i\n              : cur?.variables?.every(v => Object.keys(item).includes(v))) ||\n              cur.expr),\n        )\n      : cur.variables?.length && variableSource\n      ? [variableSource]\n      : [];\n    const variable: StringMap[] = v.map(value => {\n      return cur.expr\n        ? value\n        : cur.variables?.reduce(\n            (pre, key) =>\n              value[key]\n                ? {\n                    ...pre,\n                    [key]: value[key],\n                  }\n                : pre,\n            {},\n          );\n    });\n    const indicators = cur.indicators || cur.expr;\n    return {\n      indicators: cur.indicators,\n      exprs: cur.expr ? [indicators] : [],\n      variables: variable,\n    };\n  });\n  return {\n    indicators: value,\n    start,\n    end,\n    step,\n  };\n}\n\nexport function handleChartData(\n  { indicatorParams, metricParams }: FetchParams,\n  data: MonitorMetric[],\n) {\n  if (!data) {\n    return [];\n  }\n  const { dependentData } = metricParams;\n  return dependentData\n    ? dependOnData(indicatorParams, data)\n    : dependOnIndicator(indicatorParams, data);\n}\n\nexport function dependOnIndicator(\n  indicatorParams: IndicatorParams[],\n  data: MonitorMetric[],\n): AChartData[] {\n  return indicatorParams.reduce((pre, params) => {\n    const metricData = data?.find(item => item.indicator === params.indicators);\n    return [...pre, handleDataResult(params, metricData?.result?.[0])];\n  }, []);\n}\n\nexport function dependOnData(\n  indicatorParams: IndicatorParams[],\n  data: MonitorMetric[],\n): AChartData[] {\n  const params = indicatorParams[0];\n  return data?.reduce((pre, res) => {\n    if (params.indicators === res.indicator || params.expr === res.query) {\n      return [\n        ...pre,\n        ...res.result.map(item => handleDataResult(params, item)),\n      ];\n    }\n    return pre;\n  }, []);\n}\n\nexport function handleDataResult(\n  params: IndicatorParams,\n  res: MonitorMetricResult,\n) {\n  return {\n    name: handleLegend(params, res),\n    values: res?.values?.map(d => ({\n      x: d[0],\n      y: d[1],\n    })),\n  };\n}\n\nexport function handleLegend(\n  params: IndicatorParams,\n  result: MonitorMetricResult,\n) {\n  return isFunction(params?.legend)\n    ? params.legend(params, result)\n    : getLegendName(params?.legend, result?.metric || {});\n}\nexport const LEGEND_TEMPLATE_OPTIONS = Object.freeze({\n  // eslint-disable-next-line regexp/match-any, regexp/strict\n  interpolate: /{{\\.([\\S\\s]+?)}}/g,\n});\n\nexport function getLegendName(metricKey: string, metric: StringMap) {\n  if (!metricKey && !Object.keys(metric || {})?.length) {\n    return FIELD_NOT_AVAILABLE_PLACEHOLDER;\n  }\n  if (!metricKey && metric) {\n    return JSON.stringify(metric);\n  }\n  const metricKeys = metricKey?.split(',').map(matchLegend);\n  if (metricKeys?.length > 1) {\n    const value = metric?.[metricKeys.find(item => metric[item])];\n    return value || metricKey;\n  }\n  return (\n    getLegendTemplate(metricKey, metric) ||\n    metric[matchLegend(metricKey)] ||\n    metricKey\n  );\n}\n\nfunction getLegendTemplate(str: string, obj: object) {\n  let name: string;\n  try {\n    name = get(obj, str) || template(str, LEGEND_TEMPLATE_OPTIONS)(obj);\n  } catch {\n    name = '';\n  }\n  return name;\n}\n\nfunction matchLegend(value: string) {\n  // eslint-disable-next-line unicorn/better-regex\n  return value.match(/\\{\\{\\.(.+?)\\}\\}/)?.[1] || value;\n}\n\n// 填充空数据\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport function fillNullData(\n  { start, end, step }: MetricParams,\n  res: DataItem['values'] = [],\n  isZero = false,\n  stepLine = false,\n) {\n  if (!+start || !+end) {\n    return res;\n  }\n  const _step = step || roundInterval(start, end);\n  const curStart = +start;\n  const nullValue = isZero ? 0 : null;\n  const curEnd = start + step * ((end - start) / step);\n  const preX = stepLine\n    ? {\n        preX: dayjs(curStart)\n          .subtract((end - start) / 6, 's')\n          .valueOf(),\n      }\n    : {};\n  const result = [\n    ...(curStart === res[0]?.x ? [] : [{ x: curStart, y: nullValue, ...preX }]),\n    ...res,\n    ...(res.at(-1)?.x >= curEnd ? [] : [{ x: curEnd, y: nullValue }]),\n  ];\n\n  // query 返回数据可能存在某个时间段无数据情况，会导致前端bug\n  // 通过 step 计算出 总数据。\n  // 在出现一开始数据缺失情况，先给数据添加开始时间数据，和结束时间数据。\n  // 在进行遍历，判读当前数据和下一跳数据事件差 是否是这个 step,\n  // 如果不是计算出两者相差 几条数据，然后进行填充\n  const data = result.reduce((acc, prev, index) => {\n    const diff =\n      result[index + 1] && result[index + 1].x * 1000 - prev.x * 1000;\n    const stepM = _step * 1000;\n    // 后端可能出现 +Ifn 导致成 NaN，设置为 null\n    const curValue = {\n      ...prev,\n      y: prev.y,\n    };\n    if (diff && diff !== stepM) {\n      const total = Math.ceil(diff / stepM - 1);\n      const data = Array.from<number>({ length: total || 0 })\n        .fill(0)\n        .reduce((old, _curr, i) => {\n          const x =\n            i === 0 ? prev.x * 1000 + stepM : old[i - 1].x * 1000 + stepM;\n          return [\n            ...old,\n            {\n              x: x / 1000,\n              y: nullValue,\n              ...(stepLine\n                ? { preX: i === 0 ? result[index].x : old[i - 1].x }\n                : {}),\n            },\n          ];\n        }, []);\n      return [...acc, curValue, ...data];\n    }\n    return [...acc, curValue];\n  }, []);\n  return data.sort((a, b) => a.x - b.x);\n}\n\nexport function handleDateAxisLabelFormats(\n  params: MetricParams,\n  isRich?: boolean,\n) {\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 MD_HS_FORMAT = `${M_D_FORMAT} ${CHART_TIME_FORMAT}`;\n    return diff >= m7\n      ? isRich\n        ? MD_HS_FORMAT\n        : M_D_FORMAT\n      : diff < m7 && (diff >= m3 || diff > m1)\n      ? MD_HS_FORMAT\n      : CHART_TIME_FORMAT;\n  }\n}\n\nexport function limitMaxTooltipItem(context: TooltipValue[], limit = 15) {\n  return context.slice(0, limit);\n}\n\nexport const VARIABLE_KEY_CLUSTER = '$cluster';\nexport const VARIABLE_KEY_NAMESPACE = '$namespace';\n\nexport function replaceExprVariable(\n  expr: string | string[],\n  variable: Dictionary<any>,\n) {\n  let data = Array.isArray(expr) ? expr.join('|') : expr;\n  const variableKeys = Object.keys(variable || {});\n  const variableValues = Object.values(variable || {});\n  const vars: string[] =\n    data && typeof data.match === 'function' ? data.match(/\\$\\w+/g) : [];\n  if (\n    !variableKeys.length ||\n    !variableKeys.some(v => vars?.some(item => item.replace('$', '') === v))\n  ) {\n    return data;\n  }\n\n  vars\n    .sort((a, b) => b.length - a.length)\n    .forEach(key => {\n      const k = key.replace('$', '');\n      const index = variableKeys.indexOf(k);\n      if (index >= 0) {\n        const v = variableValues[index];\n        data = data?.replace(\n          new RegExp(`\\\\$${k}`, 'g'),\n          Array.isArray(v) ? v.join('|') : v,\n        );\n      }\n    });\n  return data;\n}\n\nexport function findTimeRange(diff: number) {\n  const time = PICKER_TIME_RANGES.find(item => {\n    return item.endTime() - item.startTime() === diff;\n  });\n  return time ? { start: time.startTime(), end: time.endTime() } : null;\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { HttpClient } from '@angular/common/http';
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { API_GATEWAY, } from '../core/public-api';
|
|
4
|
+
import { K8sApiResourceService } from './k8s-api-resource.service';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common/http";
|
|
7
|
+
import * as i2 from "./k8s-api-resource.service";
|
|
8
|
+
/**
|
|
9
|
+
* 对应后端组件 archon 的`通用`高级 API 实现
|
|
10
|
+
* 对应 API Gateway 前缀为 /acp/v1
|
|
11
|
+
*
|
|
12
|
+
* /acp/v1 包含多个 api 路径: /kubernetes, /alb, /oam, /metallb;
|
|
13
|
+
* 其中一部分是平台是通用的,在 libs/common 下实现。
|
|
14
|
+
*/
|
|
15
|
+
export class AcpCommonApiService {
|
|
16
|
+
constructor(httpClient, k8sApiResource) {
|
|
17
|
+
this.httpClient = httpClient;
|
|
18
|
+
this.k8sApiResource = k8sApiResource;
|
|
19
|
+
}
|
|
20
|
+
// 获取多项目绑定上下文中,属于某个项目的资源列表
|
|
21
|
+
// @see http://confluence.alauda.cn/pages/viewpage.action?pageId=67553504
|
|
22
|
+
getResourcesByProject(project, resourceParams, queryParams) {
|
|
23
|
+
return this.httpClient.get(`${API_GATEWAY}/acp/v1/resources/project/${project}${this.k8sApiResource
|
|
24
|
+
.getApiPath(resourceParams)
|
|
25
|
+
.replace(API_GATEWAY, '')}`, queryParams ? { params: queryParams } : undefined);
|
|
26
|
+
}
|
|
27
|
+
static { this.ɵfac = function AcpCommonApiService_Factory(t) { return new (t || AcpCommonApiService)(i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(i2.K8sApiResourceService)); }; }
|
|
28
|
+
static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: AcpCommonApiService, factory: AcpCommonApiService.ɵfac, providedIn: 'root' }); }
|
|
29
|
+
}
|
|
30
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AcpCommonApiService, [{
|
|
31
|
+
type: Injectable,
|
|
32
|
+
args: [{ providedIn: 'root' }]
|
|
33
|
+
}], function () { return [{ type: i1.HttpClient }, { type: i2.K8sApiResourceService }]; }, null); })();
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNwLWNvbW1vbi1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9hcGkvYWNwLWNvbW1vbi1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQ0wsV0FBVyxHQUlaLE1BQU0sb0JBQW9CLENBQUM7QUFFNUIsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7QUFFbkU7Ozs7OztHQU1HO0FBRUgsTUFBTSxPQUFPLG1CQUFtQjtJQUM5QixZQUNtQixVQUFzQixFQUN0QixjQUFxQztRQURyQyxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQ3RCLG1CQUFjLEdBQWQsY0FBYyxDQUF1QjtJQUNyRCxDQUFDO0lBRUosMEJBQTBCO0lBQzFCLHlFQUF5RTtJQUN6RSxxQkFBcUIsQ0FDbkIsT0FBZSxFQUNmLGNBT0MsRUFDRCxXQUF1QjtRQUV2QixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUN4QixHQUFHLFdBQVcsNkJBQTZCLE9BQU8sR0FBRyxJQUFJLENBQUMsY0FBYzthQUNyRSxVQUFVLENBQUMsY0FBYyxDQUFDO2FBQzFCLE9BQU8sQ0FBQyxXQUFXLEVBQUUsRUFBRSxDQUFDLEVBQUUsRUFDN0IsV0FBVyxDQUFDLENBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUNsRCxDQUFDO0lBQ0osQ0FBQztvRkExQlUsbUJBQW1CO3VFQUFuQixtQkFBbUIsV0FBbkIsbUJBQW1CLG1CQUROLE1BQU07O3VGQUNuQixtQkFBbUI7Y0FEL0IsVUFBVTtlQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7XG4gIEFQSV9HQVRFV0FZLFxuICBLdWJlcm5ldGVzUmVzb3VyY2UsXG4gIEt1YmVybmV0ZXNSZXNvdXJjZUxpc3QsXG4gIFN0cmluZ01hcCxcbn0gZnJvbSAnLi4vY29yZS9wdWJsaWMtYXBpJztcblxuaW1wb3J0IHsgSzhzQXBpUmVzb3VyY2VTZXJ2aWNlIH0gZnJvbSAnLi9rOHMtYXBpLXJlc291cmNlLnNlcnZpY2UnO1xuXG4vKipcbiAqIOWvueW6lOWQjuerr+e7hOS7tiBhcmNob24g55qEYOmAmueUqGDpq5jnuqcgQVBJIOWunueOsFxuICog5a+55bqUIEFQSSBHYXRld2F5IOWJjee8gOS4uiAvYWNwL3YxXG4gKlxuICogL2FjcC92MSDljIXlkKvlpJrkuKogYXBpIOi3r+W+hO+8miAva3ViZXJuZXRlcywgL2FsYiwgL29hbSwgL21ldGFsbGLvvJtcbiAqIOWFtuS4reS4gOmDqOWIhuaYr+W5s+WPsOaYr+mAmueUqOeahO+8jOWcqCBsaWJzL2NvbW1vbiDkuIvlrp7njrDjgIJcbiAqL1xuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBBY3BDb21tb25BcGlTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZWFkb25seSBodHRwQ2xpZW50OiBIdHRwQ2xpZW50LFxuICAgIHByaXZhdGUgcmVhZG9ubHkgazhzQXBpUmVzb3VyY2U6IEs4c0FwaVJlc291cmNlU2VydmljZSxcbiAgKSB7fVxuXG4gIC8vIOiOt+WPluWkmumhueebrue7keWumuS4iuS4i+aWh+S4rSzlsZ7kuo7mn5DkuKrpobnnm67nmoTotYTmupDliJfooahcbiAgLy8gQHNlZSBodHRwOi8vY29uZmx1ZW5jZS5hbGF1ZGEuY24vcGFnZXMvdmlld3BhZ2UuYWN0aW9uP3BhZ2VJZD02NzU1MzUwNFxuICBnZXRSZXNvdXJjZXNCeVByb2plY3Q8VCBleHRlbmRzIEt1YmVybmV0ZXNSZXNvdXJjZT4oXG4gICAgcHJvamVjdDogc3RyaW5nLFxuICAgIHJlc291cmNlUGFyYW1zOiB7XG4gICAgICBjbHVzdGVyPzogc3RyaW5nO1xuICAgICAgbmFtZXNwYWNlPzogc3RyaW5nO1xuICAgICAgbmFtZT86IHN0cmluZztcbiAgICAgIHR5cGU/OiBzdHJpbmc7XG4gICAgICBhcGlHcm91cD86IHN0cmluZztcbiAgICAgIGFwaVZlcnNpb24/OiBzdHJpbmc7XG4gICAgfSxcbiAgICBxdWVyeVBhcmFtcz86IFN0cmluZ01hcCxcbiAgKSB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cENsaWVudC5nZXQ8S3ViZXJuZXRlc1Jlc291cmNlTGlzdDxUPj4oXG4gICAgICBgJHtBUElfR0FURVdBWX0vYWNwL3YxL3Jlc291cmNlcy9wcm9qZWN0LyR7cHJvamVjdH0ke3RoaXMuazhzQXBpUmVzb3VyY2VcbiAgICAgICAgLmdldEFwaVBhdGgocmVzb3VyY2VQYXJhbXMpXG4gICAgICAgIC5yZXBsYWNlKEFQSV9HQVRFV0FZLCAnJyl9YCxcbiAgICAgIHF1ZXJ5UGFyYW1zID8geyBwYXJhbXM6IHF1ZXJ5UGFyYW1zIH0gOiB1bmRlZmluZWQsXG4gICAgKTtcbiAgfVxufVxuIl19
|
|
@@ -51,12 +51,6 @@ export class ClusterVersionService {
|
|
|
51
51
|
this.store[cluster] = version;
|
|
52
52
|
}));
|
|
53
53
|
}
|
|
54
|
-
set clusterVersion(version) {
|
|
55
|
-
this.version = version;
|
|
56
|
-
}
|
|
57
|
-
get clusterVersion() {
|
|
58
|
-
return this.version;
|
|
59
|
-
}
|
|
60
54
|
static { this.ɵfac = function ClusterVersionService_Factory(t) { return new (t || ClusterVersionService)(i0.ɵɵinject(i1.K8sApiService)); }; }
|
|
61
55
|
static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: ClusterVersionService, factory: ClusterVersionService.ɵfac, providedIn: 'root' }); }
|
|
62
56
|
}
|
|
@@ -64,4 +58,4 @@ export class ClusterVersionService {
|
|
|
64
58
|
type: Injectable,
|
|
65
59
|
args: [{ providedIn: 'root' }]
|
|
66
60
|
}], function () { return [{ type: i1.K8sApiService }]; }, null); })();
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2x1c3Rlci12ZXJzaW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9zcmMvYXBpL2NsdXN0ZXItdmVyc2lvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUNMLFVBQVUsRUFDVixhQUFhLEVBQ2IsR0FBRyxFQUVILEVBQUUsRUFDRixXQUFXLEVBQ1gsR0FBRyxHQUNKLE1BQU0sTUFBTSxDQUFDO0FBRWQsT0FBTyxFQUNMLG1CQUFtQixFQUNuQixnQkFBZ0IsRUFDaEIsVUFBVSxHQUNYLE1BQU0sb0JBQW9CLENBQUM7QUFFNUIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDOzs7QUFHbEQsTUFBTSxPQUFPLHFCQUFxQjtJQWNoQyxZQUE2QixNQUFxQjtRQUFyQixXQUFNLEdBQU4sTUFBTSxDQUFlO1FBYjFDLFVBQUssR0FBMkIsRUFBRSxDQUFDO1FBRTFCLHFCQUFnQixHQUFHLElBQUksQ0FBQyxNQUFNO2FBQzVDLGlCQUFpQixDQUE0QztZQUM1RCxVQUFVLEVBQUUsRUFBRSxJQUFJLEVBQUUsWUFBWSxFQUFFO1lBQ2xDLFNBQVMsRUFBRSxnQkFBZ0I7WUFDM0IsSUFBSSxFQUFFLFVBQVU7U0FDakIsQ0FBQzthQUNELElBQUksQ0FDSCxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFDM0MsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUNmLENBQUM7UUFXSixpQkFBWSxHQUFHLENBQUMsT0FBZSxFQUFFLEVBQUU7WUFDakMsT0FBTyxhQUFhLENBQUM7Z0JBQ25CLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUM7Z0JBQy9CLElBQUksQ0FBQyxlQUFlLEVBQUU7YUFDdkIsQ0FBQyxDQUFDLElBQUksQ0FDTCxHQUFHLENBQ0QsQ0FBQyxDQUFDLGNBQWMsRUFBRSxlQUFlLENBQUMsRUFBRSxFQUFFLENBQ3BDLG1CQUFtQixDQUFDLGNBQWMsRUFBRSxlQUFlLENBQUMsR0FBRyxDQUFDLENBQzNELEVBQ0QsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUMzQixVQUFVLEVBQUUsQ0FDYixDQUFDO1FBQ0osQ0FBQyxDQUFDO0lBckJtRCxDQUFDO0lBRXREOztPQUVHO0lBQ0gsU0FBUyxDQUFDLE9BQWU7UUFDdkIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFnQkQsY0FBYyxDQUFDLE9BQWUsRUFBRSxPQUFlO1FBQzdDLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FDekMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUMsbUJBQW1CLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUN2RSxVQUFVLEVBQUUsQ0FDYixDQUFDO0lBQ0osQ0FBQztJQUVELGVBQWU7UUFDYixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUMvQixDQUFDO0lBRUQsaUJBQWlCLENBQUMsT0FBZTtRQUMvQixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDdkIsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQ2hDO1FBQ0QsT0FBTyxJQUFJLENBQUMsTUFBTTthQUNmLGlCQUFpQixDQUFnQztZQUNoRCxVQUFVLEVBQUU7Z0JBQ1YsSUFBSSxFQUFFLGdCQUFnQjtnQkFDdEIsVUFBVSxFQUFFLFVBQVU7Z0JBQ3RCLFFBQVEsRUFBRSxtQkFBbUI7YUFDOUI7WUFDRCxJQUFJLEVBQUUsT0FBTztTQUNkLENBQUM7YUFDRCxJQUFJLENBQ0gsR0FBRyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQzdDLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUNaLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDO1FBQ2hDLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDTixDQUFDO3NGQW5FVSxxQkFBcUI7dUVBQXJCLHFCQUFxQixXQUFyQixxQkFBcUIsbUJBRFIsTUFBTTs7dUZBQ25CLHFCQUFxQjtjQURqQyxVQUFVO2VBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgY2F0Y2hFcnJvcixcbiAgY29tYmluZUxhdGVzdCxcbiAgbWFwLFxuICBPYnNlcnZhYmxlLFxuICBvZixcbiAgc2hhcmVSZXBsYXksXG4gIHRhcCxcbn0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7XG4gIGNvbXBhcmVNaW5vclZlcnNpb24sXG4gIFBVQkxJQ19OQU1FU1BBQ0UsXG4gIHB1Ymxpc2hSZWYsXG59IGZyb20gJy4uL2NvcmUvcHVibGljLWFwaSc7XG5cbmltcG9ydCB7IEs4c0FwaVNlcnZpY2UgfSBmcm9tICcuL2s4cy1hcGkuc2VydmljZSc7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgQ2x1c3RlclZlcnNpb25TZXJ2aWNlIHtcbiAgcHJpdmF0ZSBzdG9yZTogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IHt9O1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgcGxhdGZvcm1WZXJzaW9uJCA9IHRoaXMuazhzQXBpXG4gICAgLmdldEdsb2JhbFJlc291cmNlPHsgc3BlYzogbnVsbDsgZGF0YTogeyB2ZXJzaW9uOiBzdHJpbmcgfSB9Pih7XG4gICAgICBkZWZpbml0aW9uOiB7IHR5cGU6ICdjb25maWdtYXBzJyB9LFxuICAgICAgbmFtZXNwYWNlOiBQVUJMSUNfTkFNRVNQQUNFLFxuICAgICAgbmFtZTogJ3BsYXRmb3JtJyxcbiAgICB9KVxuICAgIC5waXBlKFxuICAgICAgbWFwKGNvbmZpZyA9PiBjb25maWcuZGF0YS52ZXJzaW9uLnNsaWNlKDEpKSxcbiAgICAgIHNoYXJlUmVwbGF5KDEpLFxuICAgICk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBrOHNBcGk6IEs4c0FwaVNlcnZpY2UpIHt9XG5cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkXG4gICAqL1xuICBpc1ByZXZMVFMoY2x1c3Rlcjogc3RyaW5nKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuaXNPbGRDbHVzdGVyKGNsdXN0ZXIpO1xuICB9XG5cbiAgaXNPbGRDbHVzdGVyID0gKGNsdXN0ZXI6IHN0cmluZykgPT4ge1xuICAgIHJldHVybiBjb21iaW5lTGF0ZXN0KFtcbiAgICAgIHRoaXMuZ2V0Q2x1c3RlclZlcnNpb24oY2x1c3RlciksXG4gICAgICB0aGlzLnBsYXRmb3JtVmVyc2lvbigpLFxuICAgIF0pLnBpcGUoXG4gICAgICBtYXAoXG4gICAgICAgIChbY2x1c3RlclZlcnNpb24sIHBsYXRmb3JtVmVyc2lvbl0pID0+XG4gICAgICAgICAgY29tcGFyZU1pbm9yVmVyc2lvbihjbHVzdGVyVmVyc2lvbiwgcGxhdGZvcm1WZXJzaW9uKSA8IDAsXG4gICAgICApLFxuICAgICAgY2F0Y2hFcnJvcigoKSA9PiBvZihmYWxzZSkpLFxuICAgICAgcHVibGlzaFJlZigpLFxuICAgICk7XG4gIH07XG5cbiAgY2x1c3Rlck9sZFRoYW4oY2x1c3Rlcjogc3RyaW5nLCB2ZXJzaW9uOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRDbHVzdGVyVmVyc2lvbihjbHVzdGVyKS5waXBlKFxuICAgICAgbWFwKGNsdXN0ZXJWZXJzaW9uID0+IGNvbXBhcmVNaW5vclZlcnNpb24oY2x1c3RlclZlcnNpb24sIHZlcnNpb24pIDwgMCksXG4gICAgICBwdWJsaXNoUmVmKCksXG4gICAgKTtcbiAgfVxuXG4gIHBsYXRmb3JtVmVyc2lvbigpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuICAgIHJldHVybiB0aGlzLnBsYXRmb3JtVmVyc2lvbiQ7XG4gIH1cblxuICBnZXRDbHVzdGVyVmVyc2lvbihjbHVzdGVyOiBzdHJpbmcpOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuICAgIGlmICh0aGlzLnN0b3JlW2NsdXN0ZXJdKSB7XG4gICAgICByZXR1cm4gb2YodGhpcy5zdG9yZVtjbHVzdGVyXSk7XG4gICAgfVxuICAgIHJldHVybiB0aGlzLms4c0FwaVxuICAgICAgLmdldEdsb2JhbFJlc291cmNlPHsgc3BlYzogeyB2ZXJzaW9uOiBzdHJpbmcgfSB9Pih7XG4gICAgICAgIGRlZmluaXRpb246IHtcbiAgICAgICAgICB0eXBlOiAnY2x1c3Rlcm1vZHVsZXMnLFxuICAgICAgICAgIGFwaVZlcnNpb246ICd2MWFscGhhMScsXG4gICAgICAgICAgYXBpR3JvdXA6ICdjbHVzdGVyLmFsYXVkYS5pbycsXG4gICAgICAgIH0sXG4gICAgICAgIG5hbWU6IGNsdXN0ZXIsXG4gICAgICB9KVxuICAgICAgLnBpcGUoXG4gICAgICAgIG1hcChjbHVzdGVyID0+IGNsdXN0ZXIuc3BlYy52ZXJzaW9uLnNsaWNlKDEpKSxcbiAgICAgICAgdGFwKHZlcnNpb24gPT4ge1xuICAgICAgICAgIHRoaXMuc3RvcmVbY2x1c3Rlcl0gPSB2ZXJzaW9uO1xuICAgICAgICB9KSxcbiAgICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { HttpClient } from '@angular/common/http';
|
|
2
2
|
import { Injectable } from '@angular/core';
|
|
3
|
-
import {
|
|
3
|
+
import { flatMap } from 'lodash-es';
|
|
4
|
+
import { forkJoin, map, pluck, switchMap } from 'rxjs';
|
|
4
5
|
import { API_GATEWAY, skipError, } from '../core/public-api';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/common/http";
|
|
@@ -17,10 +18,22 @@ export class ProjectApiService {
|
|
|
17
18
|
getNamespaces({ project, cluster }) {
|
|
18
19
|
return this.http.get(`${BASE_URL}/${project}/clusters/${cluster}/namespaces`);
|
|
19
20
|
}
|
|
21
|
+
get(name) {
|
|
22
|
+
return this.http.get(`{{API_GATEWAY}}/apis/auth.alauda.io/v1/projects/${name}`);
|
|
23
|
+
}
|
|
20
24
|
getClusterNamespaces(project, cluster) {
|
|
21
25
|
return this.http
|
|
22
|
-
.get(
|
|
23
|
-
.pipe(
|
|
26
|
+
.get(`{{API_GATEWAY}}/auth/v1/projects/${project}/clusters/${cluster}/namespaces`)
|
|
27
|
+
.pipe(map(res => res.items));
|
|
28
|
+
}
|
|
29
|
+
getProjectNamespaces(projectName) {
|
|
30
|
+
return this.get(projectName).pipe(switchMap(project => {
|
|
31
|
+
const clusters = project.spec.clusters;
|
|
32
|
+
return forkJoin(clusters.map(({ name: clusterName }) => this.getClusterNamespaces(projectName, clusterName).pipe(map(list => list.map(item => ({
|
|
33
|
+
namespace: item.metadata.name,
|
|
34
|
+
cluster: clusterName,
|
|
35
|
+
}))))));
|
|
36
|
+
}), map(groups => flatMap(groups)), skipError([]));
|
|
24
37
|
}
|
|
25
38
|
static { this.ɵfac = function ProjectApiService_Factory(t) { return new (t || ProjectApiService)(i0.ɵɵinject(i1.HttpClient)); }; }
|
|
26
39
|
static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: ProjectApiService, factory: ProjectApiService.ɵfac, providedIn: 'root' }); }
|
|
@@ -29,4 +42,4 @@ export class ProjectApiService {
|
|
|
29
42
|
type: Injectable,
|
|
30
43
|
args: [{ providedIn: 'root' }]
|
|
31
44
|
}], function () { return [{ type: i1.HttpClient }]; }, null); })();
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvamVjdC1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9hcGkvcHJvamVjdC1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3BDLE9BQU8sRUFBYyxRQUFRLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFbkUsT0FBTyxFQUNMLFdBQVcsRUFLWCxTQUFTLEdBQ1YsTUFBTSxvQkFBb0IsQ0FBQzs7O0FBRTVCLE1BQU0sUUFBUSxHQUFHLEdBQUcsV0FBVyxtQkFBbUIsQ0FBQztBQUduRCxNQUFNLE9BQU8saUJBQWlCO0lBQzVCLFlBQTZCLElBQWdCO1FBQWhCLFNBQUksR0FBSixJQUFJLENBQVk7SUFBRyxDQUFDO0lBRWpELFdBQVcsQ0FBQyxNQUEyQjtRQUNyQyxPQUFPLElBQUksQ0FBQyxJQUFJO2FBQ2IsR0FBRyxDQUNGLFFBQVEsRUFDUixNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FDaEM7YUFDQSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxFQUFFLFNBQVMsQ0FBQyxFQUFlLENBQUMsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCxhQUFhLENBQUMsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUF3QztRQUN0RSxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUNsQixHQUFHLFFBQVEsSUFBSSxPQUFPLGFBQWEsT0FBTyxhQUFhLENBQ3hELENBQUM7SUFDSixDQUFDO0lBRUQsR0FBRyxDQUFDLElBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUNsQixtREFBbUQsSUFBSSxFQUFFLENBQzFELENBQUM7SUFDSixDQUFDO0lBRUQsb0JBQW9CLENBQUMsT0FBZSxFQUFFLE9BQWU7UUFDbkQsT0FBTyxJQUFJLENBQUMsSUFBSTthQUNiLEdBQUcsQ0FDRixvQ0FBb0MsT0FBTyxhQUFhLE9BQU8sYUFBYSxDQUM3RTthQUNBLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsb0JBQW9CLENBQ2xCLFdBQW1CO1FBRW5CLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQyxJQUFJLENBQy9CLFNBQVMsQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUNsQixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztZQUV2QyxPQUFPLFFBQVEsQ0FDYixRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLEVBQUUsRUFBRSxDQUNyQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FDdEQsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQ1QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7Z0JBQ2hCLFNBQVMsRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUk7Z0JBQzdCLE9BQU8sRUFBRSxXQUFXO2FBQ3JCLENBQUMsQ0FBQyxDQUNKLENBQ0YsQ0FDRixDQUNGLENBQUM7UUFDSixDQUFDLENBQUMsRUFDRixHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsRUFDOUIsU0FBUyxDQUFDLEVBQUUsQ0FBQyxDQUNkLENBQUM7SUFDSixDQUFDO2tGQXZEVSxpQkFBaUI7dUVBQWpCLGlCQUFpQixXQUFqQixpQkFBaUIsbUJBREosTUFBTTs7dUZBQ25CLGlCQUFpQjtjQUQ3QixVQUFVO2VBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZsYXRNYXAgfSBmcm9tICdsb2Rhc2gtZXMnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgZm9ya0pvaW4sIG1hcCwgcGx1Y2ssIHN3aXRjaE1hcCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQge1xuICBBUElfR0FURVdBWSxcbiAgS3ViZXJuZXRlc1Jlc291cmNlTGlzdCxcbiAgTmFtZXNwYWNlLFxuICBQcm9qZWN0LFxuICBSZXNvdXJjZUxpc3RQYXJhbXMsXG4gIHNraXBFcnJvcixcbn0gZnJvbSAnLi4vY29yZS9wdWJsaWMtYXBpJztcblxuY29uc3QgQkFTRV9VUkwgPSBgJHtBUElfR0FURVdBWX0vYXV0aC92MS9wcm9qZWN0c2A7XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgUHJvamVjdEFwaVNlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGh0dHA6IEh0dHBDbGllbnQpIHt9XG5cbiAgZ2V0UHJvamVjdHMocGFyYW1zPzogUmVzb3VyY2VMaXN0UGFyYW1zKSB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cFxuICAgICAgLmdldDxLdWJlcm5ldGVzUmVzb3VyY2VMaXN0PFByb2plY3Q+PihcbiAgICAgICAgQkFTRV9VUkwsXG4gICAgICAgIHBhcmFtcyA/IHsgcGFyYW1zIH0gOiB1bmRlZmluZWQsXG4gICAgICApXG4gICAgICAucGlwZShwbHVjaygnaXRlbXMnKSwgc2tpcEVycm9yKFtdIGFzIFByb2plY3RbXSkpO1xuICB9XG5cbiAgZ2V0TmFtZXNwYWNlcyh7IHByb2plY3QsIGNsdXN0ZXIgfTogeyBwcm9qZWN0OiBzdHJpbmc7IGNsdXN0ZXI6IHN0cmluZyB9KSB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8S3ViZXJuZXRlc1Jlc291cmNlTGlzdDxOYW1lc3BhY2U+PihcbiAgICAgIGAke0JBU0VfVVJMfS8ke3Byb2plY3R9L2NsdXN0ZXJzLyR7Y2x1c3Rlcn0vbmFtZXNwYWNlc2AsXG4gICAgKTtcbiAgfVxuXG4gIGdldChuYW1lOiBzdHJpbmcpOiBPYnNlcnZhYmxlPFByb2plY3Q+IHtcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxQcm9qZWN0PihcbiAgICAgIGB7e0FQSV9HQVRFV0FZfX0vYXBpcy9hdXRoLmFsYXVkYS5pby92MS9wcm9qZWN0cy8ke25hbWV9YCxcbiAgICApO1xuICB9XG5cbiAgZ2V0Q2x1c3Rlck5hbWVzcGFjZXMocHJvamVjdDogc3RyaW5nLCBjbHVzdGVyOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gdGhpcy5odHRwXG4gICAgICAuZ2V0PEt1YmVybmV0ZXNSZXNvdXJjZUxpc3Q8TmFtZXNwYWNlPj4oXG4gICAgICAgIGB7e0FQSV9HQVRFV0FZfX0vYXV0aC92MS9wcm9qZWN0cy8ke3Byb2plY3R9L2NsdXN0ZXJzLyR7Y2x1c3Rlcn0vbmFtZXNwYWNlc2AsXG4gICAgICApXG4gICAgICAucGlwZShtYXAocmVzID0+IHJlcy5pdGVtcykpO1xuICB9XG5cbiAgZ2V0UHJvamVjdE5hbWVzcGFjZXMoXG4gICAgcHJvamVjdE5hbWU6IHN0cmluZyxcbiAgKTogT2JzZXJ2YWJsZTxBcnJheTx7IGNsdXN0ZXI6IHN0cmluZzsgbmFtZXNwYWNlOiBzdHJpbmcgfT4+IHtcbiAgICByZXR1cm4gdGhpcy5nZXQocHJvamVjdE5hbWUpLnBpcGUoXG4gICAgICBzd2l0Y2hNYXAocHJvamVjdCA9PiB7XG4gICAgICAgIGNvbnN0IGNsdXN0ZXJzID0gcHJvamVjdC5zcGVjLmNsdXN0ZXJzO1xuXG4gICAgICAgIHJldHVybiBmb3JrSm9pbihcbiAgICAgICAgICBjbHVzdGVycy5tYXAoKHsgbmFtZTogY2x1c3Rlck5hbWUgfSkgPT5cbiAgICAgICAgICAgIHRoaXMuZ2V0Q2x1c3Rlck5hbWVzcGFjZXMocHJvamVjdE5hbWUsIGNsdXN0ZXJOYW1lKS5waXBlKFxuICAgICAgICAgICAgICBtYXAobGlzdCA9PlxuICAgICAgICAgICAgICAgIGxpc3QubWFwKGl0ZW0gPT4gKHtcbiAgICAgICAgICAgICAgICAgIG5hbWVzcGFjZTogaXRlbS5tZXRhZGF0YS5uYW1lLFxuICAgICAgICAgICAgICAgICAgY2x1c3RlcjogY2x1c3Rlck5hbWUsXG4gICAgICAgICAgICAgICAgfSkpLFxuICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgKSxcbiAgICAgICAgICApLFxuICAgICAgICApO1xuICAgICAgfSksXG4gICAgICBtYXAoZ3JvdXBzID0+IGZsYXRNYXAoZ3JvdXBzKSksXG4gICAgICBza2lwRXJyb3IoW10pLFxuICAgICk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -19,4 +19,5 @@ export * from './product.service';
|
|
|
19
19
|
export * from './project-api.service';
|
|
20
20
|
export * from './platform-ui.service';
|
|
21
21
|
export * from './api-compatible.interceptor';
|
|
22
|
-
|
|
22
|
+
export * from './acp-common-api.service';
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9hcGkvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBRUgsY0FBYztBQUNkLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywwQkFBMEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogW1tpbmNsdWRlOmFwaS9SRUFETUUubWRdXVxuICogQG1vZHVsZSBhcGlcbiAqIEBwcmVmZXJyZWRcbiAqL1xuXG4vKiogaW1wb3J0cyAqL1xuZXhwb3J0ICogZnJvbSAnLi9hcGktZ2F0ZXdheS5pbnRlcmNlcHRvcic7XG5leHBvcnQgKiBmcm9tICcuL2FwaS1nYXRld2F5LnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jbHVzdGVyLXZlcnNpb24uc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2hlbHBlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9rOHMtYXBpLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9rOHMtYXBpLXJlc291cmNlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWdlLXZpc2liaWxpdHkuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3Jlc291cmNlLXVwZGF0ZS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9tb25pdG9yLWFwaS5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vY3J5cHRvLmludGVyY2VwdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdC5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vcHJvamVjdC1hcGkuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3BsYXRmb3JtLXVpLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9hcGktY29tcGF0aWJsZS5pbnRlcmNlcHRvcic7XG5leHBvcnQgKiBmcm9tICcuL2FjcC1jb21tb24tYXBpLnNlcnZpY2UnO1xuIl19
|