block.py 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. from typing import TYPE_CHECKING, List, Optional, Union
  2. from yandex_music import YandexMusicModel
  3. from yandex_music.utils import model
  4. if TYPE_CHECKING:
  5. from yandex_music import BlockEntity, ClientType, JSONType, PersonalPlaylistsData, PlayContextsData
  6. @model
  7. class Block(YandexMusicModel):
  8. """Класс, представляющий блок лендинга.
  9. Note:
  10. Известные значения поля `type_`: `personal-playlists`, `play-contexts`.
  11. Attributes:
  12. id (:obj:`str`): Уникальный идентификатор блока.
  13. type (:obj:`str`): Тип блока.
  14. type_for_from (:obj:`str`): Откуда получен блок (как к нему пришли).
  15. title (:obj:`str`): Заголовок.
  16. entities (:obj:`list` из :obj:`yandex_music.BlockEntity`): Содержимое блока (сущности, объекты).
  17. description (:obj:`str`, optional): Описание.
  18. data (:obj:`yandex_music.PersonalPlaylistsData` | :obj:`yandex_music.PlayContextsData`, optional):
  19. Дополнительные данные.
  20. client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
  21. """
  22. id: str
  23. type: str
  24. type_for_from: str
  25. title: str
  26. entities: List['BlockEntity']
  27. description: Optional[str] = None
  28. data: Optional[Union['PersonalPlaylistsData', 'PlayContextsData']] = None
  29. client: Optional['ClientType'] = None
  30. def __post_init__(self) -> None:
  31. self._id_attrs = (self.id, self.type, self.type_for_from, self.title, self.entities)
  32. def __getitem__(self, item: int) -> 'BlockEntity':
  33. return self.entities[item]
  34. @classmethod
  35. def de_json(cls, data: 'JSONType', client: 'ClientType') -> Optional['Block']:
  36. """Десериализация объекта.
  37. Args:
  38. data (:obj:`dict`): Поля и значения десериализуемого объекта.
  39. client (:obj:`yandex_music.Client`, optional): Клиент Yandex Music.
  40. Returns:
  41. :obj:`yandex_music.Block`: Блок лендинга.
  42. """
  43. if not cls.is_dict_model_data(data):
  44. return None
  45. cls_data = cls.cleanup_data(data, client)
  46. from yandex_music import BlockEntity, PersonalPlaylistsData, PlayContextsData
  47. cls_data['entities'] = BlockEntity.de_list(data.get('entities'), client)
  48. block_type = data.get('type')
  49. if block_type == 'personal-playlists':
  50. cls_data['data'] = PersonalPlaylistsData.de_json(data.get('data'), client)
  51. elif block_type == 'play-contexts':
  52. cls_data['data'] = PlayContextsData.de_json(data.get('data'), client)
  53. return cls(client=client, **cls_data) # type: ignore