Skip to content

Commit

Permalink
fix: color with alpha would render area opaque
Browse files Browse the repository at this point in the history
  • Loading branch information
RomRider committed Feb 11, 2021
1 parent 917a20a commit 100b6d4
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 5 deletions.
6 changes: 5 additions & 1 deletion src/apexcharts-card.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import * as pjson from '../package.json';
import {
computeColor,
computeColors,
computeColorsWithAlpha,
computeName,
computeTextColor,
computeUom,
Expand Down Expand Up @@ -637,7 +638,10 @@ class ChartsCard extends LitElement {
}

private _computeChartColors(): (string | (({ value }) => string))[] {
const defaultColors: (string | (({ value }) => string))[] = computeColors(this._colors);
const defaultColors: (string | (({ value }) => string))[] = computeColorsWithAlpha(
this._colors,
this._config?.series_in_graph,
);
this._config?.series_in_graph.forEach((serie, index) => {
if (
this._config?.experimental?.color_threshold &&
Expand Down
19 changes: 15 additions & 4 deletions src/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -98,15 +98,26 @@ export function computeColors(colors: string[] | undefined): string[] {
});
}

export function computeColor(color: string): string {
export function computeColorsWithAlpha(
colors: string[] | undefined,
series: ChartCardSeriesExternalConfig[] | undefined,
): string[] {
if (!colors) return [];
return colors.map((color, index) => {
return computeColor(color, series?.[index]?.type !== 'area');
});
}

export function computeColor(color: string, withAlpha = true): string {
if (color[0] === '#') {
return color;
} else if (color.substring(0, 3) === 'var') {
return new TinyColor(
const wColor = new TinyColor(
window.getComputedStyle(document.documentElement).getPropertyValue(color.substring(4).slice(0, -1)).trim(),
).toHex8String();
);
return withAlpha ? wColor.toHex8String() : wColor.toHexString();
} else {
return new TinyColor(color).toHex8String();
return withAlpha ? new TinyColor(color).toHex8String() : new TinyColor(color).toHexString();
}
}

Expand Down

0 comments on commit 100b6d4

Please sign in to comment.