mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-18 11:26:00 +00:00
35 lines
1.2 KiB
TypeScript
35 lines
1.2 KiB
TypeScript
import _sortBy from 'lodash/sortBy';
|
|
import _sum from 'lodash/sum';
|
|
import { ChartLimits, ChartYFieldDefinition, ProcessedChart } from './chartDefinitions';
|
|
|
|
export function getChartScore(chart: ProcessedChart): number {
|
|
if (chart.errorMessage) {
|
|
return -1; // negative score for charts with errors
|
|
}
|
|
let res = 0;
|
|
res += chart.rowsAdded * 5;
|
|
|
|
const ydefScores = chart.definition.ydefs.map(yField => getChartYFieldScore(chart, yField));
|
|
const sorted = _sortBy(ydefScores).reverse();
|
|
res += _sum(sorted.slice(0, ChartLimits.AUTODETECT_MEASURES_LIMIT));
|
|
|
|
if (chart.groupSet?.size >= 2 && chart.groupSet?.size <= 6) {
|
|
res += 50; // bonus for nice grouping
|
|
}
|
|
if (chart.groupSet?.size == 1) {
|
|
res -= 20; // penalty for single group
|
|
}
|
|
|
|
return res;
|
|
}
|
|
|
|
export function getChartYFieldScore(chart: ProcessedChart, yField: ChartYFieldDefinition): number {
|
|
let res = 0;
|
|
res += chart.validYRows[yField.field] * 5; // score for valid Y rows
|
|
res += (chart.topDistinctValues[yField.field]?.size ?? 0) * 20; // score for distinct values in Y field
|
|
res += chart.rowsAdded * 2; // base score for rows added
|
|
res -= (chart.invalidYRows[yField.field] ?? 0) * 50; // penalty for invalid Y rows
|
|
|
|
return res;
|
|
}
|