This crate brings Slack's terrific [Block Kit 🔗] to the Rust ecosystem.
Inside, you'll find models for all of Slack's Layout Blocks, Block Elements, and Composition Objects.
Every model has builders that leverage Rust's type system to help you make sure what you're sending to Slack is 100% valid to them.
Method build not found for ...Builder
- Dig into the error message,
you'll find something like RequiredMethodNotCalled<method::foo>
,
meaning you need to call .foo()
before you can call .build()
!
Using an example from Slack's Documentation:
json
{
"type": "section",
"text": {
"text": "*Sally* has requested you set the deadline for the Nano launch project",
"type": "mrkdwn"
},
"accessory": {
"type": "datepicker",
"action_id": "datepicker123",
"initial_date": "1990-04-28",
"placeholder": {
"type": "plain_text",
"text": "Select a date"
}
}
}
You can use raw Builders like so: ```rust use slack_blocks::{text::ToSlackMarkdown, blocks::Section, elems::DatePicker};
let section = Section::builder() .text("Sally has requested you set the deadline for the Nano launch project".markdown()) .accessory(DatePicker::builder() .actionid("datepicker123") .initialdate((28, 4, 1990)) .placeholder("Select a date") .build() ) .build(); ```
Or enable the unstable
feature and use xml macros:
```rust
use slack_blocks::mox::*;
let pick_date = blox! {
let section = blox! {
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.