Change Webhook.avatar to be consistent with User.avatar

This commit is contained in:
jack1142
2022-02-22 03:13:01 +01:00
committed by GitHub
parent 19ad64adda
commit 40dc8d1d9d

View File

@@ -895,16 +895,35 @@ class BaseWebhook(Hashable):
return utils.snowflake_time(self.id) return utils.snowflake_time(self.id)
@property @property
def avatar(self) -> Asset: def avatar(self) -> Optional[Asset]:
""":class:`Asset`: Returns an :class:`Asset` for the avatar the webhook has. """Optional[:class:`Asset`]: Returns an :class:`Asset` for the avatar the webhook has.
If the webhook does not have a traditional avatar, an asset for If the webhook does not have a traditional avatar, ``None`` is returned.
the default avatar is returned instead. If you want the avatar that a webhook has displayed, consider :attr:`display_avatar`.
"""
if self._avatar is not None:
return Asset._from_avatar(self._state, self.id, self._avatar)
return None
@property
def default_avatar(self) -> Asset:
"""
:class:`Asset`: Returns the default avatar. This is always the blurple avatar.
.. versionadded:: 2.0
""" """
if self._avatar is None:
# Default is always blurple apparently # Default is always blurple apparently
return Asset._from_default_avatar(self._state, 0) return Asset._from_default_avatar(self._state, 0)
return Asset._from_avatar(self._state, self.id, self._avatar)
@property
def display_avatar(self) -> Asset:
""":class:`Asset`: Returns the webhook's display avatar.
This is either webhook's default avatar or uploaded avatar.
.. versionadded:: 2.0
"""
return self.avatar or self.default_avatar
class Webhook(BaseWebhook): class Webhook(BaseWebhook):