diff --git a/packages/v3/src/css/esp-entity-table.ts b/packages/v3/src/css/esp-entity-table.ts index 82a93a6..0fc3fbb 100644 --- a/packages/v3/src/css/esp-entity-table.ts +++ b/packages/v3/src/css/esp-entity-table.ts @@ -76,4 +76,14 @@ export default css` input[type="color"]::-webkit-color-swatch-wrapper { padding: 0 !important; } + + .climate { + width: 100%; + display: grid; + text-align: center; + grid-template-columns: repeat(3, 1fr); + gap: 6px; + padding: 10px; + align-items: center; + } `; diff --git a/packages/v3/src/esp-entity-table.ts b/packages/v3/src/esp-entity-table.ts index 3b31e5b..fd94157 100644 --- a/packages/v3/src/esp-entity-table.ts +++ b/packages/v3/src/esp-entity-table.ts @@ -39,6 +39,8 @@ interface entityConfig { current_temperature?: number; modes?: number[]; mode?: number; + presets?: number[]; + preset?: number; speed_count?: number; speed_level?: number; speed: string; @@ -92,8 +94,12 @@ export class EntityTable extends LitElement implements RestAction { unique_id: data.id, id: parts.slice(1).join("-"), entity_category: data.entity_category, - value_numeric_history: [data.value], } as entityConfig; + if (typeof data.value === "number") { + entity.value_numeric_history = [data.value]; + } else if (data.current_temperature) { + entity.value_numeric_history = [Number(data.current_temperature)]; + } entity.has_action = this.hasAction(entity); if (entity.has_action) { this.has_controls = true; @@ -112,11 +118,13 @@ export class EntityTable extends LitElement implements RestAction { }); this.requestUpdate(); } else { + let history = [...this.entities[idx].value_numeric_history]; if (typeof data.value === "number") { - let history = [...this.entities[idx].value_numeric_history]; history.push(data.value); - this.entities[idx].value_numeric_history = history.splice(-50); + } else if (data.current_temperature) { + history.push(Number(data.current_temperature)); } + this.entities[idx].value_numeric_history = history.splice(-50); delete data.id; delete data.domain; @@ -217,7 +225,8 @@ export class EntityTable extends LitElement implements RestAction { ? this.control(component) : html`
${component.state}
`} - ${component.domain === "sensor" + ${component.domain === "sensor" || + component.domain === "climate" ? html`` @@ -238,7 +247,10 @@ export class EntityTable extends LitElement implements RestAction { } _handleEntityRowClick(e: any) { - if (e?.currentTarget?.domain === "sensor") { + if ( + e?.currentTarget?.domain === "sensor" || + e?.currentTarget?.domain === "climate" + ) { if (!e?.ctrlKey) e.stopPropagation(); e?.currentTarget?.classList.toggle( "expanded", @@ -285,25 +297,71 @@ class ActionRenderer { `; } + private _tempSelector(entity: entityConfig, target: string) { + if (!entity) return; + let targetTemp = + target === "high" + ? entity.target_temperature_high + : entity.target_temperature || entity.target_temperature_low; + let upValue = + target === "high" + ? Number(entity.target_temperature_high) + Number(entity.step) + : Number(entity.target_temperature || entity.target_temperature_low) + + Number(entity.step); + let downValue = + target === "high" + ? Number(entity.target_temperature_high) - Number(entity.step) + : Number(entity.target_temperature || entity.target_temperature_low) - + Number(entity.step); + upValue = + upValue > Number(entity.max_temp) ? Number(entity.max_temp) : upValue; + downValue = + downValue > Number(entity.max_temp) ? Number(entity.max_temp) : downValue; + + let upAction = target + ? `set?target_temperature_${target}=${upValue}` + : `set?target_temperature=${upValue}`; + let downAction = target + ? `set?target_temperature_${target}=${downValue}` + : `set?target_temperature=${downValue}`; + + return html`
+
+ `; + } + private _datetime( entity: entityConfig, type: string, action: string, opt: string, - value: string, + value: string ) { return html` - `; @@ -328,7 +386,11 @@ class ActionRenderer { val: string | number | undefined ) { return html` - `; + `; } else { - return html` - e.target)?.value; + this.actioner?.restAction( + entity, + `${action}?${opt}=${e.detail.state}` + ); + }}" >`; } - } private _textinput( @@ -612,57 +675,50 @@ class ActionRenderer { target_temp_label = html`${this.entity .target_temperature_low} .. ${this.entity .target_temperature_high}`; - target_temp_slider = html` - ${this._range( - this.entity, - "set", - "target_temperature_low", - this.entity.target_temperature_low, - this.entity.min_temp, - this.entity.max_temp, - this.entity.step - )} - ${this._range( - this.entity, - "set", - "target_temperature_high", - this.entity.target_temperature_high, - this.entity.min_temp, - this.entity.max_temp, - this.entity.step - )} - `; } else { target_temp_label = html`${this.entity.target_temperature}`; - target_temp_slider = html` - ${this._range( - this.entity, - "set", - "target_temperature", - this.entity.target_temperature!!, - this.entity.min_temp, - this.entity.max_temp, - this.entity.step - )} - `; } let modes = html``; if ((this.entity.modes ? this.entity.modes.length : 0) > 0) { - modes = html`Mode:
- ${this._select( - this.entity, - "set", - "mode", - this.entity.modes || [], - this.entity.mode || "" - )}`; + modes = html` ${this._select( + this.entity, + "set", + "mode", + this.entity.modes || [], + this.entity.mode || "" + )}`; + } + let presets = html``; + if ((this.entity.presets ? this.entity.presets.length : 0) > 0) { + presets = html` ${this._select( + this.entity, + "set", + "preset", + this.entity.presets || [], + this.entity.preset || "" + )}`; } + return html` - - ${target_temp_slider} ${modes} +
+
+ ${this._tempSelector( + this.entity, + this.entity.target_temperature_low ? "low" : "" + )} +
+
+ +
+
+ ${this.entity.target_temperature_high + ? this._tempSelector(this.entity, "high") + : ""} +
+
${modes}
+
${this.entity.state}
+
${presets}
+
`; } }