Move ESPHome Source Files (#20092)
* Move ESPHome source files * Update .coveragerc * Update CODEOWNERS
This commit is contained in:
parent
e505a9b7b4
commit
f225570980
8 changed files with 6 additions and 2 deletions
63
homeassistant/components/esphome/binary_sensor.py
Normal file
63
homeassistant/components/esphome/binary_sensor.py
Normal file
|
@ -0,0 +1,63 @@
|
|||
"""Support for ESPHome binary sensors."""
|
||||
import logging
|
||||
|
||||
from typing import TYPE_CHECKING, Optional
|
||||
|
||||
from homeassistant.components.binary_sensor import BinarySensorDevice
|
||||
from homeassistant.components.esphome import EsphomeEntity, \
|
||||
platform_async_setup_entry
|
||||
|
||||
if TYPE_CHECKING:
|
||||
# pylint: disable=unused-import
|
||||
from aioesphomeapi import BinarySensorInfo, BinarySensorState # noqa
|
||||
|
||||
DEPENDENCIES = ['esphome']
|
||||
_LOGGER = logging.getLogger(__name__)
|
||||
|
||||
|
||||
async def async_setup_entry(hass, entry, async_add_entities):
|
||||
"""Set up ESPHome binary sensors based on a config entry."""
|
||||
# pylint: disable=redefined-outer-name
|
||||
from aioesphomeapi import BinarySensorInfo, BinarySensorState # noqa
|
||||
|
||||
await platform_async_setup_entry(
|
||||
hass, entry, async_add_entities,
|
||||
component_key='binary_sensor',
|
||||
info_type=BinarySensorInfo, entity_type=EsphomeBinarySensor,
|
||||
state_type=BinarySensorState
|
||||
)
|
||||
|
||||
|
||||
class EsphomeBinarySensor(EsphomeEntity, BinarySensorDevice):
|
||||
"""A binary sensor implementation for ESPHome."""
|
||||
|
||||
@property
|
||||
def _static_info(self) -> 'BinarySensorInfo':
|
||||
return super()._static_info
|
||||
|
||||
@property
|
||||
def _state(self) -> Optional['BinarySensorState']:
|
||||
return super()._state
|
||||
|
||||
@property
|
||||
def is_on(self):
|
||||
"""Return true if the binary sensor is on."""
|
||||
if self._static_info.is_status_binary_sensor:
|
||||
# Status binary sensors indicated connected state.
|
||||
# So in their case what's usually _availability_ is now state
|
||||
return self._entry_data.available
|
||||
if self._state is None:
|
||||
return None
|
||||
return self._state.state
|
||||
|
||||
@property
|
||||
def device_class(self):
|
||||
"""Return the class of this device, from component DEVICE_CLASSES."""
|
||||
return self._static_info.device_class
|
||||
|
||||
@property
|
||||
def available(self):
|
||||
"""Return True if entity is available."""
|
||||
if self._static_info.is_status_binary_sensor:
|
||||
return True
|
||||
return super().available
|
Loading…
Add table
Add a link
Reference in a new issue