Room glance card fixed
- one cannot use hui- cards from home assistant in custom components reliably - cards are loaded on demand -> replaced hui-image with a normal img tag
This commit is contained in:
parent
6b8d149993
commit
44835e0fa2
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
|
@ -11,11 +11,11 @@
|
||||||
"author": "Martin Bauer",
|
"author": "Martin Bauer",
|
||||||
"license": "GPLv3",
|
"license": "GPLv3",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"home-assistant-js-websocket": "^4.2.2",
|
"home-assistant-js-websocket": "^4.5.0",
|
||||||
"lit-element": "^2.1.0",
|
"lit-element": "^2.3.1",
|
||||||
"ts-loader": "^6.0.2",
|
"ts-loader": "^6.2.2",
|
||||||
"typescript": "^3.5.1",
|
"typescript": "^3.8.3",
|
||||||
"webpack": "^4.33.0",
|
"webpack": "^4.42.1",
|
||||||
"webpack-cli": "^3.3.4"
|
"webpack-cli": "^3.3.11"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import {LitElement, html, css, customElement, property, TemplateResult, CSSResult} from "lit-element";
|
import {LitElement, html, css, customElement, property, TemplateResult, CSSResult} from "lit-element";
|
||||||
import {classMap} from "lit-html/directives/class-map";
|
import {classMap} from "lit-html/directives/class-map";
|
||||||
|
import {styleMap} from "lit-html/directives/style-map";
|
||||||
import {HomeAssistant} from "./home-assistant-interface";
|
import {HomeAssistant} from "./home-assistant-interface";
|
||||||
|
|
||||||
|
|
||||||
|
@ -26,19 +26,11 @@ export class RoomGlanceCard extends LitElement {
|
||||||
|
|
||||||
|
|
||||||
protected render(): TemplateResult | void {
|
protected render(): TemplateResult | void {
|
||||||
|
const ratio = {'w': 16, 'h': 9};
|
||||||
return html`
|
return html`
|
||||||
<ha-card>
|
<ha-card>
|
||||||
<hui-image
|
<img style="width: 100%; display: block" src="${this._config.image}">
|
||||||
class="${classMap({
|
|
||||||
clickable: true,
|
|
||||||
})}"
|
|
||||||
@ha-click="${this._handleTap}"
|
|
||||||
@ha-hold="${this._handleHold}"
|
|
||||||
.hass="${this.hass}"
|
|
||||||
image="${this._config.image}"
|
|
||||||
aspectRatio="${this._config.aspect_ratio}"
|
|
||||||
></hui-image>
|
|
||||||
|
|
||||||
<div class="box box-upper">
|
<div class="box box-upper">
|
||||||
<div>${this._config.name}</div>
|
<div>${this._config.name}</div>
|
||||||
<div>
|
<div>
|
||||||
|
@ -49,7 +41,7 @@ export class RoomGlanceCard extends LitElement {
|
||||||
<div class="box box-lower">
|
<div class="box box-lower">
|
||||||
<div class="title"></div>
|
<div class="title"></div>
|
||||||
<div>
|
<div>
|
||||||
${this._config.scenes.map( (sceneButtonCfg) => this.renderSceneButton(sceneButtonCfg))}
|
${this._config.scenes.map((sceneButtonCfg) => this.renderSceneButton(sceneButtonCfg))}
|
||||||
|
|
||||||
<paper-icon-button
|
<paper-icon-button
|
||||||
icon="mdi:close-circle"
|
icon="mdi:close-circle"
|
||||||
|
@ -66,12 +58,8 @@ export class RoomGlanceCard extends LitElement {
|
||||||
title="Dunkler"
|
title="Dunkler"
|
||||||
@click=${this.serviceHandler("dimmer", "dim", {offset: -30})}
|
@click=${this.serviceHandler("dimmer", "dim", {offset: -30})}
|
||||||
></paper-icon-button>
|
></paper-icon-button>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</ha-card>
|
</ha-card>
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
@ -108,16 +96,15 @@ export class RoomGlanceCard extends LitElement {
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
|
||||||
private serviceHandler(domain: string, service: string, serviceData: { [key: string]: any } = {})
|
private serviceHandler(domain: string, service: string, serviceData: { [key: string]: any } = {}) {
|
||||||
{
|
|
||||||
const thisObj = this;
|
const thisObj = this;
|
||||||
return function(ev) {
|
return function (ev) {
|
||||||
ev.stopPropagation();
|
ev.stopPropagation();
|
||||||
thisObj.callServiceForAllEntities(domain, service, serviceData);
|
thisObj.callServiceForAllEntities(domain, service, serviceData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private callServiceForAllEntities(domain: string, service:string, serviceData: { [key: string]: any } = {}) {
|
private callServiceForAllEntities(domain: string, service: string, serviceData: { [key: string]: any } = {}) {
|
||||||
|
|
||||||
if (!serviceData.hasOwnProperty('entity_id')) {
|
if (!serviceData.hasOwnProperty('entity_id')) {
|
||||||
for (let entity_id of this._config!.entities) {
|
for (let entity_id of this._config!.entities) {
|
||||||
|
@ -148,7 +135,7 @@ export class RoomGlanceCard extends LitElement {
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
hui-image.clickable {
|
my-image.clickable {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,7 +149,8 @@ export class RoomGlanceCard extends LitElement {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
left: 0;
|
left: 0;
|
||||||
right: 0;
|
right: 0;
|
||||||
|
bottom: 0;
|
||||||
|
|
||||||
padding-left: 8px;
|
padding-left: 8px;
|
||||||
padding-right: 8px;
|
padding-right: 8px;
|
||||||
|
|
||||||
|
@ -170,6 +158,7 @@ export class RoomGlanceCard extends LitElement {
|
||||||
line-height: 40px;
|
line-height: 40px;
|
||||||
color: white;
|
color: white;
|
||||||
display: flex;
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
background-color: rgba(0, 0, 0, 0.3);
|
background-color: rgba(0, 0, 0, 0.3);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue