Struct slack_blocks::blocks::image::Contents[][src]

pub struct Contents { /* fields omitted */ }
Expand description

Image Block

slack api docs 🔗

A simple image block, designed to make those cat photos really pop.

Implementations

impl Contents[src]

pub fn from_alt_text_and_url(
    alt_text: impl ToString,
    image_url: impl ToString
) -> Self
[src]

Create an image block, with a url and a brief description for situations where the image cannot be rendered.

Arguments

  • alt_text - A plain-text summary of the image. This should not contain any markup. Maximum length for this field is 2000 characters.

  • image_url - The URL of the image to be displayed. Maximum length for this field is 3000 characters.

Example

use slack_blocks::blocks::{Block, image};

let url = "https://www.cheese.com/favicon.ico";
let image: Block = image::Contents::from_alt_text_and_url("a small image of cheese.", url).into();

// < send to slack api >

pub fn with_title(self, title: impl Into<Plain>) -> Self[src]

Set a plain-text title to be displayed next to your image

Arguments

  • title - An optional title for the image in the form of a Plaintext text object 🔗. Maximum length for the text in this field is 2000 characters.

Example

use slack_blocks::blocks::{Block, image};

let url = "https://www.cheese.com/favicon.ico";
let image: Block = image::Contents::from_alt_text_and_url("a small image of cheese.", url)
    .with_title("here is an image of some cheese:")
    .into();

// < send block to slack's API >

pub fn with_block_id(self, block_id: impl ToString) -> Self[src]

Set the block_id for interactions on an existing image::Contents

Arguments

  • block_id - A string acting as a unique identifier for a block. You can use this block_id when you receive an interaction payload to identify the source of the action 🔗. If not specified, a block_id will be generated. Maximum length for this field is 255 characters.

Example

use slack_blocks::blocks::{Block, image};

let url = "https://www.cheese.com/favicon.ico";
let image: Block = image::Contents::from_alt_text_and_url("a small image of cheese.", url)
    .with_title("here is an image of some cheese:")
    .with_block_id("msg_id_12346")
    .into();

// < send block to slack's API >

pub fn validate(&self) -> Result<(), ValidationErrors>[src]

Validate that this Image block agrees with Slack’s model requirements

Errors

  • If with_block_id was called with a block id longer than 255 chars
  • If with_title was called with a title longer than 2000 chars
  • If from_url_and_alt_text was called with alt_text longer than 2000 chars
  • If from_url_and_alt_text was called with image_url longer than 3000 chars

Example

use slack_blocks::blocks;

let long_string = std::iter::repeat(' ').take(256).collect::<String>();

let block = blocks::image
    ::Contents
    ::from_alt_text_and_url("", "")
    .with_block_id(long_string);

assert_eq!(true, matches!(block.validate(), Err(_)));

Trait Implementations

impl Clone for Contents[src]

fn clone(&self) -> Contents[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for Contents[src]

fn fmt(&self, f: &mut Formatter<'_>) -> Result[src]

Formats the value using the given formatter. Read more

impl Default for Contents[src]

fn default() -> Contents[src]

Returns the “default value” for a type. Read more

impl<'de> Deserialize<'de> for Contents[src]

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
    __D: Deserializer<'de>, 
[src]

Deserialize this value from the given Serde deserializer. Read more

impl From<Contents> for Block<'static>[src]

fn from(src: Contents) -> Self[src]

Performs the conversion.

impl Hash for Contents[src]

fn hash<__H: Hasher>(&self, state: &mut __H)[src]

Feeds this value into the given Hasher. Read more

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0[src]

Feeds a slice of this type into the given Hasher. Read more

impl PartialEq<Contents> for Contents[src]

fn eq(&self, other: &Contents) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &Contents) -> bool[src]

This method tests for !=.

impl Serialize for Contents[src]

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error> where
    __S: Serializer
[src]

Serialize this value into the given Serde serializer. Read more

impl Validate for Contents[src]

impl StructuralPartialEq for Contents[src]

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

Creates owned data from borrowed data, usually by cloning. Read more

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

Uses borrowed data to replace owned data, usually by cloning. Read more

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]

Performs the conversion.

impl<T> DeserializeOwned for T where
    T: for<'de> Deserialize<'de>, 
[src]