Change entity helper interface
This commit is contained in:
parent
e3ba6be486
commit
951351139e
@ -54,10 +54,9 @@ class Entities(Base):
|
||||
|
||||
class Entity:
|
||||
def __init__(self, hass, entity):
|
||||
self.entity = entity
|
||||
self.domain, self.name = entity.split('.')
|
||||
self.hass = hass
|
||||
self.hass.listen_state(self._listener, entity=entity, attributes='all')
|
||||
self._entity = entity
|
||||
self._hass = hass
|
||||
self._hass.listen_state(self._listener, entity=entity, attributes='all')
|
||||
self._listeners = []
|
||||
|
||||
|
||||
@ -73,27 +72,27 @@ class Entities(Base):
|
||||
|
||||
@property
|
||||
def state(self):
|
||||
return self.hass.get_state(self.entity)
|
||||
return self._hass.get_state(self._entity)
|
||||
@state.setter
|
||||
def state(self, state):
|
||||
self.hass.set_state(self.entity, state=state)
|
||||
self._hass.set_state(self._entity, state=state)
|
||||
|
||||
@property
|
||||
def attributes(self):
|
||||
return self.hass.get_state(self.entity, attribute='all')['attributes']
|
||||
|
||||
def __getitem__(self, key):
|
||||
if key == 'state':
|
||||
return self.state
|
||||
else:
|
||||
return self.attributes.get(key, None)
|
||||
def __setitem__(self, key, value):
|
||||
if key == 'state':
|
||||
self.state = value
|
||||
else:
|
||||
d = self.attributes
|
||||
d[key] = value
|
||||
self.hass.set_state(self.entity, attributes=d)
|
||||
def __getattr__(self, key):
|
||||
return self._hass.get_state(self._entity, attribute='all')['attributes'].get(key, None)
|
||||
def __setattr__(self, key, value):
|
||||
if key.startswith('_'):
|
||||
self.__dict__[key] = value
|
||||
return
|
||||
d = self._hass.get_state(self._entity, attribute='all')['attributes']
|
||||
d[key] = value
|
||||
self._hass.set_state(self._entity, attributes=d)
|
||||
def __delattr__(self, key):
|
||||
if key.startswith('_'):
|
||||
del self.__dict__[key]
|
||||
return
|
||||
d = self._hass.get_state(self._entity, attribute='all')['attributes']
|
||||
d[key] = ''
|
||||
self._hass.set_state(self._entity, attributes=d)
|
||||
|
||||
class LightEntity(Entities.Entity):
|
||||
def __init__(self, hass, entity):
|
||||
@ -105,9 +104,9 @@ class Entities(Base):
|
||||
@state.setter
|
||||
def state(self, state):
|
||||
if state == 'on':
|
||||
self.hass.call_service('light/turn_on', entity_id = self.entity)
|
||||
self._hass.call_service('light/turn_on', entity_id = self._entity)
|
||||
elif state == 'off':
|
||||
self.hass.call_service('light/turn_off', entity_id = self.entity)
|
||||
self._hass.call_service('light/turn_off', entity_id = self._entity)
|
||||
else:
|
||||
return
|
||||
super(Entities.LightEntity, self.__class__).state.fset(self, state)
|
||||
|
@ -10,16 +10,17 @@ class HelloWorld(base.Entities, base.Timers):
|
||||
|
||||
self.run_in('test1', self.after_time, 3)
|
||||
self.run_in('test2', self.after_time2, 5)
|
||||
self.run_in(self.after_time2, 7)
|
||||
self.cancel_timer('test2')
|
||||
# self.run_in(self.after_time2, 7)
|
||||
# self.cancel_timer('test2')
|
||||
|
||||
self.register_entity('taklampa', 'light.kontoret')
|
||||
|
||||
def after_time(self, kwargs):
|
||||
self.log("Running function")
|
||||
self.e['taklampa']['state'] = "off"
|
||||
self.log(f"State is {self.e['taklampa']['state']}")
|
||||
self.e['taklampa'].icon = "mdi:lamp"
|
||||
self.log(f"State is {self.e['taklampa'].state}")
|
||||
def after_time2(self, kwargs):
|
||||
self.log("Running function2")
|
||||
self.e['taklampa']['state'] = "on"
|
||||
self.log(f"State is {self.e['taklampa']['state']}")
|
||||
del self.e['taklampa'].icon
|
||||
|
||||
self.log(f"State is {self.e['taklampa'].state}")
|
||||
|
Loading…
x
Reference in New Issue
Block a user