cursive/src/view/key_event_view.rs

59 lines
1.6 KiB
Rust
Raw Normal View History

use std::collections::HashMap;
use std::rc::Rc;
2016-03-15 22:37:57 +00:00
use Cursive;
use event::{Callback, Event, EventResult};
2016-03-15 22:37:57 +00:00
use super::{View, ViewWrapper};
/// A simple wrapper view that catches some ignored event from its child.
///
2016-07-21 05:08:06 +00:00
/// If the event doesn't have a corresponding callback, it will stay ignored.
///
/// # Examples
///
/// ```
/// # use cursive::prelude::*;
/// let view = KeyEventView::new(TextView::new("This view has an event!"))
/// .register('q', |s| s.quit())
/// .register(Key::Esc, |s| s.quit());
/// ```
pub struct KeyEventView {
content: Box<View>,
callbacks: HashMap<Event, Callback>,
}
impl KeyEventView {
/// Wraps the given view in a new KeyEventView.
pub fn new<V: View + 'static>(view: V) -> Self {
KeyEventView {
content: Box::new(view),
callbacks: HashMap::new(),
}
}
/// Registers a callback when the given key is ignored by the child.
pub fn register<F, E: Into<Event>>(mut self, event: E, cb: F) -> Self
2015-05-24 00:07:22 +00:00
where F: Fn(&mut Cursive) + 'static
{
self.callbacks.insert(event.into(), Rc::new(cb));
self
}
}
impl ViewWrapper for KeyEventView {
wrap_impl!(self.content);
fn wrap_on_event(&mut self, event: Event) -> EventResult {
match self.content.on_event(event) {
2016-06-25 23:36:22 +00:00
EventResult::Ignored => {
match self.callbacks.get(&event) {
None => EventResult::Ignored,
Some(cb) => EventResult::Consumed(Some(cb.clone())),
}
}
res => res,
}
}
}