mirror of
https://github.com/home-assistant/core.git
synced 2025-07-19 03:07:37 +00:00
Improved state card
This commit is contained in:
parent
552f78fc5c
commit
2a15e239c3
@ -10,15 +10,16 @@
|
|||||||
:host {
|
:host {
|
||||||
position: relative;
|
position: relative;
|
||||||
background-color: white;
|
background-color: white;
|
||||||
padding: 20px 20px 50px 20px;
|
padding: 20px 20px 55px 20px;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
font-weight: 300;
|
|
||||||
border-radius: 2px;
|
border-radius: 2px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.header {
|
.header {
|
||||||
text-transform: capitalize;
|
text-transform: capitalize;
|
||||||
|
|
||||||
|
font-weight: 300;
|
||||||
|
|
||||||
font-size: 1.5rem;
|
font-size: 1.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -27,8 +28,22 @@
|
|||||||
color: darkgrey;
|
color: darkgrey;
|
||||||
}
|
}
|
||||||
|
|
||||||
.content {
|
.state-attributes {
|
||||||
margin-top: 10px;
|
margin-top: 10px;
|
||||||
|
font-size: 1rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.state-attributes .key {
|
||||||
|
white-space: nowrap;
|
||||||
|
width: 85px;
|
||||||
|
float: left;
|
||||||
|
clear: left;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
}
|
||||||
|
|
||||||
|
.state-attributes .value {
|
||||||
|
margin-left: 95px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.actions {
|
.actions {
|
||||||
@ -47,7 +62,10 @@
|
|||||||
</style>
|
</style>
|
||||||
|
|
||||||
<div class="header" horizontal justified layout>
|
<div class="header" horizontal justified layout>
|
||||||
<span class="entity_id">{{entity_id | makeReadable}}</span>
|
<span class="entity_id">
|
||||||
|
<template if="{{state_attr['friendly_name']}}">{{state_attr['friendly_name']}}</template>
|
||||||
|
<template if="{{!state_attr['friendly_name']}}">{{entity_id | makeReadable}}</template>
|
||||||
|
</span>
|
||||||
<span class='state'>{{state | makeReadable}}</span>
|
<span class='state'>{{state | makeReadable}}</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -59,9 +77,12 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<div class="content">
|
<div class="state-attributes">
|
||||||
<template repeat="{{key in objectKeys(state_attr)}}">
|
<template repeat="{{key in objectKeys(state_attr)}}">
|
||||||
<div>{{key | makeReadable}}: {{state_attr[key]}}</div>
|
<template if="{{key != 'friendly_name'}}">
|
||||||
|
<div class='key'>{{key | makeReadable}}</div>
|
||||||
|
<div class='value'>{{state_attr[key] | makeReadable}}</div>
|
||||||
|
</template>
|
||||||
</template>
|
</template>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -128,7 +149,15 @@
|
|||||||
|
|
||||||
// used as filter
|
// used as filter
|
||||||
makeReadable: function(value) {
|
makeReadable: function(value) {
|
||||||
return value.replace("_", " ")
|
if(typeof value == "string") {
|
||||||
|
return value.replace(/_/g, " ");
|
||||||
|
|
||||||
|
} else if(Array.isArray(value)) {
|
||||||
|
return value.join(", ");
|
||||||
|
|
||||||
|
} else {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
objectKeys: function(obj) {
|
objectKeys: function(obj) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user