mirror of
https://github.com/home-assistant/frontend.git
synced 2025-07-21 08:16:36 +00:00
Use rgb theme variables for qrcode (#19726)
This commit is contained in:
parent
abb014745a
commit
b1e1b44c75
@ -2,6 +2,7 @@ import { LitElement, PropertyValues, css, html, nothing } from "lit";
|
|||||||
import { customElement, property, query, state } from "lit/decorators";
|
import { customElement, property, query, state } from "lit/decorators";
|
||||||
import QRCode from "qrcode";
|
import QRCode from "qrcode";
|
||||||
import "./ha-alert";
|
import "./ha-alert";
|
||||||
|
import { rgb2hex } from "../common/color/convert-color";
|
||||||
|
|
||||||
@customElement("ha-qr-code")
|
@customElement("ha-qr-code")
|
||||||
export class HaQrCode extends LitElement {
|
export class HaQrCode extends LitElement {
|
||||||
@ -65,6 +66,26 @@ export class HaQrCode extends LitElement {
|
|||||||
changedProperties.has("centerImage"))
|
changedProperties.has("centerImage"))
|
||||||
) {
|
) {
|
||||||
const computedStyles = getComputedStyle(this);
|
const computedStyles = getComputedStyle(this);
|
||||||
|
const textRgb = computedStyles.getPropertyValue(
|
||||||
|
"--rgb-primary-text-color"
|
||||||
|
);
|
||||||
|
const backgroundRgb = computedStyles.getPropertyValue(
|
||||||
|
"--rgb-card-background-color"
|
||||||
|
);
|
||||||
|
const textHex = rgb2hex(
|
||||||
|
textRgb.split(",").map((a) => parseInt(a, 10)) as [
|
||||||
|
number,
|
||||||
|
number,
|
||||||
|
number,
|
||||||
|
]
|
||||||
|
);
|
||||||
|
const backgroundHex = rgb2hex(
|
||||||
|
backgroundRgb.split(",").map((a) => parseInt(a, 10)) as [
|
||||||
|
number,
|
||||||
|
number,
|
||||||
|
number,
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
QRCode.toCanvas(canvas, this.data, {
|
QRCode.toCanvas(canvas, this.data, {
|
||||||
errorCorrectionLevel:
|
errorCorrectionLevel:
|
||||||
@ -74,8 +95,8 @@ export class HaQrCode extends LitElement {
|
|||||||
margin: this.margin,
|
margin: this.margin,
|
||||||
maskPattern: this.maskPattern,
|
maskPattern: this.maskPattern,
|
||||||
color: {
|
color: {
|
||||||
light: computedStyles.getPropertyValue("--card-background-color"),
|
light: backgroundHex,
|
||||||
dark: computedStyles.getPropertyValue("--primary-text-color"),
|
dark: textHex,
|
||||||
},
|
},
|
||||||
}).catch((err) => {
|
}).catch((err) => {
|
||||||
this._error = err.message;
|
this._error = err.message;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user