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
//! EventTarget is a DOM interface implemented by objects that can receive
//! events and may have listeners for them.

use crate::interfaces::node::NodeWrapper;
use augdom::event::{Event, EventHandle};
use moxie::cache_with;

/// EventTarget is a DOM interface implemented by objects that can receive
/// events and may have listeners for them.
///
/// Element, Document, and Window are the most common event targets, but other
/// objects can be event targets, too. For example XMLHttpRequest, AudioNode,
/// AudioContext, and others.
///
/// Many event targets (including elements, documents, and windows) also support
/// setting event handlers via onevent properties and attributes.
///
/// Note: this trait cannot be implemented outside of this crate.
pub trait EventTarget<Ev>: NodeWrapper
where
    Ev: 'static + Event,
{
    /// Declare an event handler on the element.
    ///
    /// A guard value is stored as a resulting "effect" of the mutation, and
    /// removes the attribute when `drop`ped, to ensure that the attribute
    /// is removed when this declaration is no longer referenced in the most
    /// recent (`moxie::Revision`).
    ///
    /// Currently this is performed on every Revision, as changes to event
    /// handlers don't typically affect the debugging experience and have
    /// not yet shown up in performance profiles.
    #[topo::nested]
    fn on(self, callback: impl FnMut(Ev) + 'static) -> Self {
        cache_with(
            &moxie::runtime::Revision::current(),
            |_| EventHandle::new(self.raw_node_that_has_sharp_edges_please_be_careful(), callback),
            |_| {},
        );
        self
    }
}