Skip to main content

A fast way to build Block Kit interfaces in Python.

Project description

Screenshot

Build status PyPI version Downloads


Blockkit is a Python library for building UI interfaces for Slack apps. It allows you to compose the interface from Python classes, so you type less, and your code becomes more maintainable.

Blockkit performs validation at runtime and provides user-friendly errors when data is invalid.

Generate

You don't even need to write code yourself. Go to blockkit-generator.com paste your JSON payload from Block Kit Builder and get corresponding Python code!

Screenshot

Installation

pip install blockkit

Usage

Start with one of the Home, Modal, or Message surface classes and follow the structure as you would follow it in JSON.

The library supports all types of surfaces, blocks, block elements, and composition objects Slack provides.

Once UI is ready, call the build() method to render components to dictionary:

from blockkit import Section, MarkdownText

Section(text=MarkdownText(text="hello world")).build()

{"type": "section", "text": {"text": "hello world", "type": "mrkdwn"}}

Here's the list of types of components and corresponding classes:

Surfaces

Type Class
home Home
modal Modal
Message
workflow_step WorkflowStep

Blocks

Type Class
actions Actions
context Context
divider Divider
header Header
image ImageBlock
input Input
section Section

Block elements

Type Class
button Button
checkboxes Checkboxes
datepicker DatePicker
type Image
multi_static_select MultiStaticSelect
multi_users_select MultiUsersSelect
multi_channels_select MultiChannelsSelect
multi_conversations_select MultiConversationsSelect
multi_external_select MultiExternalSelect
overflow Overflow
plain_text_input PlainTextInput
radio_buttons RadioButtons
static_select StaticSelect
users_select UsersSelect
channels_select ChannelsSelect
conversations_select ConversationsSelect
external_select ExternalSelect
timepicker Timepicker

Composition objects

Type Class
plain_text PlainText
mrkdwn MarkdownText
Confirm
PlainOption
MarkdownOption
OptionGroup
Filter
DispatchActionConfig

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

blockkit-1.5.2.tar.gz (13.5 kB view details)

Uploaded Source

Built Distribution

blockkit-1.5.2-py2.py3-none-any.whl (14.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file blockkit-1.5.2.tar.gz.

File metadata

  • Download URL: blockkit-1.5.2.tar.gz
  • Upload date:
  • Size: 13.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.14

File hashes

Hashes for blockkit-1.5.2.tar.gz
Algorithm Hash digest
SHA256 75bddc9df6ca5e651cb8e5b28cc76a14ed21abebdfee2ae6de9f0738ab99ad5e
MD5 a44b1b0a3d9353f9e4147f04465a398a
BLAKE2b-256 dcff1c01f0e1e61303efa7274819a78c2c03df5b6e4bd67638c5ae04915f22cd

See more details on using hashes here.

File details

Details for the file blockkit-1.5.2-py2.py3-none-any.whl.

File metadata

  • Download URL: blockkit-1.5.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 14.9 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.14

File hashes

Hashes for blockkit-1.5.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 2689cbf5ac58ee73ca8239eba89ecff8d390b0a8ab8f4e405f8ff15cd6adc763
MD5 986f992f603d3384e0835c10175a9e4f
BLAKE2b-256 9976855914459932795a191e4410be425ca815975b8d3bd8dd0fbadcc7b1692c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page