Skip to content

Commit

Permalink
feat(yagr): use lineColor for tooltip entity
Browse files Browse the repository at this point in the history
  • Loading branch information
korvin89 committed Mar 6, 2024
1 parent b3c90a4 commit e1b1cfa
Show file tree
Hide file tree
Showing 4 changed files with 77 additions and 60 deletions.
131 changes: 73 additions & 58 deletions src/plugins/yagr/renderer/tooltip/renderTooltip.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import {dateTime} from '@gravity-ui/date-utils';

import type {TooltipRenderOptions, TooltipRow, ValueFormatter} from '../../types';
import type {TooltipRenderOptions, TooltipRow, ValueFormatter, YagrWidgetData} from '../../types';

import {formatTooltip} from './tooltip';
import type {TooltipData, TooltipLine} from './types';
Expand All @@ -13,71 +13,86 @@ const calcOption = <T>(d: T | {[key in string]: T} | undefined) => {
: d;
};

const getLineColor = (args: {
data: TooltipRenderOptions;
userData: YagrWidgetData['data'];
rowId: string;
rowIndex: number;
}) => {
const {data, userData, rowId, rowIndex} = args;
const userSeries = userData.graphs[rowIndex];
const userLineColor = userSeries && 'lineColor' in userSeries && userSeries.lineColor;
const lineColor = data.yagr.getSeriesById(rowId)?.lineColor;

return userLineColor ? lineColor : undefined;
};

/*
* Default tooltip renderer.
* Adapter between native Yagr tooltip config and ChartKit
* tooltip renderer.
*/
export const getRenderTooltip = (timeZone?: string) => (data: TooltipRenderOptions) => {
const cfg = data.yagr.config;
const timeMultiplier = cfg.chart.timeMultiplier || 1;
const opts = data.options;
const {x, state} = data;
export const getRenderTooltip =
(userData: YagrWidgetData['data']) => (data: TooltipRenderOptions) => {
const {timeZone} = userData;
const cfg = data.yagr.config;
const timeMultiplier = cfg.chart.timeMultiplier || 1;
const opts = data.options;
const {x, state} = data;

let sumTotal = 0;
const rows = Object.values(data.scales).reduce((acc, scale) => {
sumTotal += scale.sum || 0;
return acc.concat(scale.rows);
}, [] as TooltipRow[]);
let sumTotal = 0;
const rows = Object.values(data.scales).reduce((acc, scale) => {
sumTotal += scale.sum || 0;
return acc.concat(scale.rows);
}, [] as TooltipRow[]);
const lines = rows.length;
const sum = calcOption(opts.sum);

const lines = rows.length;
const sum = calcOption(opts.sum);
const maxLines = calcOption<number>(opts.maxLines);
const valueFormatter = calcOption<ValueFormatter>(opts.value);
// eslint-disable-next-line no-nested-ternary
const hiddenRowsNumber = state.pinned
? undefined
: lines > maxLines
? Math.abs(maxLines - lines)
: undefined;

const maxLines = calcOption<number>(opts.maxLines);
const valueFormatter = calcOption<ValueFormatter>(opts.value);
// eslint-disable-next-line no-nested-ternary
const hiddenRowsNumber = state.pinned
? undefined
: lines > maxLines
? Math.abs(maxLines - lines)
: undefined;
const hiddenRowsSum = hiddenRowsNumber
? valueFormatter(
rows
.slice(-hiddenRowsNumber)
.reduce((acc, {originalValue}) => acc + (originalValue || 0), 0),
)
: undefined;
const tooltipFormatOptions: TooltipData = {
activeRowAlwaysFirstInTooltip: rows.length > 1,
tooltipHeader: dateTime({input: x / timeMultiplier, timeZone}).format(
'DD MMMM YYYY HH:mm:ss',
),
shared: true,
lines: rows.map(
(row, i) =>
({
...row,
seriesName: row.name || 'Serie ' + (i + 1),
seriesColor: row.color,
selectedSeries: row.active,
seriesIdx: row.seriesIdx,
lineColor: getLineColor({data, userData, rowId: row.id, rowIndex: i}),
percentValue:
typeof row.transformed === 'number' ? row.transformed.toFixed(1) : '',
}) as TooltipLine,
),
withPercent: calcOption<boolean>(opts.percent),
hiddenRowsNumber: hiddenRowsNumber as number,
hiddenRowsSum,
};

const hiddenRowsSum = hiddenRowsNumber
? valueFormatter(
rows
.slice(-hiddenRowsNumber)
.reduce((acc, {originalValue}) => acc + (originalValue || 0), 0),
)
: undefined;
if (sum) {
tooltipFormatOptions.sum = valueFormatter(sumTotal);
}

const tooltipFormatOptions: TooltipData = {
activeRowAlwaysFirstInTooltip: rows.length > 1,
tooltipHeader: dateTime({input: x / timeMultiplier, timeZone}).format(
'DD MMMM YYYY HH:mm:ss',
),
shared: true,
lines: rows.map(
(row, i) =>
({
...row,
seriesName: row.name || 'Serie ' + (i + 1),
seriesColor: row.color,
selectedSeries: row.active,
seriesIdx: row.seriesIdx,
percentValue:
typeof row.transformed === 'number' ? row.transformed.toFixed(1) : '',
}) as TooltipLine,
),
withPercent: calcOption<boolean>(opts.percent),
hiddenRowsNumber: hiddenRowsNumber as number,
hiddenRowsSum,
return formatTooltip(tooltipFormatOptions, {
lastVisibleRowIndex: state.pinned ? rows.length - 1 : maxLines - 1,
});
};

if (sum) {
tooltipFormatOptions.sum = valueFormatter(sumTotal);
}

return formatTooltip(tooltipFormatOptions, {
lastVisibleRowIndex: state.pinned ? rows.length - 1 : maxLines - 1,
});
};
2 changes: 1 addition & 1 deletion src/plugins/yagr/renderer/tooltip/tooltip.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ const renderEmptyCell = () => '<td />';

const renderColorCell = (line: TooltipLine) =>
`<td class="_tooltip-rows__bubble-td">
<div class="_tooltip-rows__bubble-div" style="background-color:${line.seriesColor};"></div>
<div class="_tooltip-rows__bubble-div" style="background-color:${line.lineColor || line.seriesColor};"></div>
</td>`;

const renderNameCell = (line: TooltipLine) =>
Expand Down
2 changes: 2 additions & 0 deletions src/plugins/yagr/renderer/tooltip/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ export type TooltipExtraData = {
export type TooltipLine = {
/** Color displayed in a separate cell */
seriesColor: string;
/** Color displayed in a separate cell. Relevant for areas only */
lineColor?: string;
/** Series name */
seriesName: string;
/** Series index */
Expand Down
2 changes: 1 addition & 1 deletion src/plugins/yagr/renderer/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,7 @@ export const shapeYagrConfig = (args: ShapeYagrConfigArgs): MinimalValidConfig =

if (config.tooltip?.show) {
config.tooltip = config.tooltip || {};
config.tooltip.render = config.tooltip?.render || getRenderTooltip(timeZone);
config.tooltip.render = config.tooltip?.render || getRenderTooltip(data);

if (!config.tooltip.className) {
// "className" property prevent default yagr styles adding
Expand Down

0 comments on commit e1b1cfa

Please sign in to comment.