1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
|
//! This example demonstrates using [`Color`] as a [`CellOption`] modifier to stylize
//! the cells of a [`Table`].
//!
//! * Note how the [`Color`] [setting](tabled::settings) is used to simplify creating
//! reusable themes for backgrounds.
use tabled::{
settings::{Color, Modify, Style},
Table, Tabled,
};
#[derive(Tabled)]
struct Bsd {
distribution: &'static str,
year_of_first_release: usize,
is_active: bool,
}
impl Bsd {
fn new(distribution: &'static str, year_of_first_release: usize, is_active: bool) -> Self {
Self {
distribution,
year_of_first_release,
is_active,
}
}
}
fn main() {
let data = vec![
Bsd::new("BSD", 1978, false),
Bsd::new("SunOS", 1982, false),
Bsd::new("NetBSD", 1993, true),
Bsd::new("FreeBSD", 1993, true),
Bsd::new("OpenBSD", 1995, true),
];
let mut table = Table::new(data);
table
.with(Style::psql())
.with(Modify::new((0, 0)).with(Color::BG_BLUE))
.with(Modify::new((1, 1)).with(Color::BG_GREEN))
.with(Modify::new((2, 2)).with(Color::BG_RED));
println!("{table}");
}
|