To-do List Entity
A To-do list entity is an entity that represents a To-do list. A To-do list contains
To-do items which are ordered and have a status (complete or in progress). A To-do list entity is derived from the homeassistant.components.todo.TodoListEntity
.
Properties
Properties should only return information from memory and not do I/O (like network requests). Implement update()
or async_update()
to fetch data.
Name | Type | Default | Description |
---|---|---|---|
todo_items | list[TodoItem] | None | None | Required. The ordered contents of the To-do list. |
States
A TodoListEntity
state is the count of incomplete items in the To-do list.
Supported Features
Supported features are defined by using values in the TodoListEntityFeature
enum
and are combined using the bitwise or (|
) operator.
Value | Description |
---|---|
CREATE_TODO_ITEM | Entity implements the methods to allow creation of to-do items. |
DELETE_TODO_ITEM | Entity implements the methods to allow deletion of to-do items. |
UPDATE_TODO_ITEM | Entity implements the methods to allow update of to-do items. |
MOVE_TODO_ITEM | Entity implements the methods to re-order to-do items. |
DUE_DATE | Entity implements to-do item due field as a datetime.date . |
DUE_DATETIME | Entity implements to-do item due field as a datetime.datetime . |
DESCRIPTION | Entity implements to-do item description field. |
Methods
Create To-do items
A To-do list entity may support creating To-do items by specifying the CREATE_TODO_ITEM
supported feature.
from homeassistant.components.todo import TodoListEntity
class MyTodoListEntity(TodoListEntity):
async def async_create_todo_item(self, item: TodoItem) -> None:
"""Add an item to the To-do list."""
Delete To-do items
A To-do list entity may support deleting To-do items by specifying the DELETE_TODO_ITEM
supported feature. Integrations must support deleting multiple items.
from homeassistant.components.todo import TodoListEntity
class MyTodoListEntity(TodoListEntity):
async def async_delete_todo_items(self, uids: list[str]) -> None:
"""Delete an item from the to-do list."""
Update To-do items
A To-do list entity may support updating To-do items by specifying the UPDATE_TODO_ITEM
supported feature. The TodoItem
field uid
is always present and indicates
which item should be updated. The item passed to update is a copy of the original
item with fields updated or cleared.
from homeassistant.components.todo import TodoListEntity
class MyTodoListEntity(TodoListEntity):
async def async_update_todo_item(self, item: TodoItem) -> None:
"""Add an item to the To-do list."""
Move To-do items
A To-do list entity may support re-ordering To-do items in the list by specifying
the MOVE_TODO_ITEM
supported feature. The To-do item with the specified uid
should be moved to the position in the list after the one specified by previous_uid
(None
means move to the first
position in the To-do list).
from homeassistant.components.todo import TodoListEntity
class MyTodoListEntity(TodoListEntity):
async def async_move_todo_item(
self,
uid: str,
previous_uid: str | None = None
) -> None:
"""Move an item in the To-do list."""
TodoItem
A TodoItem
represents an individual item on a To-do list. The methods
above describe any differences about which fields are optional on create or
update.
Name | Type | Default | Description |
---|---|---|---|
uid | string | None | None | A unique identifier for the to-do item. This field is required for updates and the entity state. |
summary | string | None | None | A title or summary of the to-do item. This field is required for the entity state. |
status | TodoItemStatus | None | None | Defines the overall status for the to-do item, either NEEDS_ACTION or COMPLETE . This field is required for the entity state. |
due | datetime.date | datetime.datetime | None | None | The date and time that a to-do is expected to be completed. The types supported depend on TodoListEntityFeature.DUE_DATE or TodoListEntityFeature.DUE_DATETIME or both being set. As a datetime, must have a timezone. |
description | string | None | None | A more complete description of the to-do item than that provided by the summary. Only supported when TodoListEntityFeature.DESCRIPTION is set. |