Add enabled state to Checkbox

This commit is contained in:
Alexandre Bury 2016-07-16 18:36:54 -07:00
parent 77a623674a
commit 02b6b6601f

View File

@ -2,6 +2,7 @@ use With;
use Cursive; use Cursive;
use Printer; use Printer;
use vec::Vec2; use vec::Vec2;
use theme::ColorStyle;
use view::View; use view::View;
use event::{Event, EventResult, Key}; use event::{Event, EventResult, Key};
use direction::Direction; use direction::Direction;
@ -12,6 +13,7 @@ use std::rc::Rc;
/// Checkable box. /// Checkable box.
pub struct Checkbox { pub struct Checkbox {
checked: bool, checked: bool,
enabled: bool,
on_change: Option<Rc<Fn(&mut Cursive, bool)>>, on_change: Option<Rc<Fn(&mut Cursive, bool)>>,
} }
@ -23,19 +25,51 @@ impl Checkbox {
pub fn new() -> Self { pub fn new() -> Self {
Checkbox { Checkbox {
checked: false, checked: false,
enabled: true,
on_change: None, on_change: None,
} }
} }
/// Disables this view.
///
/// A disabled view cannot be selected.
pub fn disable(&mut self) {
self.enabled = false;
}
/// Disables this view.
///
/// Chainable variant.
pub fn disabled(self) -> Self {
self.with(Self::disable)
}
/// Re-enables this view.
pub fn enable(&mut self) {
self.enabled = true;
}
/// Enable or disable this view.
pub fn set_enabled(&mut self, enabled: bool) {
self.enabled = enabled;
}
/// Returns `true` if this view is enabled.
pub fn is_enabled(&self) -> bool {
self.enabled
}
/// Sets a callback to be used when the state changes. /// Sets a callback to be used when the state changes.
pub fn set_on_change<F: 'static + Fn(&mut Cursive, bool)>(&mut self, on_change: F) { pub fn set_on_change<F: 'static + Fn(&mut Cursive, bool)>(&mut self,
on_change: F) {
self.on_change = Some(Rc::new(on_change)); self.on_change = Some(Rc::new(on_change));
} }
/// Sets a callback to be used when the state changes. /// Sets a callback to be used when the state changes.
/// ///
/// Chainable variant. /// Chainable variant.
pub fn on_change<F: 'static + Fn(&mut Cursive, bool)>(self, on_change: F) -> Self { pub fn on_change<F: 'static + Fn(&mut Cursive, bool)>(self, on_change: F)
-> Self {
self.with(|s| s.set_on_change(on_change)) self.with(|s| s.set_on_change(on_change))
} }
@ -54,7 +88,9 @@ impl Checkbox {
/// ///
/// Chainable variant. /// Chainable variant.
pub fn checked(self) -> Self { pub fn checked(self) -> Self {
self.with(|s| {s.check();}) self.with(|s| {
s.check();
})
} }
/// Returns `true` if the checkbox is checked. /// Returns `true` if the checkbox is checked.
@ -71,7 +107,9 @@ impl Checkbox {
/// ///
/// Chainable variant. /// Chainable variant.
pub fn unchecked(self) -> Self { pub fn unchecked(self) -> Self {
self.with(|s| { s.uncheck(); }) self.with(|s| {
s.uncheck();
})
} }
/// Sets the checkbox state. /// Sets the checkbox state.
@ -84,6 +122,13 @@ impl Checkbox {
EventResult::Consumed(None) EventResult::Consumed(None)
} }
} }
fn draw_internal(&self, printer: &Printer) {
printer.print((0, 0), "[ ]");
if self.checked {
printer.print((1, 0), "X");
}
}
} }
impl View for Checkbox { impl View for Checkbox {
@ -92,16 +137,17 @@ impl View for Checkbox {
} }
fn take_focus(&mut self, _: Direction) -> bool { fn take_focus(&mut self, _: Direction) -> bool {
true self.enabled
} }
fn draw(&self, printer: &Printer) { fn draw(&self, printer: &Printer) {
printer.with_selection(printer.focused, |printer| { if self.enabled {
printer.print((0, 0), "[ ]"); printer.with_selection(printer.focused,
if self.checked { |printer| self.draw_internal(printer));
printer.print((1, 0), "X"); } else {
printer.with_color(ColorStyle::Secondary,
|printer| self.draw_internal(printer));
} }
});
} }