Fix broken config switch in demo (#20971)
parent
e7f3393ec6
commit
3a855f95ad
|
@ -19,15 +19,15 @@ export const mockLovelace = (
|
|||
hass.mockWS("lovelace/resources", () => Promise.resolve([]));
|
||||
};
|
||||
|
||||
customElements.whenDefined("hui-view").then(() => {
|
||||
customElements.whenDefined("hui-card").then(() => {
|
||||
// eslint-disable-next-line
|
||||
const HUIView = customElements.get("hui-view");
|
||||
const HUIView = customElements.get("hui-card");
|
||||
// Patch HUI-VIEW to make the lovelace object available to the demo card
|
||||
const oldCreateCard = HUIView!.prototype.createCardElement;
|
||||
const oldCreateCard = HUIView!.prototype.createElement;
|
||||
|
||||
HUIView!.prototype.createCardElement = function (config) {
|
||||
HUIView!.prototype.createElement = function (config) {
|
||||
const el = oldCreateCard.call(this, config);
|
||||
if (el.tagName === "HA-DEMO-CARD") {
|
||||
if (config.type === "custom:ha-demo-card") {
|
||||
(el as HADemoCard).lovelace = this.lovelace;
|
||||
}
|
||||
return el;
|
||||
|
|
|
@ -59,14 +59,20 @@ export class HuiCard extends ReactiveElement {
|
|||
return configOptions;
|
||||
}
|
||||
|
||||
// Public to make demo happy
|
||||
public createElement(config: LovelaceCardConfig) {
|
||||
const element = createCardElement(config) as LovelaceCard;
|
||||
element.hass = this.hass;
|
||||
element.editMode = this.lovelace.editMode;
|
||||
return element;
|
||||
}
|
||||
|
||||
public setConfig(config: LovelaceCardConfig): void {
|
||||
if (this._config === config) {
|
||||
return;
|
||||
}
|
||||
this._config = config;
|
||||
this._element = createCardElement(config);
|
||||
this._element.hass = this.hass;
|
||||
this._element.editMode = this.lovelace.editMode;
|
||||
this._element = this.createElement(config);
|
||||
|
||||
while (this.lastChild) {
|
||||
this.removeChild(this.lastChild);
|
||||
|
|
|
@ -74,8 +74,7 @@ export class HUIView extends ReactiveElement {
|
|||
|
||||
private _viewConfigTheme?: string;
|
||||
|
||||
// Public to make demo happy
|
||||
public createCardElement(cardConfig: LovelaceCardConfig) {
|
||||
private _createCardElement(cardConfig: LovelaceCardConfig) {
|
||||
const element = document.createElement("hui-card");
|
||||
element.hass = this.hass;
|
||||
element.lovelace = this.lovelace;
|
||||
|
@ -371,7 +370,7 @@ export class HUIView extends ReactiveElement {
|
|||
}
|
||||
|
||||
this._cards = config.cards.map((cardConfig) => {
|
||||
const element = this.createCardElement(cardConfig);
|
||||
const element = this._createCardElement(cardConfig);
|
||||
return element;
|
||||
});
|
||||
}
|
||||
|
@ -393,7 +392,7 @@ export class HUIView extends ReactiveElement {
|
|||
cardElToReplace: HuiCard,
|
||||
config: LovelaceCardConfig
|
||||
): void {
|
||||
const newCardEl = this.createCardElement(config);
|
||||
const newCardEl = this._createCardElement(config);
|
||||
if (cardElToReplace.parentElement) {
|
||||
cardElToReplace.parentElement!.replaceChild(newCardEl, cardElToReplace);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue