#![allow(clippy::use_self, clippy::single_match_else)]
#![allow(deprecated)]
pub use crate::{
fetch::{Method, Request},
routing::{push_route, Url},
util::{body, cookies, document, error, history, html_document, log, update, window},
vdom::{App, AppBuilder},
websys_bridge::{to_html_el, to_input, to_kbevent, to_mouse_event, to_select, to_textarea},
};
use wasm_bindgen::{closure::Closure, JsCast};
#[macro_use]
pub mod shortcuts;
pub mod dom_entity_names;
pub mod css_units;
pub mod dom_types;
pub mod events;
pub mod fetch;
mod next_tick;
pub mod orders;
mod patch;
pub mod routing;
pub mod storage;
mod util;
mod vdom;
mod websys_bridge;
pub const fn empty<Ms>() -> dom_types::Node<Ms> {
dom_types::Node::Empty
}
pub fn set_interval(handler: Box<dyn Fn()>, timeout: i32) {
let callback = Closure::wrap(handler as Box<dyn Fn()>);
util::window()
.set_interval_with_callback_and_timeout_and_arguments_0(
callback.as_ref().unchecked_ref(),
timeout,
)
.expect("Problem setting interval");
callback.forget();
}
pub fn set_timeout(handler: Box<dyn Fn()>, timeout: i32) {
let callback = Closure::wrap(handler as Box<dyn Fn()>);
util::window()
.set_timeout_with_callback_and_timeout_and_arguments_0(
callback.as_ref().unchecked_ref(),
timeout,
)
.expect("Problem setting timeout");
callback.forget();
}
pub mod prelude {
pub use crate::{
css_units::*,
dom_entity_names::styles::St,
dom_types::{
did_mount, did_update, will_unmount, AsAtValue, At, AtValue, CSSValue, El,
MessageMapper, Node, Tag, UpdateEl, View,
},
events::{
input_ev, keyboard_ev, mouse_ev, pointer_ev, raw_ev, simple_ev, trigger_update_handler,
Ev,
},
orders::Orders,
routing::Url,
shortcuts::*,
util::{
request_animation_frame, ClosureNew, RequestAnimationFrameHandle,
RequestAnimationFrameTime,
},
vdom::{Init, MountType, UrlHandling},
};
pub use indexmap::IndexMap; pub use wasm_bindgen::prelude::*;
}
#[cfg(test)]
pub mod tests {
use wasm_bindgen_test::wasm_bindgen_test_configure;
wasm_bindgen_test_configure!(run_in_browser);
use wasm_bindgen_test::*;
#[wasm_bindgen_test]
#[allow(dead_code)]
pub fn app_builds() {
use crate as seed; use crate::prelude::*;
use crate::{
dom_types::{El, UpdateEl},
events::mouse_ev,
orders::Orders,
};
struct Model {
pub val: i32,
}
impl Default for Model {
fn default() -> Self {
Self { val: 0 }
}
}
#[derive(Clone)]
enum Msg {
Increment,
}
fn update(msg: Msg, model: &mut Model, _: &mut impl Orders<Msg>) {
match msg {
Msg::Increment => model.val += 1,
}
}
fn view(_model: &Model) -> Vec<Node<Msg>> {
vec![div!["Hello world"]]
}
fn window_events(_model: &Model) -> Vec<seed::events::Listener<Msg>> {
vec![mouse_ev("mousemove", |_| Msg::Increment)]
}
fn routes(_url: seed::Url) -> Option<Msg> {
Some(Msg::Increment)
}
#[wasm_bindgen]
pub fn render() {
seed::App::build(|_, _| Init::new(Model::default()), update, view)
.mount("body")
.routes(routes)
.window_events(window_events)
.finish()
.run();
}
}
}