mirror of
https://github.com/home-assistant/frontend.git
synced 2025-07-19 07:16:39 +00:00
Light hui & more-info card fixes (#7397)
This commit is contained in:
parent
37eb5af3d4
commit
2be08ce7ab
@ -14,8 +14,8 @@ class HaLabeledSlider extends PolymerElement {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.title {
|
.title {
|
||||||
margin-bottom: 16px;
|
margin-bottom: 8px;
|
||||||
color: var(--secondary-text-color);
|
color: var(--primary-text-color);
|
||||||
}
|
}
|
||||||
|
|
||||||
.slider-container {
|
.slider-container {
|
||||||
@ -43,7 +43,6 @@ class HaLabeledSlider extends PolymerElement {
|
|||||||
step="[[step]]"
|
step="[[step]]"
|
||||||
pin="[[pin]]"
|
pin="[[pin]]"
|
||||||
disabled="[[disabled]]"
|
disabled="[[disabled]]"
|
||||||
disabled="[[disabled]]"
|
|
||||||
value="{{value}}"
|
value="{{value}}"
|
||||||
></ha-slider>
|
></ha-slider>
|
||||||
</div>
|
</div>
|
||||||
|
@ -21,6 +21,7 @@ class HaSlider extends PaperSliderClass {
|
|||||||
.pin > .slider-knob > .slider-knob-inner {
|
.pin > .slider-knob > .slider-knob-inner {
|
||||||
font-size: var(--ha-slider-pin-font-size, 10px);
|
font-size: var(--ha-slider-pin-font-size, 10px);
|
||||||
line-height: normal;
|
line-height: normal;
|
||||||
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
.disabled.ring > .slider-knob > .slider-knob-inner {
|
.disabled.ring > .slider-knob > .slider-knob-inner {
|
||||||
@ -69,9 +70,9 @@ class HaSlider extends PaperSliderClass {
|
|||||||
transform: scale(1) translate(0, -10px);
|
transform: scale(1) translate(0, -10px);
|
||||||
}
|
}
|
||||||
|
|
||||||
.slider-input {
|
.slider-input {
|
||||||
width: 54px;
|
width: 54px;
|
||||||
}
|
}
|
||||||
`)
|
`)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -67,9 +67,10 @@ class MoreInfoLight extends LitElement {
|
|||||||
caption=${this.hass.localize("ui.card.light.brightness")}
|
caption=${this.hass.localize("ui.card.light.brightness")}
|
||||||
icon="hass:brightness-5"
|
icon="hass:brightness-5"
|
||||||
min="1"
|
min="1"
|
||||||
max="255"
|
max="100"
|
||||||
value=${this._brightnessSliderValue}
|
value=${this._brightnessSliderValue}
|
||||||
@change=${this._brightnessSliderChanged}
|
@change=${this._brightnessSliderChanged}
|
||||||
|
pin
|
||||||
></ha-labeled-slider>
|
></ha-labeled-slider>
|
||||||
`
|
`
|
||||||
: ""}
|
: ""}
|
||||||
@ -87,6 +88,7 @@ class MoreInfoLight extends LitElement {
|
|||||||
.max=${this.stateObj.attributes.max_mireds}
|
.max=${this.stateObj.attributes.max_mireds}
|
||||||
.value=${this._ctSliderValue}
|
.value=${this._ctSliderValue}
|
||||||
@change=${this._ctSliderChanged}
|
@change=${this._ctSliderChanged}
|
||||||
|
pin
|
||||||
></ha-labeled-slider>
|
></ha-labeled-slider>
|
||||||
`
|
`
|
||||||
: ""}
|
: ""}
|
||||||
@ -98,6 +100,7 @@ class MoreInfoLight extends LitElement {
|
|||||||
max="255"
|
max="255"
|
||||||
.value=${this._wvSliderValue}
|
.value=${this._wvSliderValue}
|
||||||
@change=${this._wvSliderChanged}
|
@change=${this._wvSliderChanged}
|
||||||
|
pin
|
||||||
></ha-labeled-slider>
|
></ha-labeled-slider>
|
||||||
`
|
`
|
||||||
: ""}
|
: ""}
|
||||||
@ -155,16 +158,22 @@ class MoreInfoLight extends LitElement {
|
|||||||
|
|
||||||
protected updated(changedProps: PropertyValues): void {
|
protected updated(changedProps: PropertyValues): void {
|
||||||
const stateObj = this.stateObj! as LightEntity;
|
const stateObj = this.stateObj! as LightEntity;
|
||||||
if (changedProps.has("stateObj") && stateObj.state === "on") {
|
if (changedProps.has("stateObj")) {
|
||||||
this._brightnessSliderValue = stateObj.attributes.brightness;
|
if (stateObj.state === "on") {
|
||||||
this._ctSliderValue = stateObj.attributes.color_temp;
|
this._brightnessSliderValue = Math.round(
|
||||||
this._wvSliderValue = stateObj.attributes.white_value;
|
(stateObj.attributes.brightness * 100) / 255
|
||||||
|
);
|
||||||
|
this._ctSliderValue = stateObj.attributes.color_temp;
|
||||||
|
this._wvSliderValue = stateObj.attributes.white_value;
|
||||||
|
|
||||||
if (stateObj.attributes.hs_color) {
|
if (stateObj.attributes.hs_color) {
|
||||||
this._colorPickerColor = {
|
this._colorPickerColor = {
|
||||||
h: stateObj.attributes.hs_color[0],
|
h: stateObj.attributes.hs_color[0],
|
||||||
s: stateObj.attributes.hs_color[1] / 100,
|
s: stateObj.attributes.hs_color[1] / 100,
|
||||||
};
|
};
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this._brightnessSliderValue = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -191,7 +200,7 @@ class MoreInfoLight extends LitElement {
|
|||||||
|
|
||||||
this.hass.callService("light", "turn_on", {
|
this.hass.callService("light", "turn_on", {
|
||||||
entity_id: this.stateObj!.entity_id,
|
entity_id: this.stateObj!.entity_id,
|
||||||
brightness: bri,
|
brightness_pct: bri,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -250,15 +259,10 @@ class MoreInfoLight extends LitElement {
|
|||||||
align-items: center;
|
align-items: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.content.is-on {
|
|
||||||
margin-top: -16px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.content > * {
|
.content > * {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
max-height: 84px;
|
max-height: 84px;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
padding-top: 16px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.color_temp {
|
.color_temp {
|
||||||
|
@ -99,7 +99,7 @@ export class HuiLightCard extends LitElement implements LovelaceCard {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const brightness =
|
const brightness =
|
||||||
Math.round((stateObj.attributes.brightness / 254) * 100) || 0;
|
Math.round((stateObj.attributes.brightness / 255) * 100) || 0;
|
||||||
|
|
||||||
return html`
|
return html`
|
||||||
<ha-card>
|
<ha-card>
|
||||||
@ -116,7 +116,8 @@ export class HuiLightCard extends LitElement implements LovelaceCard {
|
|||||||
<div id="controls">
|
<div id="controls">
|
||||||
<div id="slider">
|
<div id="slider">
|
||||||
<round-slider
|
<round-slider
|
||||||
min="0"
|
min="1"
|
||||||
|
max="100"
|
||||||
.value=${brightness}
|
.value=${brightness}
|
||||||
.disabled=${UNAVAILABLE_STATES.includes(stateObj.state)}
|
.disabled=${UNAVAILABLE_STATES.includes(stateObj.state)}
|
||||||
@value-changing=${this._dragEvent}
|
@value-changing=${this._dragEvent}
|
||||||
|
@ -61,6 +61,7 @@ export const derivedStyles = {
|
|||||||
"paper-slider-knob-color": "var(--slider-color)",
|
"paper-slider-knob-color": "var(--slider-color)",
|
||||||
"paper-slider-knob-start-color": "var(--slider-color)",
|
"paper-slider-knob-start-color": "var(--slider-color)",
|
||||||
"paper-slider-pin-color": "var(--slider-color)",
|
"paper-slider-pin-color": "var(--slider-color)",
|
||||||
|
"paper-slider-pin-start-color": "var(--slider-color)",
|
||||||
"paper-slider-active-color": "var(--slider-color)",
|
"paper-slider-active-color": "var(--slider-color)",
|
||||||
"paper-slider-secondary-color": "var(--slider-secondary-color)",
|
"paper-slider-secondary-color": "var(--slider-secondary-color)",
|
||||||
"paper-slider-container-color": "var(--slider-bar-color)",
|
"paper-slider-container-color": "var(--slider-bar-color)",
|
||||||
|
@ -46,7 +46,7 @@ class StateCardInputNumber extends mixinBehaviors(
|
|||||||
value="{{value}}"
|
value="{{value}}"
|
||||||
step="[[step]]"
|
step="[[step]]"
|
||||||
hidden="[[hiddenslider]]"
|
hidden="[[hiddenslider]]"
|
||||||
pin=""
|
pin
|
||||||
on-change="selectedValueChanged"
|
on-change="selectedValueChanged"
|
||||||
on-click="stopPropagation"
|
on-click="stopPropagation"
|
||||||
id="slider"
|
id="slider"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user