@testgorilla/tgo-ui 2.26.6 → 2.26.7
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/components/step/step.component.d.ts +12 -4
- package/components/stepper/stepper.component.d.ts +11 -3
- package/components/universal-skills-report/universal-skills-report.component.d.ts +5 -5
- package/components/universal-skills-spider-charts/universal-skills-spider-charts.component.d.ts +33 -0
- package/components/universal-skills-spider-charts/universal-skills-spider-charts.component.module.d.ts +16 -0
- package/esm2022/assets/i18n/en.json +4 -1
- package/esm2022/components/spider-chart/spider-chart.component.mjs +2 -2
- package/esm2022/components/step/step.component.mjs +51 -11
- package/esm2022/components/stepper/stepper.component.mjs +51 -17
- package/esm2022/components/universal-skills-report/universal-skills-report.component.mjs +17 -66
- package/esm2022/components/universal-skills-spider-charts/universal-skills-spider-charts.component.mjs +86 -0
- package/esm2022/components/universal-skills-spider-charts/universal-skills-spider-charts.component.module.mjs +52 -0
- package/esm2022/models/universal-skills-report.model.mjs +33 -0
- package/esm2022/public-api.mjs +5 -2
- package/esm2022/services/universal-skills.service.mjs +71 -0
- package/fesm2022/testgorilla-tgo-ui.mjs +280 -72
- package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
- package/{components/universal-skills-report → models}/universal-skills-report.model.d.ts +7 -0
- package/package.json +1 -1
- package/projects/tgo-canopy-ui/assets/i18n/en.json +4 -1
- package/public-api.d.ts +3 -1
- package/services/universal-skills.service.d.ts +11 -0
- package/esm2022/components/universal-skills-report/universal-skills-report.model.mjs +0 -33
|
@@ -1,10 +1,13 @@
|
|
|
1
|
-
import { EventEmitter, TemplateRef } from '@angular/core';
|
|
1
|
+
import { AfterViewInit, DestroyRef, ElementRef, EventEmitter, TemplateRef } from '@angular/core';
|
|
2
2
|
import { IconName } from '../icon/icon.model';
|
|
3
3
|
import { ApplicationTheme } from '../../models/application-theme.model';
|
|
4
4
|
import { HtmlDescription, StepperPosition } from '../stepper/stepper.model';
|
|
5
|
+
import { FocusMonitor } from "@angular/cdk/a11y";
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class StepComponent {
|
|
7
|
+
export declare class StepComponent implements AfterViewInit {
|
|
7
8
|
private readonly defaultAppTheme;
|
|
9
|
+
private focusMonitor;
|
|
10
|
+
private destroyRef;
|
|
8
11
|
/**
|
|
9
12
|
* Input property for the label of the step.
|
|
10
13
|
*
|
|
@@ -153,9 +156,14 @@ export declare class StepComponent {
|
|
|
153
156
|
* @memberof StepComponent
|
|
154
157
|
*/
|
|
155
158
|
stepSelected: EventEmitter<number>;
|
|
156
|
-
|
|
159
|
+
protected keyboardFocused: import("@angular/core").WritableSignal<boolean>;
|
|
160
|
+
stepElement: ElementRef<HTMLElement>;
|
|
161
|
+
constructor(defaultAppTheme: ApplicationTheme, focusMonitor: FocusMonitor, destroyRef: DestroyRef);
|
|
162
|
+
ngAfterViewInit(): void;
|
|
157
163
|
protected get hasLastStepDefaultIcon(): boolean;
|
|
158
164
|
protected onStepSelected(index: number): void;
|
|
159
|
-
|
|
165
|
+
protected subscriberFocus(): void;
|
|
166
|
+
onKeydown($event: KeyboardEvent): void;
|
|
167
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<StepComponent, [{ optional: true; }, null, null]>;
|
|
160
168
|
static ɵcmp: i0.ɵɵComponentDeclaration<StepComponent, "ui-step", never, { "label": { "alias": "label"; "required": false; }; "isVisited": { "alias": "isVisited"; "required": false; }; "submitted": { "alias": "submitted"; "required": false; }; "icon": { "alias": "icon"; "required": false; }; "index": { "alias": "index"; "required": false; }; "selected": { "alias": "selected"; "required": false; }; "isLast": { "alias": "isLast"; "required": false; }; "selectedIndex": { "alias": "selectedIndex"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "prevStepIsVisited": { "alias": "prevStepIsVisited"; "required": false; }; "mobileMode": { "alias": "mobileMode"; "required": false; }; "finalIcon": { "alias": "finalIcon"; "required": false; }; "showIconWhenSelected": { "alias": "showIconWhenSelected"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "position": { "alias": "position"; "required": false; }; "htmlDescription": { "alias": "htmlDescription"; "required": false; }; "boldLabel": { "alias": "boldLabel"; "required": false; }; "descriptionTpl": { "alias": "descriptionTpl"; "required": false; }; "labelTooltip": { "alias": "labelTooltip"; "required": false; }; "alwaysShowIcon": { "alias": "alwaysShowIcon"; "required": false; }; "context": { "alias": "context"; "required": false; }; }, { "stepSelected": "stepSelected"; }, never, never, false, never>;
|
|
161
169
|
}
|
|
@@ -1,11 +1,14 @@
|
|
|
1
|
-
import { EventEmitter } from '@angular/core';
|
|
1
|
+
import { DestroyRef, ElementRef, EventEmitter } from '@angular/core';
|
|
2
2
|
import { Step, StepperPosition } from './stepper.model';
|
|
3
3
|
import { Observable } from 'rxjs';
|
|
4
4
|
import { ApplicationTheme } from "../../models/application-theme.model";
|
|
5
|
+
import { FocusMonitor } from "@angular/cdk/a11y";
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
export declare class StepperComponent {
|
|
7
8
|
private readonly defaultAppTheme;
|
|
8
9
|
protected readonly isMobile$: Observable<boolean>;
|
|
10
|
+
protected focusMonitor: FocusMonitor;
|
|
11
|
+
protected destroyRef: DestroyRef;
|
|
9
12
|
/**
|
|
10
13
|
*
|
|
11
14
|
* Auto selects first step as visited
|
|
@@ -77,10 +80,15 @@ export declare class StepperComponent {
|
|
|
77
80
|
protected selectedIndex: number;
|
|
78
81
|
get isOpen(): boolean;
|
|
79
82
|
set isOpen(value: boolean);
|
|
80
|
-
|
|
83
|
+
protected keyboardFocused: import("@angular/core").WritableSignal<boolean>;
|
|
84
|
+
stepperElement: ElementRef<HTMLElement>;
|
|
85
|
+
constructor(defaultAppTheme: ApplicationTheme, isMobile$: Observable<boolean>, focusMonitor: FocusMonitor, destroyRef: DestroyRef);
|
|
86
|
+
ngAfterViewInit(): void;
|
|
81
87
|
protected onSelect(changedIndex: number, step: Step): void;
|
|
82
88
|
protected showStepsToggle(): void;
|
|
83
89
|
protected onCloseStepList(): void;
|
|
84
|
-
|
|
90
|
+
protected subscriberFocus(): void;
|
|
91
|
+
private selectedStepFocus;
|
|
92
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<StepperComponent, [{ optional: true; }, null, null, null]>;
|
|
85
93
|
static ɵcmp: i0.ɵɵComponentDeclaration<StepperComponent, "ui-stepper", never, { "setFirstStepAutoSelect": { "alias": "firstStepAutoSelect"; "required": false; }; "steps": { "alias": "steps"; "required": false; }; "setSelectedIndex": { "alias": "selectedIndex"; "required": false; }; "lastStepFinalIcon": { "alias": "lastStepFinalIcon"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "ariaLabel": { "alias": "ariaLabel"; "required": false; }; "position": { "alias": "position"; "required": false; }; "ariaRequired": { "alias": "ariaRequired"; "required": false; }; }, { "selectionChange": "selectionChange"; }, never, never, false, never>;
|
|
86
94
|
}
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { OnInit } from '@angular/core';
|
|
2
2
|
import { ApplicationTheme } from '../../models/application-theme.model';
|
|
3
3
|
import { RebrandBadgeColor } from '../badge/badge.model';
|
|
4
|
-
import { SkillAreaData, SkillAreaGroup, SkillAreaGroupTypes } from '
|
|
4
|
+
import { SkillAreaData, SkillAreaGroup, SkillAreaGroupTypes } from '../../models/universal-skills-report.model';
|
|
5
|
+
import { UniversalSkillsService } from '../../services/universal-skills.service';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
export declare class UniversalSkillsReportComponent implements OnInit {
|
|
7
8
|
private readonly defaultAppTheme;
|
|
9
|
+
private universalSkillsService;
|
|
8
10
|
/**
|
|
9
11
|
* Defines the application theme
|
|
10
12
|
* @property applicationTheme
|
|
@@ -21,13 +23,11 @@ export declare class UniversalSkillsReportComponent implements OnInit {
|
|
|
21
23
|
skillAreaDataList: SkillAreaData[];
|
|
22
24
|
readonly translationContext = "UNIVERSAL_SKILLS_REPORT.";
|
|
23
25
|
skillAreaGroupMap: Record<SkillAreaGroupTypes, SkillAreaGroup>;
|
|
24
|
-
constructor(defaultAppTheme: ApplicationTheme);
|
|
26
|
+
constructor(defaultAppTheme: ApplicationTheme, universalSkillsService: UniversalSkillsService);
|
|
25
27
|
ngOnInit(): void;
|
|
26
28
|
getScoreBadgeLabel(percentileScoring: number): string;
|
|
27
29
|
getScoreBadgeColor(percentileScoring: number): RebrandBadgeColor;
|
|
28
|
-
private initializeSkillAreaGroupMap;
|
|
29
|
-
private prepareSkillAreaGroupMap;
|
|
30
30
|
checkScoreClassification([percentileScoring, isLabelRequest]: [number, boolean]): string | RebrandBadgeColor;
|
|
31
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<UniversalSkillsReportComponent, [{ optional: true; }]>;
|
|
31
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<UniversalSkillsReportComponent, [{ optional: true; }, null]>;
|
|
32
32
|
static ɵcmp: i0.ɵɵComponentDeclaration<UniversalSkillsReportComponent, "ui-universal-skills-report", never, { "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "skillAreaDataList": { "alias": "skillAreaDataList"; "required": false; }; }, {}, never, never, false, never>;
|
|
33
33
|
}
|
package/components/universal-skills-spider-charts/universal-skills-spider-charts.component.d.ts
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { OnInit } from '@angular/core';
|
|
2
|
+
import { ApplicationTheme } from '../../models/application-theme.model';
|
|
3
|
+
import { SkillAreaData, SkillAreaGroup, SkillAreaGroupTypes, SkillAreaSpiderChartData } from '../../models/universal-skills-report.model';
|
|
4
|
+
import { UniversalSkillsService } from '../../services/universal-skills.service';
|
|
5
|
+
import { UiTranslatePipe } from '../../pipes/ui-translate.pipe';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export declare class UniversalSkillsSpiderChartsComponent implements OnInit {
|
|
8
|
+
private readonly defaultAppTheme;
|
|
9
|
+
private universalSkillsService;
|
|
10
|
+
private uiTranslatePipe;
|
|
11
|
+
/**
|
|
12
|
+
* Defines the application theme
|
|
13
|
+
* @property applicationTheme
|
|
14
|
+
* @type {ApplicationTheme}
|
|
15
|
+
* @memberof UniversalSkillsSpiderChartsComponent
|
|
16
|
+
*/
|
|
17
|
+
applicationTheme: ApplicationTheme;
|
|
18
|
+
/**
|
|
19
|
+
* The list of items to be used
|
|
20
|
+
* @property items
|
|
21
|
+
* @type {SkillAreaData[]}
|
|
22
|
+
* @memberof UniversalSkillsReportComponent
|
|
23
|
+
*/
|
|
24
|
+
skillAreaDataList: SkillAreaData[];
|
|
25
|
+
readonly translationContext = "UNIVERSAL_SKILLS_REPORT.";
|
|
26
|
+
skillAreaGroupMap: Record<SkillAreaGroupTypes, SkillAreaGroup>;
|
|
27
|
+
skillAreaSpiderChartData: SkillAreaSpiderChartData[];
|
|
28
|
+
constructor(defaultAppTheme: ApplicationTheme, universalSkillsService: UniversalSkillsService, uiTranslatePipe: UiTranslatePipe);
|
|
29
|
+
ngOnInit(): void;
|
|
30
|
+
prepareSpiderChartData(): void;
|
|
31
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<UniversalSkillsSpiderChartsComponent, [{ optional: true; }, null, null]>;
|
|
32
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<UniversalSkillsSpiderChartsComponent, "ui-universal-skills-spider-charts", never, { "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "skillAreaDataList": { "alias": "skillAreaDataList"; "required": false; }; }, {}, never, never, false, never>;
|
|
33
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./universal-skills-spider-charts.component";
|
|
3
|
+
import * as i2 from "@angular/common";
|
|
4
|
+
import * as i3 from "../accordion/accordion.component.module";
|
|
5
|
+
import * as i4 from "../badge/badge.component.module";
|
|
6
|
+
import * as i5 from "../progress-bar/progress-bar.component.module";
|
|
7
|
+
import * as i6 from "../spider-chart/spider-chart.module";
|
|
8
|
+
import * as i7 from "../divider/divider.component.module";
|
|
9
|
+
import * as i8 from "../../pipes/memoize-func.pipe";
|
|
10
|
+
import * as i9 from "../../pipes/ui-translate.pipe";
|
|
11
|
+
import * as i10 from "../../pipes/ui-ordinal-suffix.pipe";
|
|
12
|
+
export declare class UniversalSkillsSpiderChartsComponentModule {
|
|
13
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<UniversalSkillsSpiderChartsComponentModule, never>;
|
|
14
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<UniversalSkillsSpiderChartsComponentModule, [typeof i1.UniversalSkillsSpiderChartsComponent], [typeof i2.CommonModule, typeof i3.AccordionComponentModule, typeof i4.BadgeComponentModule, typeof i5.ProgressBarComponentModule, typeof i6.SpiderChartComponentModule, typeof i7.DividerComponentModule, typeof i8.MemoizeFuncPipe, typeof i9.UiTranslatePipe, typeof i10.OrdinalSuffixPipe, typeof i2.KeyValuePipe], [typeof i1.UniversalSkillsSpiderChartsComponent]>;
|
|
15
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<UniversalSkillsSpiderChartsComponentModule>;
|
|
16
|
+
}
|
|
@@ -11,7 +11,10 @@
|
|
|
11
11
|
"MAX_SELECTED_ERROR": "You’ve reached the maximum of ({{max}}) tags. Remove a tag to add another."
|
|
12
12
|
},
|
|
13
13
|
"STEPPER": {
|
|
14
|
-
"FINAL_STEP": "Final step"
|
|
14
|
+
"FINAL_STEP": "Final step",
|
|
15
|
+
"COMPLETED": "Completed",
|
|
16
|
+
"INCOMPLETE": "Incomplete",
|
|
17
|
+
"SELECTED_OF": "Selected ({{selected}} of {{total}}) current step"
|
|
15
18
|
},
|
|
16
19
|
"SLIDER": {
|
|
17
20
|
"MAX_LESS_THAN_MIN": "Max value ({{max}}) cannot be less then current min value ({{min}})",
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, Input, ViewChild, ViewChildren, } from '@angular/core';
|
|
2
2
|
import { LargeSpiderChartSize, SmallSpiderChartSize } from './spider-chart.model';
|
|
3
|
-
import { Color } from '
|
|
3
|
+
import { Color } from '../../models/colors.model';
|
|
4
4
|
import { BaseChartDirective } from 'ng2-charts';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@angular/common";
|
|
@@ -422,4 +422,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
422
422
|
type: ViewChildren,
|
|
423
423
|
args: ['legendItem']
|
|
424
424
|
}] } });
|
|
425
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spider-chart.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/spider-chart/spider-chart.component.ts","../../../../../projects/tgo-canopy-ui/components/spider-chart/spider-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnInit,\n  Optional,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { LargeSpiderChartSize, SmallSpiderChartSize, SpiderChartData, SpiderChartSize } from './spider-chart.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { Chart, ChartData, ChartOptions } from 'chart.js';\nimport { Color } from './../../models/colors.model';\nimport { BaseChartDirective } from 'ng2-charts';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { Language } from '../../utils/localization/language.model';\n\n@Component({\n  selector: 'ui-spider-chart',\n  templateUrl: './spider-chart.component.html',\n  styleUrls: ['./spider-chart.component.scss'],\n})\nexport class SpiderChartComponent implements OnInit {\n  /**\n   * The size of the spider chart.\n   * @type {SpiderChartSize}\n   * @memberof SpiderChartComponent\n   */\n  @Input() size: SpiderChartSize = 'large';\n\n  /**\n   * The data to be used for the spider chart.\n   * @type {SpiderChartData}\n   * @memberof SpiderChartComponent\n   */\n  @Input() spiderChartData: SpiderChartData;\n\n  /**\n   * The step size for the spider chart.\n   * @type {number}\n   * @memberof SpiderChartComponent\n   */\n  @Input() stepSize: number = 20;\n\n  /**\n   * The aria label for the spider chart.\n   * @type {string}\n   * @memberof SpiderChartComponent\n   */\n  @Input() ariaLabel: string = 'Radar chart. Press tab to navigate through the chart.';\n\n  /**\n   * Whether the spider chart is loading.\n   * @type {boolean}\n   * @memberof SpiderChartComponent\n   */\n  @Input() loading: boolean = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SpinnerComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  @ViewChild(BaseChartDirective) chart: BaseChartDirective;\n  @ViewChildren('labelContainer') labelContainers: QueryList<ElementRef>;\n  @ViewChildren('fakeDataPoints') fakeDataPoints: QueryList<ElementRef>;\n  @ViewChildren('fakeDataPointsSecondary') fakeDataPointsSecondary: QueryList<ElementRef>;\n  @ViewChildren('legendItem') legendItems: QueryList<ElementRef>;\n\n  radarChartData: ChartData<'radar'> = {\n    labels: [],\n    datasets: [],\n  };\n  radarChartOptions: ChartOptions<'radar'>;\n  labelPositions: { [key: string]: { x: number; y: number } } = {};\n  labelPositionsVisible: boolean = false;\n  focusedLabelIndex: number = 0;\n  focusedFakeDataPointIndex: number = 0;\n  loadingChartData: ChartData<'radar'> = {\n    labels: [1, 2, 3, 4, 5, 6],\n    datasets: [],\n  };\n  loadingChartOptions: ChartOptions<'radar'> = {\n    responsive: true,\n    layout: {\n      padding: {\n        left: 40,\n        right: 40,\n        top: 40,\n        bottom: 40,\n      },\n    },\n    scales: {\n      r: {\n        angleLines: {\n          display: true,\n          color: Color.GRAYSCALE_30,\n        },\n        grid: {\n          color: () => Color.GRAYSCALE_30,\n        },\n        pointLabels: {\n          display: false,\n        },\n        suggestedMin: 0,\n        suggestedMax: 100,\n        ticks: {\n          stepSize: this.stepSize,\n          display: false,\n        },\n      },\n    },\n  };\n  protected readonly translationContext = 'CHARTS.SPIDER.';\n\n  ngOnInit(): void {\n    if (!this.loading) {\n      this.handleInputErrors();\n      this.setChartData();\n      this.setChartOptions();\n    }\n  }\n\n  private handleInputErrors() {\n    if (!this.spiderChartData.labels || this.spiderChartData.labels.length === 0) {\n      throw new Error('The \"labels\" input is required and cannot be empty.');\n    }\n    if (!this.spiderChartData.labelDescription || this.spiderChartData.labelDescription.length === 0) {\n      throw new Error('The \"labelDescription\" input is required and cannot be empty.');\n    }\n    if (\n      this.spiderChartData.labelDescription &&\n      this.spiderChartData.labelDescription.length !== this.spiderChartData.labels.length\n    ) {\n      throw new Error('The \"labelDescription\" input must have the same length as \"labels\".');\n    }\n    if (!this.spiderChartData.plotData[0].databaseLabel) {\n      throw new Error('The \"plotData.databaseLabel\" input is required.');\n    }\n    if (!this.spiderChartData.plotData[0].data || this.spiderChartData.plotData[0].data.length === 0) {\n      throw new Error('The \"plotData.data\" input is required and cannot be empty.');\n    }\n    if (this.spiderChartData.plotData[0].data.length !== this.spiderChartData.labels.length) {\n      throw new Error('The \"plotData.data\" input must have the same length as \"labels\".');\n    }\n    if (\n      this.spiderChartData.plotData.length === 2 &&\n      this.spiderChartData.labels.length > 0 &&\n      this.spiderChartData.plotData[1].data &&\n      this.spiderChartData.plotData[1].data.length !== this.spiderChartData.labels.length\n    ) {\n      throw new Error('The \"plotData.data\" input must have the same length as \"labels\".');\n    }\n  }\n\n  private setChartData() {\n    const datasets = [];\n    datasets.push({\n      label: this.spiderChartData.plotData[0].databaseLabel,\n      data: this.spiderChartData.plotData[0].data,\n      fill: true,\n      backgroundColor: 'rgba(212, 16, 170, 0.2)',\n      borderColor: Color.BRAND_50,\n      pointBackgroundColor: Color.BRAND_50,\n      pointBorderColor: Color.TGO_WHITE,\n      pointHoverBackgroundColor: Color.TGO_WHITE,\n      pointHoverBorderColor: Color.BRAND_50,\n    });\n    if (this.spiderChartData.plotData.length === 2) {\n      datasets.push({\n        label: this.spiderChartData.plotData[1].databaseLabel,\n        data: this.spiderChartData.plotData[1].data,\n        fill: false,\n        borderColor: Color.BLACK,\n        borderDash: [5, 5],\n        borderWidth: 1,\n        pointBackgroundColor: Color.BLACK,\n        pointBorderColor: Color.TGO_WHITE,\n        pointHoverBackgroundColor: Color.TGO_WHITE,\n        pointHoverBorderColor: Color.BLACK,\n      });\n    }\n    this.radarChartData = {\n      labels: this.spiderChartData.labels,\n      datasets: datasets,\n    };\n  }\n\n  private setChartOptions() {\n    this.radarChartOptions = {\n      responsive: true,\n      elements: {\n        line: {\n          borderWidth: 3,\n        },\n      },\n      layout: {\n        padding: {\n          left: 40,\n          right: 40,\n          top: 40,\n          bottom: 40,\n        },\n      },\n      scales: {\n        r: {\n          angleLines: {\n            display: true,\n            color: Color.BLACK,\n          },\n          grid: {\n            color: context => {\n              if (context.tick.value === 100) {\n                return Color.BLACK;\n              }\n              return Color.GRAYSCALE_30;\n            },\n          },\n          pointLabels: {\n            color: 'black',\n            font: {\n              family: 'Arial',\n              size: 14,\n            },\n            display: false,\n          },\n          suggestedMin: 0,\n          suggestedMax: 100,\n          ticks: {\n            stepSize: this.stepSize,\n            display: false,\n          },\n        },\n      },\n      plugins: {\n        legend: {\n          display: false,\n        },\n      },\n    };\n  }\n\n  ngAfterViewInit(): void {\n    if (this.chart?.chart && !this.loading) {\n      this.logCornerCoordinates(this.chart.chart);\n    }\n  }\n\n  private logCornerCoordinates(chart: Chart) {\n    const scale = chart.scales['r'] as any;\n    const canvasWidth = this.size === 'large' ? LargeSpiderChartSize : SmallSpiderChartSize;\n    const canvasHeight = this.size === 'large' ? LargeSpiderChartSize : SmallSpiderChartSize;\n\n    // Loop through the labels and calculate the percentage coordinates\n    this.spiderChartData.labels.forEach((label, index) => {\n      const position = scale.getPointPositionForValue(index, scale.max);\n\n      // Calculate percentage values relative to the canvas size\n      const xPercent = (position.x / canvasWidth) * 100;\n      const yPercent = ((canvasHeight - position.y) / canvasHeight) * 100; // Inverting the Y-axis\n\n      this.labelPositions[label] = { x: Number(xPercent.toFixed(2)), y: Number(yPercent.toFixed(2)) };\n    });\n    this.labelPositionsVisible = true;\n  }\n\n  getCenteredLabelBottomPosition(label: string, height: number) {\n    const position = this.labelPositions[label];\n    const padding = 7;\n    if (position.x > 50 || position.x < 50) {\n      return `calc(${position.y}% - ${height / 2}px)`;\n    } else if (position.y < 50) {\n      return `calc(${position.y}% - ${height}px - ${padding}px)`;\n    } else {\n      return `calc(${position.y}% + ${padding}px)`;\n    }\n  }\n\n  getCenteredLabelLeftPosition(label: string, width: number) {\n    const position = this.labelPositions[label];\n    const padding = 15;\n    if (position.x === 50) {\n      return `calc(${position.x}% - ${width / 2}px)`;\n    } else if (position.x < 50) {\n      return `calc(${position.x}% - ${width}px - ${padding}px)`;\n    } else {\n      return `calc(${position.x}% + ${padding}px)`;\n    }\n  }\n\n  onLabelKeyDown(event: KeyboardEvent, index: number) {\n    if (event.key === 'ArrowRight' || event.key === 'ArrowDown') {\n      this.focusNextLabel(index);\n    } else if (event.key === 'ArrowLeft' || event.key === 'ArrowUp') {\n      this.focusPreviousLabel(index);\n    }\n  }\n\n  private focusNextLabel(index: number) {\n    const nextIndex = index + 1;\n    if (nextIndex < this.labelContainers.length) {\n      this.labelContainers.get(nextIndex)?.nativeElement.focus();\n    } else {\n      this.labelContainers.first?.nativeElement.focus();\n    }\n    this.focusedLabelIndex = nextIndex;\n  }\n\n  private focusPreviousLabel(index: number) {\n    const previousIndex = index - 1;\n    if (previousIndex >= 0) {\n      this.labelContainers.get(previousIndex)?.nativeElement.focus();\n    } else {\n      this.labelContainers.last?.nativeElement.focus();\n    }\n    this.focusedLabelIndex = previousIndex;\n  }\n\n  onLegendItemKeyDown(event: KeyboardEvent, index: number) {\n    if (event.key === 'Enter') {\n      this.toggleDatasetVisibility(index);\n    } else if (event.key === 'ArrowRight' || event.key === 'ArrowDown') {\n      this.focusNextLegendItem(index);\n    } else if (event.key === 'ArrowLeft' || event.key === 'ArrowUp') {\n      this.focusPreviousLegendItem(index);\n    }\n  }\n\n  private focusNextLegendItem(index: number) {\n    const nextIndex = index + 1;\n    if (nextIndex < this.legendItems.length) {\n      this.legendItems.get(nextIndex)?.nativeElement.focus();\n    } else {\n      this.legendItems.first?.nativeElement.focus();\n    }\n  }\n\n  private focusPreviousLegendItem(index: number) {\n    const previousIndex = index - 1;\n    if (previousIndex >= 0) {\n      this.legendItems.get(previousIndex)?.nativeElement.focus();\n    } else {\n      this.legendItems.last?.nativeElement.focus();\n    }\n  }\n\n  onFakeDataPointsKeyDown(event: KeyboardEvent, index: number, isSecondary: boolean = false) {\n    if (event.key === 'ArrowRight' || event.key === 'ArrowDown') {\n      this.focusNextFakeDataPoint(index, isSecondary);\n      this.showTooltipForDataPoint(index + 1 > this.spiderChartData.labels.length ? 0 : index + 1, isSecondary);\n    } else if (event.key === 'ArrowLeft' || event.key === 'ArrowUp') {\n      this.focusPreviousFakeDataPoint(index, isSecondary);\n      this.showTooltipForDataPoint(index - 1 < 0 ? this.spiderChartData.labels.length - 1 : index - 1, isSecondary);\n    } else if (event.key === 'Tab') {\n      this.resetActiveElement();\n    }\n  }\n\n  private focusNextFakeDataPoint(index: number, isSecondary: boolean = false) {\n    const nextIndex = index + 1;\n    if (nextIndex < this.fakeDataPoints.length) {\n      const fakeDataPoints = isSecondary ? this.fakeDataPointsSecondary : this.fakeDataPoints;\n      fakeDataPoints.get(nextIndex)?.nativeElement.focus();\n    } else {\n      const fakeDataPoints = isSecondary ? this.fakeDataPointsSecondary : this.fakeDataPoints;\n      fakeDataPoints.first?.nativeElement.focus();\n    }\n    if (!isSecondary) {\n      this.focusedFakeDataPointIndex = nextIndex;\n    }\n  }\n\n  private focusPreviousFakeDataPoint(index: number, isSecondary: boolean = false) {\n    const previousIndex = index - 1;\n    if (previousIndex >= 0) {\n      const fakeDataPoints = isSecondary ? this.fakeDataPointsSecondary : this.fakeDataPoints;\n      fakeDataPoints.get(previousIndex)?.nativeElement.focus();\n    } else {\n      const fakeDataPoints = isSecondary ? this.fakeDataPointsSecondary : this.fakeDataPoints;\n      fakeDataPoints.last?.nativeElement.focus();\n    }\n    if (!isSecondary) {\n      this.focusedFakeDataPointIndex = previousIndex;\n    }\n  }\n\n  showTooltipForDataPoint(index: number, isSecondary: boolean = false) {\n    const chartInstance = this.chart?.chart;\n    if (!chartInstance) return;\n    const activeElement = [{ datasetIndex: isSecondary ? 1 : 0, index }];\n    const meta = chartInstance.getDatasetMeta(isSecondary ? 1 : 0);\n    const dataPoint = meta.data[index];\n    const eventPosition = {\n      x: dataPoint.x,\n      y: dataPoint.y,\n    };\n    if (!isSecondary) {\n      this.focusedFakeDataPointIndex = index;\n    }\n\n    chartInstance.tooltip?.setActiveElements(activeElement, eventPosition);\n\n    chartInstance.update();\n  }\n\n  private resetActiveElement() {\n    const chartInstance = this.chart?.chart;\n    if (!chartInstance) return;\n\n    // Clear the active elements to hide the tooltip\n    chartInstance.tooltip?.setActiveElements([], { x: 0, y: 0 });\n\n    chartInstance.update();\n  }\n\n  toggleDatasetVisibility(datasetIndex: number) {\n    const chartInstance = this.chart?.chart;\n    if (!chartInstance) return;\n\n    const dataset = chartInstance.data.datasets[datasetIndex];\n    dataset.hidden = !dataset.hidden;\n    chartInstance.update();\n  }\n\n  isDatasetVisible(datasetIndex: number) {\n    const chartInstance = this.chart?.chart;\n    if (!chartInstance) return;\n    return !chartInstance.data.datasets[datasetIndex].hidden;\n  }\n}\n","<div class=\"container\"\n  tabindex=\"0\"\n  [attr.aria-label]=\"ariaLabel\">\n  <div class=\"spacing-container\"\n    [ngClass]=\"{'small-spacing': radarChartData.labels && radarChartData.labels.length % 2 === 1 && !loading}\">\n    <div class=\"chart-container\"\n      [style.width]=\"size === 'large' ? '280px' : '200px'\"\n      [style.height]=\"size === 'large' ? '280px' : '200px'\">\n      @if (!loading) {\n        <canvas\n          baseChart\n          [data]=\"radarChartData\"\n          [options]=\"radarChartOptions\"\n          type=\"radar\"\n          class=\"chart\"\n        >\n        </canvas>\n      } @else {\n        <canvas\n          baseChart\n          [data]=\"loadingChartData\"\n          [options]=\"loadingChartOptions\"\n          type=\"radar\"\n          class=\"chart\"\n        >\n        </canvas>\n        <ui-spinner></ui-spinner>\n      }\n\n      @if (labelPositionsVisible) {\n      <div class=\"overlay-container\">\n          @for (label of spiderChartData.labels; track label) {\n            <div class=\"label-container\" #labelContainer\n              [matTooltip]=\"label + ': ' + spiderChartData.labelDescription[$index]\"\n              [tabindex]=\"$index === 0 ? '0' : '-1'\"\n              (keydown)=\"onLabelKeyDown($event, $index)\"\n              [attr.aria-label]=\"label + ': ' + spiderChartData.labelDescription[$index]\"\n              [style.left]=\"getCenteredLabelLeftPosition(label, labelContainer.offsetWidth)\"\n              [style.bottom]=\"getCenteredLabelBottomPosition(label, labelContainer.offsetHeight)\">\n              <div class=\"label\" #labelElement [style.max-width]=\"size === 'large' ? '150px' : '100px'\"\n                [class.two-lines]=\"label.length > 20 && size === 'large' && spiderChartData.labels.length < 9\">\n                {{ label }}\n              </div>\n              <span class=\"value\">{{ spiderChartData.plotData[0].data[$index] }}</span>\n            </div>\n            <span class=\"fake-data-points\" #fakeDataPoints\n              [tabindex]=\"focusedLabelIndex === $index ? '0' : '-1'\"\n              (focus)=\"$index === focusedLabelIndex ? showTooltipForDataPoint($index) : null\"\n              (keydown)=\"onFakeDataPointsKeyDown($event, $index)\">\n            </span>\n            @if (radarChartData.datasets.length > 1) {\n              <span class=\"fake-data-points-secondary\" #fakeDataPointsSecondary\n                [tabindex]=\"focusedFakeDataPointIndex === $index ? '0' : '-1'\"\n                (focus)=\"$index === focusedFakeDataPointIndex ? showTooltipForDataPoint($index, true) : null\"\n                (keydown)=\"onFakeDataPointsKeyDown($event, $index, true)\">\n              </span>\n            }\n          }\n        </div>\n      }\n    </div>\n  </div>\n  @if (radarChartData.datasets.length > 0) {\n    <div class=\"legend-container\">\n      @for (dataset of radarChartData.datasets; track dataset.label) {\n        <div class=\"legend-item\"\n          (click)=\"toggleDatasetVisibility($index)\"\n          [tabindex]=\"$index === 0 ? '0' : '-1'\"\n          role=\"button\"\n          [attr.aria-pressed]=\"isDatasetVisible($index) ? false : true\"\n          [attr.aria-label]=\"isDatasetVisible($index) ?\n          ((translationContext + 'DATASET_VISIBLE') | uiTranslate : { dataset: dataset.label } | async) :\n          ((translationContext + 'DATASET_HIDDEN') | uiTranslate : { dataset: dataset.label } | async)\"\n          (keydown)=\"onLegendItemKeyDown($event, $index)\"\n          #legendItem>\n          <span class=\"legend-line\" [ngClass]=\"{'solid-line': $index === 0, 'dashed-line': $index === 1}\"></span>\n          <span class=\"legend-label\" [style.text-decoration]=\"isDatasetVisible($index) ? 'none' : 'line-through'\">\n            {{ dataset.label }}\n          </span>\n        </div>\n      }\n    </div>\n  }\n</div>\n\n"]}
|
|
425
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spider-chart.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/spider-chart/spider-chart.component.ts","../../../../../projects/tgo-canopy-ui/components/spider-chart/spider-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { LargeSpiderChartSize, SmallSpiderChartSize, SpiderChartData, SpiderChartSize } from './spider-chart.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { Chart, ChartData, ChartOptions } from 'chart.js';\nimport { Color } from '../../models/colors.model';\nimport { BaseChartDirective } from 'ng2-charts';\n\n@Component({\n  selector: 'ui-spider-chart',\n  templateUrl: './spider-chart.component.html',\n  styleUrls: ['./spider-chart.component.scss'],\n})\nexport class SpiderChartComponent implements OnInit {\n  /**\n   * The size of the spider chart.\n   * @type {SpiderChartSize}\n   * @memberof SpiderChartComponent\n   */\n  @Input() size: SpiderChartSize = 'large';\n\n  /**\n   * The data to be used for the spider chart.\n   * @type {SpiderChartData}\n   * @memberof SpiderChartComponent\n   */\n  @Input() spiderChartData: SpiderChartData;\n\n  /**\n   * The step size for the spider chart.\n   * @type {number}\n   * @memberof SpiderChartComponent\n   */\n  @Input() stepSize: number = 20;\n\n  /**\n   * The aria label for the spider chart.\n   * @type {string}\n   * @memberof SpiderChartComponent\n   */\n  @Input() ariaLabel: string = 'Radar chart. Press tab to navigate through the chart.';\n\n  /**\n   * Whether the spider chart is loading.\n   * @type {boolean}\n   * @memberof SpiderChartComponent\n   */\n  @Input() loading: boolean = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof SpinnerComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  @ViewChild(BaseChartDirective) chart: BaseChartDirective;\n  @ViewChildren('labelContainer') labelContainers: QueryList<ElementRef>;\n  @ViewChildren('fakeDataPoints') fakeDataPoints: QueryList<ElementRef>;\n  @ViewChildren('fakeDataPointsSecondary') fakeDataPointsSecondary: QueryList<ElementRef>;\n  @ViewChildren('legendItem') legendItems: QueryList<ElementRef>;\n\n  radarChartData: ChartData<'radar'> = {\n    labels: [],\n    datasets: [],\n  };\n  radarChartOptions: ChartOptions<'radar'>;\n  labelPositions: { [key: string]: { x: number; y: number } } = {};\n  labelPositionsVisible: boolean = false;\n  focusedLabelIndex: number = 0;\n  focusedFakeDataPointIndex: number = 0;\n  loadingChartData: ChartData<'radar'> = {\n    labels: [1, 2, 3, 4, 5, 6],\n    datasets: [],\n  };\n  loadingChartOptions: ChartOptions<'radar'> = {\n    responsive: true,\n    layout: {\n      padding: {\n        left: 40,\n        right: 40,\n        top: 40,\n        bottom: 40,\n      },\n    },\n    scales: {\n      r: {\n        angleLines: {\n          display: true,\n          color: Color.GRAYSCALE_30,\n        },\n        grid: {\n          color: () => Color.GRAYSCALE_30,\n        },\n        pointLabels: {\n          display: false,\n        },\n        suggestedMin: 0,\n        suggestedMax: 100,\n        ticks: {\n          stepSize: this.stepSize,\n          display: false,\n        },\n      },\n    },\n  };\n  protected readonly translationContext = 'CHARTS.SPIDER.';\n\n  ngOnInit(): void {\n    if (!this.loading) {\n      this.handleInputErrors();\n      this.setChartData();\n      this.setChartOptions();\n    }\n  }\n\n  private handleInputErrors() {\n    if (!this.spiderChartData.labels || this.spiderChartData.labels.length === 0) {\n      throw new Error('The \"labels\" input is required and cannot be empty.');\n    }\n    if (!this.spiderChartData.labelDescription || this.spiderChartData.labelDescription.length === 0) {\n      throw new Error('The \"labelDescription\" input is required and cannot be empty.');\n    }\n    if (\n      this.spiderChartData.labelDescription &&\n      this.spiderChartData.labelDescription.length !== this.spiderChartData.labels.length\n    ) {\n      throw new Error('The \"labelDescription\" input must have the same length as \"labels\".');\n    }\n    if (!this.spiderChartData.plotData[0].databaseLabel) {\n      throw new Error('The \"plotData.databaseLabel\" input is required.');\n    }\n    if (!this.spiderChartData.plotData[0].data || this.spiderChartData.plotData[0].data.length === 0) {\n      throw new Error('The \"plotData.data\" input is required and cannot be empty.');\n    }\n    if (this.spiderChartData.plotData[0].data.length !== this.spiderChartData.labels.length) {\n      throw new Error('The \"plotData.data\" input must have the same length as \"labels\".');\n    }\n    if (\n      this.spiderChartData.plotData.length === 2 &&\n      this.spiderChartData.labels.length > 0 &&\n      this.spiderChartData.plotData[1].data &&\n      this.spiderChartData.plotData[1].data.length !== this.spiderChartData.labels.length\n    ) {\n      throw new Error('The \"plotData.data\" input must have the same length as \"labels\".');\n    }\n  }\n\n  private setChartData() {\n    const datasets = [];\n    datasets.push({\n      label: this.spiderChartData.plotData[0].databaseLabel,\n      data: this.spiderChartData.plotData[0].data,\n      fill: true,\n      backgroundColor: 'rgba(212, 16, 170, 0.2)',\n      borderColor: Color.BRAND_50,\n      pointBackgroundColor: Color.BRAND_50,\n      pointBorderColor: Color.TGO_WHITE,\n      pointHoverBackgroundColor: Color.TGO_WHITE,\n      pointHoverBorderColor: Color.BRAND_50,\n    });\n    if (this.spiderChartData.plotData.length === 2) {\n      datasets.push({\n        label: this.spiderChartData.plotData[1].databaseLabel,\n        data: this.spiderChartData.plotData[1].data,\n        fill: false,\n        borderColor: Color.BLACK,\n        borderDash: [5, 5],\n        borderWidth: 1,\n        pointBackgroundColor: Color.BLACK,\n        pointBorderColor: Color.TGO_WHITE,\n        pointHoverBackgroundColor: Color.TGO_WHITE,\n        pointHoverBorderColor: Color.BLACK,\n      });\n    }\n    this.radarChartData = {\n      labels: this.spiderChartData.labels,\n      datasets: datasets,\n    };\n  }\n\n  private setChartOptions() {\n    this.radarChartOptions = {\n      responsive: true,\n      elements: {\n        line: {\n          borderWidth: 3,\n        },\n      },\n      layout: {\n        padding: {\n          left: 40,\n          right: 40,\n          top: 40,\n          bottom: 40,\n        },\n      },\n      scales: {\n        r: {\n          angleLines: {\n            display: true,\n            color: Color.BLACK,\n          },\n          grid: {\n            color: context => {\n              if (context.tick.value === 100) {\n                return Color.BLACK;\n              }\n              return Color.GRAYSCALE_30;\n            },\n          },\n          pointLabels: {\n            color: 'black',\n            font: {\n              family: 'Arial',\n              size: 14,\n            },\n            display: false,\n          },\n          suggestedMin: 0,\n          suggestedMax: 100,\n          ticks: {\n            stepSize: this.stepSize,\n            display: false,\n          },\n        },\n      },\n      plugins: {\n        legend: {\n          display: false,\n        },\n      },\n    };\n  }\n\n  ngAfterViewInit(): void {\n    if (this.chart?.chart && !this.loading) {\n      this.logCornerCoordinates(this.chart.chart);\n    }\n  }\n\n  private logCornerCoordinates(chart: Chart) {\n    const scale = chart.scales['r'] as any;\n    const canvasWidth = this.size === 'large' ? LargeSpiderChartSize : SmallSpiderChartSize;\n    const canvasHeight = this.size === 'large' ? LargeSpiderChartSize : SmallSpiderChartSize;\n\n    // Loop through the labels and calculate the percentage coordinates\n    this.spiderChartData.labels.forEach((label, index) => {\n      const position = scale.getPointPositionForValue(index, scale.max);\n\n      // Calculate percentage values relative to the canvas size\n      const xPercent = (position.x / canvasWidth) * 100;\n      const yPercent = ((canvasHeight - position.y) / canvasHeight) * 100; // Inverting the Y-axis\n\n      this.labelPositions[label] = { x: Number(xPercent.toFixed(2)), y: Number(yPercent.toFixed(2)) };\n    });\n    this.labelPositionsVisible = true;\n  }\n\n  getCenteredLabelBottomPosition(label: string, height: number) {\n    const position = this.labelPositions[label];\n    const padding = 7;\n    if (position.x > 50 || position.x < 50) {\n      return `calc(${position.y}% - ${height / 2}px)`;\n    } else if (position.y < 50) {\n      return `calc(${position.y}% - ${height}px - ${padding}px)`;\n    } else {\n      return `calc(${position.y}% + ${padding}px)`;\n    }\n  }\n\n  getCenteredLabelLeftPosition(label: string, width: number) {\n    const position = this.labelPositions[label];\n    const padding = 15;\n    if (position.x === 50) {\n      return `calc(${position.x}% - ${width / 2}px)`;\n    } else if (position.x < 50) {\n      return `calc(${position.x}% - ${width}px - ${padding}px)`;\n    } else {\n      return `calc(${position.x}% + ${padding}px)`;\n    }\n  }\n\n  onLabelKeyDown(event: KeyboardEvent, index: number) {\n    if (event.key === 'ArrowRight' || event.key === 'ArrowDown') {\n      this.focusNextLabel(index);\n    } else if (event.key === 'ArrowLeft' || event.key === 'ArrowUp') {\n      this.focusPreviousLabel(index);\n    }\n  }\n\n  private focusNextLabel(index: number) {\n    const nextIndex = index + 1;\n    if (nextIndex < this.labelContainers.length) {\n      this.labelContainers.get(nextIndex)?.nativeElement.focus();\n    } else {\n      this.labelContainers.first?.nativeElement.focus();\n    }\n    this.focusedLabelIndex = nextIndex;\n  }\n\n  private focusPreviousLabel(index: number) {\n    const previousIndex = index - 1;\n    if (previousIndex >= 0) {\n      this.labelContainers.get(previousIndex)?.nativeElement.focus();\n    } else {\n      this.labelContainers.last?.nativeElement.focus();\n    }\n    this.focusedLabelIndex = previousIndex;\n  }\n\n  onLegendItemKeyDown(event: KeyboardEvent, index: number) {\n    if (event.key === 'Enter') {\n      this.toggleDatasetVisibility(index);\n    } else if (event.key === 'ArrowRight' || event.key === 'ArrowDown') {\n      this.focusNextLegendItem(index);\n    } else if (event.key === 'ArrowLeft' || event.key === 'ArrowUp') {\n      this.focusPreviousLegendItem(index);\n    }\n  }\n\n  private focusNextLegendItem(index: number) {\n    const nextIndex = index + 1;\n    if (nextIndex < this.legendItems.length) {\n      this.legendItems.get(nextIndex)?.nativeElement.focus();\n    } else {\n      this.legendItems.first?.nativeElement.focus();\n    }\n  }\n\n  private focusPreviousLegendItem(index: number) {\n    const previousIndex = index - 1;\n    if (previousIndex >= 0) {\n      this.legendItems.get(previousIndex)?.nativeElement.focus();\n    } else {\n      this.legendItems.last?.nativeElement.focus();\n    }\n  }\n\n  onFakeDataPointsKeyDown(event: KeyboardEvent, index: number, isSecondary: boolean = false) {\n    if (event.key === 'ArrowRight' || event.key === 'ArrowDown') {\n      this.focusNextFakeDataPoint(index, isSecondary);\n      this.showTooltipForDataPoint(index + 1 > this.spiderChartData.labels.length ? 0 : index + 1, isSecondary);\n    } else if (event.key === 'ArrowLeft' || event.key === 'ArrowUp') {\n      this.focusPreviousFakeDataPoint(index, isSecondary);\n      this.showTooltipForDataPoint(index - 1 < 0 ? this.spiderChartData.labels.length - 1 : index - 1, isSecondary);\n    } else if (event.key === 'Tab') {\n      this.resetActiveElement();\n    }\n  }\n\n  private focusNextFakeDataPoint(index: number, isSecondary: boolean = false) {\n    const nextIndex = index + 1;\n    if (nextIndex < this.fakeDataPoints.length) {\n      const fakeDataPoints = isSecondary ? this.fakeDataPointsSecondary : this.fakeDataPoints;\n      fakeDataPoints.get(nextIndex)?.nativeElement.focus();\n    } else {\n      const fakeDataPoints = isSecondary ? this.fakeDataPointsSecondary : this.fakeDataPoints;\n      fakeDataPoints.first?.nativeElement.focus();\n    }\n    if (!isSecondary) {\n      this.focusedFakeDataPointIndex = nextIndex;\n    }\n  }\n\n  private focusPreviousFakeDataPoint(index: number, isSecondary: boolean = false) {\n    const previousIndex = index - 1;\n    if (previousIndex >= 0) {\n      const fakeDataPoints = isSecondary ? this.fakeDataPointsSecondary : this.fakeDataPoints;\n      fakeDataPoints.get(previousIndex)?.nativeElement.focus();\n    } else {\n      const fakeDataPoints = isSecondary ? this.fakeDataPointsSecondary : this.fakeDataPoints;\n      fakeDataPoints.last?.nativeElement.focus();\n    }\n    if (!isSecondary) {\n      this.focusedFakeDataPointIndex = previousIndex;\n    }\n  }\n\n  showTooltipForDataPoint(index: number, isSecondary: boolean = false) {\n    const chartInstance = this.chart?.chart;\n    if (!chartInstance) return;\n    const activeElement = [{ datasetIndex: isSecondary ? 1 : 0, index }];\n    const meta = chartInstance.getDatasetMeta(isSecondary ? 1 : 0);\n    const dataPoint = meta.data[index];\n    const eventPosition = {\n      x: dataPoint.x,\n      y: dataPoint.y,\n    };\n    if (!isSecondary) {\n      this.focusedFakeDataPointIndex = index;\n    }\n\n    chartInstance.tooltip?.setActiveElements(activeElement, eventPosition);\n\n    chartInstance.update();\n  }\n\n  private resetActiveElement() {\n    const chartInstance = this.chart?.chart;\n    if (!chartInstance) return;\n\n    // Clear the active elements to hide the tooltip\n    chartInstance.tooltip?.setActiveElements([], { x: 0, y: 0 });\n\n    chartInstance.update();\n  }\n\n  toggleDatasetVisibility(datasetIndex: number) {\n    const chartInstance = this.chart?.chart;\n    if (!chartInstance) return;\n\n    const dataset = chartInstance.data.datasets[datasetIndex];\n    dataset.hidden = !dataset.hidden;\n    chartInstance.update();\n  }\n\n  isDatasetVisible(datasetIndex: number) {\n    const chartInstance = this.chart?.chart;\n    if (!chartInstance) return;\n    return !chartInstance.data.datasets[datasetIndex].hidden;\n  }\n}\n","<div class=\"container\"\n  tabindex=\"0\"\n  [attr.aria-label]=\"ariaLabel\">\n  <div class=\"spacing-container\"\n    [ngClass]=\"{'small-spacing': radarChartData.labels && radarChartData.labels.length % 2 === 1 && !loading}\">\n    <div class=\"chart-container\"\n      [style.width]=\"size === 'large' ? '280px' : '200px'\"\n      [style.height]=\"size === 'large' ? '280px' : '200px'\">\n      @if (!loading) {\n        <canvas\n          baseChart\n          [data]=\"radarChartData\"\n          [options]=\"radarChartOptions\"\n          type=\"radar\"\n          class=\"chart\"\n        >\n        </canvas>\n      } @else {\n        <canvas\n          baseChart\n          [data]=\"loadingChartData\"\n          [options]=\"loadingChartOptions\"\n          type=\"radar\"\n          class=\"chart\"\n        >\n        </canvas>\n        <ui-spinner></ui-spinner>\n      }\n\n      @if (labelPositionsVisible) {\n      <div class=\"overlay-container\">\n          @for (label of spiderChartData.labels; track label) {\n            <div class=\"label-container\" #labelContainer\n              [matTooltip]=\"label + ': ' + spiderChartData.labelDescription[$index]\"\n              [tabindex]=\"$index === 0 ? '0' : '-1'\"\n              (keydown)=\"onLabelKeyDown($event, $index)\"\n              [attr.aria-label]=\"label + ': ' + spiderChartData.labelDescription[$index]\"\n              [style.left]=\"getCenteredLabelLeftPosition(label, labelContainer.offsetWidth)\"\n              [style.bottom]=\"getCenteredLabelBottomPosition(label, labelContainer.offsetHeight)\">\n              <div class=\"label\" #labelElement [style.max-width]=\"size === 'large' ? '150px' : '100px'\"\n                [class.two-lines]=\"label.length > 20 && size === 'large' && spiderChartData.labels.length < 9\">\n                {{ label }}\n              </div>\n              <span class=\"value\">{{ spiderChartData.plotData[0].data[$index] }}</span>\n            </div>\n            <span class=\"fake-data-points\" #fakeDataPoints\n              [tabindex]=\"focusedLabelIndex === $index ? '0' : '-1'\"\n              (focus)=\"$index === focusedLabelIndex ? showTooltipForDataPoint($index) : null\"\n              (keydown)=\"onFakeDataPointsKeyDown($event, $index)\">\n            </span>\n            @if (radarChartData.datasets.length > 1) {\n              <span class=\"fake-data-points-secondary\" #fakeDataPointsSecondary\n                [tabindex]=\"focusedFakeDataPointIndex === $index ? '0' : '-1'\"\n                (focus)=\"$index === focusedFakeDataPointIndex ? showTooltipForDataPoint($index, true) : null\"\n                (keydown)=\"onFakeDataPointsKeyDown($event, $index, true)\">\n              </span>\n            }\n          }\n        </div>\n      }\n    </div>\n  </div>\n  @if (radarChartData.datasets.length > 0) {\n    <div class=\"legend-container\">\n      @for (dataset of radarChartData.datasets; track dataset.label) {\n        <div class=\"legend-item\"\n          (click)=\"toggleDatasetVisibility($index)\"\n          [tabindex]=\"$index === 0 ? '0' : '-1'\"\n          role=\"button\"\n          [attr.aria-pressed]=\"isDatasetVisible($index) ? false : true\"\n          [attr.aria-label]=\"isDatasetVisible($index) ?\n          ((translationContext + 'DATASET_VISIBLE') | uiTranslate : { dataset: dataset.label } | async) :\n          ((translationContext + 'DATASET_HIDDEN') | uiTranslate : { dataset: dataset.label } | async)\"\n          (keydown)=\"onLegendItemKeyDown($event, $index)\"\n          #legendItem>\n          <span class=\"legend-line\" [ngClass]=\"{'solid-line': $index === 0, 'dashed-line': $index === 1}\"></span>\n          <span class=\"legend-label\" [style.text-decoration]=\"isDatasetVisible($index) ? 'none' : 'line-through'\">\n            {{ dataset.label }}\n          </span>\n        </div>\n      }\n    </div>\n  }\n</div>\n\n"]}
|