mirror of
https://github.com/home-assistant/core.git
synced 2025-07-28 15:47:12 +00:00
Add pending damage and pending quest items sensors (#145449)
Add pending damage and quest items sensors
This commit is contained in:
parent
a15572bb8c
commit
2f318927bc
@ -159,6 +159,12 @@
|
|||||||
},
|
},
|
||||||
"quest_scrolls": {
|
"quest_scrolls": {
|
||||||
"default": "mdi:script-text-outline"
|
"default": "mdi:script-text-outline"
|
||||||
|
},
|
||||||
|
"pending_damage": {
|
||||||
|
"default": "mdi:sword"
|
||||||
|
},
|
||||||
|
"pending_quest_items": {
|
||||||
|
"default": "mdi:sack"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"switch": {
|
"switch": {
|
||||||
|
@ -40,7 +40,13 @@ from homeassistant.util import dt as dt_util
|
|||||||
from .const import ASSETS_URL, DOMAIN
|
from .const import ASSETS_URL, DOMAIN
|
||||||
from .coordinator import HabiticaConfigEntry, HabiticaDataUpdateCoordinator
|
from .coordinator import HabiticaConfigEntry, HabiticaDataUpdateCoordinator
|
||||||
from .entity import HabiticaBase
|
from .entity import HabiticaBase
|
||||||
from .util import get_attribute_points, get_attributes_total, inventory_list
|
from .util import (
|
||||||
|
get_attribute_points,
|
||||||
|
get_attributes_total,
|
||||||
|
inventory_list,
|
||||||
|
pending_damage,
|
||||||
|
pending_quest_items,
|
||||||
|
)
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -99,6 +105,8 @@ class HabiticaSensorEntity(StrEnum):
|
|||||||
FOOD_TOTAL = "food_total"
|
FOOD_TOTAL = "food_total"
|
||||||
SADDLE = "saddle"
|
SADDLE = "saddle"
|
||||||
QUEST_SCROLLS = "quest_scrolls"
|
QUEST_SCROLLS = "quest_scrolls"
|
||||||
|
PENDING_DAMAGE = "pending_damage"
|
||||||
|
PENDING_QUEST_ITEMS = "pending_quest_items"
|
||||||
|
|
||||||
|
|
||||||
SENSOR_DESCRIPTIONS: tuple[HabiticaSensorEntityDescription, ...] = (
|
SENSOR_DESCRIPTIONS: tuple[HabiticaSensorEntityDescription, ...] = (
|
||||||
@ -263,6 +271,18 @@ SENSOR_DESCRIPTIONS: tuple[HabiticaSensorEntityDescription, ...] = (
|
|||||||
entity_picture="inventory_quest_scroll_dustbunnies.png",
|
entity_picture="inventory_quest_scroll_dustbunnies.png",
|
||||||
attributes_fn=lambda user, content: inventory_list(user, content, "quests"),
|
attributes_fn=lambda user, content: inventory_list(user, content, "quests"),
|
||||||
),
|
),
|
||||||
|
HabiticaSensorEntityDescription(
|
||||||
|
key=HabiticaSensorEntity.PENDING_DAMAGE,
|
||||||
|
translation_key=HabiticaSensorEntity.PENDING_DAMAGE,
|
||||||
|
value_fn=pending_damage,
|
||||||
|
suggested_display_precision=1,
|
||||||
|
entity_picture=ha.DAMAGE,
|
||||||
|
),
|
||||||
|
HabiticaSensorEntityDescription(
|
||||||
|
key=HabiticaSensorEntity.PENDING_QUEST_ITEMS,
|
||||||
|
translation_key=HabiticaSensorEntity.PENDING_QUEST_ITEMS,
|
||||||
|
value_fn=pending_quest_items,
|
||||||
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -426,6 +426,14 @@
|
|||||||
"quest_scrolls": {
|
"quest_scrolls": {
|
||||||
"name": "Quest scrolls",
|
"name": "Quest scrolls",
|
||||||
"unit_of_measurement": "scrolls"
|
"unit_of_measurement": "scrolls"
|
||||||
|
},
|
||||||
|
"pending_damage": {
|
||||||
|
"name": "Pending damage",
|
||||||
|
"unit_of_measurement": "damage"
|
||||||
|
},
|
||||||
|
"pending_quest_items": {
|
||||||
|
"name": "Pending quest items",
|
||||||
|
"unit_of_measurement": "items"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"switch": {
|
"switch": {
|
||||||
|
@ -162,3 +162,25 @@ def inventory_list(
|
|||||||
for k, v in getattr(user.items, item_type, {}).items()
|
for k, v in getattr(user.items, item_type, {}).items()
|
||||||
if k != "Saddle"
|
if k != "Saddle"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def pending_quest_items(user: UserData, content: ContentData) -> int | None:
|
||||||
|
"""Pending quest items."""
|
||||||
|
|
||||||
|
return (
|
||||||
|
user.party.quest.progress.collectedItems
|
||||||
|
if user.party.quest.key
|
||||||
|
and content.quests[user.party.quest.key].collect is not None
|
||||||
|
else None
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def pending_damage(user: UserData, content: ContentData) -> float | None:
|
||||||
|
"""Pending damage."""
|
||||||
|
|
||||||
|
return (
|
||||||
|
user.party.quest.progress.up
|
||||||
|
if user.party.quest.key
|
||||||
|
and content.quests[user.party.quest.key].boss is not None
|
||||||
|
else None
|
||||||
|
)
|
||||||
|
@ -1038,6 +1038,106 @@
|
|||||||
'state': '880',
|
'state': '880',
|
||||||
})
|
})
|
||||||
# ---
|
# ---
|
||||||
|
# name: test_sensors[sensor.test_user_pending_damage-entry]
|
||||||
|
EntityRegistryEntrySnapshot({
|
||||||
|
'aliases': set({
|
||||||
|
}),
|
||||||
|
'area_id': None,
|
||||||
|
'capabilities': None,
|
||||||
|
'config_entry_id': <ANY>,
|
||||||
|
'config_subentry_id': <ANY>,
|
||||||
|
'device_class': None,
|
||||||
|
'device_id': <ANY>,
|
||||||
|
'disabled_by': None,
|
||||||
|
'domain': 'sensor',
|
||||||
|
'entity_category': None,
|
||||||
|
'entity_id': 'sensor.test_user_pending_damage',
|
||||||
|
'has_entity_name': True,
|
||||||
|
'hidden_by': None,
|
||||||
|
'icon': None,
|
||||||
|
'id': <ANY>,
|
||||||
|
'labels': set({
|
||||||
|
}),
|
||||||
|
'name': None,
|
||||||
|
'options': dict({
|
||||||
|
'sensor': dict({
|
||||||
|
'suggested_display_precision': 1,
|
||||||
|
}),
|
||||||
|
}),
|
||||||
|
'original_device_class': None,
|
||||||
|
'original_icon': None,
|
||||||
|
'original_name': 'Pending damage',
|
||||||
|
'platform': 'habitica',
|
||||||
|
'previous_unique_id': None,
|
||||||
|
'supported_features': 0,
|
||||||
|
'translation_key': <HabiticaSensorEntity.PENDING_DAMAGE: 'pending_damage'>,
|
||||||
|
'unique_id': 'a380546a-94be-4b8e-8a0b-23e0d5c03303_pending_damage',
|
||||||
|
'unit_of_measurement': 'damage',
|
||||||
|
})
|
||||||
|
# ---
|
||||||
|
# name: test_sensors[sensor.test_user_pending_damage-state]
|
||||||
|
StateSnapshot({
|
||||||
|
'attributes': ReadOnlyDict({
|
||||||
|
'entity_picture': '',
|
||||||
|
'friendly_name': 'test-user Pending damage',
|
||||||
|
'unit_of_measurement': 'damage',
|
||||||
|
}),
|
||||||
|
'context': <ANY>,
|
||||||
|
'entity_id': 'sensor.test_user_pending_damage',
|
||||||
|
'last_changed': <ANY>,
|
||||||
|
'last_reported': <ANY>,
|
||||||
|
'last_updated': <ANY>,
|
||||||
|
'state': 'unknown',
|
||||||
|
})
|
||||||
|
# ---
|
||||||
|
# name: test_sensors[sensor.test_user_pending_quest_items-entry]
|
||||||
|
EntityRegistryEntrySnapshot({
|
||||||
|
'aliases': set({
|
||||||
|
}),
|
||||||
|
'area_id': None,
|
||||||
|
'capabilities': None,
|
||||||
|
'config_entry_id': <ANY>,
|
||||||
|
'config_subentry_id': <ANY>,
|
||||||
|
'device_class': None,
|
||||||
|
'device_id': <ANY>,
|
||||||
|
'disabled_by': None,
|
||||||
|
'domain': 'sensor',
|
||||||
|
'entity_category': None,
|
||||||
|
'entity_id': 'sensor.test_user_pending_quest_items',
|
||||||
|
'has_entity_name': True,
|
||||||
|
'hidden_by': None,
|
||||||
|
'icon': None,
|
||||||
|
'id': <ANY>,
|
||||||
|
'labels': set({
|
||||||
|
}),
|
||||||
|
'name': None,
|
||||||
|
'options': dict({
|
||||||
|
}),
|
||||||
|
'original_device_class': None,
|
||||||
|
'original_icon': None,
|
||||||
|
'original_name': 'Pending quest items',
|
||||||
|
'platform': 'habitica',
|
||||||
|
'previous_unique_id': None,
|
||||||
|
'supported_features': 0,
|
||||||
|
'translation_key': <HabiticaSensorEntity.PENDING_QUEST_ITEMS: 'pending_quest_items'>,
|
||||||
|
'unique_id': 'a380546a-94be-4b8e-8a0b-23e0d5c03303_pending_quest_items',
|
||||||
|
'unit_of_measurement': 'items',
|
||||||
|
})
|
||||||
|
# ---
|
||||||
|
# name: test_sensors[sensor.test_user_pending_quest_items-state]
|
||||||
|
StateSnapshot({
|
||||||
|
'attributes': ReadOnlyDict({
|
||||||
|
'friendly_name': 'test-user Pending quest items',
|
||||||
|
'unit_of_measurement': 'items',
|
||||||
|
}),
|
||||||
|
'context': <ANY>,
|
||||||
|
'entity_id': 'sensor.test_user_pending_quest_items',
|
||||||
|
'last_changed': <ANY>,
|
||||||
|
'last_reported': <ANY>,
|
||||||
|
'last_updated': <ANY>,
|
||||||
|
'state': 'unknown',
|
||||||
|
})
|
||||||
|
# ---
|
||||||
# name: test_sensors[sensor.test_user_perception-entry]
|
# name: test_sensors[sensor.test_user_perception-entry]
|
||||||
EntityRegistryEntrySnapshot({
|
EntityRegistryEntrySnapshot({
|
||||||
'aliases': set({
|
'aliases': set({
|
||||||
|
Loading…
x
Reference in New Issue
Block a user