( packagesData: ReadonlyArray<PackageComparisonData | null>, packages: string[], xFacet: ComparisonFacet, yFacet: ComparisonFacet, )
| 92 | } |
| 93 | |
| 94 | export function buildCompareScatterChartDataset( |
| 95 | packagesData: ReadonlyArray<PackageComparisonData | null>, |
| 96 | packages: string[], |
| 97 | xFacet: ComparisonFacet, |
| 98 | yFacet: ComparisonFacet, |
| 99 | ): VueUiScatterDatasetItem[] { |
| 100 | return packagesData.reduce<VueUiScatterDatasetItem[]>((acc, packageData, index) => { |
| 101 | if (!packageData) { |
| 102 | return acc |
| 103 | } |
| 104 | |
| 105 | const x = getNumericFacetValue(packageData, xFacet) |
| 106 | const y = getNumericFacetValue(packageData, yFacet) |
| 107 | |
| 108 | if (x === null || y === null) { |
| 109 | return acc |
| 110 | } |
| 111 | |
| 112 | const fallbackName = packages[index] || `package-${index + 1}` |
| 113 | const packageName = getPackageName(packageData, fallbackName) |
| 114 | |
| 115 | acc.push({ |
| 116 | name: applyEllipsis(packageName, 14), |
| 117 | fullName: packageName, |
| 118 | color: isListedFramework(packageName) ? getFrameworkColor(packageName) : undefined, |
| 119 | values: [ |
| 120 | { |
| 121 | x, |
| 122 | y, |
| 123 | name: applyEllipsis(packageName, 14), |
| 124 | fullName: packageName, |
| 125 | }, |
| 126 | ], |
| 127 | }) |
| 128 | |
| 129 | return acc |
| 130 | }, []) |
| 131 | } |
no test coverage detected