make run sensors sane and adjust on_edit to just use ui as ctx (so two run calls needed)
This commit is contained in:
@@ -4,9 +4,13 @@ use crate::{
|
||||
};
|
||||
|
||||
pub trait UiCtx {
|
||||
fn ui(&mut self) -> &mut Ui
|
||||
where
|
||||
Self: Sized;
|
||||
fn ui(&mut self) -> &mut Ui;
|
||||
}
|
||||
|
||||
impl UiCtx for Ui {
|
||||
fn ui(&mut self) -> &mut Ui {
|
||||
self
|
||||
}
|
||||
}
|
||||
|
||||
pub trait Event<Ctx>: Sized {
|
||||
@@ -21,48 +25,36 @@ pub trait EventModule<Ctx, E: Event<Ctx>> {
|
||||
pub trait EventFn<Ctx, Data>: FnMut(&mut Ctx, Data) + 'static {}
|
||||
impl<F: FnMut(&mut Ctx, Data) + 'static, Ctx, Data> EventFn<Ctx, Data> for F {}
|
||||
|
||||
pub trait Eventable<W, Ctx, Tag> {
|
||||
fn on<E: Event<Ctx>>(
|
||||
pub trait Eventable<W, Tag> {
|
||||
fn on<E: Event<Ctx>, Ctx>(
|
||||
self,
|
||||
event: E,
|
||||
f: impl EventFn<Ctx, E::Data>,
|
||||
) -> impl WidgetIdFn<W> + Eventable<W, Ctx, IdFnTag>;
|
||||
) -> impl WidgetIdFn<W> + Eventable<W, IdFnTag>;
|
||||
|
||||
fn id_on<E: Event<Ctx>>(
|
||||
fn id_on<E: Event<Ctx>, Ctx>(
|
||||
self,
|
||||
event: E,
|
||||
f: impl FnMut(&WidgetId<W>, &mut Ctx, E::Data) + 'static,
|
||||
) -> impl WidgetIdFn<W> + Eventable<W, Ctx, IdFnTag>
|
||||
) -> impl WidgetIdFn<W> + Eventable<W, IdFnTag>
|
||||
where
|
||||
W: Widget;
|
||||
|
||||
fn edit_on<E: Event<Ctx>>(
|
||||
fn edit_on<E: Event<Ui>>(
|
||||
self,
|
||||
event: E,
|
||||
f: impl FnMut(&mut W, E::Data) + 'static,
|
||||
) -> impl WidgetIdFn<W> + Eventable<W, Ctx, IdFnTag>
|
||||
) -> impl WidgetIdFn<W> + Eventable<W, IdFnTag>
|
||||
where
|
||||
W: Widget,
|
||||
Ctx: UiCtx;
|
||||
W: Widget;
|
||||
}
|
||||
|
||||
pub trait Ctxable<W, Tag> {
|
||||
/// sets context which lets event functions work without needing to specify generics
|
||||
fn ctx<Ctx>(self) -> impl WidgetLike<Tag> + Eventable<W, Ctx, Tag>;
|
||||
}
|
||||
|
||||
impl<W: WidgetLike<Tag>, Tag> Ctxable<W::Widget, Tag> for W {
|
||||
fn ctx<Ctx>(self) -> impl WidgetLike<Tag> + Eventable<W::Widget, Ctx, Tag> {
|
||||
self
|
||||
}
|
||||
}
|
||||
|
||||
impl<W: WidgetLike<Tag>, Ctx, Tag> Eventable<W::Widget, Ctx, Tag> for W {
|
||||
fn on<E: Event<Ctx>>(
|
||||
impl<W: WidgetLike<Tag>, Tag> Eventable<W::Widget, Tag> for W {
|
||||
fn on<E: Event<Ctx>, Ctx>(
|
||||
self,
|
||||
event: E,
|
||||
f: impl EventFn<Ctx, E::Data>,
|
||||
) -> impl WidgetIdFn<W::Widget> + Eventable<W::Widget, Ctx, IdFnTag> {
|
||||
) -> impl WidgetIdFn<W::Widget> {
|
||||
move |ui| {
|
||||
let id = self.add(ui);
|
||||
ui.modules
|
||||
@@ -72,11 +64,11 @@ impl<W: WidgetLike<Tag>, Ctx, Tag> Eventable<W::Widget, Ctx, Tag> for W {
|
||||
}
|
||||
}
|
||||
|
||||
fn id_on<E: Event<Ctx>>(
|
||||
fn id_on<E: Event<Ctx>, Ctx>(
|
||||
self,
|
||||
event: E,
|
||||
mut f: impl FnMut(&WidgetId<W::Widget>, &mut Ctx, E::Data) + 'static,
|
||||
) -> impl WidgetIdFn<W::Widget> + Eventable<W::Widget, Ctx, IdFnTag>
|
||||
) -> impl WidgetIdFn<W::Widget>
|
||||
where
|
||||
W::Widget: Widget,
|
||||
{
|
||||
@@ -86,15 +78,14 @@ impl<W: WidgetLike<Tag>, Ctx, Tag> Eventable<W::Widget, Ctx, Tag> for W {
|
||||
})
|
||||
}
|
||||
|
||||
fn edit_on<E: Event<Ctx>>(
|
||||
fn edit_on<E: Event<Ui>>(
|
||||
self,
|
||||
event: E,
|
||||
mut f: impl FnMut(&mut W::Widget, E::Data) + 'static,
|
||||
) -> impl WidgetIdFn<W::Widget> + Eventable<W::Widget, Ctx, IdFnTag>
|
||||
) -> impl WidgetIdFn<W::Widget>
|
||||
where
|
||||
W::Widget: Widget,
|
||||
Ctx: UiCtx,
|
||||
{
|
||||
self.id_on(event, move |id, ctx, pos| f(&mut ctx.ui()[id], pos))
|
||||
self.id_on(event, move |id, ui, pos| f(&mut ui[id], pos))
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user