#![forbid(unsafe_code)]
#![allow(
clippy::use_self,
clippy::single_match_else,
clippy::must_use_candidate
)]
#![allow(deprecated)]
pub use crate::{
app::{App, AppBuilder},
browser::dom::cast::{
to_html_el, to_input, to_kbevent, to_mouse_event, to_select, to_textarea,
},
browser::service::fetch,
browser::service::fetch::{Method, Request, ResponseDataResult, ResponseResult},
browser::service::routing::push_route,
browser::service::storage,
browser::url::Url,
browser::util::{
self, body, canvas, canvas_context_2d, cookies, document, error, history, html_document,
log, window,
},
virtual_dom::{Attrs, EventHandler, Style},
};
use wasm_bindgen::{closure::Closure, JsCast};
#[macro_use]
pub mod shortcuts;
pub mod app;
pub mod browser;
pub mod dom_entity_names;
pub mod virtual_dom;
pub const fn empty<Ms>() -> virtual_dom::Node<Ms> {
virtual_dom::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::{
app::{
builder::init::Init, AfterMount, App, BeforeMount, MessageMapper, MountType, Orders,
RenderTimestampDelta, UrlHandling,
},
browser::dom::css_units::*,
browser::dom::event_handler::{
ev, input_ev, keyboard_ev, mouse_ev, pointer_ev, raw_ev, simple_ev,
},
browser::util::{
request_animation_frame, ClosureNew, RequestAnimationFrameHandle,
RequestAnimationFrameTime,
},
browser::Url,
shortcuts::*,
virtual_dom::{
el_ref::el_ref, AsAtValue, At, AtValue, CSSValue, El, ElRef, Ev, EventHandler, Node,
St, Tag, UpdateEl, View,
},
};
pub use indexmap::IndexMap; pub use wasm_bindgen::prelude::*;
pub use web_sys::Event;
}
#[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::app::{builder::init::Init, Orders};
use crate::browser::dom::event_handler::mouse_ev;
use crate::prelude::*;
use crate::virtual_dom::{EventHandler, Node};
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<EventHandler<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();
}
}
}