Class: Discordrb::Webhooks::View::RowBuilder

Inherits:
Object
  • Object
show all
Defined in:
lib/discordrb/webhooks/view.rb

Overview

This builder is used when constructing an ActionRow. All current components must be within an action row, but this can change in the future. A message can have 5 action rows, each action row can hold a weight of 5. Buttons have a weight of 1, and dropdowns have a weight of 5.

Instance Method Summary collapse

Instance Method Details

#button(style:, label: nil, emoji: nil, custom_id: nil, disabled: nil, url: nil) ⇒ Object

Add a button to this action row.

Parameters:

  • style (Symbol, Integer)

    The button's style type. See BUTTON_STYLES

  • label (String, nil) (defaults to: nil)

    The text label for the button. Either a label or emoji must be provided.

  • emoji (#to_h, String, Integer) (defaults to: nil)

    An emoji ID, or unicode emoji to attach to the button. Can also be a object that responds to #to_h which returns a hash in the format of { id: Integer, name: string }.

  • custom_id (String) (defaults to: nil)

    Custom IDs are used to pass state to the events that are raised from interactions. There is a limit of 100 characters to each custom_id.

  • disabled (true, false) (defaults to: nil)

    Whether this button is disabled and shown as greyed out.

  • url (String, nil) (defaults to: nil)

    The URL, when using a link style button.



40
41
42
43
44
45
46
47
48
49
50
51
# File 'lib/discordrb/webhooks/view.rb', line 40

def button(style:, label: nil, emoji: nil, custom_id: nil, disabled: nil, url: nil)
  style = BUTTON_STYLES[style] || style

  emoji = case emoji
          when Integer, String
            emoji.to_i.positive? ? { id: emoji } : { name: emoji }
          else
            emoji.to_h
          end

  @components << { type: COMPONENT_TYPES[:button], label: label, emoji: emoji, style: style, custom_id: custom_id, disabled: disabled, url: url }
end

#select_menu(custom_id:, options: [], placeholder: nil, min_values: nil, max_values: nil) {|builder| ... } ⇒ Object

Add a select menu to this action row.

Parameters:

  • custom_id (String)

    Custom IDs are used to pass state to the events that are raised from interactions. There is a limit of 100 characters to each custom_id.

  • options (Array<Hash>) (defaults to: [])

    Options that can be selected in this menu. Can also be provided via the yielded builder.

  • placeholder (String, nil) (defaults to: nil)

    Default text to show when no entries are selected.

  • min_values (Integer, nil) (defaults to: nil)

    The minimum amount of values a user must select.

  • max_values (Integer, nil) (defaults to: nil)

    The maximum amount of values a user can select.

Yield Parameters:



61
62
63
64
65
66
67
# File 'lib/discordrb/webhooks/view.rb', line 61

def select_menu(custom_id:, options: [], placeholder: nil, min_values: nil, max_values: nil)
  builder = SelectMenuBuilder.new(custom_id, options, placeholder, min_values, max_values)

  yield builder if block_given?

  @components << builder.to_h
end