#slack #markdown-html #markdown #data-model #html

slack-blocks-render

Slack blocks render is a Rust library to render Slack blocks as Markdown

9 releases

0.3.0 Dec 14, 2024
0.2.5 Dec 13, 2024
0.2.1 Oct 21, 2024
0.1.1 Jun 10, 2024

#265 in Text processing

Download history 14/week @ 2024-09-20 46/week @ 2024-09-27 7/week @ 2024-10-04 11/week @ 2024-10-11 324/week @ 2024-10-18 31/week @ 2024-10-25 3/week @ 2024-11-29 499/week @ 2024-12-06 381/week @ 2024-12-13 26/week @ 2024-12-20 63/week @ 2024-12-27

971 downloads per month

Apache-2.0

130KB
3K SLoC

slack-blocks-render

Crates.io Version Docs.rs Latest Build Status

Slack blocks render is a Rust library to render Slack blocks as Markdown.

Usage

First, add the slack_blocks_render crate as a dependency:

cargo add slack_blocks_render

Slack blocks render uses the slack_morphism data model as input so you should also add it as a dependency:

cargo add slack_morphism

Simple usage (without Slack references resolution)

use slack_morphism::prelude::*;
use slack_blocks_render::{render_blocks_as_markdown, SlackReferences};

let blocks: Vec<SlackBlock> = vec![
    SlackBlock::RichText(serde_json::json!({
        "type": "rich_text",
        "elements": [
            {
                "type": "rich_text_section",
                "elements": [
                    {
                        "type": "text",
                        "text": "Hello World"
                    }
                ]
            },
        ]
    })),
];
let markdown_text = render_blocks_as_markdown(blocks, SlackReferences::default(), None);

Usage with Slack references resolution

Slack references resolution is useful when you want to resolve user ID, channel ID, or user group ID in the Slack blocks. Here is an example on how to use it:

use slack_morphism::prelude::*;
use slack_blocks_render::{
  find_slack_references_in_blocks, render_blocks_as_markdown, SlackReferences
};

let blocks: Vec<SlackBlock> = vec![
    SlackBlock::RichText(serde_json::json!({
        "type": "rich_text",
        "elements": [
            {
                "type": "rich_text_section",
                "elements": [
                    {
                        "type": "text",
                        "text": "Hello "
                    }
                ]
            },
            {
                "type": "rich_text_section",
                "elements": [
                    {
                        "type": "user",
                        "text": "U123456"
                    }
                ]
            },
        ]
    })),
];
// First, extract Slack references from the blocks
let slack_references = find_slack_references_in_blocks(&blocks);
// Then, resolve the references before rendering the blocks, this is on your own
// For example, you can use Slack API to resolve them
// ...
// let slack_user_ids = slack_references.users.keys().cloned().collect::<Vec<_>>();
// for slack_user_id in slack_user_ids {
//     let user_info = slack_api_client.users_info(slack_user_id).await?;
//     slack_references.users.insert(slack_user_id, user_info.name);
// }
// Finally, render the blocks as Markdown
let markdown_text = render_blocks_as_markdown(blocks, slack_references, None);

License

This project is distributed under the terms of the Apache License (Version 2.0).

See LICENSE

Dependencies

~10–20MB
~265K SLoC