diff --git a/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-bar-type/should-render-with-blended-background-color-chrome-linux.png b/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-bar-type/should-render-with-blended-background-color-chrome-linux.png new file mode 100644 index 0000000000..8749152cba Binary files /dev/null and b/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-bar-type/should-render-with-blended-background-color-chrome-linux.png differ diff --git a/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-none-type/should-render-with-blended-background-color-chrome-linux.png b/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-none-type/should-render-with-blended-background-color-chrome-linux.png new file mode 100644 index 0000000000..fe7b1a1dfc Binary files /dev/null and b/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-none-type/should-render-with-blended-background-color-chrome-linux.png differ diff --git a/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-trend-type/should-render-with-blended-background-color-chrome-linux.png b/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-trend-type/should-render-with-blended-background-color-chrome-linux.png new file mode 100644 index 0000000000..b866037303 Binary files /dev/null and b/e2e/screenshots/metric_stories.test.ts-snapshots/metric/metric-trend-type/should-render-with-blended-background-color-chrome-linux.png differ diff --git a/e2e/tests/metric_stories.test.ts b/e2e/tests/metric_stories.test.ts index a10d78392c..484eb26c09 100644 --- a/e2e/tests/metric_stories.test.ts +++ b/e2e/tests/metric_stories.test.ts @@ -56,6 +56,12 @@ test.describe('Metric', () => { pwEach.describe(['trend', 'bar', 'none'])( (v) => `Metric - ${v} type`, (type) => { + test('should render with blended background color', async ({ page }) => { + await common.expectChartAtUrlToMatchScreenshot(page)( + `http://localhost:9001/?path=/story/metric-alpha--basic&globals=toggles.showHeader:true;toggles.showChartTitle:false;toggles.showChartDescription:false;toggles.showChartBoundary:false;background:red;theme:light&knob-Config 1 - Color_Color Bands=rgba(245, 247, 250, 1)&knob-Config 2 - Palette_Color Bands=5&knob-Config 2 - Steps_Color Bands=5&knob-Config 3 - json_Color Bands={"classes":5,"colors":["pink","yellow","blue"]}&knob-Config 4 - json_Color Bands=[{"color":"red","gte":0,"lt":20},{"color":"green","gte":20,"lte":40},{"color":"blue","gt":40,"lte":{"type":"percentage","value":100}}]&knob-Domain padding unit=pixel&knob-EUI icon glyph name=warning&knob-EUI value icon glyph name=sortUp&knob-SeriesType=line&knob-Specs to fit (yDomain)=theshold,rect&knob-active tick step=0&knob-add series=true&knob-attach click handler=true&knob-bars padding=0.25&knob-blending background=rgba(255,255,255,1)&knob-color=rgba(51, 143, 200, 0.49)&knob-color config_Color Bands=2&knob-constrain padding=true&knob-dataset=both&knob-debug=true&knob-empty background=rgba(99, 69, 69, 0)&knob-enableHistogramMode=true&knob-end=100&knob-end_Domain=100&knob-end_General=100&knob-extra=last 5m&knob-fit Y domain to data=true&knob-format=0&knob-format (numeraljs)_General=0.[0]&knob-hasHistogramBarSeries=true&knob-histogram padding=0.05&knob-is numeric metric=true&knob-max trend data points=30&knob-nice=true&knob-number of columns=4&knob-number of series=1&knob-other series=line&knob-point series alignment=center&knob-progress bar direction=vertical&knob-progress max=100&knob-progress or trend=${type}&knob-stacked=true&knob-start=-113&knob-start_Domain=0&knob-start_General=0&knob-subtitle=Cluster CPU usage&knob-subtitle_General=Lorem laborum nostrud consectetur&knob-subtype=two-thirds-circle&knob-subtype_General=vertical&knob-sync cursor=true&knob-target=75&knob-target_Domain=75&knob-target_General=75&knob-theshold - rect={"y0":100,"y1":null}&knob-thesholds - line=200&knob-tick label padding=10&knob-tick strategy_Ticks=auto&knob-tickFormat=0[.]00&knob-ticks(approx. count)_Ticks=5&knob-ticks(placements)_Ticks=-,2,0,,,5,,,1,0,,,1,5,,,0,2,0,,,2,5,,,5,0,,,1,0,0,0,,,2,0,0,,,-,1,0,0,,&knob-title=21d7f8b7-92ea-41a0-8c03-0db0ec7e11b9&knob-title_General=Ea consequat voluptate&knob-trend a11y description=The trend shows a peak of CPU usage in the last 5 minutes&knob-trend a11y title=The Cluster CPU Usage trend&knob-trend data points=30&knob-trend shape=area&knob-use blending background=true&knob-use custom minInterval of 30s=true&knob-use multilayer time axis=true&knob-use progress bar=true&knob-value=55.23&knob-value color=#3c3c3c&knob-value prefix=&knob-value postfix= %&knob-use value color=&knob-show icon=&knob-show value icon=`, + ); + }); + eachTheme.describe( ({ urlParam }) => { const metricUrl = `http://localhost:9001/?path=/story/metric-alpha--basic&${urlParam}&knob-EUI icon glyph name=warning&knob-EUI value icon glyph name=sortUp&knob-color=rgba(157, 66, 66, 0.44)&knob-extra=last 5m&knob-is numeric metric=true&knob-progress bar direction=vertical&knob-progress max=100&knob-progress or trend=${type}&knob-subtitle=Cluster CPU usage&knob-title=21d7f8b7-92ea-41a0-8c03-0db0ec7e11b9&knob-trend a11y description=The trend shows a peak of CPU usage in the last 5 minutes&knob-trend a11y title=The Cluster CPU Usage trend&knob-trend data points=30&knob-trend shape=area&knob-value=55.23&knob-value color=#3c3c3c&knob-value prefix=&knob-value postfix= %&knob-use value color=&knob-show icon=&knob-show value icon=`; diff --git a/packages/charts/api/charts.api.md b/packages/charts/api/charts.api.md index 5d426febd9..5bd905f0d6 100644 --- a/packages/charts/api/charts.api.md +++ b/packages/charts/api/charts.api.md @@ -1828,6 +1828,7 @@ export const Metric: FC; export interface MetricStyle { // (undocumented) barBackground: Color; + blendingBackground?: Color; // (undocumented) border: Color; // (undocumented) diff --git a/packages/charts/src/chart_types/metric/renderer/dom/metric.tsx b/packages/charts/src/chart_types/metric/renderer/dom/metric.tsx index b3dfaae861..3ccedd9b3c 100644 --- a/packages/charts/src/chart_types/metric/renderer/dom/metric.tsx +++ b/packages/charts/src/chart_types/metric/renderer/dom/metric.tsx @@ -56,7 +56,7 @@ export const Metric: React.FunctionComponent<{ datum, panel, style, - backgroundColor, + backgroundColor: chartBackgroundColor, contrastOptions, locale, onElementClick, @@ -80,12 +80,21 @@ export const Metric: React.FunctionComponent<{ const lightnessAmount = mouseState === 'leave' ? 0 : mouseState === 'enter' ? 0.05 : 0.1; + const backgroundColor = datum.background + ? RGBATupleToString(combineColors(colorToRgba(datum.background), colorToRgba(chartBackgroundColor))) + : chartBackgroundColor; + const blendingBackgroundColor = !style.blendingBackground + ? colorToRgba(backgroundColor) + : combineColors(colorToRgba(style.blendingBackground), colorToRgba(backgroundColor)); const interactionColor = changeColorLightness(hasProgressBar ? backgroundColor : datum.color, lightnessAmount, 0.8); - const blendedBarColor = RGBATupleToString(combineColors(colorToRgba(datum.color), colorToRgba(backgroundColor))); + const blendedColor = RGBATupleToString(combineColors(colorToRgba(datum.color), blendingBackgroundColor)); + const blendedInteractionColor = RGBATupleToString( + combineColors(colorToRgba(interactionColor), blendingBackgroundColor), + ); const datumWithInteractionColor: MetricDatum = { ...datum, - color: interactionColor, + color: blendedInteractionColor, }; const event: MetricElementEvent = { type: 'metricElementEvent', rowIndex, columnIndex }; @@ -98,7 +107,7 @@ export const Metric: React.FunctionComponent<{ const highContrastTextColor = fillTextColor( backgroundColor, - isMetricWProgress(datum) ? backgroundColor : datum.color, + isMetricWProgress(datum) ? backgroundColor : blendedColor, undefined, contrastOptions, ); @@ -107,7 +116,7 @@ export const Metric: React.FunctionComponent<{ if (isMetricWTrend(datum)) { const { ratio, color, shade } = fillTextColor( backgroundColor, - getSparkLineColor(datum.color), + getSparkLineColor(blendedColor), undefined, contrastOptions, ); @@ -169,7 +178,7 @@ export const Metric: React.FunctionComponent<{ )}
diff --git a/packages/charts/src/chart_types/metric/renderer/dom/sparkline.tsx b/packages/charts/src/chart_types/metric/renderer/dom/sparkline.tsx index d83e17bb16..0fb581fb64 100644 --- a/packages/charts/src/chart_types/metric/renderer/dom/sparkline.tsx +++ b/packages/charts/src/chart_types/metric/renderer/dom/sparkline.tsx @@ -55,19 +55,6 @@ export const SparkLine: FunctionComponent<{ role="img" aria-labelledby={`${titleId} ${descriptionId}`} > - - - - - - - {trendA11yTitle} @@ -75,7 +62,8 @@ export const SparkLine: FunctionComponent<{ {trendA11yDescription} - + + ; diff --git a/packages/charts/src/common/fill_text_color.ts b/packages/charts/src/common/fill_text_color.ts index 68b2371264..f021a65a9b 100644 --- a/packages/charts/src/common/fill_text_color.ts +++ b/packages/charts/src/common/fill_text_color.ts @@ -40,7 +40,7 @@ export function fillTextColor( return highContrastColor(blendedFgBg, 'WCAG2', options); } - return highContrastColor(backgroundRGBA); + return highContrastColor(backgroundRGBA, 'WCAG2', options); } /** @internal */ diff --git a/packages/charts/src/utils/themes/theme.ts b/packages/charts/src/utils/themes/theme.ts index 71c6b37878..721d7e49df 100644 --- a/packages/charts/src/utils/themes/theme.ts +++ b/packages/charts/src/utils/themes/theme.ts @@ -328,6 +328,10 @@ export interface MetricStyle { border: Color; barBackground: Color; emptyBackground: Color; + /** + * Optional color used to blend transparent colors. Defaults to `Theme.background` + */ + blendingBackground?: Color; nonFiniteText: string; minHeight: Pixels; } diff --git a/storybook/stories/metric/1_basic.story.tsx b/storybook/stories/metric/1_basic.story.tsx index fca6f2f987..db25d0523e 100644 --- a/storybook/stories/metric/1_basic.story.tsx +++ b/storybook/stories/metric/1_basic.story.tsx @@ -68,6 +68,8 @@ export const Example: ChartsStory = (_, { title: storyTitle, description }) => { const iconType = text('EUI icon glyph name', 'warning'); const showValueIcon = boolean('show value icon', false); const valueIconType = text('EUI value icon glyph name', 'sortUp'); + const useBlendingBackground = boolean('use blending background', false); + const blendingBackground = color('blending background', 'rgba(255,255,255,1)'); const getIcon = (type: string) => ({ width, height, color }: { width: number; height: number; color: string }) => ( @@ -119,6 +121,11 @@ export const Example: ChartsStory = (_, { title: storyTitle, description }) => { return ( { if (isMetricElementEvent(d)) {