2019-10-23 01:33:38 +11:00
|
|
|
use std::fmt::Display;
|
|
|
|
|
2019-10-28 07:07:09 +11:00
|
|
|
use super::StyledContent;
|
2019-10-23 01:33:38 +11:00
|
|
|
|
|
|
|
/// Provides a set of methods to set the colors.
|
|
|
|
///
|
|
|
|
/// Every method with the `on_` prefix sets the background color. All other methods set
|
|
|
|
/// the foreground color.
|
|
|
|
///
|
|
|
|
/// Method names correspond to the [`Color`](enum.Color.html) enum variants.
|
|
|
|
///
|
|
|
|
/// # Examples
|
|
|
|
///
|
|
|
|
/// ```no_run
|
|
|
|
/// use crossterm::Colorize;
|
|
|
|
///
|
|
|
|
/// let styled_text = "Red foreground color on blue background.".red().on_blue();
|
|
|
|
/// println!("{}", styled_text);
|
|
|
|
/// ```
|
|
|
|
pub trait Colorize<D: Display + Clone> {
|
2019-10-28 07:07:09 +11:00
|
|
|
fn black(self) -> StyledContent<D>;
|
|
|
|
fn dark_grey(self) -> StyledContent<D>;
|
|
|
|
fn red(self) -> StyledContent<D>;
|
|
|
|
fn dark_red(self) -> StyledContent<D>;
|
|
|
|
fn green(self) -> StyledContent<D>;
|
|
|
|
fn dark_green(self) -> StyledContent<D>;
|
|
|
|
fn yellow(self) -> StyledContent<D>;
|
|
|
|
fn dark_yellow(self) -> StyledContent<D>;
|
|
|
|
fn blue(self) -> StyledContent<D>;
|
|
|
|
fn dark_blue(self) -> StyledContent<D>;
|
|
|
|
fn magenta(self) -> StyledContent<D>;
|
|
|
|
fn dark_magenta(self) -> StyledContent<D>;
|
|
|
|
fn cyan(self) -> StyledContent<D>;
|
|
|
|
fn dark_cyan(self) -> StyledContent<D>;
|
|
|
|
fn white(self) -> StyledContent<D>;
|
|
|
|
fn grey(self) -> StyledContent<D>;
|
2019-10-23 01:33:38 +11:00
|
|
|
|
2019-10-28 07:07:09 +11:00
|
|
|
fn on_black(self) -> StyledContent<D>;
|
|
|
|
fn on_dark_grey(self) -> StyledContent<D>;
|
|
|
|
fn on_red(self) -> StyledContent<D>;
|
|
|
|
fn on_dark_red(self) -> StyledContent<D>;
|
|
|
|
fn on_green(self) -> StyledContent<D>;
|
|
|
|
fn on_dark_green(self) -> StyledContent<D>;
|
|
|
|
fn on_yellow(self) -> StyledContent<D>;
|
|
|
|
fn on_dark_yellow(self) -> StyledContent<D>;
|
|
|
|
fn on_blue(self) -> StyledContent<D>;
|
|
|
|
fn on_dark_blue(self) -> StyledContent<D>;
|
|
|
|
fn on_magenta(self) -> StyledContent<D>;
|
|
|
|
fn on_dark_magenta(self) -> StyledContent<D>;
|
|
|
|
fn on_cyan(self) -> StyledContent<D>;
|
|
|
|
fn on_dark_cyan(self) -> StyledContent<D>;
|
|
|
|
fn on_white(self) -> StyledContent<D>;
|
|
|
|
fn on_grey(self) -> StyledContent<D>;
|
2019-10-23 01:33:38 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Provides a set of methods to set the text attributes.
|
|
|
|
///
|
|
|
|
/// Method names correspond to the [`Attribute`](enum.Attribute.html) enum variants.
|
|
|
|
///
|
|
|
|
/// # Examples
|
|
|
|
///
|
|
|
|
/// ```no_run
|
|
|
|
/// use crossterm::Styler;
|
|
|
|
///
|
|
|
|
/// println!("{}", "Bold text".bold());
|
|
|
|
/// println!("{}", "Underlined text".underlined());
|
|
|
|
/// println!("{}", "Negative text".negative());
|
|
|
|
/// ```
|
|
|
|
pub trait Styler<D: Display + Clone> {
|
2019-10-28 07:07:09 +11:00
|
|
|
fn reset(self) -> StyledContent<D>;
|
|
|
|
fn bold(self) -> StyledContent<D>;
|
|
|
|
fn underlined(self) -> StyledContent<D>;
|
|
|
|
fn reverse(self) -> StyledContent<D>;
|
|
|
|
fn dim(self) -> StyledContent<D>;
|
|
|
|
fn italic(self) -> StyledContent<D>;
|
|
|
|
fn negative(self) -> StyledContent<D>;
|
|
|
|
fn slow_blink(self) -> StyledContent<D>;
|
|
|
|
fn rapid_blink(self) -> StyledContent<D>;
|
|
|
|
fn hidden(self) -> StyledContent<D>;
|
|
|
|
fn crossed_out(self) -> StyledContent<D>;
|
2019-10-23 01:33:38 +11:00
|
|
|
}
|