@testgorilla/tgo-ui 2.26.9 → 2.26.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/button/button.component.d.ts +7 -5
- package/components/checkbox/checkbox.component.d.ts +13 -3
- package/components/field/field.component.d.ts +1 -0
- package/components/filter-button/filter-button.component.d.ts +6 -1
- package/components/password-criteria/password.component.d.ts +3 -1
- package/components/radio-button/radio-button.component.d.ts +11 -1
- package/components/spider-chart/spider-chart.component.d.ts +2 -0
- package/components/spider-chart/spider-chart.module.d.ts +3 -2
- package/components/universal-skills-spider-charts/universal-skills-spider-charts.component.d.ts +8 -1
- package/esm2022/assets/i18n/en.json +12 -2
- package/esm2022/components/alert-banner/alert-banner.component.mjs +2 -2
- package/esm2022/components/avatar/avatar.component.mjs +1 -1
- package/esm2022/components/button/button.component.mjs +8 -5
- package/esm2022/components/card/card.component.mjs +2 -2
- package/esm2022/components/checkbox/checkbox.component.mjs +17 -3
- package/esm2022/components/checklist/checklist.component.mjs +2 -2
- package/esm2022/components/dialog/dialog.component.mjs +1 -1
- package/esm2022/components/dropdown/dropdown.component.mjs +1 -1
- package/esm2022/components/empty-state/empty-state.component.mjs +1 -1
- package/esm2022/components/field/field.component.mjs +8 -3
- package/esm2022/components/filter-button/filter-button.component.mjs +27 -4
- package/esm2022/components/media-card/media-card.component.mjs +2 -2
- package/esm2022/components/navbar/mobile-navbar-side-sheet/mobile-navbar-side-sheet.component.mjs +2 -2
- package/esm2022/components/navbar/navbar.component.mjs +1 -1
- package/esm2022/components/page-header/page-header.component.mjs +1 -1
- package/esm2022/components/password-criteria/password.component.mjs +10 -4
- package/esm2022/components/radial-progress/radial-progress.component.mjs +1 -1
- package/esm2022/components/radio-button/radio-button.component.mjs +17 -3
- package/esm2022/components/side-panel/side-panel.component.mjs +2 -2
- package/esm2022/components/side-sheet/side-sheet.component.mjs +1 -1
- package/esm2022/components/snackbar/snackbar.component.mjs +2 -2
- package/esm2022/components/spider-chart/spider-chart.component.mjs +22 -4
- package/esm2022/components/spider-chart/spider-chart.module.mjs +4 -1
- package/esm2022/components/step/step.component.mjs +2 -2
- package/esm2022/components/stepper/stepper.component.mjs +3 -3
- package/esm2022/components/table/table.component.mjs +3 -3
- package/esm2022/components/universal-skills-spider-charts/universal-skills-spider-charts.component.mjs +45 -31
- package/fesm2022/testgorilla-tgo-ui.mjs +179 -71
- package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
- package/package.json +1 -1
- package/projects/tgo-canopy-ui/assets/i18n/en.json +12 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Inject, Input, Optional } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { take } from 'rxjs';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../../services/universal-skills.service";
|
|
5
5
|
import * as i2 from "../../pipes/ui-translate.pipe";
|
|
@@ -19,6 +19,13 @@ export class UniversalSkillsSpiderChartsComponent {
|
|
|
19
19
|
* @memberof UniversalSkillsSpiderChartsComponent
|
|
20
20
|
*/
|
|
21
21
|
this.applicationTheme = 'light';
|
|
22
|
+
/**
|
|
23
|
+
* Defines if the component is loading
|
|
24
|
+
* @property loading
|
|
25
|
+
* @type {boolean}
|
|
26
|
+
* @memberof UniversalSkillsSpiderChartsComponent
|
|
27
|
+
*/
|
|
28
|
+
this.loading = false;
|
|
22
29
|
this.translationContext = 'UNIVERSAL_SKILLS_REPORT.';
|
|
23
30
|
this.skillAreaSpiderChartData = [];
|
|
24
31
|
if (defaultAppTheme) {
|
|
@@ -36,43 +43,48 @@ export class UniversalSkillsSpiderChartsComponent {
|
|
|
36
43
|
Object.values(this.skillAreaGroupMap).forEach(skillAreaGroup => {
|
|
37
44
|
const labelObservables = skillAreaGroup.skillAreaList.map(skillArea => this.uiTranslatePipe.transform(`${this.translationContext}SKILL_AREA_TYPES.${skillArea.skillAreaName}.TITLE`));
|
|
38
45
|
const labelDescriptionObservables = skillAreaGroup.skillAreaList.map(skillArea => this.uiTranslatePipe.transform(`${this.translationContext}SKILL_AREA_TYPES.${skillArea.skillAreaName}.DESCRIPTION`));
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
description: skillAreaGroup.description,
|
|
45
|
-
spiderChartData: {
|
|
46
|
-
labels: labels,
|
|
47
|
-
labelDescription: labelDescriptions,
|
|
48
|
-
plotData: skillAreaGroup.skillAreaList?.[0]?.poolPercentileScoring !== undefined
|
|
49
|
-
? [
|
|
50
|
-
{
|
|
51
|
-
data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.percentileScoring),
|
|
52
|
-
databaseLabel: "This candidate's score",
|
|
53
|
-
},
|
|
54
|
-
{
|
|
55
|
-
data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.poolPercentileScoring ?? 0),
|
|
56
|
-
databaseLabel: 'Average score of all candidates',
|
|
57
|
-
},
|
|
58
|
-
]
|
|
59
|
-
: [
|
|
60
|
-
{
|
|
61
|
-
data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.percentileScoring),
|
|
62
|
-
databaseLabel: "This candidate's score",
|
|
63
|
-
},
|
|
64
|
-
],
|
|
65
|
-
},
|
|
46
|
+
const allObservables = [...labelObservables, ...labelDescriptionObservables];
|
|
47
|
+
const translations = [];
|
|
48
|
+
allObservables.forEach(observable => {
|
|
49
|
+
observable.pipe(take(1)).subscribe(translation => {
|
|
50
|
+
translations.push(translation);
|
|
66
51
|
});
|
|
67
52
|
});
|
|
53
|
+
const labels = translations.slice(0, labelObservables.length);
|
|
54
|
+
const labelDescriptions = translations.slice(labelObservables.length);
|
|
55
|
+
this.skillAreaSpiderChartData.push({
|
|
56
|
+
title: skillAreaGroup.title,
|
|
57
|
+
description: skillAreaGroup.description,
|
|
58
|
+
spiderChartData: {
|
|
59
|
+
labels: labels,
|
|
60
|
+
labelDescription: labelDescriptions,
|
|
61
|
+
plotData: skillAreaGroup.skillAreaList?.[0]?.poolPercentileScoring !== undefined
|
|
62
|
+
? [
|
|
63
|
+
{
|
|
64
|
+
data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.percentileScoring),
|
|
65
|
+
databaseLabel: "This candidate's score",
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.poolPercentileScoring ?? 0),
|
|
69
|
+
databaseLabel: 'Average score of all candidates',
|
|
70
|
+
},
|
|
71
|
+
]
|
|
72
|
+
: [
|
|
73
|
+
{
|
|
74
|
+
data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.percentileScoring),
|
|
75
|
+
databaseLabel: "This candidate's score",
|
|
76
|
+
},
|
|
77
|
+
],
|
|
78
|
+
},
|
|
79
|
+
});
|
|
68
80
|
});
|
|
69
81
|
}
|
|
70
82
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: UniversalSkillsSpiderChartsComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: i1.UniversalSkillsService }, { token: i2.UiTranslatePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: UniversalSkillsSpiderChartsComponent, selector: "ui-universal-skills-spider-charts", inputs: { applicationTheme: "applicationTheme", skillAreaDataList: "skillAreaDataList" }, ngImport: i0, template: "@for (spiderChartData of skillAreaSpiderChartData; track spiderChartData) {\n <ui-accordion class=\"universal-skills-spider-charts\" [label]=\"(spiderChartData.title | uiTranslate | async) || ''\" variant=\"filter\">\n <ui-spider-chart [spiderChartData]=\"spiderChartData.spiderChartData\"></ui-spider-chart>\n </ui-accordion>\n @if ($index < skillAreaSpiderChartData.length - 1) {\n <ui-divider class=\"universal-skills-spider-charts-divider\" size=\"small\"></ui-divider>\n }\n}\n", styles: [".universal-skills-spider-charts ::ng-deep .accordion-wrapper[theme=light] .mat-expansion-panel .mat-expansion-panel-header .accordion-label{font-weight:700}.universal-skills-spider-charts-divider ::ng-deep .ui-divider-wrapper{margin-top:8px;margin-bottom:8px}\n"], dependencies: [{ kind: "component", type: i3.AccordionComponent, selector: "ui-accordion", inputs: ["label", "open", "disabled", "showPremiumIcon", "premiumTooltipText", "applicationTheme", "labelIcon", "variant", "allowCustomHeader", "noBackgroundColor", "toggleIconPosition"], outputs: ["closed", "opened"] }, { kind: "component", type: i4.SpiderChartComponent, selector: "ui-spider-chart", inputs: ["size", "spiderChartData", "stepSize", "ariaLabel", "loading", "applicationTheme"] }, { kind: "component", type: i5.DividerComponent, selector: "ui-divider", inputs: ["size", "companyColor", "applicationTheme", "label"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.UiTranslatePipe, name: "uiTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
83
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: UniversalSkillsSpiderChartsComponent, selector: "ui-universal-skills-spider-charts", inputs: { applicationTheme: "applicationTheme", skillAreaDataList: "skillAreaDataList", loading: "loading" }, ngImport: i0, template: "@for (spiderChartData of skillAreaSpiderChartData; track spiderChartData) {\n <ui-accordion class=\"universal-skills-spider-charts\" [label]=\"(spiderChartData.title | uiTranslate | async) || ''\" variant=\"filter\">\n <ui-spider-chart [spiderChartData]=\"spiderChartData.spiderChartData\" [loading]=\"loading\"></ui-spider-chart>\n </ui-accordion>\n @if ($index < skillAreaSpiderChartData.length - 1) {\n <ui-divider class=\"universal-skills-spider-charts-divider\" size=\"small\"></ui-divider>\n }\n}\n", styles: [".universal-skills-spider-charts ::ng-deep .accordion-wrapper[theme=light] .mat-expansion-panel .mat-expansion-panel-header .accordion-label{font-weight:700}.universal-skills-spider-charts-divider ::ng-deep .ui-divider-wrapper{margin-top:8px;margin-bottom:8px}\n"], dependencies: [{ kind: "component", type: i3.AccordionComponent, selector: "ui-accordion", inputs: ["label", "open", "disabled", "showPremiumIcon", "premiumTooltipText", "applicationTheme", "labelIcon", "variant", "allowCustomHeader", "noBackgroundColor", "toggleIconPosition"], outputs: ["closed", "opened"] }, { kind: "component", type: i4.SpiderChartComponent, selector: "ui-spider-chart", inputs: ["size", "spiderChartData", "stepSize", "ariaLabel", "loading", "applicationTheme"] }, { kind: "component", type: i5.DividerComponent, selector: "ui-divider", inputs: ["size", "companyColor", "applicationTheme", "label"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.UiTranslatePipe, name: "uiTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
72
84
|
}
|
|
73
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: UniversalSkillsSpiderChartsComponent, decorators: [{
|
|
74
86
|
type: Component,
|
|
75
|
-
args: [{ selector: 'ui-universal-skills-spider-charts', changeDetection: ChangeDetectionStrategy.OnPush, template: "@for (spiderChartData of skillAreaSpiderChartData; track spiderChartData) {\n <ui-accordion class=\"universal-skills-spider-charts\" [label]=\"(spiderChartData.title | uiTranslate | async) || ''\" variant=\"filter\">\n <ui-spider-chart [spiderChartData]=\"spiderChartData.spiderChartData\"></ui-spider-chart>\n </ui-accordion>\n @if ($index < skillAreaSpiderChartData.length - 1) {\n <ui-divider class=\"universal-skills-spider-charts-divider\" size=\"small\"></ui-divider>\n }\n}\n", styles: [".universal-skills-spider-charts ::ng-deep .accordion-wrapper[theme=light] .mat-expansion-panel .mat-expansion-panel-header .accordion-label{font-weight:700}.universal-skills-spider-charts-divider ::ng-deep .ui-divider-wrapper{margin-top:8px;margin-bottom:8px}\n"] }]
|
|
87
|
+
args: [{ selector: 'ui-universal-skills-spider-charts', changeDetection: ChangeDetectionStrategy.OnPush, template: "@for (spiderChartData of skillAreaSpiderChartData; track spiderChartData) {\n <ui-accordion class=\"universal-skills-spider-charts\" [label]=\"(spiderChartData.title | uiTranslate | async) || ''\" variant=\"filter\">\n <ui-spider-chart [spiderChartData]=\"spiderChartData.spiderChartData\" [loading]=\"loading\"></ui-spider-chart>\n </ui-accordion>\n @if ($index < skillAreaSpiderChartData.length - 1) {\n <ui-divider class=\"universal-skills-spider-charts-divider\" size=\"small\"></ui-divider>\n }\n}\n", styles: [".universal-skills-spider-charts ::ng-deep .accordion-wrapper[theme=light] .mat-expansion-panel .mat-expansion-panel-header .accordion-label{font-weight:700}.universal-skills-spider-charts-divider ::ng-deep .ui-divider-wrapper{margin-top:8px;margin-bottom:8px}\n"] }]
|
|
76
88
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
77
89
|
type: Optional
|
|
78
90
|
}, {
|
|
@@ -82,5 +94,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
82
94
|
type: Input
|
|
83
95
|
}], skillAreaDataList: [{
|
|
84
96
|
type: Input
|
|
97
|
+
}], loading: [{
|
|
98
|
+
type: Input
|
|
85
99
|
}] } });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"universal-skills-spider-charts.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/universal-skills-spider-charts/universal-skills-spider-charts.component.ts","../../../../../projects/tgo-canopy-ui/components/universal-skills-spider-charts/universal-skills-spider-charts.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject, Input, OnInit, Optional } from '@angular/core';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport {\n  SkillAreaData,\n  SkillAreaGroup,\n  SkillAreaGroupTypes,\n  SkillAreaSpiderChartData,\n} from '../../models/universal-skills-report.model';\nimport { UniversalSkillsService } from '../../services/universal-skills.service';\nimport { UiTranslatePipe } from '../../pipes/ui-translate.pipe';\nimport { forkJoin } from 'rxjs';\n\n@Component({\n  selector: 'ui-universal-skills-spider-charts',\n  templateUrl: './universal-skills-spider-charts.component.html',\n  styleUrls: ['./universal-skills-spider-charts.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class UniversalSkillsSpiderChartsComponent implements OnInit {\n  /**\n   * Defines the application theme\n   * @property applicationTheme\n   * @type {ApplicationTheme}\n   * @memberof UniversalSkillsSpiderChartsComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * The list of items to be used\n   * @property items\n   * @type {SkillAreaData[]}\n   * @memberof UniversalSkillsReportComponent\n   */\n  @Input() skillAreaDataList: SkillAreaData[];\n\n  readonly translationContext = 'UNIVERSAL_SKILLS_REPORT.';\n\n  skillAreaGroupMap: Record<SkillAreaGroupTypes, SkillAreaGroup>;\n  skillAreaSpiderChartData: SkillAreaSpiderChartData[] = [];\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private universalSkillsService: UniversalSkillsService,\n    private uiTranslatePipe: UiTranslatePipe\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnInit() {\n    this.universalSkillsService.initializeSkillAreaGroupMap();\n    this.universalSkillsService.prepareSkillAreaGroupMap(this.skillAreaDataList);\n    this.skillAreaGroupMap = this.universalSkillsService.getSkillAreaGroupMap();\n    this.prepareSpiderChartData();\n  }\n\n  prepareSpiderChartData(): void {\n    this.skillAreaSpiderChartData = [];\n    Object.values(this.skillAreaGroupMap).forEach(skillAreaGroup => {\n      const labelObservables = skillAreaGroup.skillAreaList.map(skillArea =>\n        this.uiTranslatePipe.transform(`${this.translationContext}SKILL_AREA_TYPES.${skillArea.skillAreaName}.TITLE`)\n      );\n\n      const labelDescriptionObservables = skillAreaGroup.skillAreaList.map(skillArea =>\n        this.uiTranslatePipe.transform(\n          `${this.translationContext}SKILL_AREA_TYPES.${skillArea.skillAreaName}.DESCRIPTION`\n        )\n      );\n\n      forkJoin([...labelObservables, ...labelDescriptionObservables]).subscribe(translations => {\n        const labels = translations.slice(0, labelObservables.length);\n        const labelDescriptions = translations.slice(labelObservables.length);\n\n        this.skillAreaSpiderChartData.push({\n          title: skillAreaGroup.title,\n          description: skillAreaGroup.description,\n          spiderChartData: {\n            labels: labels,\n            labelDescription: labelDescriptions,\n            plotData:\n              skillAreaGroup.skillAreaList?.[0]?.poolPercentileScoring !== undefined\n                ? [\n                    {\n                      data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.percentileScoring),\n                      databaseLabel: \"This candidate's score\",\n                    },\n                    {\n                      data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.poolPercentileScoring ?? 0),\n                      databaseLabel: 'Average score of all candidates',\n                    },\n                  ]\n                : [\n                    {\n                      data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.percentileScoring),\n                      databaseLabel: \"This candidate's score\",\n                    },\n                  ],\n          },\n        });\n      });\n    });\n  }\n}\n","@for (spiderChartData of skillAreaSpiderChartData; track spiderChartData) {\n  <ui-accordion class=\"universal-skills-spider-charts\" [label]=\"(spiderChartData.title | uiTranslate | async) || ''\" variant=\"filter\">\n    <ui-spider-chart [spiderChartData]=\"spiderChartData.spiderChartData\"></ui-spider-chart>\n  </ui-accordion>\n  @if ($index < skillAreaSpiderChartData.length - 1) {\n    <ui-divider class=\"universal-skills-spider-charts-divider\" size=\"small\"></ui-divider>\n  }\n}\n"]}
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"universal-skills-spider-charts.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/universal-skills-spider-charts/universal-skills-spider-charts.component.ts","../../../../../projects/tgo-canopy-ui/components/universal-skills-spider-charts/universal-skills-spider-charts.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAU,QAAQ,EAAE,MAAM,eAAe,CAAC;AAUpG,OAAO,EAAY,IAAI,EAAE,MAAM,MAAM,CAAC;;;;;;;;AAQtC,MAAM,OAAO,oCAAoC;IA8B/C,YAC6E,eAAiC,EACpG,sBAA8C,EAC9C,eAAgC;QAFmC,oBAAe,GAAf,eAAe,CAAkB;QACpG,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,oBAAe,GAAf,eAAe,CAAiB;QAhC1C;;;;;WAKG;QACM,qBAAgB,GAAqB,OAAO,CAAC;QAUtD;;;;;WAKG;QACM,YAAO,GAAY,KAAK,CAAC;QAEzB,uBAAkB,GAAG,0BAA0B,CAAC;QAGzD,6BAAwB,GAA+B,EAAE,CAAC;QAOxD,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,sBAAsB,CAAC,2BAA2B,EAAE,CAAC;QAC1D,IAAI,CAAC,sBAAsB,CAAC,wBAAwB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC7E,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,sBAAsB,CAAC,oBAAoB,EAAE,CAAC;QAC5E,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAED,sBAAsB;QACpB,IAAI,CAAC,wBAAwB,GAAG,EAAE,CAAC;QACnC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE;YAC7D,MAAM,gBAAgB,GAAG,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CACpE,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,kBAAkB,oBAAoB,SAAS,CAAC,aAAa,QAAQ,CAAC,CAC9G,CAAC;YAEF,MAAM,2BAA2B,GAAG,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAC/E,IAAI,CAAC,eAAe,CAAC,SAAS,CAC5B,GAAG,IAAI,CAAC,kBAAkB,oBAAoB,SAAS,CAAC,aAAa,cAAc,CACpF,CACF,CAAC;YAEF,MAAM,cAAc,GAAG,CAAC,GAAG,gBAAgB,EAAE,GAAG,2BAA2B,CAAC,CAAC;YAC7E,MAAM,YAAY,GAAa,EAAE,CAAC;YAClC,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;gBAClC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE;oBAC/C,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBACjC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,MAAM,MAAM,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAC9D,MAAM,iBAAiB,GAAG,YAAY,CAAC,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAEtE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC;gBACjC,KAAK,EAAE,cAAc,CAAC,KAAK;gBAC3B,WAAW,EAAE,cAAc,CAAC,WAAW;gBACvC,eAAe,EAAE;oBACf,MAAM,EAAE,MAAM;oBACd,gBAAgB,EAAE,iBAAiB;oBACnC,QAAQ,EACN,cAAc,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,EAAE,qBAAqB,KAAK,SAAS;wBACpE,CAAC,CAAC;4BACE;gCACE,IAAI,EAAE,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,iBAAiB,CAAC;gCAChF,aAAa,EAAE,wBAAwB;6BACxC;4BACD;gCACE,IAAI,EAAE,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,qBAAqB,IAAI,CAAC,CAAC;gCACzF,aAAa,EAAE,iCAAiC;6BACjD;yBACF;wBACH,CAAC,CAAC;4BACE;gCACE,IAAI,EAAE,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,iBAAiB,CAAC;gCAChF,aAAa,EAAE,wBAAwB;6BACxC;yBACF;iBACR;aACF,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;+GAjGU,oCAAoC,kBA+BzB,oCAAoC;mGA/B/C,oCAAoC,uLClBjD,ogBAQA;;4FDUa,oCAAoC;kBANhD,SAAS;+BACE,mCAAmC,mBAG5B,uBAAuB,CAAC,MAAM;;0BAiC5C,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;4GAxBjD,gBAAgB;sBAAxB,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAQG,OAAO;sBAAf,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject, Input, OnInit, Optional } from '@angular/core';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport {\n  SkillAreaData,\n  SkillAreaGroup,\n  SkillAreaGroupTypes,\n  SkillAreaSpiderChartData,\n} from '../../models/universal-skills-report.model';\nimport { UniversalSkillsService } from '../../services/universal-skills.service';\nimport { UiTranslatePipe } from '../../pipes/ui-translate.pipe';\nimport { forkJoin, take } from 'rxjs';\n\n@Component({\n  selector: 'ui-universal-skills-spider-charts',\n  templateUrl: './universal-skills-spider-charts.component.html',\n  styleUrls: ['./universal-skills-spider-charts.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class UniversalSkillsSpiderChartsComponent implements OnInit {\n  /**\n   * Defines the application theme\n   * @property applicationTheme\n   * @type {ApplicationTheme}\n   * @memberof UniversalSkillsSpiderChartsComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * The list of items to be used\n   * @property items\n   * @type {SkillAreaData[]}\n   * @memberof UniversalSkillsReportComponent\n   */\n  @Input() skillAreaDataList: SkillAreaData[];\n\n  /**\n   * Defines if the component is loading\n   * @property loading\n   * @type {boolean}\n   * @memberof UniversalSkillsSpiderChartsComponent\n   */\n  @Input() loading: boolean = false;\n\n  readonly translationContext = 'UNIVERSAL_SKILLS_REPORT.';\n\n  skillAreaGroupMap: Record<SkillAreaGroupTypes, SkillAreaGroup>;\n  skillAreaSpiderChartData: SkillAreaSpiderChartData[] = [];\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private universalSkillsService: UniversalSkillsService,\n    private uiTranslatePipe: UiTranslatePipe\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnInit() {\n    this.universalSkillsService.initializeSkillAreaGroupMap();\n    this.universalSkillsService.prepareSkillAreaGroupMap(this.skillAreaDataList);\n    this.skillAreaGroupMap = this.universalSkillsService.getSkillAreaGroupMap();\n    this.prepareSpiderChartData();\n  }\n\n  prepareSpiderChartData(): void {\n    this.skillAreaSpiderChartData = [];\n    Object.values(this.skillAreaGroupMap).forEach(skillAreaGroup => {\n      const labelObservables = skillAreaGroup.skillAreaList.map(skillArea =>\n        this.uiTranslatePipe.transform(`${this.translationContext}SKILL_AREA_TYPES.${skillArea.skillAreaName}.TITLE`)\n      );\n\n      const labelDescriptionObservables = skillAreaGroup.skillAreaList.map(skillArea =>\n        this.uiTranslatePipe.transform(\n          `${this.translationContext}SKILL_AREA_TYPES.${skillArea.skillAreaName}.DESCRIPTION`\n        )\n      );\n\n      const allObservables = [...labelObservables, ...labelDescriptionObservables];\n      const translations: string[] = [];\n      allObservables.forEach(observable => {\n        observable.pipe(take(1)).subscribe(translation => {\n          translations.push(translation);\n        });\n      });\n      const labels = translations.slice(0, labelObservables.length);\n      const labelDescriptions = translations.slice(labelObservables.length);\n\n      this.skillAreaSpiderChartData.push({\n        title: skillAreaGroup.title,\n        description: skillAreaGroup.description,\n        spiderChartData: {\n          labels: labels,\n          labelDescription: labelDescriptions,\n          plotData:\n            skillAreaGroup.skillAreaList?.[0]?.poolPercentileScoring !== undefined\n              ? [\n                  {\n                    data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.percentileScoring),\n                    databaseLabel: \"This candidate's score\",\n                  },\n                  {\n                    data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.poolPercentileScoring ?? 0),\n                    databaseLabel: 'Average score of all candidates',\n                  },\n                ]\n              : [\n                  {\n                    data: skillAreaGroup.skillAreaList.map(skillArea => skillArea.percentileScoring),\n                    databaseLabel: \"This candidate's score\",\n                  },\n                ],\n        },\n      });\n    });\n  }\n}\n","@for (spiderChartData of skillAreaSpiderChartData; track spiderChartData) {\n  <ui-accordion class=\"universal-skills-spider-charts\" [label]=\"(spiderChartData.title | uiTranslate | async) || ''\" variant=\"filter\">\n    <ui-spider-chart [spiderChartData]=\"spiderChartData.spiderChartData\" [loading]=\"loading\"></ui-spider-chart>\n  </ui-accordion>\n  @if ($index < skillAreaSpiderChartData.length - 1) {\n    <ui-divider class=\"universal-skills-spider-charts-divider\" size=\"small\"></ui-divider>\n  }\n}\n"]}
|