Skip to main content

MultiSelect

Struct MultiSelect 

Source
pub struct MultiSelect<'a, T> {
    pub title: String,
    pub theme: &'a Theme,
    pub description: String,
    pub options: Vec<DemandOption<T>>,
    pub min: usize,
    pub max: usize,
    pub filterable: bool,
    pub filtering: bool,
    pub filter: String,
    /* private fields */
}
Expand description

Select multiple options from a list

§Example

use demand::{DemandOption, MultiSelect};

let multiselect = MultiSelect::new("Toppings")
  .description("Select your toppings")
  .min(1)
  .max(4)
  .filterable(true)
  .option(DemandOption::new("Lettuce").selected(true))
  .option(DemandOption::new("Tomatoes").selected(true))
  .option(DemandOption::new("Charm Sauce"))
  .option(DemandOption::new("Jalapenos").label("Jalapeños"))
  .option(DemandOption::new("Cheese"))
  .option(DemandOption::new("Vegan Cheese"))
  .option(DemandOption::new("Nutella"));
let toppings = match multiselect.run() {
  Ok(toppings) => toppings,
  Err(e) => {
      if e.kind() == std::io::ErrorKind::Interrupted {
          println!("Input cancelled");
          return;
      } else {
          panic!("Error: {}", e);
      }
  }
};

Fields§

§title: String

The title of the selector

§theme: &'a Theme

The colors/style of the selector

§description: String

A description to display after the title

§options: Vec<DemandOption<T>>

The options which can be selected

§min: usize

The minimum number of options which must be selected

§max: usize

The maximum number of options which can be selected

§filterable: bool

Whether the selector can be filtered with a query

§filtering: bool

Whether the selector is currently being filtered

§filter: String

A filter query to preset when filtering is true

Implementations§

Source§

impl<'a, T> MultiSelect<'a, T>

Source

pub fn new<S: Into<String>>(title: S) -> Self

Create a new multi select with the given title

Source

pub fn description(self, description: &str) -> Self

Set the description of the selector

Source

pub fn option(self, option: DemandOption<T>) -> Self

Add an option to the selector

Source

pub fn options(self, options: Vec<DemandOption<T>>) -> Self

Add multiple options to the selector

Source

pub fn min(self, min: usize) -> Self

Set the minimum number of options which must be selected

Source

pub fn max(self, max: usize) -> Self

Set the maximum number of options which can be selected

Source

pub fn filterable(self, filterable: bool) -> Self

Set whether the selector can be filtered with a query

Source

pub fn filtering(self, filtering: bool) -> Self

Source

pub fn filter(self, filter: &str) -> Self

Source

pub fn theme(self, theme: &'a Theme) -> Self

Set the theme of the selector

Source

pub fn run(self) -> Result<Vec<T>>

Displays the selector to the user and returns their selected options

This function will block until the user submits the input. If the user cancels the input, an error of type io::ErrorKind::Interrupted is returned.

Auto Trait Implementations§

§

impl<'a, T> !Freeze for MultiSelect<'a, T>

§

impl<'a, T> RefUnwindSafe for MultiSelect<'a, T>
where T: RefUnwindSafe,

§

impl<'a, T> Send for MultiSelect<'a, T>
where T: Send,

§

impl<'a, T> Sync for MultiSelect<'a, T>
where T: Sync,

§

impl<'a, T> Unpin for MultiSelect<'a, T>
where T: Unpin,

§

impl<'a, T> UnwindSafe for MultiSelect<'a, T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.