@alauda-fe/common 1.4.9 → 1.4.11
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/core/pipes/parse-json-translate.pipe.d.ts +1 -1
- package/core/services/plugin-util.service.d.ts +31 -0
- package/core/services/public-api.d.ts +1 -0
- package/core/types/k8s/crd.d.ts +3 -2
- package/core/types/resource-definitions.d.ts +21 -1
- package/esm2022/api/project-api.service.mjs +7 -2
- package/esm2022/chart/common/axis/x-axis-ticks.component.mjs +8 -13
- package/esm2022/chart/common/legend/legend.component.mjs +5 -6
- package/esm2022/chart/common/tooltip/tooltip.component.mjs +6 -7
- package/esm2022/code/code-display-dialog/component.mjs +3 -3
- package/esm2022/core/pipes/parse-json-translate.pipe.mjs +3 -4
- package/esm2022/core/services/plugin-util.service.mjs +60 -0
- package/esm2022/core/services/public-api.mjs +2 -1
- package/esm2022/core/types/k8s/crd.mjs +1 -1
- package/esm2022/core/types/resource-definitions.mjs +11 -1
- package/esm2022/core/utils/resources.mjs +2 -2
- package/esm2022/editable/editable.component.mjs +5 -17
- package/esm2022/k8s-resource-list/footer/component.mjs +2 -2
- package/esm2022/multi-search/action-input/component.mjs +83 -51
- package/esm2022/multi-search/form/component.mjs +33 -16
- package/esm2022/multi-search/multi-search-tags/component.mjs +7 -5
- package/esm2022/page-scaffold/navigation/lottie-icons/animation-data.mjs +3 -1
- package/esm2022/page-scaffold/navigation/lottie-icons/animations/observe.json +1 -0
- package/esm2022/page-scaffold/page-header/common-layout/context.service.mjs +6 -11
- package/esm2022/page-scaffold/page-header/common-layout/product-select/component.mjs +12 -13
- package/esm2022/table/component.mjs +6 -6
- package/esm2022/translate/i18n-assets-loader.mjs +4 -4
- package/esm2022/translate/i18n-config.mjs +4 -1
- package/esm2022/translate/translate.pipe.mjs +17 -23
- package/esm2022/translate/translate.service.mjs +14 -24
- package/esm2022/view-chart/legend/legend.component.mjs +5 -6
- package/esm2022/view-chart/view-chart.component.mjs +7 -9
- package/esm2022/view-zchart/legend/legend.component.mjs +5 -6
- package/esm2022/view-zchart/view-zchart.component.mjs +8 -15
- package/esm2022/widget/field-set/item/component.mjs +2 -2
- package/multi-search/action-input/component.d.ts +4 -1
- package/multi-search/form/component.d.ts +4 -1
- package/multi-search/multi-search-tags/component.d.ts +2 -1
- package/package.json +1 -1
- package/page-scaffold/page-header/common-layout/context.service.d.ts +1 -2
- package/styles/markdown-body.scss +4 -2
- package/translate/i18n-config.d.ts +1 -0
- package/translate/translate.pipe.d.ts +1 -2
- package/translate/translate.service.d.ts +8 -10
|
@@ -3,7 +3,7 @@ import { TranslatePipe } from '../../translate/translate.pipe';
|
|
|
3
3
|
import { TranslateKey } from '../../translate/types';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class ParseJsonTranslatePipe extends TranslatePipe implements PipeTransform {
|
|
6
|
-
transform(key: TranslateKey, data?: unknown
|
|
6
|
+
transform(key: TranslateKey, data?: unknown): string;
|
|
7
7
|
static ɵfac: i0.ɵɵFactoryDeclaration<ParseJsonTranslatePipe, never>;
|
|
8
8
|
static ɵpipe: i0.ɵɵPipeDeclaration<ParseJsonTranslatePipe, "aclParseJsonTranslate", true>;
|
|
9
9
|
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* @module utils
|
|
4
|
+
*/
|
|
5
|
+
import { HttpClient } from '@angular/common/http';
|
|
6
|
+
import { Observable } from 'rxjs';
|
|
7
|
+
import { KubernetesResource } from '../types/k8s/core';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export type ModulePluginPhase = 'Running' | 'Processing' | 'Deleting' | 'Failed' | 'Upgrading' | 'Unknown';
|
|
10
|
+
export interface ModulePluginInstallStatus {
|
|
11
|
+
cluster: string;
|
|
12
|
+
name: string;
|
|
13
|
+
phase: ModulePluginPhase;
|
|
14
|
+
version: string;
|
|
15
|
+
}
|
|
16
|
+
export interface ModulePluginView extends KubernetesResource {
|
|
17
|
+
status: {
|
|
18
|
+
modulePluginExist: boolean;
|
|
19
|
+
installed: ModulePluginInstallStatus[];
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
export declare const modulePluginIsRunning: (pluginView: ModulePluginView, cluster: string) => boolean;
|
|
23
|
+
export declare class PluginUtilService {
|
|
24
|
+
private readonly httpClient;
|
|
25
|
+
constructor(httpClient: HttpClient);
|
|
26
|
+
isOperatorEnabled(operator: string, cluster: string): Observable<boolean>;
|
|
27
|
+
isModulePluginEnabled(plugin: string, cluster: string): Observable<boolean>;
|
|
28
|
+
getModulePluginsViews(): Observable<ModulePluginView[]>;
|
|
29
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<PluginUtilService, never>;
|
|
30
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<PluginUtilService>;
|
|
31
|
+
}
|
|
@@ -13,4 +13,5 @@ export * from './yaml-util.service';
|
|
|
13
13
|
export * from './form-row-duplicate/form-row-duplicate.service';
|
|
14
14
|
export * from './context.service';
|
|
15
15
|
export * from './disaster-recovery.service';
|
|
16
|
+
export * from './plugin-util.service';
|
|
16
17
|
export { EncodeUrlParamsSafelyInterceptor } from './encode-url-param.interceptor';
|
package/core/types/k8s/crd.d.ts
CHANGED
|
@@ -111,8 +111,9 @@ type GenProduct<T extends ProductKey> = Record<T, {
|
|
|
111
111
|
install: boolean;
|
|
112
112
|
}>;
|
|
113
113
|
export interface Tls {
|
|
114
|
-
|
|
115
|
-
|
|
114
|
+
secretRef: {
|
|
115
|
+
name: string;
|
|
116
|
+
};
|
|
116
117
|
}
|
|
117
118
|
export interface ProductBaseSpec extends GenProduct<ProductKey> {
|
|
118
119
|
alternativeURLs: string[];
|
|
@@ -402,6 +402,16 @@ export declare const COMMON_RESOURCE_DEFINITIONS: {
|
|
|
402
402
|
readonly apiVersion: string;
|
|
403
403
|
readonly type: string;
|
|
404
404
|
};
|
|
405
|
+
readonly OPERATOR_VIEW: {
|
|
406
|
+
readonly type: string;
|
|
407
|
+
readonly apiGroup: string;
|
|
408
|
+
readonly apiVersion: string;
|
|
409
|
+
};
|
|
410
|
+
readonly MODULE_PLUGIN_VIEW: {
|
|
411
|
+
readonly type: string;
|
|
412
|
+
readonly apiGroup: string;
|
|
413
|
+
readonly apiVersion: string;
|
|
414
|
+
};
|
|
405
415
|
};
|
|
406
416
|
export declare const RESOURCE_TYPES: {
|
|
407
417
|
readonly ALAUDA_LOADBALANCER2: "ALAUDA_LOADBALANCER2";
|
|
@@ -494,8 +504,10 @@ export declare const RESOURCE_TYPES: {
|
|
|
494
504
|
readonly OAM_APPLICATION: "OAM_APPLICATION";
|
|
495
505
|
readonly ARGOCD_APPLICATION_SET: "ARGOCD_APPLICATION_SET";
|
|
496
506
|
readonly ARGOCD_APPLICATION: "ARGOCD_APPLICATION";
|
|
507
|
+
readonly OPERATOR_VIEW: "OPERATOR_VIEW";
|
|
508
|
+
readonly MODULE_PLUGIN_VIEW: "MODULE_PLUGIN_VIEW";
|
|
497
509
|
};
|
|
498
|
-
export declare const getYamlApiVersion: (definition: "ALAUDA_LOADBALANCER2" | "ALB2" | "HELM_REQUEST" | "HELM_REQUEST_V1" | "DEPLOYMENT" | "DAEMONSET" | "STATEFULSET" | "FRONTEND" | "RULE" | "POD" | "PODS_EXEC" | "PODS_ROOT_EXEC" | "CONFIG_MAP" | "ALERT_TEMPLATE" | "APPLICATION" | "APPLICATION_HISTORY" | "CLUSTER" | "CLUSTER_VIEW" | "DAEMON_SET" | "STATEFUL_SET" | "DOMAIN" | "FEATURE" | "ALAUDA_FEATURE_GATE" | "CLUSTER_ALAUDA_FEATURE_GATE" | "HORIZONTAL_POD_AUTOSCALER" | "LOG" | "PROJECT" | "PROMETHEUS_RULE" | "ALERT_HISTORY" | "SELF_SUBJECT_ACCESS_REVIEW" | "VIEW" | "SERVICE" | "LIMIT_RANGE" | "SECRET" | "CRON_JOB" | "ADVANCED_CRON_JOB" | "JOB" | "INGRESS" | "PERSISTENT_VOLUME_CLAIM" | "NAMESPACE" | "NODE" | "NODE_METRICS" | "PV" | "CRD" | "CHART_REPO" | "CHART" | "NETWORK_POLICY" | "SERVICE_ACCOUNT" | "REPLICA_SET" | "POD_SECURITY_POLICY" | "NAMESPACE_OVERVIEW" | "CSP" | "RESOURCE_QUOTA" | "CLUSTER_NETWORK_POLICY" | "PROJECT_QUOTA" | "TKE_CLUSTER" | "TKE_MACHINE" | "MACHINE" | "NODE_GROUP" | "CLUSTERSERVICEVERSION" | "TENANT" | "SUBSCRIPTION" | "PACKAGE_MANIFEST" | "BUCKET_CLASS" | "PRODUCT_CONFIG" | "STORAGE_CLASS" | "VOLUME_SNAPSHOT_CLASS" | "PRODUCT_BASE" | "MODULE_INFO" | "MODULE_CONFIG" | "MODULE_PLUGIN" | "PRODUCT_ENTRY" | "PRODUCT_DOCS_ENTRY" | "SERVICEMESH_GROUP" | "CLUSTER_MODULE" | "USER_SECURITY_POLICY" | "CONNECTOR" | "ACCESS_TOKEN_INFO" | "FUNCTION_RESOURCE" | "USER_BINDING" | "USER" | "GROUP" | "PROJECT_MEMBER" | "ROLE_TEMPLATE" | "BATCH_ACTION" | "EVENT" | "SERVICE_MONITOR" | "OAM_APPLICATION" | "ARGOCD_APPLICATION_SET" | "ARGOCD_APPLICATION" | {
|
|
510
|
+
export declare const getYamlApiVersion: (definition: "ALAUDA_LOADBALANCER2" | "ALB2" | "HELM_REQUEST" | "HELM_REQUEST_V1" | "DEPLOYMENT" | "DAEMONSET" | "STATEFULSET" | "FRONTEND" | "RULE" | "POD" | "PODS_EXEC" | "PODS_ROOT_EXEC" | "CONFIG_MAP" | "ALERT_TEMPLATE" | "APPLICATION" | "APPLICATION_HISTORY" | "CLUSTER" | "CLUSTER_VIEW" | "DAEMON_SET" | "STATEFUL_SET" | "DOMAIN" | "FEATURE" | "ALAUDA_FEATURE_GATE" | "CLUSTER_ALAUDA_FEATURE_GATE" | "HORIZONTAL_POD_AUTOSCALER" | "LOG" | "PROJECT" | "PROMETHEUS_RULE" | "ALERT_HISTORY" | "SELF_SUBJECT_ACCESS_REVIEW" | "VIEW" | "SERVICE" | "LIMIT_RANGE" | "SECRET" | "CRON_JOB" | "ADVANCED_CRON_JOB" | "JOB" | "INGRESS" | "PERSISTENT_VOLUME_CLAIM" | "NAMESPACE" | "NODE" | "NODE_METRICS" | "PV" | "CRD" | "CHART_REPO" | "CHART" | "NETWORK_POLICY" | "SERVICE_ACCOUNT" | "REPLICA_SET" | "POD_SECURITY_POLICY" | "NAMESPACE_OVERVIEW" | "CSP" | "RESOURCE_QUOTA" | "CLUSTER_NETWORK_POLICY" | "PROJECT_QUOTA" | "TKE_CLUSTER" | "TKE_MACHINE" | "MACHINE" | "NODE_GROUP" | "CLUSTERSERVICEVERSION" | "TENANT" | "SUBSCRIPTION" | "PACKAGE_MANIFEST" | "BUCKET_CLASS" | "PRODUCT_CONFIG" | "STORAGE_CLASS" | "VOLUME_SNAPSHOT_CLASS" | "PRODUCT_BASE" | "MODULE_INFO" | "MODULE_CONFIG" | "MODULE_PLUGIN" | "PRODUCT_ENTRY" | "PRODUCT_DOCS_ENTRY" | "SERVICEMESH_GROUP" | "CLUSTER_MODULE" | "USER_SECURITY_POLICY" | "CONNECTOR" | "ACCESS_TOKEN_INFO" | "FUNCTION_RESOURCE" | "USER_BINDING" | "USER" | "GROUP" | "PROJECT_MEMBER" | "ROLE_TEMPLATE" | "BATCH_ACTION" | "EVENT" | "SERVICE_MONITOR" | "OAM_APPLICATION" | "ARGOCD_APPLICATION_SET" | "ARGOCD_APPLICATION" | "OPERATOR_VIEW" | "MODULE_PLUGIN_VIEW" | {
|
|
499
511
|
apiGroup: string;
|
|
500
512
|
type: string;
|
|
501
513
|
} | {
|
|
@@ -800,6 +812,14 @@ export declare const getYamlApiVersion: (definition: "ALAUDA_LOADBALANCER2" | "A
|
|
|
800
812
|
apiGroup: string;
|
|
801
813
|
apiVersion: string;
|
|
802
814
|
type: string;
|
|
815
|
+
} | {
|
|
816
|
+
type: string;
|
|
817
|
+
apiGroup: string;
|
|
818
|
+
apiVersion: string;
|
|
819
|
+
} | {
|
|
820
|
+
type: string;
|
|
821
|
+
apiGroup: string;
|
|
822
|
+
apiVersion: string;
|
|
803
823
|
}) => string;
|
|
804
824
|
export type ResourceType = keyof typeof RESOURCE_TYPES;
|
|
805
825
|
export declare const MachineMeta: TypeMeta;
|
|
@@ -3,6 +3,7 @@ import { Injectable } from '@angular/core';
|
|
|
3
3
|
import { flatMap } from 'lodash-es';
|
|
4
4
|
import { forkJoin, map, switchMap } from 'rxjs';
|
|
5
5
|
import { API_GATEWAY, skipError, } from '../core/public-api';
|
|
6
|
+
import { matchLabelsToString } from '../k8s-resource-list/utils';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/common/http";
|
|
8
9
|
const BASE_URL = `${API_GATEWAY}/auth/v1/projects`;
|
|
@@ -26,7 +27,11 @@ export class ProjectApiService {
|
|
|
26
27
|
return this.http.get(`${BASE_URL}/${project}/clusters/${cluster}/namespaces`);
|
|
27
28
|
}
|
|
28
29
|
get(name) {
|
|
29
|
-
return this.
|
|
30
|
+
return this.getProjects({
|
|
31
|
+
fieldSelector: matchLabelsToString({
|
|
32
|
+
'metadata.name': name,
|
|
33
|
+
}),
|
|
34
|
+
}).pipe(map(list => list[0]));
|
|
30
35
|
}
|
|
31
36
|
getClusterNamespaces(project, cluster) {
|
|
32
37
|
return this.http
|
|
@@ -52,4 +57,4 @@ export class ProjectApiService {
|
|
|
52
57
|
type: Injectable,
|
|
53
58
|
args: [{ providedIn: 'root' }]
|
|
54
59
|
}], () => [{ type: i1.HttpClient }], null); })();
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvamVjdC1hcGkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9hcGkvcHJvamVjdC1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBQ3BDLE9BQU8sRUFBYyxRQUFRLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUU1RCxPQUFPLEVBQ0wsV0FBVyxFQUtYLFNBQVMsR0FDVixNQUFNLG9CQUFvQixDQUFDO0FBQzVCLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7QUFFakUsTUFBTSxRQUFRLEdBQUcsR0FBRyxXQUFXLG1CQUFtQixDQUFDO0FBR25ELE1BQU0sT0FBTyxpQkFBaUI7SUFDNUIsWUFBNkIsSUFBZ0I7UUFBaEIsU0FBSSxHQUFKLElBQUksQ0FBWTtJQUFHLENBQUM7SUFFakQsV0FBVyxDQUFDLE1BQTJCO1FBQ3JDLE9BQU8sSUFBSSxDQUFDLElBQUk7YUFDYixHQUFHLENBRUYsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO2FBQzNDLElBQUksQ0FDSCxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQ3JCLFNBQVMsQ0FBQyxFQUFlLENBQUMsQ0FDM0IsQ0FBQztJQUNOLENBQUM7SUFFRCxjQUFjLENBQUMsTUFBMkI7UUFDeEMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FDbEIsUUFBUSxFQUNSLE1BQU07WUFDSixDQUFDLENBQUM7Z0JBQ0UsTUFBTTthQUNQO1lBQ0gsQ0FBQyxDQUFDLFNBQVMsQ0FDZCxDQUFDO0lBQ0osQ0FBQztJQUVELGFBQWEsQ0FBQyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQXdDO1FBQ3RFLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQ2xCLEdBQUcsUUFBUSxJQUFJLE9BQU8sYUFBYSxPQUFPLGFBQWEsQ0FDeEQsQ0FBQztJQUNKLENBQUM7SUFFRCxHQUFHLENBQUMsSUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztZQUN0QixhQUFhLEVBQUUsbUJBQW1CLENBQUM7Z0JBQ2pDLGVBQWUsRUFBRSxJQUFJO2FBQ3RCLENBQUM7U0FDSCxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVELG9CQUFvQixDQUFDLE9BQWUsRUFBRSxPQUFlO1FBQ25ELE9BQU8sSUFBSSxDQUFDLElBQUk7YUFDYixHQUFHLENBRUYsb0NBQW9DLE9BQU8sYUFBYSxPQUFPLGFBQWEsQ0FBQzthQUM5RSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVELGFBQWEsQ0FBQyxPQUFlO1FBQzNCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQ3JCLEdBQUcsV0FBVyxxQkFBcUIsT0FBTyxFQUFFLENBQzdDLENBQUM7SUFDSixDQUFDO0lBRUQsb0JBQW9CLENBQ2xCLFdBQW1CO1FBRW5CLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQyxJQUFJLENBQy9CLFNBQVMsQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUNsQixNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztZQUV2QyxPQUFPLFFBQVEsQ0FDYixRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLEVBQUUsRUFBRSxDQUNyQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FDdEQsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQ1QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7Z0JBQ2hCLFNBQVMsRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUk7Z0JBQzdCLE9BQU8sRUFBRSxXQUFXO2FBQ3JCLENBQUMsQ0FBQyxDQUNKLEVBQ0QsU0FBUyxDQUFDLEVBQUUsQ0FBQyxDQUNkLENBQ0YsQ0FDRixDQUFDO1FBQ0osQ0FBQyxDQUFDLEVBQ0YsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQzlCLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FDZCxDQUFDO0lBQ0osQ0FBQztrRkE3RVUsaUJBQWlCO3VFQUFqQixpQkFBaUIsV0FBakIsaUJBQWlCLG1CQURKLE1BQU07O2lGQUNuQixpQkFBaUI7Y0FEN0IsVUFBVTtlQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBmbGF0TWFwIH0gZnJvbSAnbG9kYXNoLWVzJztcbmltcG9ydCB7IE9ic2VydmFibGUsIGZvcmtKb2luLCBtYXAsIHN3aXRjaE1hcCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQge1xuICBBUElfR0FURVdBWSxcbiAgS3ViZXJuZXRlc1Jlc291cmNlTGlzdCxcbiAgTmFtZXNwYWNlLFxuICBQcm9qZWN0LFxuICBSZXNvdXJjZUxpc3RQYXJhbXMsXG4gIHNraXBFcnJvcixcbn0gZnJvbSAnLi4vY29yZS9wdWJsaWMtYXBpJztcbmltcG9ydCB7IG1hdGNoTGFiZWxzVG9TdHJpbmcgfSBmcm9tICcuLi9rOHMtcmVzb3VyY2UtbGlzdC91dGlscyc7XG5cbmNvbnN0IEJBU0VfVVJMID0gYCR7QVBJX0dBVEVXQVl9L2F1dGgvdjEvcHJvamVjdHNgO1xuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46ICdyb290JyB9KVxuZXhwb3J0IGNsYXNzIFByb2plY3RBcGlTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBodHRwOiBIdHRwQ2xpZW50KSB7fVxuXG4gIGdldFByb2plY3RzKHBhcmFtcz86IFJlc291cmNlTGlzdFBhcmFtcykge1xuICAgIHJldHVybiB0aGlzLmh0dHBcbiAgICAgIC5nZXQ8XG4gICAgICAgIEt1YmVybmV0ZXNSZXNvdXJjZUxpc3Q8UHJvamVjdD5cbiAgICAgID4oQkFTRV9VUkwsIHBhcmFtcyA/IHsgcGFyYW1zIH0gOiB1bmRlZmluZWQpXG4gICAgICAucGlwZShcbiAgICAgICAgbWFwKHJlcyA9PiByZXMuaXRlbXMpLFxuICAgICAgICBza2lwRXJyb3IoW10gYXMgUHJvamVjdFtdKSxcbiAgICAgICk7XG4gIH1cblxuICBnZXRQcm9qZWN0TGlzdChwYXJhbXM/OiBSZXNvdXJjZUxpc3RQYXJhbXMpIHtcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxLdWJlcm5ldGVzUmVzb3VyY2VMaXN0PFByb2plY3Q+PihcbiAgICAgIEJBU0VfVVJMLFxuICAgICAgcGFyYW1zXG4gICAgICAgID8ge1xuICAgICAgICAgICAgcGFyYW1zLFxuICAgICAgICAgIH1cbiAgICAgICAgOiB1bmRlZmluZWQsXG4gICAgKTtcbiAgfVxuXG4gIGdldE5hbWVzcGFjZXMoeyBwcm9qZWN0LCBjbHVzdGVyIH06IHsgcHJvamVjdDogc3RyaW5nOyBjbHVzdGVyOiBzdHJpbmcgfSkge1xuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PEt1YmVybmV0ZXNSZXNvdXJjZUxpc3Q8TmFtZXNwYWNlPj4oXG4gICAgICBgJHtCQVNFX1VSTH0vJHtwcm9qZWN0fS9jbHVzdGVycy8ke2NsdXN0ZXJ9L25hbWVzcGFjZXNgLFxuICAgICk7XG4gIH1cblxuICBnZXQobmFtZTogc3RyaW5nKTogT2JzZXJ2YWJsZTxQcm9qZWN0PiB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0UHJvamVjdHMoe1xuICAgICAgZmllbGRTZWxlY3RvcjogbWF0Y2hMYWJlbHNUb1N0cmluZyh7XG4gICAgICAgICdtZXRhZGF0YS5uYW1lJzogbmFtZSxcbiAgICAgIH0pLFxuICAgIH0pLnBpcGUobWFwKGxpc3QgPT4gbGlzdFswXSkpO1xuICB9XG5cbiAgZ2V0Q2x1c3Rlck5hbWVzcGFjZXMocHJvamVjdDogc3RyaW5nLCBjbHVzdGVyOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gdGhpcy5odHRwXG4gICAgICAuZ2V0PFxuICAgICAgICBLdWJlcm5ldGVzUmVzb3VyY2VMaXN0PE5hbWVzcGFjZT5cbiAgICAgID4oYHt7QVBJX0dBVEVXQVl9fS9hdXRoL3YxL3Byb2plY3RzLyR7cHJvamVjdH0vY2x1c3RlcnMvJHtjbHVzdGVyfS9uYW1lc3BhY2VzYClcbiAgICAgIC5waXBlKG1hcChyZXMgPT4gcmVzLml0ZW1zKSk7XG4gIH1cblxuICBkZWxldGVQcm9qZWN0KHByb2plY3Q6IHN0cmluZykge1xuICAgIHJldHVybiB0aGlzLmh0dHAuZGVsZXRlPFByb2plY3Q+KFxuICAgICAgYCR7QVBJX0dBVEVXQVl9L2F1dGgvdjEvcHJvamVjdHMvJHtwcm9qZWN0fWAsXG4gICAgKTtcbiAgfVxuXG4gIGdldFByb2plY3ROYW1lc3BhY2VzKFxuICAgIHByb2plY3ROYW1lOiBzdHJpbmcsXG4gICk6IE9ic2VydmFibGU8QXJyYXk8eyBjbHVzdGVyOiBzdHJpbmc7IG5hbWVzcGFjZTogc3RyaW5nIH0+PiB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0KHByb2plY3ROYW1lKS5waXBlKFxuICAgICAgc3dpdGNoTWFwKHByb2plY3QgPT4ge1xuICAgICAgICBjb25zdCBjbHVzdGVycyA9IHByb2plY3Quc3BlYy5jbHVzdGVycztcblxuICAgICAgICByZXR1cm4gZm9ya0pvaW4oXG4gICAgICAgICAgY2x1c3RlcnMubWFwKCh7IG5hbWU6IGNsdXN0ZXJOYW1lIH0pID0+XG4gICAgICAgICAgICB0aGlzLmdldENsdXN0ZXJOYW1lc3BhY2VzKHByb2plY3ROYW1lLCBjbHVzdGVyTmFtZSkucGlwZShcbiAgICAgICAgICAgICAgbWFwKGxpc3QgPT5cbiAgICAgICAgICAgICAgICBsaXN0Lm1hcChpdGVtID0+ICh7XG4gICAgICAgICAgICAgICAgICBuYW1lc3BhY2U6IGl0ZW0ubWV0YWRhdGEubmFtZSxcbiAgICAgICAgICAgICAgICAgIGNsdXN0ZXI6IGNsdXN0ZXJOYW1lLFxuICAgICAgICAgICAgICAgIH0pKSxcbiAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgc2tpcEVycm9yKFtdKSxcbiAgICAgICAgICAgICksXG4gICAgICAgICAgKSxcbiAgICAgICAgKTtcbiAgICAgIH0pLFxuICAgICAgbWFwKGdyb3VwcyA9PiBmbGF0TWFwKGdyb3VwcykpLFxuICAgICAgc2tpcEVycm9yKFtdKSxcbiAgICApO1xuICB9XG59XG4iXX0=
|
|
@@ -7,7 +7,6 @@ import { ScaleType, reduceTicks } from '../../utils';
|
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
import * as i1 from "../../chart.service";
|
|
9
9
|
const _c0 = ["aclXAxisTicks", ""];
|
|
10
|
-
const _c1 = () => ({});
|
|
11
10
|
function XAxisTicksComponent_ng_container_0__svg_g_1_Template(rf, ctx) { if (rf & 1) {
|
|
12
11
|
i0.ɵɵnamespaceSVG();
|
|
13
12
|
i0.ɵɵelementStart(0, "g")(1, "text", 4);
|
|
@@ -23,13 +22,13 @@ function XAxisTicksComponent_ng_container_0__svg_g_1_Template(rf, ctx) { if (rf
|
|
|
23
22
|
i0.ɵɵadvance();
|
|
24
23
|
i0.ɵɵattribute("x", i_r2 === ctx_r2.ticks.length - 1 && tick_r1.x >= (ctx_r2.context.chartView == null ? null : ctx_r2.context.chartView.height) ? tick_r1.x - 5 : tick_r1.x)("y", tick_r1.y + 16)("text-anchor", ctx_r2.textAnchor);
|
|
25
24
|
i0.ɵɵadvance();
|
|
26
|
-
i0.ɵɵtextInterpolate1(" ", ctx_r2.translation ? i0.ɵɵ
|
|
25
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r2.translation ? i0.ɵɵpipeBind1(3, 8, tick_r1.value) : tick_r1.value, " ");
|
|
27
26
|
i0.ɵɵadvance(2);
|
|
28
27
|
i0.ɵɵattribute("x1", tick_r1.x)("x2", tick_r1.x)("y1", tick_r1.y)("y2", tick_r1.y + 6);
|
|
29
28
|
} }
|
|
30
29
|
function XAxisTicksComponent_ng_container_0_Template(rf, ctx) { if (rf & 1) {
|
|
31
30
|
i0.ɵɵelementContainerStart(0);
|
|
32
|
-
i0.ɵɵtemplate(1, XAxisTicksComponent_ng_container_0__svg_g_1_Template, 5,
|
|
31
|
+
i0.ɵɵtemplate(1, XAxisTicksComponent_ng_container_0__svg_g_1_Template, 5, 10, "g", 2);
|
|
33
32
|
i0.ɵɵnamespaceSVG();
|
|
34
33
|
i0.ɵɵelementStart(2, "g");
|
|
35
34
|
i0.ɵɵelement(3, "path", 3);
|
|
@@ -55,10 +54,10 @@ function XAxisTicksComponent_ng_template_1__svg_g_0_Template(rf, ctx) { if (rf &
|
|
|
55
54
|
i0.ɵɵadvance();
|
|
56
55
|
i0.ɵɵattribute("y", tick_r4.x);
|
|
57
56
|
i0.ɵɵadvance();
|
|
58
|
-
i0.ɵɵtextInterpolate1(" ", ctx_r2.translation ? i0.ɵɵ
|
|
57
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r2.translation ? i0.ɵɵpipeBind1(4, 4, i0.ɵɵpipeBind1(3, 2, tick_r4.value)) : tick_r4.value, " ");
|
|
59
58
|
} }
|
|
60
59
|
function XAxisTicksComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
|
|
61
|
-
i0.ɵɵtemplate(0, XAxisTicksComponent_ng_template_1__svg_g_0_Template, 5,
|
|
60
|
+
i0.ɵɵtemplate(0, XAxisTicksComponent_ng_template_1__svg_g_0_Template, 5, 6, "g", 2);
|
|
62
61
|
i0.ɵɵnamespaceSVG();
|
|
63
62
|
i0.ɵɵelementStart(1, "g");
|
|
64
63
|
i0.ɵɵelement(2, "path", 3);
|
|
@@ -160,7 +159,7 @@ export class XAxisTicksComponent {
|
|
|
160
159
|
[attr.text-anchor]="textAnchor"
|
|
161
160
|
font-size="11"
|
|
162
161
|
>
|
|
163
|
-
{{ translation ? (tick.value | translate
|
|
162
|
+
{{ translation ? (tick.value | translate) : tick.value }}
|
|
164
163
|
</text>
|
|
165
164
|
<line
|
|
166
165
|
[attr.x1]="tick.x"
|
|
@@ -190,11 +189,7 @@ export class XAxisTicksComponent {
|
|
|
190
189
|
font-size="11"
|
|
191
190
|
alignment-baseline="middle"
|
|
192
191
|
>
|
|
193
|
-
{{
|
|
194
|
-
translation
|
|
195
|
-
? (tick.value | translate | translate: {}:true)
|
|
196
|
-
: tick.value
|
|
197
|
-
}}
|
|
192
|
+
{{ translation ? (tick.value | translate | translate) : tick.value }}
|
|
198
193
|
</text>
|
|
199
194
|
</svg:g>
|
|
200
195
|
<svg:g>
|
|
@@ -213,5 +208,5 @@ export class XAxisTicksComponent {
|
|
|
213
208
|
}], translation: [{
|
|
214
209
|
type: Input
|
|
215
210
|
}] }); })();
|
|
216
|
-
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(XAxisTicksComponent, { className: "XAxisTicksComponent", filePath: "chart/common/axis/x-axis-ticks.component.ts", lineNumber:
|
|
217
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
211
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(XAxisTicksComponent, { className: "XAxisTicksComponent", filePath: "chart/common/axis/x-axis-ticks.component.ts", lineNumber: 82 }); })();
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"x-axis-ticks.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/axis/x-axis-ticks.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnInit,\n} from '@angular/core';\nimport { ScalePoint, ScaleTime } from 'd3';\nimport dayjs from 'dayjs';\nimport { map } from 'rxjs';\n\nimport { ContextChartService } from '../../chart.service';\nimport { Orientation, Tick, TickValue } from '../../types';\nimport { ScaleType, reduceTicks } from '../../utils';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'g[aclXAxisTicks]',\n  template: `\n    <ng-container\n      *ngIf=\"\n        context.barOptions.orientation === orientation.VERTICAL;\n        else elseTemplate\n      \"\n    >\n      <svg:g *ngFor=\"let tick of ticks; let i = index\">\n        <text\n          [attr.x]=\"\n            i === ticks.length - 1 && tick.x >= context.chartView?.height\n              ? tick.x - 5\n              : tick.x\n          \"\n          [attr.y]=\"tick.y + 16\"\n          fill=\"#666\"\n          [attr.text-anchor]=\"textAnchor\"\n          font-size=\"11\"\n        >\n          {{ translation ? (tick.value | translate) : tick.value }}\n        </text>\n        <line\n          [attr.x1]=\"tick.x\"\n          [attr.x2]=\"tick.x\"\n          [attr.y1]=\"tick.y\"\n          [attr.y2]=\"tick.y + 6\"\n          stroke-width=\"1\"\n          stroke=\"#ccd6eb\"\n        ></line>\n      </svg:g>\n      <svg:g>\n        <path\n          [attr.d]=\"xAxisLine\"\n          stroke=\"#ccd6eb\"\n          fill=\"none\"\n        />\n      </svg:g>\n    </ng-container>\n\n    <ng-template #elseTemplate>\n      <svg:g *ngFor=\"let tick of ticks; let i = index\">\n        <text\n          x=\"-8\"\n          [attr.y]=\"tick.x\"\n          fill=\"#666\"\n          text-anchor=\"end\"\n          font-size=\"11\"\n          alignment-baseline=\"middle\"\n        >\n          {{ translation ? (tick.value | translate | translate) : tick.value }}\n        </text>\n      </svg:g>\n      <svg:g>\n        <path\n          [attr.d]=\"yAxisLine\"\n          stroke=\"#ccd6eb\"\n          fill=\"none\"\n        />\n      </svg:g>\n    </ng-template>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class XAxisTicksComponent implements OnInit {\n  @Input() dateFormat: string;\n\n  @Input() translation: boolean;\n\n  textAnchor = 'middle';\n  orientation = Orientation;\n  get context() {\n    return this.contextService;\n  }\n\n  ticks: Tick[];\n  get yAxisLine() {\n    return `M${0} ${0}L${0} ${this.context.chartView.height}Z`;\n  }\n\n  get xAxisLine() {\n    const { width } = this.contextService.chartView;\n    return `M0 0L${width} 0Z`;\n  }\n\n  getTicks() {\n    let ticks: Tick[];\n    if (this.context.scaleType === ScaleType.ORDINAL) {\n      const maxTicks = this.getMaxTicks(20);\n      ticks = reduceTicks(this.context.x.domain(), maxTicks).map(\n        this.handleTicksData,\n      );\n    } else {\n      ticks = (this.context.x as ScaleTime<number, number>)\n        .ticks(this.getMaxTicks(100))\n        .map(this.handleTicksData);\n    }\n    return ticks;\n  }\n\n  handleTicksData = (value: TickValue): Tick => {\n    const bandwidth = this.context.barOptions.isBand\n      ? (this.context.x as ScalePoint<string>).bandwidth() * 0.5\n      : 0;\n    return {\n      value: this.format(value),\n      x: this.context.x(value) + bandwidth,\n      y: 0,\n    } as Tick;\n  };\n\n  getMaxTicks(tickWidth: number): number {\n    const width = this.context.horizontal\n      ? this.context.chartView.height\n      : this.context.chartView.width;\n    return Math.floor(width / tickWidth);\n  }\n\n  constructor(\n    private readonly contextService: ContextChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit() {\n    this.contextService.seriesData$\n      .pipe(map(() => this.getTicks()))\n      .subscribe(res => {\n        this.ticks = res;\n        this.cdr.detectChanges();\n      });\n  }\n\n  format(value: string | number | Date) {\n    return this.contextService.scaleType === ScaleType.TIME\n      ? dayjs(value).format(this.dateFormat)\n      : value;\n  }\n}\n"]}
|
|
@@ -5,7 +5,6 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
import * as i1 from "../../chart.service";
|
|
6
6
|
const _c0 = a0 => ({ context: a0 });
|
|
7
7
|
const _c1 = a0 => [a0, "label-symbol"];
|
|
8
|
-
const _c2 = () => ({});
|
|
9
8
|
function ChartLegendComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
10
9
|
i0.ɵɵelementStart(0, "div", 5);
|
|
11
10
|
i0.ɵɵelementContainer(1, 6);
|
|
@@ -110,15 +109,15 @@ function ChartLegendComponent_ng_template_3_li_3_Template(rf, ctx) { if (rf & 1)
|
|
|
110
109
|
i0.ɵɵclassProp("disable", !legend_r7.activate || i0.ɵɵpipeBind1(1, 10, ctx_r0.context.noData$))("forbid", i0.ɵɵpipeBind1(2, 12, ctx_r0.context.noData$))("hover", legend_r7.activate && legend_r7.hover);
|
|
111
110
|
i0.ɵɵadvance(3);
|
|
112
111
|
i0.ɵɵstyleProp("background", legend_r7.color);
|
|
113
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(
|
|
112
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(16, _c1, ctx_r0.symbolName));
|
|
114
113
|
i0.ɵɵadvance(2);
|
|
115
|
-
i0.ɵɵtextInterpolate(ctx_r0.translation ? i0.ɵɵ
|
|
114
|
+
i0.ɵɵtextInterpolate(ctx_r0.translation ? i0.ɵɵpipeBind1(6, 14, legend_r7.name) : legend_r7.name);
|
|
116
115
|
} }
|
|
117
116
|
function ChartLegendComponent_ng_template_3_Template(rf, ctx) { if (rf & 1) {
|
|
118
117
|
i0.ɵɵelementStart(0, "ul", 13);
|
|
119
118
|
i0.ɵɵtemplate(1, ChartLegendComponent_ng_template_3_li_1_Template, 4, 4, "li", 14);
|
|
120
119
|
i0.ɵɵpipe(2, "async");
|
|
121
|
-
i0.ɵɵtemplate(3, ChartLegendComponent_ng_template_3_li_3_Template, 7,
|
|
120
|
+
i0.ɵɵtemplate(3, ChartLegendComponent_ng_template_3_li_3_Template, 7, 18, "li", 15);
|
|
122
121
|
i0.ɵɵelementEnd();
|
|
123
122
|
} if (rf & 2) {
|
|
124
123
|
const ctx_r0 = i0.ɵɵnextContext();
|
|
@@ -236,7 +235,7 @@ export class ChartLegendComponent {
|
|
|
236
235
|
}
|
|
237
236
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ChartLegendComponent, [{
|
|
238
237
|
type: Component,
|
|
239
|
-
args: [{ selector: 'acl-legend', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"operation\"\n *ngIf=\"isTemplateRef(leftOperation)\"\n>\n <ng-container [ngTemplateOutlet]=\"leftOperation\"></ng-container>\n</div>\n\n<div\n class=\"legend-wrap\"\n *ngIf=\"!hideLegend\"\n>\n <ng-container *ngIf=\"!template; else custom\">\n <ng-container [ngTemplateOutlet]=\"legendTemplate\"></ng-container>\n </ng-container>\n <ng-template #custom>\n <ng-container *ngIf=\"isTemplateRef(template); else builtinTemplate\">\n <ng-container\n [ngTemplateOutlet]=\"$any(template)\"\n [ngTemplateOutletContext]=\"{ context: legendEntries }\"\n ></ng-container>\n </ng-container>\n <ng-template #builtinTemplate>\n <ng-container [ngSwitch]=\"template\">\n <acl-dropdown-legend\n class=\"legend-vertical\"\n *ngSwitchCase=\"'dropdown'\"\n [data]=\"legendEntries\"\n [noData]=\"context.noData$ | async\"\n [legendTemplate]=\"legendTemplate\"\n [isCard]=\"mode === 'card'\"\n >\n </acl-dropdown-legend>\n </ng-container>\n </ng-template>\n </ng-template>\n</div>\n\n<div\n class=\"operation\"\n *ngIf=\"isTemplateRef(rightOperation)\"\n>\n <ng-container [ngTemplateOutlet]=\"rightOperation\"></ng-container>\n</div>\n\n<ng-template #legendTemplate>\n <ul class=\"legend-labels\">\n <li\n class=\"select-all\"\n *ngIf=\"\n !(context.noData$ | async) &&\n selectAllOperation &&\n template === 'dropdown'\n \"\n >\n <aui-checkbox\n [(ngModel)]=\"allSelected\"\n (ngModelChange)=\"allSelect($event)\"\n >\n {{ selectAllName || ('select_all' | translate) }}\n </aui-checkbox>\n </li>\n <li\n class=\"legend-label\"\n [class.disable]=\"!legend.activate || (context.noData$ | async)\"\n [class.forbid]=\"context.noData$ | async\"\n *ngFor=\"let legend of legendEntries\"\n (click)=\"selected(legend)\"\n [class.hover]=\"legend.activate && legend.hover\"\n (mouseenter)=\"mouseenter(legend)\"\n (mouseleave)=\"mouseleave(legend)\"\n >\n <span\n [ngClass]=\"[symbolName, 'label-symbol']\"\n [style.background]=\"legend.color\"\n >\n </span>\n <span class=\"label-name\">{{\n translation ? (legend.name | translate
|
|
238
|
+
args: [{ selector: 'acl-legend', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"operation\"\n *ngIf=\"isTemplateRef(leftOperation)\"\n>\n <ng-container [ngTemplateOutlet]=\"leftOperation\"></ng-container>\n</div>\n\n<div\n class=\"legend-wrap\"\n *ngIf=\"!hideLegend\"\n>\n <ng-container *ngIf=\"!template; else custom\">\n <ng-container [ngTemplateOutlet]=\"legendTemplate\"></ng-container>\n </ng-container>\n <ng-template #custom>\n <ng-container *ngIf=\"isTemplateRef(template); else builtinTemplate\">\n <ng-container\n [ngTemplateOutlet]=\"$any(template)\"\n [ngTemplateOutletContext]=\"{ context: legendEntries }\"\n ></ng-container>\n </ng-container>\n <ng-template #builtinTemplate>\n <ng-container [ngSwitch]=\"template\">\n <acl-dropdown-legend\n class=\"legend-vertical\"\n *ngSwitchCase=\"'dropdown'\"\n [data]=\"legendEntries\"\n [noData]=\"context.noData$ | async\"\n [legendTemplate]=\"legendTemplate\"\n [isCard]=\"mode === 'card'\"\n >\n </acl-dropdown-legend>\n </ng-container>\n </ng-template>\n </ng-template>\n</div>\n\n<div\n class=\"operation\"\n *ngIf=\"isTemplateRef(rightOperation)\"\n>\n <ng-container [ngTemplateOutlet]=\"rightOperation\"></ng-container>\n</div>\n\n<ng-template #legendTemplate>\n <ul class=\"legend-labels\">\n <li\n class=\"select-all\"\n *ngIf=\"\n !(context.noData$ | async) &&\n selectAllOperation &&\n template === 'dropdown'\n \"\n >\n <aui-checkbox\n [(ngModel)]=\"allSelected\"\n (ngModelChange)=\"allSelect($event)\"\n >\n {{ selectAllName || ('select_all' | translate) }}\n </aui-checkbox>\n </li>\n <li\n class=\"legend-label\"\n [class.disable]=\"!legend.activate || (context.noData$ | async)\"\n [class.forbid]=\"context.noData$ | async\"\n *ngFor=\"let legend of legendEntries\"\n (click)=\"selected(legend)\"\n [class.hover]=\"legend.activate && legend.hover\"\n (mouseenter)=\"mouseenter(legend)\"\n (mouseleave)=\"mouseleave(legend)\"\n >\n <span\n [ngClass]=\"[symbolName, 'label-symbol']\"\n [style.background]=\"legend.color\"\n >\n </span>\n <span class=\"label-name\">{{\n translation ? (legend.name | translate) : legend.name\n }}</span>\n </li>\n </ul>\n</ng-template>\n", styles: [".legend-wrap{display:inline-block}.legend-wrap ul,.legend-wrap li{padding:0;margin:0;list-style:none}.legend-wrap .legend-labels{display:flex}.legend-wrap .legend-label{display:flex;align-items:center;cursor:pointer;justify-content:center}.legend-wrap .legend-label:not(:last-child){margin-right:20px}.legend-wrap .forbid{cursor:no-drop}.legend-wrap .label-name{font-size:12px;color:rgb(var(--aui-color-secondary-text))}.legend-wrap .label-symbol{margin-right:4px}.disable .label-symbol{background:rgb(var(--aui-color-n-6))!important}.disable .label-name{color:rgb(var(--aui-color-n-6))}.hover .label-name{color:rgb(var(--aui-color-n-1))}.symbol-square{width:12px;height:12px;display:inline-block}.symbol-line{width:12px;height:2px;display:inline-block}.symbol-circle{width:12px;height:12px;border-radius:50%;display:inline-block}.operation{display:flex;justify-content:center}.select-all ::ng-deep .aui-checkbox{font-size:12px;line-height:16px;margin-bottom:8px}\n"] }]
|
|
240
239
|
}], () => [{ type: i1.ContextChartService }, { type: i0.ChangeDetectorRef }], { symbol: [{
|
|
241
240
|
type: Input
|
|
242
241
|
}], template: [{
|
|
@@ -263,4 +262,4 @@ export class ChartLegendComponent {
|
|
|
263
262
|
type: Output
|
|
264
263
|
}] }); })();
|
|
265
264
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ChartLegendComponent, { className: "ChartLegendComponent", filePath: "chart/common/legend/legend.component.ts", lineNumber: 33 }); })();
|
|
266
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"legend.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/legend/legend.component.ts","../../../../../../../libs/common/src/chart/common/legend/legend.component.html"],"names":[],"mappings":"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","sourcesContent":["import { isTemplateRef } from '@alauda/ui';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n} from '@angular/core';\n\nimport { ChartDataItem } from '../../../public-api';\nimport { ContextChartService } from '../../chart.service';\n\nexport interface LegendItem {\n  name: string;\n  color: string;\n  activate?: boolean;\n  hover?: boolean;\n}\n\nexport class LegendPayload {\n  legendItem: LegendItem;\n  legends: LegendItem[];\n}\n@Component({\n  selector: 'acl-legend',\n  templateUrl: './legend.component.html',\n  styleUrls: ['./legend.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ChartLegendComponent implements OnInit {\n  legendEntries: LegendItem[];\n\n  @Input() symbol: 'circle' | 'square' | 'line' = 'line';\n\n  @Input() template: TemplateRef<unknown> | string | 'dropdown';\n\n  @Input() mode: 'card' | 'default' = 'default';\n\n  @Input() translation = true;\n\n  @Input() leftOperation: TemplateRef<unknown>;\n\n  @Input() rightOperation: TemplateRef<unknown>;\n\n  @Input() hideLegend: boolean;\n\n  @Input() selectAllOperation = false;\n\n  @Input() selectAllName: string;\n\n  @Output() labelClick = new EventEmitter<LegendPayload>();\n\n  @Output() labelActivate = new EventEmitter<LegendItem>();\n\n  @Output() labelDeactivate = new EventEmitter<LegendItem>();\n\n  isTemplateRef = isTemplateRef;\n\n  allSelected = true;\n\n  get symbolName() {\n    return `symbol-${this.symbol}`;\n  }\n\n  constructor(\n    public readonly context: ContextChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit(): void {\n    this.context.seriesData$.subscribe(() => {\n      this.legendEntries = this.context.barOptions.isBand\n        ? this.context.chartData\n            .flatMap(item => item.values)\n            .reduce(\n              (\n                pre,\n                cur: ChartDataItem<{ x: string; y: number; color?: string }>,\n              ) => [\n                ...pre,\n                ...(pre.some(d => d.name === cur.x)\n                  ? []\n                  : [\n                      {\n                        name: cur.x,\n                        color:\n                          cur.color ||\n                          this.context.getChartDefaultColor(pre.length),\n                        activate: !this.context.disabledLegend.has(cur.x),\n                        hover: false,\n                      },\n                    ]),\n              ],\n              [],\n            )\n        : this.context.noData\n        ? []\n        : this.context.chartData.map(d => ({\n            name: d.name,\n            color: d.color,\n            activate: !this.context.disabledLegend.has(d.name),\n            hover: false,\n          }));\n      this.cdr.detectChanges();\n    });\n  }\n\n  selected(legend: LegendItem) {\n    if (this.context.noData) {\n      return;\n    }\n    const legendItem = this.legendEntries.find(\n      item => item.name === legend.name,\n    );\n    legendItem.activate = !legend.activate;\n    const payload = {\n      legendItem,\n      legends: this.legendEntries,\n    };\n    this.labelClick.next(payload);\n    if (legend.activate) {\n      this.labelActivate.next(legend);\n      this.context.selectedLegend(payload);\n    } else {\n      this.labelDeactivate.next(legend);\n      legend.hover = false;\n      this.context.deactivateLegend(payload);\n    }\n    this.cdr.detectChanges();\n  }\n\n  mouseenter(legend: LegendItem) {\n    if (legend.activate && !this.context.noData) {\n      legend.hover = true;\n      this.context.legendActivate$$.next(legend.name);\n    }\n    this.cdr.detectChanges();\n  }\n\n  mouseleave(legend: LegendItem) {\n    this.context.legendActivate$$.next('');\n    legend.hover = false;\n    this.cdr.detectChanges();\n  }\n\n  allSelect(select: boolean) {\n    this.legendEntries = this.legendEntries.map(d => ({\n      ...d,\n      activate: select,\n    }));\n    select\n      ? this.context.selectedAllLegend()\n      : this.context.unselectAllLegend(this.legendEntries.map(d => d.name));\n    this.labelClick.next({\n      legendItem: null,\n      legends: this.legendEntries,\n    });\n  }\n}\n","<div\n  class=\"operation\"\n  *ngIf=\"isTemplateRef(leftOperation)\"\n>\n  <ng-container [ngTemplateOutlet]=\"leftOperation\"></ng-container>\n</div>\n\n<div\n  class=\"legend-wrap\"\n  *ngIf=\"!hideLegend\"\n>\n  <ng-container *ngIf=\"!template; else custom\">\n    <ng-container [ngTemplateOutlet]=\"legendTemplate\"></ng-container>\n  </ng-container>\n  <ng-template #custom>\n    <ng-container *ngIf=\"isTemplateRef(template); else builtinTemplate\">\n      <ng-container\n        [ngTemplateOutlet]=\"$any(template)\"\n        [ngTemplateOutletContext]=\"{ context: legendEntries }\"\n      ></ng-container>\n    </ng-container>\n    <ng-template #builtinTemplate>\n      <ng-container [ngSwitch]=\"template\">\n        <acl-dropdown-legend\n          class=\"legend-vertical\"\n          *ngSwitchCase=\"'dropdown'\"\n          [data]=\"legendEntries\"\n          [noData]=\"context.noData$ | async\"\n          [legendTemplate]=\"legendTemplate\"\n          [isCard]=\"mode === 'card'\"\n        >\n        </acl-dropdown-legend>\n      </ng-container>\n    </ng-template>\n  </ng-template>\n</div>\n\n<div\n  class=\"operation\"\n  *ngIf=\"isTemplateRef(rightOperation)\"\n>\n  <ng-container [ngTemplateOutlet]=\"rightOperation\"></ng-container>\n</div>\n\n<ng-template #legendTemplate>\n  <ul class=\"legend-labels\">\n    <li\n      class=\"select-all\"\n      *ngIf=\"\n        !(context.noData$ | async) &&\n        selectAllOperation &&\n        template === 'dropdown'\n      \"\n    >\n      <aui-checkbox\n        [(ngModel)]=\"allSelected\"\n        (ngModelChange)=\"allSelect($event)\"\n      >\n        {{ selectAllName || ('select_all' | translate) }}\n      </aui-checkbox>\n    </li>\n    <li\n      class=\"legend-label\"\n      [class.disable]=\"!legend.activate || (context.noData$ | async)\"\n      [class.forbid]=\"context.noData$ | async\"\n      *ngFor=\"let legend of legendEntries\"\n      (click)=\"selected(legend)\"\n      [class.hover]=\"legend.activate && legend.hover\"\n      (mouseenter)=\"mouseenter(legend)\"\n      (mouseleave)=\"mouseleave(legend)\"\n    >\n      <span\n        [ngClass]=\"[symbolName, 'label-symbol']\"\n        [style.background]=\"legend.color\"\n      >\n      </span>\n      <span class=\"label-name\">{{\n        translation ? (legend.name | translate: {}:true) : legend.name\n      }}</span>\n    </li>\n  </ul>\n</ng-template>\n"]}
|
|
265
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"legend.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/legend/legend.component.ts","../../../../../../../libs/common/src/chart/common/legend/legend.component.html"],"names":[],"mappings":"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","sourcesContent":["import { isTemplateRef } from '@alauda/ui';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n} from '@angular/core';\n\nimport { ChartDataItem } from '../../../public-api';\nimport { ContextChartService } from '../../chart.service';\n\nexport interface LegendItem {\n  name: string;\n  color: string;\n  activate?: boolean;\n  hover?: boolean;\n}\n\nexport class LegendPayload {\n  legendItem: LegendItem;\n  legends: LegendItem[];\n}\n@Component({\n  selector: 'acl-legend',\n  templateUrl: './legend.component.html',\n  styleUrls: ['./legend.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ChartLegendComponent implements OnInit {\n  legendEntries: LegendItem[];\n\n  @Input() symbol: 'circle' | 'square' | 'line' = 'line';\n\n  @Input() template: TemplateRef<unknown> | string | 'dropdown';\n\n  @Input() mode: 'card' | 'default' = 'default';\n\n  @Input() translation = true;\n\n  @Input() leftOperation: TemplateRef<unknown>;\n\n  @Input() rightOperation: TemplateRef<unknown>;\n\n  @Input() hideLegend: boolean;\n\n  @Input() selectAllOperation = false;\n\n  @Input() selectAllName: string;\n\n  @Output() labelClick = new EventEmitter<LegendPayload>();\n\n  @Output() labelActivate = new EventEmitter<LegendItem>();\n\n  @Output() labelDeactivate = new EventEmitter<LegendItem>();\n\n  isTemplateRef = isTemplateRef;\n\n  allSelected = true;\n\n  get symbolName() {\n    return `symbol-${this.symbol}`;\n  }\n\n  constructor(\n    public readonly context: ContextChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit(): void {\n    this.context.seriesData$.subscribe(() => {\n      this.legendEntries = this.context.barOptions.isBand\n        ? this.context.chartData\n            .flatMap(item => item.values)\n            .reduce(\n              (\n                pre,\n                cur: ChartDataItem<{ x: string; y: number; color?: string }>,\n              ) => [\n                ...pre,\n                ...(pre.some(d => d.name === cur.x)\n                  ? []\n                  : [\n                      {\n                        name: cur.x,\n                        color:\n                          cur.color ||\n                          this.context.getChartDefaultColor(pre.length),\n                        activate: !this.context.disabledLegend.has(cur.x),\n                        hover: false,\n                      },\n                    ]),\n              ],\n              [],\n            )\n        : this.context.noData\n        ? []\n        : this.context.chartData.map(d => ({\n            name: d.name,\n            color: d.color,\n            activate: !this.context.disabledLegend.has(d.name),\n            hover: false,\n          }));\n      this.cdr.detectChanges();\n    });\n  }\n\n  selected(legend: LegendItem) {\n    if (this.context.noData) {\n      return;\n    }\n    const legendItem = this.legendEntries.find(\n      item => item.name === legend.name,\n    );\n    legendItem.activate = !legend.activate;\n    const payload = {\n      legendItem,\n      legends: this.legendEntries,\n    };\n    this.labelClick.next(payload);\n    if (legend.activate) {\n      this.labelActivate.next(legend);\n      this.context.selectedLegend(payload);\n    } else {\n      this.labelDeactivate.next(legend);\n      legend.hover = false;\n      this.context.deactivateLegend(payload);\n    }\n    this.cdr.detectChanges();\n  }\n\n  mouseenter(legend: LegendItem) {\n    if (legend.activate && !this.context.noData) {\n      legend.hover = true;\n      this.context.legendActivate$$.next(legend.name);\n    }\n    this.cdr.detectChanges();\n  }\n\n  mouseleave(legend: LegendItem) {\n    this.context.legendActivate$$.next('');\n    legend.hover = false;\n    this.cdr.detectChanges();\n  }\n\n  allSelect(select: boolean) {\n    this.legendEntries = this.legendEntries.map(d => ({\n      ...d,\n      activate: select,\n    }));\n    select\n      ? this.context.selectedAllLegend()\n      : this.context.unselectAllLegend(this.legendEntries.map(d => d.name));\n    this.labelClick.next({\n      legendItem: null,\n      legends: this.legendEntries,\n    });\n  }\n}\n","<div\n  class=\"operation\"\n  *ngIf=\"isTemplateRef(leftOperation)\"\n>\n  <ng-container [ngTemplateOutlet]=\"leftOperation\"></ng-container>\n</div>\n\n<div\n  class=\"legend-wrap\"\n  *ngIf=\"!hideLegend\"\n>\n  <ng-container *ngIf=\"!template; else custom\">\n    <ng-container [ngTemplateOutlet]=\"legendTemplate\"></ng-container>\n  </ng-container>\n  <ng-template #custom>\n    <ng-container *ngIf=\"isTemplateRef(template); else builtinTemplate\">\n      <ng-container\n        [ngTemplateOutlet]=\"$any(template)\"\n        [ngTemplateOutletContext]=\"{ context: legendEntries }\"\n      ></ng-container>\n    </ng-container>\n    <ng-template #builtinTemplate>\n      <ng-container [ngSwitch]=\"template\">\n        <acl-dropdown-legend\n          class=\"legend-vertical\"\n          *ngSwitchCase=\"'dropdown'\"\n          [data]=\"legendEntries\"\n          [noData]=\"context.noData$ | async\"\n          [legendTemplate]=\"legendTemplate\"\n          [isCard]=\"mode === 'card'\"\n        >\n        </acl-dropdown-legend>\n      </ng-container>\n    </ng-template>\n  </ng-template>\n</div>\n\n<div\n  class=\"operation\"\n  *ngIf=\"isTemplateRef(rightOperation)\"\n>\n  <ng-container [ngTemplateOutlet]=\"rightOperation\"></ng-container>\n</div>\n\n<ng-template #legendTemplate>\n  <ul class=\"legend-labels\">\n    <li\n      class=\"select-all\"\n      *ngIf=\"\n        !(context.noData$ | async) &&\n        selectAllOperation &&\n        template === 'dropdown'\n      \"\n    >\n      <aui-checkbox\n        [(ngModel)]=\"allSelected\"\n        (ngModelChange)=\"allSelect($event)\"\n      >\n        {{ selectAllName || ('select_all' | translate) }}\n      </aui-checkbox>\n    </li>\n    <li\n      class=\"legend-label\"\n      [class.disable]=\"!legend.activate || (context.noData$ | async)\"\n      [class.forbid]=\"context.noData$ | async\"\n      *ngFor=\"let legend of legendEntries\"\n      (click)=\"selected(legend)\"\n      [class.hover]=\"legend.activate && legend.hover\"\n      (mouseenter)=\"mouseenter(legend)\"\n      (mouseleave)=\"mouseleave(legend)\"\n    >\n      <span\n        [ngClass]=\"[symbolName, 'label-symbol']\"\n        [style.background]=\"legend.color\"\n      >\n      </span>\n      <span class=\"label-name\">{{\n        translation ? (legend.name | translate) : legend.name\n      }}</span>\n    </li>\n  </ul>\n</ng-template>\n"]}
|