diff options
| author | 2022-12-04 11:31:52 +0100 | |
|---|---|---|
| committer | 2022-12-04 11:31:52 +0100 | |
| commit | 37b43a6c04af0498d96bd28ec544973d2e653941 (patch) | |
| tree | fd5d4ac952537bfd793d7db9246eeb540f160c3e | |
| parent | make SELF_ASSIGNABLE_ROLES_MESSAGE more inviting for people to interact with (diff) | |
ditch prepare_self_assignable_roles_view by constructing the buttons inside the view itself
| -rw-r--r-- | bot/exts/info/subscribe.py | 30 | 
1 files changed, 9 insertions, 21 deletions
| diff --git a/bot/exts/info/subscribe.py b/bot/exts/info/subscribe.py index b77dcd8b0..0c12da37d 100644 --- a/bot/exts/info/subscribe.py +++ b/bot/exts/info/subscribe.py @@ -74,12 +74,18 @@ class RoleButtonView(discord.ui.View):      anchor_message: discord.Message -    def __init__(self, member: discord.Member): +    def __init__(self, member: discord.Member, assignable_roles: list[AssignableRole]):          super().__init__(timeout=DELETE_MESSAGE_AFTER)          # We can't obtain the reference to the message before the view is sent          self.anchor_message = None          self.interaction_owner = member +        author_roles = [role.id for role in member.roles] + +        for index, role in enumerate(assignable_roles): +            row = index // ITEMS_PER_ROW +            self.add_item(SingleRoleButton(role, role.role_id in author_roles, row)) +      async def interaction_check(self, interaction: Interaction) -> bool:          """Ensure that the user clicking the button is the member who invoked the command."""          if interaction.user != self.interaction_owner: @@ -173,7 +179,7 @@ class AllSelfAssignableRolesView(discord.ui.View):      async def show_all_self_assignable_roles(self, interaction: Interaction, button: discord.ui.Button) -> None:          """Sends the original subscription view containing the available self assignable roles."""          await interaction.response.defer() -        view = prepare_self_assignable_roles_view(interaction, self.assignable_roles) +        view = RoleButtonView(interaction.user, self.assignable_roles)          message = await interaction.followup.send(              view=view,              ephemeral=True @@ -229,8 +235,7 @@ class Subscribe(commands.Cog):      )      async def subscribe_command(self, ctx: commands.Context, *_) -> None:  # We don't actually care about the args          """Display the member's current state for each role, and allow them to add/remove the roles.""" -        view = prepare_self_assignable_roles_view(ctx, self.assignable_roles) - +        view = RoleButtonView(ctx.author, self.assignable_roles)          message = await ctx.send(              "Click the buttons below to add or remove your roles!",              view=view, @@ -274,23 +279,6 @@ class Subscribe(commands.Cog):          self.bot.add_view(view, message_id=placeholder_message.id) -def prepare_self_assignable_roles_view( -        trigger_action: commands.Context | Interaction, -        assignable_roles: list[AssignableRole] -) -> discord.ui.View: -    """Prepares the view containing the self assignable roles before its sent.""" -    author = trigger_action.author if isinstance(trigger_action, commands.Context) else trigger_action.user -    author_roles = [role.id for role in author.roles] -    button_view = RoleButtonView(member=author) -    button_view.anchor_message = trigger_action.message - -    for index, role in enumerate(assignable_roles): -        row = index // ITEMS_PER_ROW -        button_view.add_item(SingleRoleButton(role, role.role_id in author_roles, row)) - -    return button_view - -  async def setup(bot: Bot) -> None:      """Load the 'Subscribe' cog."""      if len(ASSIGNABLE_ROLES) > ITEMS_PER_ROW * 5:  # Discord limits views to 5 rows of buttons. | 
