Skip to content

Commit

Permalink
Improve version sensor (#18292)
Browse files Browse the repository at this point in the history
* Validate value against valid list

* Show correct name

Constants in alphabetical order.
Added default name when not showing the local/current version.

* Add icon

Icon was already defined but not set

* Unnecessary "elif" after "return" (no-else-return)
  • Loading branch information
tjorim authored and Danielhiversen committed Nov 7, 2018
1 parent ec732c8 commit 29be78e
Showing 1 changed file with 25 additions and 8 deletions.
33 changes: 25 additions & 8 deletions homeassistant/components/sensor/version.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,21 @@

_LOGGER = logging.getLogger(__name__)

ALL_IMAGES = [
'default', 'intel-nuc', 'qemux86', 'qemux86-64', 'qemuarm',
'qemuarm-64', 'raspberrypi', 'raspberrypi2', 'raspberrypi3',
'raspberrypi3-64', 'tinker', 'odroid-c2', 'odroid-xu'
]
ALL_SOURCES = [
'local', 'pypi', 'hassio', 'docker'
]

CONF_BETA = 'beta'
CONF_IMAGE = 'image'

DEFAULT_IMAGE = 'default'
DEFAULT_NAME = "Current Version"
DEFAULT_NAME_LATEST = "Latest Version"
DEFAULT_NAME_LOCAL = "Current Version"
DEFAULT_SOURCE = 'local'

ICON = 'mdi:package-up'
Expand All @@ -33,11 +43,9 @@

PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
vol.Optional(CONF_BETA, default=False): cv.boolean,
vol.Optional(CONF_IMAGE, default=DEFAULT_IMAGE): vol.All(cv.string,
vol.Lower),
vol.Optional(CONF_NAME, default=DEFAULT_NAME): cv.string,
vol.Optional(CONF_SOURCE, default=DEFAULT_SOURCE): vol.All(cv.string,
vol.Lower),
vol.Optional(CONF_IMAGE, default=DEFAULT_IMAGE): vol.In(ALL_IMAGES),
vol.Optional(CONF_NAME, default=''): cv.string,
vol.Optional(CONF_SOURCE, default=DEFAULT_SOURCE): vol.In(ALL_SOURCES),
})


Expand All @@ -63,7 +71,7 @@ async def async_setup_platform(
class VersionSensor(Entity):
"""Representation of a Home Assistant version sensor."""

def __init__(self, haversion, name):
def __init__(self, haversion, name=''):
"""Initialize the Version sensor."""
self.haversion = haversion
self._name = name
Expand All @@ -76,7 +84,11 @@ async def async_update(self):
@property
def name(self):
"""Return the name of the sensor."""
return self._name
if self._name:
return self._name
if self.haversion.source == DEFAULT_SOURCE:
return DEFAULT_NAME_LOCAL
return DEFAULT_NAME_LATEST

@property
def state(self):
Expand All @@ -88,6 +100,11 @@ def device_state_attributes(self):
"""Return attributes for the sensor."""
return self.haversion.api.version_data

@property
def icon(self):
"""Return the icon to use in the frontend, if any."""
return ICON


class VersionData:
"""Get the latest data and update the states."""
Expand Down

0 comments on commit 29be78e

Please sign in to comment.