@alauda-fe/common 1.0.1 → 1.0.3
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/components/legend/base-legend.component.d.ts +3 -4
- package/a-chart/constant.d.ts +3 -0
- package/a-chart/types.d.ts +2 -2
- package/a-chart/utils.d.ts +1 -1
- package/a-metric-chart/a-metric-chart.component.d.ts +1 -2
- package/a-metric-chart/bar-gauge/bar-gauge.component.d.ts +1 -1
- package/a-metric-chart/base-chart.component.d.ts +1 -1
- package/a-metric-chart/types.d.ts +1 -1
- package/a-metric-chart/utils/unit.d.ts +1 -1
- package/a-metric-chart/utils/util.d.ts +1 -1
- package/core/types/k8s/crd.d.ts +100 -1
- package/esm2022/a-chart/base-chart.mjs +2 -2
- package/esm2022/a-chart/chart-status.component.mjs +2 -2
- package/esm2022/a-chart/chart.component.mjs +15 -4
- package/esm2022/a-chart/components/legend/base-legend.component.mjs +15 -14
- package/esm2022/a-chart/constant.mjs +3 -1
- package/esm2022/a-chart/types.mjs +1 -1
- package/esm2022/a-chart/utils.mjs +1 -1
- package/esm2022/a-metric-chart/a-metric-chart.component.mjs +3 -3
- package/esm2022/a-metric-chart/a-metric-chart.module.mjs +3 -3
- package/esm2022/a-metric-chart/bar-gauge/bar-gauge.component.mjs +1 -1
- package/esm2022/a-metric-chart/base-chart.component.mjs +1 -1
- package/esm2022/a-metric-chart/types.mjs +1 -1
- package/esm2022/a-metric-chart/utils/unit.mjs +2 -2
- package/esm2022/a-metric-chart/utils/util.mjs +2 -2
- package/esm2022/business/resource-select/internals/data-grid/component.mjs +23 -23
- package/esm2022/business/resource-select/utils.mjs +7 -2
- package/esm2022/core/types/k8s/crd.mjs +1 -1
- package/esm2022/form/directives/value-trace.directive.mjs +61 -0
- package/esm2022/form/public-api.mjs +2 -1
- package/form/directives/value-trace.directive.d.ts +27 -0
- package/form/public-api.d.ts +1 -0
- package/package.json +5 -5
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectorRef, EventEmitter,
|
|
1
|
+
import { ChangeDetectorRef, EventEmitter, OnChanges, OnInit, SimpleChanges } from '@angular/core';
|
|
2
2
|
import { BehaviorSubject, Subject } from 'rxjs';
|
|
3
3
|
import { Legend, LegendItem as ALegendItem, DataItem } from 'zz-chart';
|
|
4
4
|
import { ChartComponent } from '../../chart.component';
|
|
@@ -10,8 +10,8 @@ export interface LegendItem extends ALegendItem {
|
|
|
10
10
|
unit?: string;
|
|
11
11
|
}
|
|
12
12
|
export declare class BaseLegendComponent implements OnInit, OnChanges {
|
|
13
|
-
readonly
|
|
14
|
-
|
|
13
|
+
private readonly chartRefFromInjection;
|
|
14
|
+
protected cdr: ChangeDetectorRef;
|
|
15
15
|
chartRef: ChartComponent;
|
|
16
16
|
changeLegend: EventEmitter<LegendItem[]>;
|
|
17
17
|
get noData(): boolean;
|
|
@@ -19,7 +19,6 @@ export declare class BaseLegendComponent implements OnInit, OnChanges {
|
|
|
19
19
|
get legendCtr(): Legend;
|
|
20
20
|
legendItems$$: BehaviorSubject<LegendItem[]>;
|
|
21
21
|
legendChange$$: Subject<LegendItem[]>;
|
|
22
|
-
constructor(cdr: ChangeDetectorRef, injector: Injector);
|
|
23
22
|
ngOnChanges({ chartRef }: SimpleChanges): void;
|
|
24
23
|
ngOnInit(): void;
|
|
25
24
|
setChartRef(chartRef: ChartComponent): void;
|
package/a-chart/constant.d.ts
CHANGED
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
1
2
|
import { ChartOption } from 'zz-chart';
|
|
3
|
+
import { ChartComponent } from './chart.component';
|
|
2
4
|
export declare const CHART_TIME_FORMAT = "HH:mm";
|
|
3
5
|
export declare const DEFAULT_CONFIG: ChartOption;
|
|
6
|
+
export declare const CHART_COMPONENT_TOKEN: InjectionToken<ChartComponent>;
|
package/a-chart/types.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DataItem, Options, TooltipValue } from 'zz-chart';
|
|
2
|
-
import { IndicatorType } from '../api/
|
|
3
|
-
import { Translation } from '../translate/
|
|
2
|
+
import { IndicatorType } from '../api/public-api';
|
|
3
|
+
import { Translation } from '../translate/public-api';
|
|
4
4
|
export type AOptions = Omit<Options, 'data' | 'padding' | 'container'>;
|
|
5
5
|
export type AType = 'line' | 'area' | 'bar' | 'point' | 'pie' | 'gauge' | 'stat' | 'table' | 'bar-gauge';
|
|
6
6
|
export interface AChartStatus {
|
package/a-chart/utils.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ConfigType } from 'dayjs';
|
|
2
2
|
import { TooltipValue } from 'zz-chart';
|
|
3
|
-
import { ContextItem } from '../view-chart/
|
|
3
|
+
import { ContextItem } from '../view-chart/public-api';
|
|
4
4
|
export declare function transformMaximum(value: number | string): string;
|
|
5
5
|
export declare function limitMaxContext(context: TooltipValue[], limit?: number): TooltipValue[];
|
|
6
6
|
export declare function pointFormat(value: number): string;
|
|
@@ -3,8 +3,7 @@ import { BehaviorSubject, Observable, Subject } from 'rxjs';
|
|
|
3
3
|
import { Chart, DataItem, Options, BrushContext } from 'zz-chart';
|
|
4
4
|
import { AChartData, AChartStatus, AType, ChartComponent, LegendComponent, MarkContext, MonitorDataItem, TitleComponent } from '../a-chart/public-api';
|
|
5
5
|
import { IndicatorType, MonitorApiService, MonitorMetric } from '../api/public-api';
|
|
6
|
-
import { TranslateService } from '../translate/
|
|
7
|
-
import { Translation } from '../translate/types';
|
|
6
|
+
import { TranslateService, Translation } from '../translate/public-api';
|
|
8
7
|
import { MetricChartRefreshService } from './metric-chart-refresh.service';
|
|
9
8
|
import { IndicatorParams, AMatchUnitParams, MetricParams, SeriesParams, FetchParams, AMetricChartOptions, Orientation } from './types';
|
|
10
9
|
import * as i0 from "@angular/core";
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { EventEmitter, TemplateRef } from '@angular/core';
|
|
2
2
|
import { Observable } from 'rxjs';
|
|
3
|
-
import { AChartData, AChartStatus } from '../a-chart/
|
|
3
|
+
import { AChartData, AChartStatus } from '../a-chart/public-api';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class BaseComponentChart {
|
|
6
6
|
status: AChartStatus;
|
|
@@ -3,7 +3,7 @@ import { XOR } from 'ts-essentials';
|
|
|
3
3
|
import { LegendOpt, Options, TooltipOption, TooltipValue } from 'zz-chart';
|
|
4
4
|
import { MonitorMetricResult } from '../api/public-api';
|
|
5
5
|
import { StringMap, WorkspaceParams } from '../core/public-api';
|
|
6
|
-
import { Translation } from '../translate/
|
|
6
|
+
import { Translation } from '../translate/public-api';
|
|
7
7
|
export declare enum MetricScope {
|
|
8
8
|
'CLUSTER' = "cluster",
|
|
9
9
|
'PROJECT' = "project",
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { AChartData } from '../../a-chart/
|
|
1
|
+
import { AChartData } from '../../a-chart/public-api';
|
|
2
2
|
import { AMatchUnitParams, IndicatorUnit } from '../types';
|
|
3
3
|
export declare const MATCH_UNIT_DEFAULT_BASE = 1024;
|
|
4
4
|
export declare function adaptChartUnit(data: Array<{
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { DataItem, TooltipValue } from 'zz-chart';
|
|
2
|
-
import { AChartData } from '../../a-chart/
|
|
2
|
+
import { AChartData } from '../../a-chart/public-api';
|
|
3
3
|
import { MonitorMetric, MonitorMetricResult } from '../../api/public-api';
|
|
4
4
|
import { Dictionary, StringMap } from '../../core/public-api';
|
|
5
5
|
import { FetchParams, IndicatorParams, MetricParams } from '../types';
|
package/core/types/k8s/crd.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ValueOf } from 'ts-essentials';
|
|
2
2
|
import { StringMap } from '../commons';
|
|
3
3
|
import { Condition, KubernetesResource, ObjectMeta } from './core';
|
|
4
|
-
import { ConfigMapKeyRef, Node, NodeTaint, SecretKeyRef } from './raw';
|
|
4
|
+
import { ConfigMapKeyRef, Node, NodeStatus, NodeTaint, SecretKeyRef } from './raw';
|
|
5
5
|
/**
|
|
6
6
|
* 只保留common中需要用到的crd 扩展类
|
|
7
7
|
*/
|
|
@@ -399,6 +399,105 @@ export interface TKEMachineSpec {
|
|
|
399
399
|
annotations?: StringMap;
|
|
400
400
|
taints?: NodeTaint[];
|
|
401
401
|
}
|
|
402
|
+
export interface ClusterCredential extends KubernetesResource {
|
|
403
|
+
clusterName: string;
|
|
404
|
+
caCert: string;
|
|
405
|
+
token: string;
|
|
406
|
+
}
|
|
407
|
+
export interface TKEMachine extends KubernetesResource {
|
|
408
|
+
spec?: TKEMachineSpec;
|
|
409
|
+
status?: NodeStatus;
|
|
410
|
+
}
|
|
411
|
+
export interface Machine extends KubernetesResource {
|
|
412
|
+
spec?: MachineSpec;
|
|
413
|
+
status?: MachineStatus;
|
|
414
|
+
}
|
|
415
|
+
export interface MachineSpec {
|
|
416
|
+
cluster: string;
|
|
417
|
+
provider: string;
|
|
418
|
+
providerSpec: unknown;
|
|
419
|
+
}
|
|
420
|
+
export interface MachineStatus {
|
|
421
|
+
userDataSecret?: {
|
|
422
|
+
name?: string;
|
|
423
|
+
};
|
|
424
|
+
nodeRef?: {
|
|
425
|
+
name?: string;
|
|
426
|
+
};
|
|
427
|
+
lastUpdate: string;
|
|
428
|
+
errReason: string;
|
|
429
|
+
errMessage: string;
|
|
430
|
+
phase: string;
|
|
431
|
+
conditions: Condition[];
|
|
432
|
+
}
|
|
433
|
+
export interface ClusterView extends KubernetesResource {
|
|
434
|
+
spec?: void;
|
|
435
|
+
status?: ClusterViewStatus;
|
|
436
|
+
}
|
|
437
|
+
export interface ClusterViewStatus {
|
|
438
|
+
provisionType: 'SelfHosted' | 'ProviderHosted' | 'Imported' | 'Registered';
|
|
439
|
+
clusterType: string;
|
|
440
|
+
supportWindows: boolean;
|
|
441
|
+
registryAddress: string;
|
|
442
|
+
conditions: Condition[];
|
|
443
|
+
projects: Array<{
|
|
444
|
+
name: string;
|
|
445
|
+
displayName: string;
|
|
446
|
+
}>;
|
|
447
|
+
controlPlaneEndpoints: {
|
|
448
|
+
default: string;
|
|
449
|
+
advertise: string;
|
|
450
|
+
public?: string;
|
|
451
|
+
};
|
|
452
|
+
nodesInfo: {
|
|
453
|
+
readyNodes: number;
|
|
454
|
+
notReadyNodes: number;
|
|
455
|
+
architectures: string[];
|
|
456
|
+
totalCPUCores: number;
|
|
457
|
+
totalMemories: number;
|
|
458
|
+
totalNvidiaCores: number;
|
|
459
|
+
totalVGPUCores: number;
|
|
460
|
+
totalVGPUMemoryUnits: number;
|
|
461
|
+
extraResources: unknown;
|
|
462
|
+
criVersions: string[];
|
|
463
|
+
};
|
|
464
|
+
clusterNetwork: {
|
|
465
|
+
haLoadBalancerType?: 'Alive' | 'ThirdParty';
|
|
466
|
+
cniType: string;
|
|
467
|
+
protocolStack: 'IPv4' | 'IPv6' | 'Dual-Stack';
|
|
468
|
+
serviceCIDRs: string[];
|
|
469
|
+
podCIDRs: string[];
|
|
470
|
+
extraInfo: Record<string, string>;
|
|
471
|
+
vrid?: number;
|
|
472
|
+
maxNodes?: number;
|
|
473
|
+
};
|
|
474
|
+
managedBy?: {
|
|
475
|
+
pluginName: string;
|
|
476
|
+
entrypoint: string;
|
|
477
|
+
};
|
|
478
|
+
gpuPluginType?: 'Virtual' | 'Physical';
|
|
479
|
+
highAvailable: boolean;
|
|
480
|
+
needUpgrade: boolean;
|
|
481
|
+
upgradable: boolean;
|
|
482
|
+
version: string;
|
|
483
|
+
phase: string;
|
|
484
|
+
extraArgs: Record<string, Record<string, string>>;
|
|
485
|
+
publicAlternativeNames: string[];
|
|
486
|
+
}
|
|
487
|
+
export interface ProviderNetworkSpec {
|
|
488
|
+
defaultInterface: string;
|
|
489
|
+
customInterfaces: Array<{
|
|
490
|
+
interface: string;
|
|
491
|
+
nodes: string[];
|
|
492
|
+
}>;
|
|
493
|
+
excludeNodes: string[];
|
|
494
|
+
}
|
|
495
|
+
export interface ProviderNetwork extends KubernetesResource {
|
|
496
|
+
spec: ProviderNetworkSpec;
|
|
497
|
+
status?: {
|
|
498
|
+
ready: boolean;
|
|
499
|
+
};
|
|
500
|
+
}
|
|
402
501
|
export interface LocaleDisplay {
|
|
403
502
|
zh: string;
|
|
404
503
|
en: string;
|
|
@@ -2,7 +2,7 @@ import { Directive } from '@angular/core';
|
|
|
2
2
|
import { cloneDeep, merge } from 'lodash-es';
|
|
3
3
|
import { BehaviorSubject, Subject } from 'rxjs';
|
|
4
4
|
import { Chart } from 'zz-chart';
|
|
5
|
-
import { hasNoData } from '../metric-chart/
|
|
5
|
+
import { hasNoData } from '../metric-chart/public-api';
|
|
6
6
|
import { DEFAULT_CONFIG } from './constant';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export class BaseChart {
|
|
@@ -81,4 +81,4 @@ export class BaseChart {
|
|
|
81
81
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseChart, [{
|
|
82
82
|
type: Directive
|
|
83
83
|
}], null, null); })();
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jaGFydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9hLWNoYXJ0L2Jhc2UtY2hhcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUM3QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNoRCxPQUFPLEVBQUUsS0FBSyxFQUFlLE1BQU0sVUFBVSxDQUFDO0FBRTlDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUV2RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sWUFBWSxDQUFDOztBQUk1QyxNQUFNLE9BQU8sU0FBUztJQUR0QjtRQUtFLGlCQUFZLEdBQUcsSUFBSSxlQUFlLENBQUM7WUFDakMsT0FBTyxFQUFFLElBQUk7WUFDYixNQUFNLEVBQUUsS0FBSztZQUNiLE1BQU0sRUFBRSxLQUFLO1lBQ2IsUUFBUSxFQUFFLEtBQUs7U0FDaEIsQ0FBQyxDQUFDO1FBSUgscUJBQWdCLEdBQUcsSUFBSSxPQUFPLEVBQVMsQ0FBQztLQWtFekM7SUFoRUMsSUFBSSxDQUFDLE1BQW1CO1FBQ3RCLElBQUksQ0FBQyxZQUFZLENBQUMsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNyRSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDZixNQUFNLEVBQUUsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDLGNBQWMsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3BELElBQUksQ0FBQyxZQUFZLEdBQUcsRUFBRSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDM0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBaUIsQ0FBQztRQUMxRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVELE1BQU07UUFDSixJQUFJLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxZQUFZLENBQUMsTUFBb0I7UUFDL0IscUJBQXFCLENBQUMsR0FBRyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDO2dCQUNyQixHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSztnQkFDMUIsR0FBRyxNQUFNO2FBQ1YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsZUFBZSxDQUFDLElBQVc7UUFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDZixPQUFPO1NBQ1I7UUFDRCxRQUFRLElBQUksRUFBRTtZQUNaLEtBQUssTUFBTSxDQUFDLENBQUM7Z0JBQ1gsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDbEIsT0FBTzthQUNSO1lBQ0QsS0FBSyxNQUFNLENBQUMsQ0FBQztnQkFDWCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUNsQixPQUFPO2FBQ1I7WUFDRCxLQUFLLEtBQUssQ0FBQyxDQUFDO2dCQUNWLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUM7Z0JBQ2pCLE9BQU87YUFDUjtZQUNELEtBQUssT0FBTyxDQUFDLENBQUM7Z0JBQ1osSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQztnQkFDbkIsT0FBTzthQUNSO1lBQ0QsS0FBSyxLQUFLLENBQUMsQ0FBQztnQkFDVixJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxDQUFDO2dCQUNqQixPQUFPO2FBQ1I7WUFDRCxLQUFLLE9BQU8sQ0FBQyxDQUFDO2dCQUNaLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7Z0JBQ25CLE9BQU87YUFDUjtZQUNELE9BQU8sQ0FBQyxDQUFDO2dCQUNQLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUM7YUFDbkI7U0FDRjtJQUNILENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLEtBQUssRUFBRSxHQUFHLEVBQUUsQ0FBQztRQUNsQixJQUFJLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO0lBQ3BCLENBQUM7MEVBOUVVLFNBQVM7b0VBQVQsU0FBUzs7dUZBQVQsU0FBUztjQURyQixTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBjbG9uZURlZXAsIG1lcmdlIH0gZnJvbSAnbG9kYXNoLWVzJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQ2hhcnQsIENoYXJ0T3B0aW9uIH0gZnJvbSAnenotY2hhcnQnO1xuXG5pbXBvcnQgeyBoYXNOb0RhdGEgfSBmcm9tICcuLi9tZXRyaWMtY2hhcnQvcHVibGljLWFwaSc7XG5cbmltcG9ydCB7IERFRkFVTFRfQ09ORklHIH0gZnJvbSAnLi9jb25zdGFudCc7XG5pbXBvcnQgeyBBQ2hhcnRTdGF0dXMsIEFUeXBlIH0gZnJvbSAnLi90eXBlcyc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGNsYXNzIEJhc2VDaGFydCB7XG4gIGNoYXJ0OiBDaGFydDtcbiAgY2hhcnRPcHRpb25zOiBDaGFydE9wdGlvbjtcblxuICBjaGFydFN0YXR1cyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0KHtcbiAgICBsb2FkaW5nOiB0cnVlLFxuICAgIG5vRGF0YTogZmFsc2UsXG4gICAgZmFpbGVkOiBmYWxzZSxcbiAgICBub0xlZ2VuZDogZmFsc2UsXG4gIH0pO1xuXG4gIGNoYXJ0UmVhY3RpdmU6IENoYXJ0T3B0aW9uO1xuXG4gIHJlbmRlckNvbXBsZXRlJCQgPSBuZXcgU3ViamVjdDxDaGFydD4oKTtcblxuICBpbml0KGNvbmZpZzogQ2hhcnRPcHRpb24pIHtcbiAgICB0aGlzLmNoYW5nZVN0YXR1cyh7IGxvYWRpbmc6IHRydWUsIG5vRGF0YTogaGFzTm9EYXRhKGNvbmZpZy5kYXRhKSB9KTtcbiAgICB0aGlzLmRlc3Ryb3koKTtcbiAgICBjb25zdCBjZiA9IG1lcmdlKGNsb25lRGVlcChERUZBVUxUX0NPTkZJRyksIGNvbmZpZyk7XG4gICAgdGhpcy5jaGFydE9wdGlvbnMgPSBjZjtcbiAgICB0aGlzLmNoYXJ0ID0gbmV3IENoYXJ0KGNmKTtcbiAgICB0aGlzLmNoYXJ0UmVhY3RpdmUgPSB0aGlzLmNoYXJ0LnJlYWN0aXZlKCkgYXMgQ2hhcnRPcHRpb247XG4gICAgcmV0dXJuIHRoaXMuY2hhcnQ7XG4gIH1cblxuICByZW5kZXIoKSB7XG4gICAgdGhpcy5jaGFydD8ucmVuZGVyKCk7XG4gICAgdGhpcy5yZW5kZXJDb21wbGV0ZSQkLm5leHQodGhpcy5jaGFydCk7XG4gIH1cblxuICBjaGFuZ2VTdGF0dXMoc3RhdHVzOiBBQ2hhcnRTdGF0dXMpIHtcbiAgICByZXF1ZXN0QW5pbWF0aW9uRnJhbWUoKCkgPT4ge1xuICAgICAgdGhpcy5jaGFydFN0YXR1cyQubmV4dCh7XG4gICAgICAgIC4uLnRoaXMuY2hhcnRTdGF0dXMkLnZhbHVlLFxuICAgICAgICAuLi5zdGF0dXMsXG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIGhhbmRsZUNoYXJ0VHlwZSh0eXBlOiBBVHlwZSkge1xuICAgIGlmICghdGhpcy5jaGFydCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBzd2l0Y2ggKHR5cGUpIHtcbiAgICAgIGNhc2UgJ2xpbmUnOiB7XG4gICAgICAgIHRoaXMuY2hhcnQubGluZSgpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBjYXNlICdhcmVhJzoge1xuICAgICAgICB0aGlzLmNoYXJ0LmFyZWEoKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgICAgY2FzZSAnYmFyJzoge1xuICAgICAgICB0aGlzLmNoYXJ0LmJhcigpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBjYXNlICdwb2ludCc6IHtcbiAgICAgICAgdGhpcy5jaGFydC5wb2ludCgpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBjYXNlICdwaWUnOiB7XG4gICAgICAgIHRoaXMuY2hhcnQucGllKCk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIGNhc2UgJ2dhdWdlJzoge1xuICAgICAgICB0aGlzLmNoYXJ0LmdhdWdlKCk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIGRlZmF1bHQ6IHtcbiAgICAgICAgdGhpcy5jaGFydC5hcmVhKCk7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgZGVzdHJveSgpIHtcbiAgICB0aGlzLmNoYXJ0Py5vZmYoKTtcbiAgICB0aGlzLmNoYXJ0Py5kZXN0cm95KCk7XG4gICAgdGhpcy5jaGFydCA9IG51bGw7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -2,7 +2,7 @@ import { __decorate, __metadata } from "tslib";
|
|
|
2
2
|
import { isTemplateRef } from '@alauda/ui';
|
|
3
3
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, TemplateRef, } from '@angular/core';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
|
-
import { ObservableInput } from '../core/
|
|
5
|
+
import { ObservableInput } from '../core/public-api';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
function ChartStatusComponent_div_0_div_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
8
8
|
i0.ɵɵelementContainerStart(0);
|
|
@@ -192,4 +192,4 @@ __decorate([
|
|
|
192
192
|
}], status$: [], refresh: [{
|
|
193
193
|
type: Output
|
|
194
194
|
}] }); })();
|
|
195
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
195
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQtc3RhdHVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9hLWNoYXJ0L2NoYXJ0LXN0YXR1cy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDM0MsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEVBQ04sV0FBVyxHQUNaLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFbEMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDOzs7SUFlN0MsNkJBQStEO0lBQzdELDJCQUE4RDtJQUNoRSwwQkFBZTs7O0lBREMsZUFBZ0M7SUFBaEMscURBQWdDOzs7O0lBRzlDLCtCQUdZO0lBQ1osWUFDQTs7SUFBQSxrQ0FHQztJQURDLHVMQUFTLGVBQUEsa0JBQVcsQ0FBQSxJQUFDO0lBRXJCLFlBQ0Y7O0lBQUEsaUJBQVM7O0lBTlQsZUFDQTtJQURBLDJFQUNBO0lBSUUsZUFDRjtJQURFLDhFQUNGOzs7SUFsQkosOEJBR0M7SUFDQyxtR0FFZTtJQUNmLGtJQVljO0lBQ2hCLGlCQUFNOzs7O0lBaEJXLGVBQW1CO0lBQW5CLHlDQUFtQixpQkFBQTs7O0lBaUJwQywrQkFHQztJQUNDLCtCQUFvQztJQUFDLFlBQ3ZDOztJQUFBLGlCQUFNOztJQURpQyxlQUN2QztJQUR1QyxnRUFDdkM7OztJQUNBLCtCQUdDO0lBQ0MsWUFDRjs7SUFBQSxpQkFBTTs7SUFESixlQUNGO0lBREUsOEVBQ0Y7OztJQU1FLDZCQUtDO0lBQ0MsMkJBQStEO0lBQ2pFLDBCQUFlOzs7SUFEQyxlQUFpQztJQUFqQyx1REFBaUM7OztJQUcvQyxZQUNGOzs7O0lBREUsd0ZBQ0Y7OztJQWRGLCtCQUdDO0lBQ0MsbUdBT2U7SUFDZixtSUFFYztJQUNoQixpQkFBTTs7OztJQVZELGVBRWM7SUFGZCx1RkFFYyxrQkFBQTs7O0lBN0NyQiw4QkFHQztJQUNDLDJFQW9CTTtJQUNOLDJFQUtNO0lBQ04sMkVBS007SUFFTiwyRUFlTTtJQUNSLGlCQUFNOzs7SUFqREQsZUFBc0M7SUFBdEMsNkRBQXNDO0lBcUJ0QyxlQUFvQjtJQUFwQix3Q0FBb0I7SUFNcEIsZUFBd0M7SUFBeEMsK0RBQXdDO0lBT3hDLGVBQXdEO0lBQXhELGtGQUF3RDs7QUFvQmpFLE1BQU0sT0FBTyxvQkFBb0I7SUE5RGpDO1FBc0VFLGtCQUFhLEdBQUcsYUFBYSxDQUFDO1FBRXBCLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO0tBSzlDO0lBSEMsU0FBUztRQUNQLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLENBQUM7cUZBZFUsb0JBQW9CO29FQUFwQixvQkFBb0I7WUEzRDdCLHFFQXNETTs7O1lBcERILHdEQUFzQjs7O0FBK0QzQjtJQURDLGVBQWUsRUFBRTs4QkFDUixVQUFVO3FEQUFlO3VGQU54QixvQkFBb0I7Y0E5RGhDLFNBQVM7MkJBQ0Usa0JBQWtCLFlBQ2xCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXdEVCxtQkFFZ0IsdUJBQXVCLENBQUMsTUFBTTtnQkFHdEMsWUFBWTtrQkFBcEIsS0FBSztZQUNHLFdBQVc7a0JBQW5CLEtBQUs7WUFFRyxNQUFNO2tCQUFkLEtBQUs7WUFFTixPQUFPLE1BSUcsT0FBTztrQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzVGVtcGxhdGVSZWYgfSBmcm9tICdAYWxhdWRhL3VpJztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgVGVtcGxhdGVSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBPYnNlcnZhYmxlSW5wdXQgfSBmcm9tICcuLi9jb3JlL3B1YmxpYy1hcGknO1xuXG5pbXBvcnQgeyBBQ2hhcnRTdGF0dXMgfSBmcm9tICcuL3R5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYWNsLWNoYXJ0LXN0YXR1cycsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdlxuICAgICAgY2xhc3M9XCJjaGFydC1zdGF0dXNcIlxuICAgICAgKm5nSWY9XCJzdGF0dXMkIHwgYXN5bmMgYXMgc3RhdHVzXCJcbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgICpuZ0lmPVwic3RhdHVzLmZhaWxlZCAmJiAhc3RhdHVzLmxvYWRpbmdcIlxuICAgICAgICBjbGFzcz1cInN0YXR1cyBmYWlsZWRcIlxuICAgICAgPlxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiY3VzdG9tRXJyb3I7IGVsc2Ugbm9DdXN0b21FcnJvckNvbnRhaW5lclwiPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgW25nVGVtcGxhdGVPdXRsZXRdPVwiY3VzdG9tRXJyb3JcIj48L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICAgIDxuZy10ZW1wbGF0ZSAjbm9DdXN0b21FcnJvckNvbnRhaW5lcj5cbiAgICAgICAgICA8YXVpLWljb25cbiAgICAgICAgICAgIGljb249XCJleGNsYW1hdGlvbl90cmlhbmdsZV9zXCJcbiAgICAgICAgICAgIGJhY2tncm91bmQ9XCJ0cmlhbmdsZVwiXG4gICAgICAgICAgPjwvYXVpLWljb24+XG4gICAgICAgICAge3sgJ2ZhaWxlZF9sb2FkX3BsZWFzZScgfCB0cmFuc2xhdGUgfX1cbiAgICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgICBhdWktYnV0dG9uPVwidGV4dFwiXG4gICAgICAgICAgICAoY2xpY2spPVwib25SZWZyZXNoKClcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHt7ICgncmVmcmVzaCcgfCB0cmFuc2xhdGUpLnRvTG93ZXJDYXNlKCkgfX1cbiAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdlxuICAgICAgICAqbmdJZj1cInN0YXR1cy5sb2FkaW5nXCJcbiAgICAgICAgY2xhc3M9XCJzdGF0dXMgbG9hZGluZ1wiXG4gICAgICA+XG4gICAgICAgIDxhdWktaWNvbiBpY29uPVwic3Bpbm5lclwiPjwvYXVpLWljb24+IHt7ICdsb2FkaW5nJyB8IHRyYW5zbGF0ZSB9fVxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2XG4gICAgICAgICpuZ0lmPVwic3RhdHVzLm5vTGVnZW5kICYmICFzdGF0dXMubG9hZGluZ1wiXG4gICAgICAgIGNsYXNzPVwic3RhdHVzIG5vLWxlZ2VuZFwiXG4gICAgICA+XG4gICAgICAgIHt7ICdub19pbmRpY2F0b3Jfc2VsZWN0ZWQnIHwgdHJhbnNsYXRlIH19XG4gICAgICA8L2Rpdj5cblxuICAgICAgPGRpdlxuICAgICAgICAqbmdJZj1cInN0YXR1cy5ub0RhdGEgJiYgIXN0YXR1cy5sb2FkaW5nICYmICFzdGF0dXMuZmFpbGVkXCJcbiAgICAgICAgY2xhc3M9XCJzdGF0dXMgbm8tZGF0YVwiXG4gICAgICA+XG4gICAgICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgICAqbmdJZj1cIlxuICAgICAgICAgICAgY3VzdG9tTm9EYXRhICYmIGlzVGVtcGxhdGVSZWYoY3VzdG9tTm9EYXRhKTtcbiAgICAgICAgICAgIGVsc2Ugbm9EYXRhVGl0bGVUZW1wbGF0ZVxuICAgICAgICAgIFwiXG4gICAgICAgID5cbiAgICAgICAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImN1c3RvbU5vRGF0YVwiPjwvbmctY29udGFpbmVyPlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPG5nLXRlbXBsYXRlICNub0RhdGFUaXRsZVRlbXBsYXRlPlxuICAgICAgICAgIHt7IGN1c3RvbU5vRGF0YSB8fCAoJ25vX2RhdGEnIHwgdHJhbnNsYXRlKSB9fVxuICAgICAgICA8L25nLXRlbXBsYXRlPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL2NoYXJ0LXN0YXR1cy5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBDaGFydFN0YXR1c0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGN1c3RvbU5vRGF0YTogVGVtcGxhdGVSZWY8dW5rbm93bj4gfCBzdHJpbmc7XG4gIEBJbnB1dCgpIGN1c3RvbUVycm9yOiBUZW1wbGF0ZVJlZjx1bmtub3duPjtcblxuICBASW5wdXQoKSBzdGF0dXM6IEFDaGFydFN0YXR1cztcbiAgQE9ic2VydmFibGVJbnB1dCgpXG4gIHN0YXR1cyQhOiBPYnNlcnZhYmxlPEFDaGFydFN0YXR1cz47XG5cbiAgaXNUZW1wbGF0ZVJlZiA9IGlzVGVtcGxhdGVSZWY7XG5cbiAgQE91dHB1dCgpIHJlZnJlc2ggPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cbiAgb25SZWZyZXNoKCkge1xuICAgIHRoaXMucmVmcmVzaC5uZXh0KG51bGwpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
2
|
import { ThemeService, isTemplateRef } from '@alauda/ui';
|
|
3
|
-
import { Component, ChangeDetectionStrategy, Input, ViewChild, ElementRef, TemplateRef, EventEmitter, Output, ContentChild, } from '@angular/core';
|
|
3
|
+
import { Component, ChangeDetectionStrategy, Input, ViewChild, ElementRef, TemplateRef, EventEmitter, Output, ContentChild, forwardRef, } from '@angular/core';
|
|
4
4
|
import { omit } from 'lodash-es';
|
|
5
5
|
import { Observable, Subject, combineLatest, distinctUntilChanged, takeUntil, } from 'rxjs';
|
|
6
6
|
import { ActionType, ChartEvent, } from 'zz-chart';
|
|
7
7
|
import { ObservableInput, isEqual } from '../core/public-api';
|
|
8
8
|
import { BaseChart } from './base-chart';
|
|
9
9
|
import { LegendComponent, LegendDropdownComponent, TitleComponent, } from './components/public-api';
|
|
10
|
+
import { CHART_COMPONENT_TOKEN } from './constant';
|
|
10
11
|
import { handleDateFormat, pointFormat } from './utils';
|
|
11
12
|
import * as i0 from "@angular/core";
|
|
12
13
|
import * as i1 from "@alauda/ui";
|
|
@@ -179,7 +180,12 @@ export class ChartComponent extends BaseChart {
|
|
|
179
180
|
} if (rf & 2) {
|
|
180
181
|
let _t;
|
|
181
182
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.chartEl = _t.first);
|
|
182
|
-
} }, inputs: { status: "status", data: "data", backgroundColor: "backgroundColor", tooltipAppendToBody: "tooltipAppendToBody", autoFit: "autoFit", width: "width", height: "height", padding: "padding", theme: "theme", options: "options", type: "type", customNoData: "customNoData", customError: "customError", xAccessor: "xAccessor", yAccessor: "yAccessor", enableZoom: "enableZoom" }, outputs: { refresh: "refresh", markClick: "markClick", mouseUp: "mouseUp", contextCallback: "contextCallback" }, exportAs: ["aChart"], features: [i0.ɵɵ
|
|
183
|
+
} }, inputs: { status: "status", data: "data", backgroundColor: "backgroundColor", tooltipAppendToBody: "tooltipAppendToBody", autoFit: "autoFit", width: "width", height: "height", padding: "padding", theme: "theme", options: "options", type: "type", customNoData: "customNoData", customError: "customError", xAccessor: "xAccessor", yAccessor: "yAccessor", enableZoom: "enableZoom" }, outputs: { refresh: "refresh", markClick: "markClick", mouseUp: "mouseUp", contextCallback: "contextCallback" }, exportAs: ["aChart"], features: [i0.ɵɵProvidersFeature([
|
|
184
|
+
{
|
|
185
|
+
provide: CHART_COMPONENT_TOKEN,
|
|
186
|
+
useExisting: forwardRef(() => ChartComponent),
|
|
187
|
+
},
|
|
188
|
+
]), i0.ɵɵInheritDefinitionFeature], ngContentSelectors: _c2, decls: 14, vars: 13, consts: [[1, "a-chart"], [1, "tw-flex"], ["header", ""], [1, "tw-w-full"], ["chartDom", ""], [3, "status", "customNoData", "customError", "refresh"]], template: function ChartComponent_Template(rf, ctx) { if (rf & 1) {
|
|
183
189
|
i0.ɵɵprojectionDef(_c1);
|
|
184
190
|
i0.ɵɵelementStart(0, "div", 0)(1, "div", 1, 2);
|
|
185
191
|
i0.ɵɵprojection(3);
|
|
@@ -227,7 +233,12 @@ __decorate([
|
|
|
227
233
|
], ChartComponent.prototype, "enableZoom$", void 0);
|
|
228
234
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ChartComponent, [{
|
|
229
235
|
type: Component,
|
|
230
|
-
args: [{ selector: 'a-chart', exportAs: 'aChart', changeDetection: ChangeDetectionStrategy.OnPush,
|
|
236
|
+
args: [{ selector: 'a-chart', exportAs: 'aChart', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
237
|
+
{
|
|
238
|
+
provide: CHART_COMPONENT_TOKEN,
|
|
239
|
+
useExisting: forwardRef(() => ChartComponent),
|
|
240
|
+
},
|
|
241
|
+
], template: "<div\n class=\"a-chart\"\n [style.background]=\"background\"\n>\n <div\n class=\"tw-flex\"\n #header\n >\n <ng-content select=\"a-title\"></ng-content>\n <ng-content select=\"a-legend\"></ng-content>\n <ng-content select=\"a-legend-dropdown\"></ng-content>\n <ng-content select=\"acl-chart-zoom-button\"></ng-content>\n <ng-content></ng-content>\n </div>\n <div\n class=\"tw-w-full\"\n [style.height]=\"header.clientHeight | pure: getHeight:chartOption\"\n >\n <div #chartDom></div>\n </div>\n\n <acl-chart-status\n [status]=\"chartStatus$ | async\"\n [customNoData]=\"customNoData\"\n [customError]=\"customError\"\n (refresh)=\"onRefresh()\"\n ></acl-chart-status>\n</div>\n", styles: [":host{width:100%;height:100%;display:block;min-height:0}.a-chart{display:flex;width:100%;position:relative;height:100%;box-sizing:border-box;flex-direction:column}.a-chart ::ng-deep .achart-title{font-size:var(--aui-font-size-l)}.a-chart-container{width:100%}.a-chart-status{left:50%;position:absolute;top:50%;white-space:nowrap;transform:translate(-50%,-50%)}.status{padding:6px 16px;display:flex;align-items:center;justify-content:center;background-color:rgb(var(--aui-color-n-8));color:rgb(var(--aui-color-n-4));border-radius:2px}.status aui-icon{font-size:14px;margin-right:4px}.loading aui-icon{color:rgb(var(--aui-color-primary))}.failed aui-icon{color:rgb(var(--aui-color-red))}\n"] }]
|
|
231
242
|
}], function () { return [{ type: i1.ThemeService }]; }, { status: [{
|
|
232
243
|
type: Input
|
|
233
244
|
}], status$: [], data: [{
|
|
@@ -281,4 +292,4 @@ __decorate([
|
|
|
281
292
|
type: ContentChild,
|
|
282
293
|
args: [LegendDropdownComponent]
|
|
283
294
|
}] }); })();
|
|
284
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.component.js","sourceRoot":"","sources":["../../../../../libs/common/src/a-chart/chart.component.ts","../../../../../libs/common/src/a-chart/chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ThemeService, isTemplateRef } from '@alauda/ui';\nimport {\n  Component,\n  ChangeDetectionStrategy,\n  Input,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  OnDestroy,\n  TemplateRef,\n  EventEmitter,\n  Output,\n  ContentChild,\n} from '@angular/core';\nimport { omit } from 'lodash-es';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  distinctUntilChanged,\n  takeUntil,\n} from 'rxjs';\nimport {\n  ActionType,\n  Chart,\n  ChartEvent,\n  Data,\n  DataItem,\n  Legend,\n  Options,\n  Padding,\n  Theme,\n  BrushContext,\n} from 'zz-chart';\n\nimport { ObservableInput, isEqual } from '../core/public-api';\n\nimport { BaseChart } from './base-chart';\nimport {\n  LegendComponent,\n  LegendDropdownComponent,\n  TitleComponent,\n} from './components/public-api';\nimport {\n  AChartData,\n  AChartStatus,\n  AOptions,\n  AType,\n  MarkContext,\n} from './types';\nimport { handleDateFormat, pointFormat } from './utils';\n\n@Component({\n  selector: 'a-chart',\n  exportAs: 'aChart',\n  templateUrl: './chart.component.html',\n  styleUrls: ['./chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ChartComponent\n  extends BaseChart\n  implements AfterViewInit, OnDestroy\n{\n  @Input() status: AChartStatus;\n  @ObservableInput()\n  status$!: Observable<AChartStatus>;\n\n  @Input() data: AChartData[];\n  @ObservableInput()\n  data$!: Observable<AChartData[]>;\n\n  @Input() backgroundColor: string;\n\n  @Input() tooltipAppendToBody = true;\n\n  @Input() autoFit = true;\n  @Input() width: number;\n  @Input() height: number;\n  @Input() padding: Padding;\n  @Input() theme: Theme;\n\n  @Input() options: AOptions;\n  @ObservableInput()\n  options$!: Observable<AOptions>;\n\n  @Input() type: AType = 'area';\n  @ObservableInput()\n  type$!: Observable<AType>;\n\n  @Input() customNoData: TemplateRef<unknown> | string;\n  @Input() customError: TemplateRef<unknown>;\n\n  @Input() xAccessor = (d: DataItem['values'][0]) =>\n    String(d.x).length === 10 ? d.x * 1000 : d.x;\n\n  @Input() yAccessor = (d: DataItem['values'][0]) => d.y;\n\n  @Input() enableZoom = false;\n  @ObservableInput()\n  enableZoom$: Observable<boolean>;\n\n  @Output() refresh = new EventEmitter<void>();\n\n  @Output() markClick = new EventEmitter<MarkContext>();\n\n  @Output() mouseUp = new EventEmitter<BrushContext>();\n\n  @Output() contextCallback = new EventEmitter<Chart>();\n\n  @ViewChild('chartDom') chartEl!: ElementRef<HTMLDivElement>;\n\n  @ContentChild(TitleComponent)\n  titleRef: TitleComponent;\n\n  @ContentChild(LegendComponent)\n  legendRef: LegendComponent;\n\n  @ContentChild(LegendDropdownComponent)\n  legendDropdownRef: LegendDropdownComponent;\n\n  private readonly onDestroy$ = new Subject<void>();\n\n  get background() {\n    return this.backgroundColor;\n  }\n\n  isTemplateRef = isTemplateRef;\n\n  constructor(private readonly themeService: ThemeService) {\n    super();\n    combineLatest([\n      this.type$,\n      this.options$.pipe(distinctUntilChanged((a, b) => isEqual(a, b))),\n      this.data$,\n    ]).subscribe(([type, options]) => {\n      const render =\n        (!options?.annotation?.lineX && !this.chartOption?.annotation?.lineX) ||\n        !isEqual(\n          options?.annotation?.lineX,\n          this.chartOption?.annotation?.lineX,\n        );\n      if (!render) {\n        this.chart.annotation().lineX(options?.annotation?.lineX);\n      }\n      if (options && type && render) {\n        this.renderChart();\n      }\n    });\n    this.status$.pipe(takeUntil(this.onDestroy$)).subscribe(res => {\n      res && this.changeStatus(res);\n    });\n  }\n\n  ngAfterViewInit() {\n    this.renderChart();\n  }\n\n  get chartOption(): Options {\n    const customHeader =\n      this.titleRef || this.legendRef || this.legendDropdownRef;\n    const tooltip =\n      this.options?.tooltip === false\n        ? this.options.tooltip\n        : {\n            popupContainer: this.tooltipAppendToBody\n              ? null\n              : this.chartEl?.nativeElement,\n            titleFormatter: (value: string) => handleDateFormat(+value),\n            valueFormatter: (value: number) => pointFormat(+value),\n            ...(typeof this.options?.tooltip === 'object'\n              ? this.options.tooltip\n              : {}),\n          };\n    return {\n      ...(customHeader ? { title: false, legend: false } : {}),\n      scale: {\n        y: {},\n      },\n      ...omit(this.options, 'tooltip'),\n      tooltip,\n    };\n  }\n\n  private renderChart() {\n    if (this.chart) {\n      this.destroy();\n    }\n    if (!this.chartEl?.nativeElement) {\n      return;\n    }\n    this.init({\n      container: this.chartEl.nativeElement,\n      data: this.handelData(this.data),\n      options: this.chartOption,\n    });\n    this.handleChartType(this.type);\n    this.handleTheme();\n    this.render();\n    this.contextCallback.next(this.chart);\n    this.data$.subscribe(data => {\n      const values = this.handelData(data);\n      this.chart?.data(values);\n      this.changeStatus({\n        loading: false,\n      });\n    });\n    this.handleChartEvent();\n  }\n\n  private handelData(data: Data) {\n    return data.map(d => ({\n      ...d,\n      values: d.values?.map(v => ({\n        ...v,\n        x: this.xAccessor(v),\n        y: this.yAccessor(v),\n      })),\n    }));\n  }\n\n  private handleTheme() {\n    if (this.theme) {\n      this.chart.theme(this.theme);\n    }\n    this.themeService.currentTheme$\n      .pipe(takeUntil(this.onDestroy$))\n      .subscribe(type => {\n        this.chart.theme(type);\n      });\n  }\n\n  private handleChartEvent() {\n    if (!this.legendRef && !this.legendDropdownRef) {\n      const legend = this.chart?.components.get('legend') as Legend;\n      this.chart.on(ChartEvent.LEGEND_ITEM_CLICK, () => {\n        this.changeStatus({\n          noLegend: legend.inactivatedSet.size === legend.getLegend().length,\n        });\n      });\n    }\n    this.chart.on(ChartEvent.PLOT_CLICK, (value: MarkContext) => {\n      this.markClick.next(value);\n    });\n    this.enableZoom$.pipe(takeUntil(this.onDestroy$)).subscribe(() => {\n      if (this.enableZoom) {\n        this.chart.interaction('brush-x', {\n          end: [\n            {\n              trigger: ChartEvent.PLOT_MOUSEUP,\n              action: ActionType.BRUSH_X_END,\n              callback: (e: BrushContext) => {\n                if (e.start !== e.end) {\n                  this.mouseUp.next(e);\n                }\n              },\n            },\n          ],\n        });\n      }\n    });\n  }\n\n  onRefresh() {\n    this.refresh.next(null);\n  }\n\n  getHeight(height: number, chartOption: Options) {\n    return typeof chartOption.legend === 'object' &&\n      chartOption.legend?.position?.includes('bottom-left')\n      ? `calc(100% - ${height || 0}px)`\n      : '100%';\n  }\n\n  ngOnDestroy(): void {\n    this.destroy();\n    this.onDestroy$.next();\n  }\n}\n","<div\n  class=\"a-chart\"\n  [style.background]=\"background\"\n>\n  <div\n    class=\"tw-flex\"\n    #header\n  >\n    <ng-content select=\"a-title\"></ng-content>\n    <ng-content select=\"a-legend\"></ng-content>\n    <ng-content select=\"a-legend-dropdown\"></ng-content>\n    <ng-content select=\"acl-chart-zoom-button\"></ng-content>\n    <ng-content></ng-content>\n  </div>\n  <div\n    class=\"tw-w-full\"\n    [style.height]=\"header.clientHeight | pure: getHeight:chartOption\"\n  >\n    <div #chartDom></div>\n  </div>\n\n  <acl-chart-status\n    [status]=\"chartStatus$ | async\"\n    [customNoData]=\"customNoData\"\n    [customError]=\"customError\"\n    (refresh)=\"onRefresh()\"\n  ></acl-chart-status>\n</div>\n"]}
|
|
295
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.component.js","sourceRoot":"","sources":["../../../../../libs/common/src/a-chart/chart.component.ts","../../../../../libs/common/src/a-chart/chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ThemeService, isTemplateRef } from '@alauda/ui';\nimport {\n  Component,\n  ChangeDetectionStrategy,\n  Input,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  OnDestroy,\n  TemplateRef,\n  EventEmitter,\n  Output,\n  ContentChild,\n  forwardRef,\n} from '@angular/core';\nimport { omit } from 'lodash-es';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  distinctUntilChanged,\n  takeUntil,\n} from 'rxjs';\nimport {\n  ActionType,\n  Chart,\n  ChartEvent,\n  Data,\n  DataItem,\n  Legend,\n  Options,\n  Padding,\n  Theme,\n  BrushContext,\n} from 'zz-chart';\n\nimport { ObservableInput, isEqual } from '../core/public-api';\n\nimport { BaseChart } from './base-chart';\nimport {\n  LegendComponent,\n  LegendDropdownComponent,\n  TitleComponent,\n} from './components/public-api';\nimport { CHART_COMPONENT_TOKEN } from './constant';\nimport {\n  AChartData,\n  AChartStatus,\n  AOptions,\n  AType,\n  MarkContext,\n} from './types';\nimport { handleDateFormat, pointFormat } from './utils';\n\n@Component({\n  selector: 'a-chart',\n  exportAs: 'aChart',\n  templateUrl: './chart.component.html',\n  styleUrls: ['./chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: CHART_COMPONENT_TOKEN,\n      useExisting: forwardRef(() => ChartComponent),\n    },\n  ],\n})\nexport class ChartComponent\n  extends BaseChart\n  implements AfterViewInit, OnDestroy\n{\n  @Input() status: AChartStatus;\n  @ObservableInput()\n  status$!: Observable<AChartStatus>;\n\n  @Input() data: AChartData[];\n  @ObservableInput()\n  data$!: Observable<AChartData[]>;\n\n  @Input() backgroundColor: string;\n\n  @Input() tooltipAppendToBody = true;\n\n  @Input() autoFit = true;\n  @Input() width: number;\n  @Input() height: number;\n  @Input() padding: Padding;\n  @Input() theme: Theme;\n\n  @Input() options: AOptions;\n  @ObservableInput()\n  options$!: Observable<AOptions>;\n\n  @Input() type: AType = 'area';\n  @ObservableInput()\n  type$!: Observable<AType>;\n\n  @Input() customNoData: TemplateRef<unknown> | string;\n  @Input() customError: TemplateRef<unknown>;\n\n  @Input() xAccessor = (d: DataItem['values'][0]) =>\n    String(d.x).length === 10 ? d.x * 1000 : d.x;\n\n  @Input() yAccessor = (d: DataItem['values'][0]) => d.y;\n\n  @Input() enableZoom = false;\n  @ObservableInput()\n  enableZoom$: Observable<boolean>;\n\n  @Output() refresh = new EventEmitter<void>();\n\n  @Output() markClick = new EventEmitter<MarkContext>();\n\n  @Output() mouseUp = new EventEmitter<BrushContext>();\n\n  @Output() contextCallback = new EventEmitter<Chart>();\n\n  @ViewChild('chartDom') chartEl!: ElementRef<HTMLDivElement>;\n\n  @ContentChild(TitleComponent)\n  titleRef: TitleComponent;\n\n  @ContentChild(LegendComponent)\n  legendRef: LegendComponent;\n\n  @ContentChild(LegendDropdownComponent)\n  legendDropdownRef: LegendDropdownComponent;\n\n  private readonly onDestroy$ = new Subject<void>();\n\n  get background() {\n    return this.backgroundColor;\n  }\n\n  isTemplateRef = isTemplateRef;\n\n  constructor(private readonly themeService: ThemeService) {\n    super();\n    combineLatest([\n      this.type$,\n      this.options$.pipe(distinctUntilChanged((a, b) => isEqual(a, b))),\n      this.data$,\n    ]).subscribe(([type, options]) => {\n      const render =\n        (!options?.annotation?.lineX && !this.chartOption?.annotation?.lineX) ||\n        !isEqual(\n          options?.annotation?.lineX,\n          this.chartOption?.annotation?.lineX,\n        );\n      if (!render) {\n        this.chart.annotation().lineX(options?.annotation?.lineX);\n      }\n      if (options && type && render) {\n        this.renderChart();\n      }\n    });\n    this.status$.pipe(takeUntil(this.onDestroy$)).subscribe(res => {\n      res && this.changeStatus(res);\n    });\n  }\n\n  ngAfterViewInit() {\n    this.renderChart();\n  }\n\n  get chartOption(): Options {\n    const customHeader =\n      this.titleRef || this.legendRef || this.legendDropdownRef;\n    const tooltip =\n      this.options?.tooltip === false\n        ? this.options.tooltip\n        : {\n            popupContainer: this.tooltipAppendToBody\n              ? null\n              : this.chartEl?.nativeElement,\n            titleFormatter: (value: string) => handleDateFormat(+value),\n            valueFormatter: (value: number) => pointFormat(+value),\n            ...(typeof this.options?.tooltip === 'object'\n              ? this.options.tooltip\n              : {}),\n          };\n    return {\n      ...(customHeader ? { title: false, legend: false } : {}),\n      scale: {\n        y: {},\n      },\n      ...omit(this.options, 'tooltip'),\n      tooltip,\n    };\n  }\n\n  private renderChart() {\n    if (this.chart) {\n      this.destroy();\n    }\n    if (!this.chartEl?.nativeElement) {\n      return;\n    }\n    this.init({\n      container: this.chartEl.nativeElement,\n      data: this.handelData(this.data),\n      options: this.chartOption,\n    });\n    this.handleChartType(this.type);\n    this.handleTheme();\n    this.render();\n    this.contextCallback.next(this.chart);\n    this.data$.subscribe(data => {\n      const values = this.handelData(data);\n      this.chart?.data(values);\n      this.changeStatus({\n        loading: false,\n      });\n    });\n    this.handleChartEvent();\n  }\n\n  private handelData(data: Data) {\n    return data.map(d => ({\n      ...d,\n      values: d.values?.map(v => ({\n        ...v,\n        x: this.xAccessor(v),\n        y: this.yAccessor(v),\n      })),\n    }));\n  }\n\n  private handleTheme() {\n    if (this.theme) {\n      this.chart.theme(this.theme);\n    }\n    this.themeService.currentTheme$\n      .pipe(takeUntil(this.onDestroy$))\n      .subscribe(type => {\n        this.chart.theme(type);\n      });\n  }\n\n  private handleChartEvent() {\n    if (!this.legendRef && !this.legendDropdownRef) {\n      const legend = this.chart?.components.get('legend') as Legend;\n      this.chart.on(ChartEvent.LEGEND_ITEM_CLICK, () => {\n        this.changeStatus({\n          noLegend: legend.inactivatedSet.size === legend.getLegend().length,\n        });\n      });\n    }\n    this.chart.on(ChartEvent.PLOT_CLICK, (value: MarkContext) => {\n      this.markClick.next(value);\n    });\n    this.enableZoom$.pipe(takeUntil(this.onDestroy$)).subscribe(() => {\n      if (this.enableZoom) {\n        this.chart.interaction('brush-x', {\n          end: [\n            {\n              trigger: ChartEvent.PLOT_MOUSEUP,\n              action: ActionType.BRUSH_X_END,\n              callback: (e: BrushContext) => {\n                if (e.start !== e.end) {\n                  this.mouseUp.next(e);\n                }\n              },\n            },\n          ],\n        });\n      }\n    });\n  }\n\n  onRefresh() {\n    this.refresh.next(null);\n  }\n\n  getHeight(height: number, chartOption: Options) {\n    return typeof chartOption.legend === 'object' &&\n      chartOption.legend?.position?.includes('bottom-left')\n      ? `calc(100% - ${height || 0}px)`\n      : '100%';\n  }\n\n  ngOnDestroy(): void {\n    this.destroy();\n    this.onDestroy$.next();\n  }\n}\n","<div\n  class=\"a-chart\"\n  [style.background]=\"background\"\n>\n  <div\n    class=\"tw-flex\"\n    #header\n  >\n    <ng-content select=\"a-title\"></ng-content>\n    <ng-content select=\"a-legend\"></ng-content>\n    <ng-content select=\"a-legend-dropdown\"></ng-content>\n    <ng-content select=\"acl-chart-zoom-button\"></ng-content>\n    <ng-content></ng-content>\n  </div>\n  <div\n    class=\"tw-w-full\"\n    [style.height]=\"header.clientHeight | pure: getHeight:chartOption\"\n  >\n    <div #chartDom></div>\n  </div>\n\n  <acl-chart-status\n    [status]=\"chartStatus$ | async\"\n    [customNoData]=\"customNoData\"\n    [customError]=\"customError\"\n    (refresh)=\"onRefresh()\"\n  ></acl-chart-status>\n</div>\n"]}
|
|
@@ -1,28 +1,29 @@
|
|
|
1
|
-
import { ChangeDetectorRef, Directive, EventEmitter,
|
|
1
|
+
import { ChangeDetectorRef, Directive, EventEmitter, Input, Output, inject, } from '@angular/core';
|
|
2
2
|
import { get } from 'lodash-es';
|
|
3
3
|
import { BehaviorSubject, Subject } from 'rxjs';
|
|
4
4
|
import { ChartEvent, } from 'zz-chart';
|
|
5
5
|
import { ChartComponent } from '../../chart.component';
|
|
6
|
+
import { CHART_COMPONENT_TOKEN } from '../../constant';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
export class BaseLegendComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.chartRefFromInjection = inject(CHART_COMPONENT_TOKEN, {
|
|
11
|
+
optional: true,
|
|
12
|
+
});
|
|
13
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
14
|
+
this.changeLegend = new EventEmitter();
|
|
15
|
+
this.legendItems$$ = new BehaviorSubject([]);
|
|
16
|
+
this.legendChange$$ = new Subject();
|
|
17
|
+
}
|
|
8
18
|
get noData() {
|
|
9
19
|
return !this.legendItems$$.value.length;
|
|
10
20
|
}
|
|
11
21
|
get aChartCtrl() {
|
|
12
|
-
return this.
|
|
13
|
-
optional: true,
|
|
14
|
-
});
|
|
22
|
+
return this.chartRefFromInjection || this.chartRef;
|
|
15
23
|
}
|
|
16
24
|
get legendCtr() {
|
|
17
25
|
return this.aChartCtrl.chart?.components.get('legend');
|
|
18
26
|
}
|
|
19
|
-
constructor(cdr, injector) {
|
|
20
|
-
this.cdr = cdr;
|
|
21
|
-
this.injector = injector;
|
|
22
|
-
this.changeLegend = new EventEmitter();
|
|
23
|
-
this.legendItems$$ = new BehaviorSubject([]);
|
|
24
|
-
this.legendChange$$ = new Subject();
|
|
25
|
-
}
|
|
26
27
|
ngOnChanges({ chartRef }) {
|
|
27
28
|
if (chartRef?.currentValue) {
|
|
28
29
|
this.init();
|
|
@@ -97,14 +98,14 @@ export class BaseLegendComponent {
|
|
|
97
98
|
this.legendItems$$.next(legends);
|
|
98
99
|
this.cdr.markForCheck();
|
|
99
100
|
}
|
|
100
|
-
static { this.ɵfac = function BaseLegendComponent_Factory(t) { return new (t || BaseLegendComponent)(
|
|
101
|
+
static { this.ɵfac = function BaseLegendComponent_Factory(t) { return new (t || BaseLegendComponent)(); }; }
|
|
101
102
|
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: BaseLegendComponent, inputs: { chartRef: "chartRef" }, outputs: { changeLegend: "changeLegend" }, features: [i0.ɵɵNgOnChangesFeature] }); }
|
|
102
103
|
}
|
|
103
104
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseLegendComponent, [{
|
|
104
105
|
type: Directive
|
|
105
|
-
}],
|
|
106
|
+
}], null, { chartRef: [{
|
|
106
107
|
type: Input
|
|
107
108
|
}], changeLegend: [{
|
|
108
109
|
type: Output
|
|
109
110
|
}] }); })();
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-legend.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/a-chart/components/legend/base-legend.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Directive,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  inject,\n} from '@angular/core';\nimport { get } from 'lodash-es';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport {\n  ChartEvent,\n  Data,\n  Legend,\n  LegendItem as ALegendItem,\n  DataItem,\n} from 'zz-chart';\n\nimport { ChartComponent } from '../../chart.component';\nimport { CHART_COMPONENT_TOKEN } from '../../constant';\n\nexport interface LegendItem extends ALegendItem {\n  name: string;\n  value?: number;\n  source?: DataItem;\n  unit?: string;\n}\n\n@Directive()\nexport class BaseLegendComponent implements OnInit, OnChanges {\n  private readonly chartRefFromInjection = inject(CHART_COMPONENT_TOKEN, {\n    optional: true,\n  });\n\n  protected cdr = inject(ChangeDetectorRef);\n\n  @Input()\n  chartRef: ChartComponent;\n\n  @Output() changeLegend = new EventEmitter<LegendItem[]>();\n\n  get noData() {\n    return !this.legendItems$$.value.length;\n  }\n\n  get aChartCtrl(): ChartComponent {\n    return this.chartRefFromInjection || this.chartRef;\n  }\n\n  get legendCtr(): Legend {\n    return this.aChartCtrl.chart?.components.get('legend') as Legend;\n  }\n\n  legendItems$$ = new BehaviorSubject<LegendItem[]>([]);\n\n  legendChange$$ = new Subject<LegendItem[]>();\n\n  ngOnChanges({ chartRef }: SimpleChanges): void {\n    if (chartRef?.currentValue) {\n      this.init();\n    }\n  }\n\n  ngOnInit(): void {\n    this.init();\n  }\n\n  setChartRef(chartRef: ChartComponent) {\n    this.chartRef = chartRef;\n    this.init();\n  }\n\n  init() {\n    if (this.aChartCtrl) {\n      this.handleLegends(this.aChartCtrl?.chart?.getData() || []);\n      this.aChartCtrl.renderComplete$$.subscribe(chart => {\n        if (!chart) {\n          return;\n        }\n        this.legendItems$$.next(this.legendCtr?.getLegend());\n        chart?.on(ChartEvent.DATA_CHANGE, (data: Data) => {\n          this.handleLegends(data);\n        });\n      });\n    }\n  }\n\n  private handleLegends(data: Data) {\n    this.legendItems$$.next(\n      data.reduce(\n        (acc, d) => [\n          ...acc,\n          ...(d.name\n            ? [\n                {\n                  name: d.name,\n                  color: d.color,\n                  activated: true,\n                  hover: false,\n                  value: d.values[d.values?.length - 1].y,\n                  source: d,\n                  unit: get(d, 'unit'),\n                  ...d,\n                },\n              ]\n            : []),\n        ],\n        [],\n      ),\n    );\n    this.cdr.detectChanges();\n  }\n\n  onSelect(legend: LegendItem) {\n    this.legendCtr.legendItemClick({\n      name: legend.name,\n      activated: !legend.activated,\n    });\n    const legends = this.legendItems$$.value;\n    const legendItem = legends.find(item => item.name === legend.name);\n    legendItem.activated = !legend.activated;\n    this.aChartCtrl.changeStatus({\n      noLegend: legends.every(item => !item.activated),\n    });\n    this.legendItems$$.next(legends);\n  }\n\n  onAllSelect(select: boolean) {\n    const legends = this.legendItems$$.value;\n    legends.forEach(legend => {\n      this.legendCtr.legendItemClick({\n        name: legend.name,\n        activated: select,\n      });\n      legend.activated = select;\n    });\n    this.aChartCtrl.changeStatus({\n      noLegend: legends.every(item => !item.activated),\n    });\n    this.legendItems$$.next(legends);\n    this.cdr.markForCheck();\n  }\n}\n"]}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
1
2
|
import dayjs from 'dayjs';
|
|
2
3
|
import { transformMaximum } from './utils';
|
|
3
4
|
export const CHART_TIME_FORMAT = 'HH:mm';
|
|
@@ -19,4 +20,5 @@ export const DEFAULT_CONFIG = {
|
|
|
19
20
|
},
|
|
20
21
|
},
|
|
21
22
|
};
|
|
22
|
-
|
|
23
|
+
export const CHART_COMPONENT_TOKEN = new InjectionToken('CHART_COMPONENT_TOKEN');
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9zcmMvYS1jaGFydC9jb25zdGFudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sS0FBSyxNQUFNLE9BQU8sQ0FBQztBQUkxQixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFFM0MsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsT0FBTyxDQUFDO0FBRXpDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixPQUFPLEVBQUUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDdkIsT0FBTyxFQUFFO1FBQ1AsSUFBSSxFQUFFO1lBQ0osQ0FBQyxFQUFFO2dCQUNELFNBQVMsRUFBRSxDQUFDLEtBQWEsRUFBRSxFQUFFLENBQzNCLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7b0JBQzFCLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUM7b0JBQ3pDLENBQUMsQ0FBQyxLQUFLO2FBQ1o7WUFDRCxDQUFDLEVBQUU7Z0JBQ0QsU0FBUyxFQUFFLENBQUMsS0FBc0IsRUFBRSxFQUFFLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDO2FBQy9EO1NBQ0Y7UUFDRCxPQUFPLEVBQUU7WUFDUCxJQUFJLEVBQUUsQ0FBQyxDQUFlLEVBQUUsQ0FBZSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxLQUFLO1NBQzlEO0tBQ0Y7Q0FDYSxDQUFDO0FBRWpCLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLElBQUksY0FBYyxDQUNyRCx1QkFBdUIsQ0FDeEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgZGF5anMgZnJvbSAnZGF5anMnO1xuaW1wb3J0IHsgQ2hhcnRPcHRpb24sIFRvb2x0aXBWYWx1ZSB9IGZyb20gJ3p6LWNoYXJ0JztcblxuaW1wb3J0IHsgQ2hhcnRDb21wb25lbnQgfSBmcm9tICcuL2NoYXJ0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyB0cmFuc2Zvcm1NYXhpbXVtIH0gZnJvbSAnLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBDSEFSVF9USU1FX0ZPUk1BVCA9ICdISDptbSc7XG5cbmV4cG9ydCBjb25zdCBERUZBVUxUX0NPTkZJRyA9IHtcbiAgcGFkZGluZzogWzE2LCAxMiwgMiwgMF0sXG4gIG9wdGlvbnM6IHtcbiAgICBheGlzOiB7XG4gICAgICB4OiB7XG4gICAgICAgIGZvcm1hdHRlcjogKHZhbHVlOiBzdHJpbmcpID0+XG4gICAgICAgICAgZGF5anMuaXNEYXlqcyhkYXlqcygrdmFsdWUpKVxuICAgICAgICAgICAgPyBkYXlqcygrdmFsdWUpLmZvcm1hdChDSEFSVF9USU1FX0ZPUk1BVClcbiAgICAgICAgICAgIDogdmFsdWUsXG4gICAgICB9LFxuICAgICAgeToge1xuICAgICAgICBmb3JtYXR0ZXI6ICh2YWx1ZTogbnVtYmVyIHwgc3RyaW5nKSA9PiB0cmFuc2Zvcm1NYXhpbXVtKHZhbHVlKSxcbiAgICAgIH0sXG4gICAgfSxcbiAgICB0b29sdGlwOiB7XG4gICAgICBzb3J0OiAoYTogVG9vbHRpcFZhbHVlLCBiOiBUb29sdGlwVmFsdWUpID0+IGIudmFsdWUgLSBhLnZhbHVlLFxuICAgIH0sXG4gIH0sXG59IGFzIENoYXJ0T3B0aW9uO1xuXG5leHBvcnQgY29uc3QgQ0hBUlRfQ09NUE9ORU5UX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuPENoYXJ0Q29tcG9uZW50PihcbiAgJ0NIQVJUX0NPTVBPTkVOVF9UT0tFTicsXG4pO1xuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9zcmMvYS1jaGFydC90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGF0YUl0ZW0sIE9wdGlvbnMsIFRvb2x0aXBWYWx1ZSB9IGZyb20gJ3p6LWNoYXJ0JztcblxuaW1wb3J0IHsgSW5kaWNhdG9yVHlwZSB9IGZyb20gJy4uL2FwaS9wdWJsaWMtYXBpJztcbmltcG9ydCB7IFRyYW5zbGF0aW9uIH0gZnJvbSAnLi4vdHJhbnNsYXRlL3B1YmxpYy1hcGknO1xuXG5leHBvcnQgdHlwZSBBT3B0aW9ucyA9IE9taXQ8T3B0aW9ucywgJ2RhdGEnIHwgJ3BhZGRpbmcnIHwgJ2NvbnRhaW5lcic+O1xuXG5leHBvcnQgdHlwZSBBVHlwZSA9XG4gIHwgJ2xpbmUnXG4gIHwgJ2FyZWEnXG4gIHwgJ2JhcidcbiAgfCAncG9pbnQnXG4gIHwgJ3BpZSdcbiAgfCAnZ2F1Z2UnXG4gIHwgJ3N0YXQnXG4gIHwgJ3RhYmxlJ1xuICB8ICdiYXItZ2F1Z2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFDaGFydFN0YXR1cyB7XG4gIGxvYWRpbmc/OiBib29sZWFuO1xuICBub0RhdGE/OiBib29sZWFuO1xuICBmYWlsZWQ/OiBib29sZWFuO1xuICBub0xlZ2VuZD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUNoYXJ0RGF0YSBleHRlbmRzIERhdGFJdGVtIHtcbiAgbWF4PzogbnVtYmVyO1xuICB1bml0Pzogc3RyaW5nIHwgVHJhbnNsYXRpb247XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFya0NvbnRleHQge1xuICB0aXRsZTogc3RyaW5nO1xuICB2YWx1ZXM6IFRvb2x0aXBWYWx1ZVtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1vbml0b3JEYXRhSXRlbSB7XG4gIGlkPzogc3RyaW5nOyAvLyDlj6/kvZzkuLrllK/kuIDooajnpLrojrflj5blr7nlupTkv6Hmga/vvIzpnZ7lv4Xloavml6DliJnkvb/nlKggdGl0bGUg5L2c5Li65ZSv5LiA6KGo56S6XG4gIHRpdGxlPzogc3RyaW5nOyAvLyDmoIfpophcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gIGluZGljYXRvcnM/OiBzdHJpbmcgfCBzdHJpbmdbXTtcbiAgZXhwcj86IHN0cmluZyB8IHN0cmluZ1tdO1xuICB2YXJpYWJsZXM/OlxuICAgIHwgQXJyYXk8UmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10+PlxuICAgIHwgUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10+O1xuICBxdWVyaWVzOiBJbmRpY2F0b3JUeXBlW107XG59XG4iXX0=
|
|
@@ -34,4 +34,4 @@ export function randomColor() {
|
|
|
34
34
|
.toString(16)
|
|
35
35
|
.padStart(6, '0')}`;
|
|
36
36
|
}
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9zcmMvYS1jaGFydC91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQXFCLE1BQU0sT0FBTyxDQUFDO0FBRzFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBR3RELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxLQUFzQjtJQUNyRCxNQUFNLElBQUksR0FBRyxHQUFHLENBQUM7SUFDakIsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQyxJQUFJLElBQUksSUFBSSxJQUFJLEVBQUU7UUFDaEIsTUFBTSxHQUFHLEdBQUcsQ0FBQyxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdEMsT0FBTyxHQUFHLEdBQUcsR0FBRyxJQUFJLEVBQUUsQ0FBQztLQUN4QjtJQUNELE9BQU8sRUFBRSxHQUFHLEtBQUssQ0FBQztBQUNwQixDQUFDO0FBRUQsTUFBTSxVQUFVLGVBQWUsQ0FBQyxPQUF1QixFQUFFLEtBQUssR0FBRyxFQUFFO0lBQ2pFLE9BQU8sT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFDakMsQ0FBQztBQUVELE1BQU0sVUFBVSxXQUFXLENBQUMsS0FBYTtJQUN2QyxNQUFNLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQztJQUNwQixJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksS0FBSyxDQUFDLEVBQUU7UUFDdkIsT0FBTyxFQUFFLEdBQUcsS0FBSyxDQUFDO0tBQ25CO0lBQ0QsT0FBTyxJQUFJLEdBQUcsQ0FBQyxJQUFJLElBQUksR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUM3RCxDQUFDO0FBRUQsTUFBTSxVQUFVLGdCQUFnQixDQUFDLElBQWdCLEVBQUUsTUFBTSxHQUFHLGdCQUFnQjtJQUMxRSxPQUFPLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQzNFLENBQUM7QUFFRCxNQUFNLFVBQVUsb0JBQW9CLENBQUMsRUFBRSxDQUFDLEVBQWU7SUFDckQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3ZCLENBQUM7QUFFRDs7O0dBR0c7QUFDSCxNQUFNLFVBQVUsV0FBVztJQUN6QixPQUFPLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7U0FDN0MsUUFBUSxDQUFDLEVBQUUsQ0FBQztTQUNaLFFBQVEsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQztBQUN4QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGRheWpzLCB7IENvbmZpZ1R5cGUgfSBmcm9tICdkYXlqcyc7XG5pbXBvcnQgeyBUb29sdGlwVmFsdWUgfSBmcm9tICd6ei1jaGFydCc7XG5cbmltcG9ydCB7IERBVEVfVElNRV9GT1JNQVQgfSBmcm9tICcuLi9jb3JlL3B1YmxpYy1hcGknO1xuaW1wb3J0IHsgQ29udGV4dEl0ZW0gfSBmcm9tICcuLi92aWV3LWNoYXJ0L3B1YmxpYy1hcGknO1xuXG5leHBvcnQgZnVuY3Rpb24gdHJhbnNmb3JtTWF4aW11bSh2YWx1ZTogbnVtYmVyIHwgc3RyaW5nKSB7XG4gIGNvbnN0IHVuaXQgPSAnayc7XG4gIGNvbnN0IGRhdGEgPSBOdW1iZXIodmFsdWUpIHx8IDA7XG4gIGlmIChkYXRhID49IDEwMDApIHtcbiAgICBjb25zdCBudW0gPSArKGRhdGEgLyAxMDAwKS50b0ZpeGVkKDIpO1xuICAgIHJldHVybiBgJHtudW19JHt1bml0fWA7XG4gIH1cbiAgcmV0dXJuICcnICsgdmFsdWU7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBsaW1pdE1heENvbnRleHQoY29udGV4dDogVG9vbHRpcFZhbHVlW10sIGxpbWl0ID0gMTUpIHtcbiAgcmV0dXJuIGNvbnRleHQuc2xpY2UoMCwgbGltaXQpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcG9pbnRGb3JtYXQodmFsdWU6IG51bWJlcikge1xuICBjb25zdCBkYXRhID0gK3ZhbHVlO1xuICBpZiAoIWRhdGEgJiYgZGF0YSAhPT0gMCkge1xuICAgIHJldHVybiAnJyArIHZhbHVlO1xuICB9XG4gIHJldHVybiBkYXRhID4gMCAmJiBkYXRhIDwgMC4wMSA/ICc8MC4wMScgOiBkYXRhLnRvRml4ZWQoMik7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBoYW5kbGVEYXRlRm9ybWF0KGRhdGU6IENvbmZpZ1R5cGUsIGZvcm1hdCA9IERBVEVfVElNRV9GT1JNQVQpIHtcbiAgcmV0dXJuIFN0cmluZyhkYXlqcyhkYXRlKS5pc1ZhbGlkKCkgPyBkYXlqcyhkYXRlKS5mb3JtYXQoZm9ybWF0KSA6IGRhdGUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW50ZWdlclRvb2x0aXBGb3JtYXQoeyB5IH06IENvbnRleHRJdGVtKSB7XG4gIHJldHVybiBNYXRoLmZsb29yKHkpO1xufVxuXG4vKipcbiAqIEBuYW1lIHJhbmRvbUNvbG9yXG4gKiBAc2VlIGh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vcXVlc3Rpb25zLzE0ODQ1MDYvcmFuZG9tLWNvbG9yLWdlbmVyYXRvclxuICovXG5leHBvcnQgZnVuY3Rpb24gcmFuZG9tQ29sb3IoKTogc3RyaW5nIHtcbiAgcmV0dXJuIGAjJHtNYXRoLnRydW5jKCgxIDw8IDI0KSAqIE1hdGgucmFuZG9tKCkpXG4gICAgLnRvU3RyaW5nKDE2KVxuICAgIC5wYWRTdGFydCg2LCAnMCcpfWA7XG59XG4iXX0=
|