Module slack_sdk.models.dialogs

Classes

class AbstractDialogSelector (*,
name: str,
label: str,
optional: bool = False,
value: Option | str | None = None,
placeholder: str | None = None)

The base class for JSON serializable class objects

Expand source code
class AbstractDialogSelector(JsonObject, metaclass=ABCMeta):
    DataSourceTypes = DynamicSelectElementTypes.union({"external", "static"})

    attributes = {"data_source", "label", "name", "optional", "placeholder", "type"}

    name_max_length = 300
    label_max_length = 48
    placeholder_max_length = 150

    @property
    @abstractmethod
    def data_source(self) -> str:
        pass

    def __init__(
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        value: Optional[Union[Option, str]] = None,
        placeholder: Optional[str] = None,
    ):
        self.name = name
        self.label = label
        self.optional = optional
        self.value = value
        self.placeholder = placeholder
        self.type = "select"

    @JsonValidator(f"name attribute cannot exceed {name_max_length} characters")
    def name_length(self) -> bool:
        return len(self.name) < self.name_max_length

    @JsonValidator(f"label attribute cannot exceed {label_max_length} characters")
    def label_length(self) -> bool:
        return len(self.label) < self.label_max_length

    @JsonValidator(f"placeholder attribute cannot exceed {placeholder_max_length} characters")
    def placeholder_length(self) -> bool:
        return self.placeholder is None or len(self.placeholder) < self.placeholder_max_length

    @EnumValidator("data_source", DataSourceTypes)
    def data_source_valid(self) -> bool:
        return self.data_source in self.DataSourceTypes

    def to_dict(self) -> dict:  # skipcq: PYL-W0221
        json = super().to_dict()
        if self.data_source == "external":
            if isinstance(self.value, Option):
                json["selected_options"] = extract_json([self.value], "dialog")
            elif self.value is not None:
                json["selected_options"] = Option.from_single_value(self.value)
        else:
            if isinstance(self.value, Option):
                json["value"] = self.value.value
            elif self.value is not None:
                json["value"] = self.value
        return json

Ancestors

Subclasses

Class variables

var DataSourceTypes

The type of the None singleton.

var attributes

The type of the None singleton.

var label_max_length

The type of the None singleton.

var name_max_length

The type of the None singleton.

var placeholder_max_length

The type of the None singleton.

Instance variables

prop data_source : str
Expand source code
@property
@abstractmethod
def data_source(self) -> str:
    pass

Methods

def data_source_valid(self) ‑> bool
def label_length(self) ‑> bool
def name_length(self) ‑> bool
def placeholder_length(self) ‑> bool

Inherited members

class DialogBuilder

The base class for JSON serializable class objects

Create a DialogBuilder to more easily construct the JSON required to submit a dialog to Slack

Expand source code
class DialogBuilder(JsonObject):
    attributes = {}  # no attributes because to_dict has unique implementation

    _callback_id: Optional[str]
    _elements: List[Union[DialogTextComponent, AbstractDialogSelector]]
    _submit_label: Optional[str]
    _notify_on_cancel: bool
    _state: Optional[str]

    title_max_length = 24
    submit_label_max_length = 24
    elements_max_length = 10
    state_max_length = 3000

    def __init__(self):
        """
        Create a DialogBuilder to more easily construct the JSON required to submit a
        dialog to Slack
        """
        self._title = None
        self._callback_id = None
        self._elements = []
        self._submit_label = None
        self._notify_on_cancel = False
        self._state = None

    def title(self, title: str) -> "DialogBuilder":
        """
        Specify a title for this dialog

        Args:
          title: must not exceed 24 characters
        """
        self._title = title
        return self

    def state(self, state: Union[dict, str]) -> "DialogBuilder":
        """
        Pass state into this dialog - dictionaries will be automatically formatted to
        JSON

        Args:
            state: Extra state information that you need to pass from this dialog
                back to your application on submission
        """
        if isinstance(state, dict):
            self._state = dumps(state)
        else:
            self._state = state
        return self

    def callback_id(self, callback_id: str) -> "DialogBuilder":
        """
        Specify a callback ID for this dialog, which your application will then
        receive upon dialog submission

        Args:
          callback_id: a string identifying this particular dialog
        """
        self._callback_id = callback_id
        return self

    def submit_label(self, label: str) -> "DialogBuilder":
        """
        The label to use on the 'Submit' button on the dialog. Defaults to 'Submit'
        if not specified.

        Args:
            label: must not exceed 24 characters, and must be a single word (no
                spaces)
        """
        self._submit_label = label
        return self

    def notify_on_cancel(self, notify: bool) -> "DialogBuilder":
        """
        Whether this dialog should send a request to your application even if the
        user cancels their interaction. Defaults to False.

        Args:
            notify: Set to True to indicate that your application should receive a
                request even if the user cancels interaction with the dialog.
        """
        self._notify_on_cancel = notify
        return self

    def text_field(
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        placeholder: Optional[str] = None,
        hint: Optional[str] = None,
        value: Optional[str] = None,
        min_length: int = 0,
        max_length: int = 150,
        subtype: Optional[str] = None,
    ) -> "DialogBuilder":
        """
        Text elements are single-line plain text fields.

        https://api.slack.com/dialogs#attributes_text_elements

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. 48 character maximum.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
            hint: Helpful text provided to assist users in answering a question.
                Up to 150 characters.
            value: A default value for this field. Up to 150 characters.
            min_length: Minimum input length allowed for element. Up to 150
                characters. Defaults to 0.
            max_length: Maximum input length allowed for element. Up to 150
                characters. Defaults to 150.
            subtype: A subtype for this text input. Accepts email, number, tel,
                    or url. In some form factors, optimized input is provided for this
                    subtype.
        """
        self._elements.append(
            DialogTextField(
                name=name,
                label=label,
                optional=optional,
                placeholder=placeholder,
                hint=hint,
                value=value,
                min_length=min_length,
                max_length=max_length,
                subtype=subtype,
            )
        )
        return self

    def text_area(
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        placeholder: Optional[str] = None,
        hint: Optional[str] = None,
        value: Optional[str] = None,
        min_length: int = 0,
        max_length: int = 3000,
        subtype: Optional[str] = None,
    ) -> "DialogBuilder":
        """
        A textarea is a multi-line plain text editing control. You've likely
        encountered these on the world wide web. Use this element if you want a
        relatively long answer from users. The element UI provides a remaining
        character count to the max_length you have set or the default,
        3000.

        https://api.slack.com/dialogs#attributes_textarea_elements

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. 48 character maximum.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
            hint: Helpful text provided to assist users in answering a question.
                Up to 150 characters.
            value: A default value for this field. Up to 3000 characters.
            min_length: Minimum input length allowed for element. 1-3000
                characters. Defaults to 0.
            max_length: Maximum input length allowed for element. 0-3000
                characters. Defaults to 3000.
            subtype: A subtype for this text input. Accepts email, number, tel,
                or url. In some form factors, optimized input is provided for this
                subtype.
        """
        self._elements.append(
            DialogTextArea(
                name=name,
                label=label,
                optional=optional,
                placeholder=placeholder,
                hint=hint,
                value=value,
                min_length=min_length,
                max_length=max_length,
                subtype=subtype,
            )
        )
        return self

    def static_selector(
        self,
        *,
        name: str,
        label: str,
        options: Union[Sequence[Option], Sequence[OptionGroup]],
        optional: bool = False,
        value: Optional[str] = None,
        placeholder: Optional[str] = None,
    ) -> "DialogBuilder":
        """
        Use the select element for multiple choice selections allowing users to pick
        a single item from a list. True to web roots, this selection is displayed as
        a dropdown menu.

        A select element may contain up to 100 selections, provided as a list of
        Option or OptionGroup objects

        https://api.slack.com/dialogs#attributes_select_elements

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            options: A list of up to 100 Option or OptionGroup objects. Object
                types cannot be mixed.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        self._elements.append(
            DialogStaticSelector(
                name=name,
                label=label,
                options=options,
                optional=optional,
                value=value,
                placeholder=placeholder,
            )
        )
        return self

    def external_selector(
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        value: Optional[Option] = None,
        placeholder: Optional[str] = None,
        min_query_length: Optional[int] = None,
    ) -> "DialogBuilder":
        """
        Use the select element for multiple choice selections allowing users to pick
        a single item from a list. True to web roots, this selection is displayed as
        a dropdown menu.

        A list of options can be loaded from an external URL and used in your dialog
        menus.

        https://api.slack.com/dialogs#dynamic_select_elements_external

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            min_query_length: Specify the number of characters that must be
                typed by a user into a dynamic select menu before dispatching to your
                application.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value. This should be a single
                Option or OptionGroup that exactly matches one that will be returned
                from your external endpoint.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        self._elements.append(
            DialogExternalSelector(
                name=name,
                label=label,
                optional=optional,
                value=value,
                placeholder=placeholder,
                min_query_length=min_query_length,
            )
        )
        return self

    def user_selector(
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        value: Optional[str] = None,
        placeholder: Optional[str] = None,
    ) -> "DialogBuilder":
        """
        Now you can easily populate a select menu with a list of users. For example,
        when you are creating a bug tracking app, you want to include a field for an
        assignee. Slack pre-populates the user list in client-side, so your app
        doesn't need access to a related OAuth scope.

        https://api.slack.com/dialogs#dynamic_select_elements_users

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        self._elements.append(
            DialogUserSelector(
                name=name,
                label=label,
                optional=optional,
                value=value,
                placeholder=placeholder,
            )
        )
        return self

    def channel_selector(
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        value: Optional[str] = None,
        placeholder: Optional[str] = None,
    ) -> "DialogBuilder":
        """
        You can also provide a select menu with a list of channels. Specify your
        data_source as channels to limit only to public channels

        https://api.slack.com/dialogs#dynamic_select_elements_channels_conversations

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        self._elements.append(
            DialogChannelSelector(
                name=name,
                label=label,
                optional=optional,
                value=value,
                placeholder=placeholder,
            )
        )
        return self

    def conversation_selector(
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        value: Optional[str] = None,
        placeholder: Optional[str] = None,
    ) -> "DialogBuilder":
        """
        You can also provide a select menu with a list of conversations - including
        private channels, direct messages, MPIMs, and whatever else we consider a
        conversation-like thing.

        https://api.slack.com/dialogs#dynamic_select_elements_channels_conversations

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        self._elements.append(
            DialogConversationSelector(
                name=name,
                label=label,
                optional=optional,
                value=value,
                placeholder=placeholder,
            )
        )
        return self

    @JsonValidator("title attribute is required")
    def title_present(self) -> bool:
        return self._title is not None

    @JsonValidator(f"title attribute cannot exceed {title_max_length} characters")
    def title_length(self) -> bool:
        return self._title is not None and len(self._title) <= self.title_max_length

    @JsonValidator("callback_id attribute is required")
    def callback_id_present(self) -> bool:
        return self._callback_id is not None

    @JsonValidator(f"dialogs must contain between 1 and {elements_max_length} elements")
    def elements_length(self) -> bool:
        return 0 < len(self._elements) <= self.elements_max_length

    @JsonValidator(f"submit_label cannot exceed {submit_label_max_length} characters")
    def submit_label_length(self) -> bool:
        return self._submit_label is None or len(self._submit_label) <= self.submit_label_max_length

    @JsonValidator("submit_label can only be one word")
    def submit_label_valid(self) -> bool:
        return self._submit_label is None or " " not in self._submit_label

    @JsonValidator(f"state cannot exceed {state_max_length} characters")
    def state_length(self) -> bool:
        return not self._state or len(self._state) <= self.state_max_length

    def to_dict(self) -> dict:  # skipcq: PYL-W0221
        self.validate_json()
        json = {
            "title": self._title,
            "callback_id": self._callback_id,
            "elements": extract_json(self._elements),
            "notify_on_cancel": self._notify_on_cancel,
        }
        if self._submit_label is not None:
            json["submit_label"] = self._submit_label
        if self._state is not None:
            json["state"] = self._state
        return json

Ancestors

Class variables

var attributes

The type of the None singleton.

var elements_max_length

The type of the None singleton.

var state_max_length

The type of the None singleton.

var submit_label_max_length

The type of the None singleton.

var title_max_length

The type of the None singleton.

Methods

def callback_id(self, callback_id: str) ‑> DialogBuilder

Specify a callback ID for this dialog, which your application will then receive upon dialog submission

Args

callback_id
a string identifying this particular dialog
def callback_id_present(self) ‑> bool
def channel_selector(self,
*,
name: str,
label: str,
optional: bool = False,
value: str | None = None,
placeholder: str | None = None) ‑> DialogBuilder

You can also provide a select menu with a list of channels. Specify your data_source as channels to limit only to public channels

https://api.slack.com/dialogs#dynamic_select_elements_channels_conversations

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
def conversation_selector(self,
*,
name: str,
label: str,
optional: bool = False,
value: str | None = None,
placeholder: str | None = None) ‑> DialogBuilder

You can also provide a select menu with a list of conversations - including private channels, direct messages, MPIMs, and whatever else we consider a conversation-like thing.

https://api.slack.com/dialogs#dynamic_select_elements_channels_conversations

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
def elements_length(self) ‑> bool
def external_selector(self,
*,
name: str,
label: str,
optional: bool = False,
value: Option | None = None,
placeholder: str | None = None,
min_query_length: int | None = None) ‑> DialogBuilder

Use the select element for multiple choice selections allowing users to pick a single item from a list. True to web roots, this selection is displayed as a dropdown menu.

A list of options can be loaded from an external URL and used in your dialog menus.

https://api.slack.com/dialogs#dynamic_select_elements_external

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
min_query_length
Specify the number of characters that must be typed by a user into a dynamic select menu before dispatching to your application.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value. This should be a single Option or OptionGroup that exactly matches one that will be returned from your external endpoint.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
def notify_on_cancel(self, notify: bool) ‑> DialogBuilder

Whether this dialog should send a request to your application even if the user cancels their interaction. Defaults to False.

Args

notify
Set to True to indicate that your application should receive a request even if the user cancels interaction with the dialog.
def state(self, state: dict | str) ‑> DialogBuilder

Pass state into this dialog - dictionaries will be automatically formatted to JSON

Args

state
Extra state information that you need to pass from this dialog back to your application on submission
def state_length(self) ‑> bool
def static_selector(self,
*,
name: str,
label: str,
options: Sequence[Option] | Sequence[OptionGroup],
optional: bool = False,
value: str | None = None,
placeholder: str | None = None) ‑> DialogBuilder

Use the select element for multiple choice selections allowing users to pick a single item from a list. True to web roots, this selection is displayed as a dropdown menu.

A select element may contain up to 100 selections, provided as a list of Option or OptionGroup objects

https://api.slack.com/dialogs#attributes_select_elements

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
options
A list of up to 100 Option or OptionGroup objects. Object types cannot be mixed.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
def submit_label(self, label: str) ‑> DialogBuilder

The label to use on the 'Submit' button on the dialog. Defaults to 'Submit' if not specified.

Args

label
must not exceed 24 characters, and must be a single word (no spaces)
def submit_label_length(self) ‑> bool
def submit_label_valid(self) ‑> bool
def text_area(self,
*,
name: str,
label: str,
optional: bool = False,
placeholder: str | None = None,
hint: str | None = None,
value: str | None = None,
min_length: int = 0,
max_length: int = 3000,
subtype: str | None = None) ‑> DialogBuilder

A textarea is a multi-line plain text editing control. You've likely encountered these on the world wide web. Use this element if you want a relatively long answer from users. The element UI provides a remaining character count to the max_length you have set or the default, 3000.

https://api.slack.com/dialogs#attributes_textarea_elements

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. 48 character maximum.
optional
Provide true when the form element is not required. By default, form elements are required.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
hint
Helpful text provided to assist users in answering a question. Up to 150 characters.
value
A default value for this field. Up to 3000 characters.
min_length
Minimum input length allowed for element. 1-3000 characters. Defaults to 0.
max_length
Maximum input length allowed for element. 0-3000 characters. Defaults to 3000.
subtype
A subtype for this text input. Accepts email, number, tel, or url. In some form factors, optimized input is provided for this subtype.
def text_field(self,
*,
name: str,
label: str,
optional: bool = False,
placeholder: str | None = None,
hint: str | None = None,
value: str | None = None,
min_length: int = 0,
max_length: int = 150,
subtype: str | None = None) ‑> DialogBuilder

Text elements are single-line plain text fields.

https://api.slack.com/dialogs#attributes_text_elements

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. 48 character maximum.
optional
Provide true when the form element is not required. By default, form elements are required.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
hint
Helpful text provided to assist users in answering a question. Up to 150 characters.
value
A default value for this field. Up to 150 characters.
min_length
Minimum input length allowed for element. Up to 150 characters. Defaults to 0.
max_length
Maximum input length allowed for element. Up to 150 characters. Defaults to 150.
subtype
A subtype for this text input. Accepts email, number, tel, or url. In some form factors, optimized input is provided for this subtype.
def title(self, title: str) ‑> DialogBuilder

Specify a title for this dialog

Args

title
must not exceed 24 characters
def title_length(self) ‑> bool
def title_present(self) ‑> bool
def user_selector(self,
*,
name: str,
label: str,
optional: bool = False,
value: str | None = None,
placeholder: str | None = None) ‑> DialogBuilder

Now you can easily populate a select menu with a list of users. For example, when you are creating a bug tracking app, you want to include a field for an assignee. Slack pre-populates the user list in client-side, so your app doesn't need access to a related OAuth scope.

https://api.slack.com/dialogs#dynamic_select_elements_users

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.

Inherited members

class DialogChannelSelector (*,
name: str,
label: str,
optional: bool = False,
value: str | None = None,
placeholder: str | None = None)

The base class for JSON serializable class objects

You can also provide a select menu with a list of channels. Specify your data_source as channels to limit only to public channels

https://api.slack.com/dialogs#dynamic_select_elements_channels_conversations

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
Expand source code
class DialogChannelSelector(AbstractDialogSelector):
    data_source = "channels"

    def __init__(  # skipcq: PYL-W0235
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        value: Optional[str] = None,
        placeholder: Optional[str] = None,
    ):
        """
        You can also provide a select menu with a list of channels. Specify your
        data_source as channels to limit only to public channels

        https://api.slack.com/dialogs#dynamic_select_elements_channels_conversations

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        super().__init__(
            name=name,
            label=label,
            optional=optional,
            value=value,
            placeholder=placeholder,
        )

Ancestors

Class variables

var data_source

The type of the None singleton.

Inherited members

class DialogConversationSelector (*,
name: str,
label: str,
optional: bool = False,
value: str | None = None,
placeholder: str | None = None)

The base class for JSON serializable class objects

You can also provide a select menu with a list of conversations - including private channels, direct messages, MPIMs, and whatever else we consider a conversation-like thing.

https://api.slack.com/dialogs#dynamic_select_elements_channels_conversations

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
Expand source code
class DialogConversationSelector(AbstractDialogSelector):
    data_source = "conversations"

    def __init__(  # skipcq: PYL-W0235
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        value: Optional[str] = None,
        placeholder: Optional[str] = None,
    ):
        """
        You can also provide a select menu with a list of conversations - including
        private channels, direct messages, MPIMs, and whatever else we consider a
        conversation-like thing.

        https://api.slack.com/dialogs#dynamic_select_elements_channels_conversations

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        super().__init__(
            name=name,
            label=label,
            optional=optional,
            value=value,
            placeholder=placeholder,
        )

Ancestors

Class variables

var data_source

The type of the None singleton.

Inherited members

class DialogExternalSelector (*,
name: str,
label: str,
value: Option | None = None,
min_query_length: int | None = None,
optional: bool | None = False,
placeholder: str | None = None)

The base class for JSON serializable class objects

Use the select element for multiple choice selections allowing users to pick a single item from a list. True to web roots, this selection is displayed as a dropdown menu.

A list of options can be loaded from an external URL and used in your dialog menus.

https://api.slack.com/dialogs#dynamic_select_elements_external

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
min_query_length
Specify the number of characters that must be typed by a user into a dynamic select menu before dispatching to the app.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value. This should be a single Option or OptionGroup that exactly matches one that will be returned from your external endpoint.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
Expand source code
class DialogExternalSelector(AbstractDialogSelector):
    data_source = "external"

    @property
    def attributes(self) -> Set[str]:
        return super().attributes.union({"min_query_length"})

    def __init__(
        self,
        *,
        name: str,
        label: str,
        value: Optional[Option] = None,
        min_query_length: Optional[int] = None,
        optional: Optional[bool] = False,
        placeholder: Optional[str] = None,
    ):
        """
        Use the select element for multiple choice selections allowing users to pick
        a single item from a list. True to web roots, this selection is displayed as
        a dropdown menu.

        A list of options can be loaded from an external URL and used in your dialog
        menus.

        https://api.slack.com/dialogs#dynamic_select_elements_external

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            min_query_length: Specify the number of characters that must be typed
                by a user into a dynamic select menu before dispatching to the app.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value. This should be a single
                Option or OptionGroup that exactly matches one that will be returned
                from your external endpoint.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        super().__init__(
            name=name,
            label=label,
            value=value,
            optional=optional,
            placeholder=placeholder,
        )
        self.min_query_length = min_query_length

Ancestors

Class variables

var data_source

The type of the None singleton.

Instance variables

prop attributes : Set[str]

Build an unordered collection of unique elements.

Expand source code
@property
def attributes(self) -> Set[str]:
    return super().attributes.union({"min_query_length"})

Inherited members

class DialogStaticSelector (*,
name: str,
label: str,
options: Sequence[Option] | Sequence[OptionGroup],
optional: bool = False,
value: Option | str | None = None,
placeholder: str | None = None)

Use the select element for multiple choice selections allowing users to pick a single item from a list. True to web roots, this selection is displayed as a dropdown menu.

https://api.slack.com/dialogs#select_elements

Use the select element for multiple choice selections allowing users to pick a single item from a list. True to web roots, this selection is displayed as a dropdown menu.

A select element may contain up to 100 selections, provided as a list of Option or OptionGroup objects

https://api.slack.com/dialogs#attributes_select_elements

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
options
A list of up to 100 Option or OptionGroup objects. Object types cannot be mixed.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
Expand source code
class DialogStaticSelector(AbstractDialogSelector):
    """
    Use the select element for multiple choice selections allowing users to pick a
    single item from a list. True to web roots, this selection is displayed as a
    dropdown menu.

    https://api.slack.com/dialogs#select_elements
    """

    data_source = "static"

    options_max_length = 100

    def __init__(
        self,
        *,
        name: str,
        label: str,
        options: Union[Sequence[Option], Sequence[OptionGroup]],
        optional: bool = False,
        value: Optional[Union[Option, str]] = None,
        placeholder: Optional[str] = None,
    ):
        """
        Use the select element for multiple choice selections allowing users to pick
        a single item from a list. True to web roots, this selection is displayed as
        a dropdown menu.

        A select element may contain up to 100 selections, provided as a list of
        Option or OptionGroup objects

        https://api.slack.com/dialogs#attributes_select_elements

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            options: A list of up to 100 Option or OptionGroup objects. Object
                types cannot be mixed.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        super().__init__(
            name=name,
            label=label,
            optional=optional,
            value=value,
            placeholder=placeholder,
        )
        self.options = options

    @JsonValidator(f"options attribute cannot exceed {options_max_length} items")
    def options_length(self) -> bool:
        return len(self.options) < self.options_max_length

    def to_dict(self) -> dict:
        json = super().to_dict()
        if isinstance(self.options[0], OptionGroup):
            json["option_groups"] = extract_json(self.options, "dialog")
        else:
            json["options"] = extract_json(self.options, "dialog")
        return json

Ancestors

Class variables

var data_source

The type of the None singleton.

var options_max_length

The type of the None singleton.

Methods

def options_length(self) ‑> bool

Inherited members

class DialogTextArea (*,
name: str,
label: str,
optional: bool = False,
placeholder: str | None = None,
hint: str | None = None,
value: str | None = None,
min_length: int = 0,
max_length: int | None = None,
subtype: str | None = None)

A textarea is a multi-line plain text editing control. You've likely encountered these on the world wide web. Use this element if you want a relatively long answer from users. The element UI provides a remaining character count to the max_length you have set or the default, 3000.

https://api.slack.com/dialogs#textarea_elements

Expand source code
class DialogTextArea(DialogTextComponent):
    """
    A textarea is a multi-line plain text editing control. You've likely encountered
    these on the world wide web. Use this element if you want a relatively long
    answer from users. The element UI provides a remaining character count to the
    max_length you have set or the default, 3000.

    https://api.slack.com/dialogs#textarea_elements
    """

    type = "textarea"
    max_value_length = 3000

Ancestors

Class variables

var max_value_length

The type of the None singleton.

var type

The type of the None singleton.

Inherited members

class DialogTextComponent (*,
name: str,
label: str,
optional: bool = False,
placeholder: str | None = None,
hint: str | None = None,
value: str | None = None,
min_length: int = 0,
max_length: int | None = None,
subtype: str | None = None)

The base class for JSON serializable class objects

Expand source code
class DialogTextComponent(JsonObject, metaclass=ABCMeta):
    attributes = {
        "hint",
        "label",
        "max_length",
        "min_length",
        "name",
        "optional",
        "placeholder",
        "subtype",
        "type",
        "value",
    }

    name_max_length = 300
    label_max_length = 48
    placeholder_max_length = 150
    hint_max_length = 150

    @property
    @abstractmethod
    def type(self):
        pass

    @property
    @abstractmethod
    def max_value_length(self):
        pass

    def __init__(
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        placeholder: Optional[str] = None,
        hint: Optional[str] = None,
        value: Optional[str] = None,
        min_length: int = 0,
        max_length: Optional[int] = None,
        subtype: Optional[str] = None,
    ):
        self.name = name
        self.label = label
        self.optional = optional
        self.placeholder = placeholder
        self.hint = hint
        self.value = value
        self.min_length = min_length
        self.max_length = max_length or self.max_value_length
        self.subtype = subtype

    @JsonValidator(f"name attribute cannot exceed {name_max_length} characters")
    def name_length(self) -> bool:
        return len(self.name) < self.name_max_length

    @JsonValidator(f"label attribute cannot exceed {label_max_length} characters")
    def label_length(self) -> bool:
        return len(self.label) < self.label_max_length

    @JsonValidator(f"placeholder attribute cannot exceed {placeholder_max_length} characters")
    def placeholder_length(self) -> bool:
        return self.placeholder is None or len(self.placeholder) < self.placeholder_max_length

    @JsonValidator(f"hint attribute cannot exceed {hint_max_length} characters")
    def hint_length(self) -> bool:
        return self.hint is None or len(self.hint) < self.hint_max_length

    @JsonValidator("value attribute exceeded bounds")
    def value_length(self) -> bool:
        return self.value is None or len(self.value) < self.max_value_length

    @JsonValidator("min_length attribute must be greater than or equal to 0")
    def min_length_above_zero(self) -> bool:
        return self.min_length is None or self.min_length >= 0

    @JsonValidator("min_length attribute exceed bounds")
    def min_length_length(self) -> bool:
        return self.min_length is None or self.min_length <= self.max_value_length

    @JsonValidator("min_length attribute must be less than max value attribute")
    def min_length_below_max_length(self) -> bool:
        return self.min_length is None or self.min_length < self.max_length

    @JsonValidator("max_length attribute must be greater than or equal to 0")
    def max_length_above_zero(self) -> bool:
        return self.max_length is None or self.max_length > 0

    @JsonValidator("max_length attribute exceeded bounds")
    def max_length_length(self) -> bool:
        return self.max_length is None or self.max_length <= self.max_value_length

    @EnumValidator("subtype", TextElementSubtypes)
    def subtype_valid(self) -> bool:
        return self.subtype is None or self.subtype in TextElementSubtypes

Ancestors

Subclasses

Class variables

var attributes

The type of the None singleton.

var hint_max_length

The type of the None singleton.

var label_max_length

The type of the None singleton.

var name_max_length

The type of the None singleton.

var placeholder_max_length

The type of the None singleton.

Instance variables

prop max_value_length
Expand source code
@property
@abstractmethod
def max_value_length(self):
    pass
prop type
Expand source code
@property
@abstractmethod
def type(self):
    pass

Methods

def hint_length(self) ‑> bool
def label_length(self) ‑> bool
def max_length_above_zero(self) ‑> bool
def max_length_length(self) ‑> bool
def min_length_above_zero(self) ‑> bool
def min_length_below_max_length(self) ‑> bool
def min_length_length(self) ‑> bool
def name_length(self) ‑> bool
def placeholder_length(self) ‑> bool
def subtype_valid(self) ‑> bool
def value_length(self) ‑> bool

Inherited members

class DialogTextField (*,
name: str,
label: str,
optional: bool = False,
placeholder: str | None = None,
hint: str | None = None,
value: str | None = None,
min_length: int = 0,
max_length: int | None = None,
subtype: str | None = None)

Text elements are single-line plain text fields.

https://api.slack.com/dialogs#text_elements

Expand source code
class DialogTextField(DialogTextComponent):
    """
    Text elements are single-line plain text fields.

    https://api.slack.com/dialogs#text_elements
    """

    type = "text"
    max_value_length = 150

Ancestors

Class variables

var max_value_length

The type of the None singleton.

var type

The type of the None singleton.

Inherited members

class DialogUserSelector (*,
name: str,
label: str,
optional: bool = False,
value: str | None = None,
placeholder: str | None = None)

The base class for JSON serializable class objects

Now you can easily populate a select menu with a list of users. For example, when you are creating a bug tracking app, you want to include a field for an assignee. Slack pre-populates the user list in client-side, so your app doesn't need access to a related OAuth scope.

https://api.slack.com/dialogs#dynamic_select_elements_users

Args

name
Name of form element. Required. No more than 300 characters.
label
Label displayed to user. Required. No more than 48 characters.
optional
Provide true when the form element is not required. By default, form elements are required.
value
Provide a default selected value.
placeholder
A string displayed as needed to help guide users in completing the element. 150 character maximum.
Expand source code
class DialogUserSelector(AbstractDialogSelector):
    data_source = "users"

    def __init__(  # skipcq: PYL-W0235
        self,
        *,
        name: str,
        label: str,
        optional: bool = False,
        value: Optional[str] = None,
        placeholder: Optional[str] = None,
    ):
        """
        Now you can easily populate a select menu with a list of users. For example,
        when you are creating a bug tracking app, you want to include a field for an
        assignee. Slack pre-populates the user list in client-side, so your app
        doesn't need access to a related OAuth scope.

        https://api.slack.com/dialogs#dynamic_select_elements_users

        Args:
            name: Name of form element. Required. No more than 300 characters.
            label: Label displayed to user. Required. No more than 48 characters.
            optional: Provide true when the form element is not required. By
                default, form elements are required.
            value: Provide a default selected value.
            placeholder: A string displayed as needed to help guide users in
                completing the element. 150 character maximum.
        """
        super().__init__(
            name=name,
            label=label,
            optional=optional,
            value=value,
            placeholder=placeholder,
        )

Ancestors

Class variables

var data_source

The type of the None singleton.

Inherited members