//!
//!

🌗🚀 📦 Dioxus

//!

//! A concurrent, functional, virtual DOM for Rust //!

//!
//! Dioxus: a concurrent, functional, reactive virtual dom for any renderer in Rust. //! //! This crate aims to maintain a uniform hook-based, renderer-agnostic UI framework for cross-platform development. //! //! ## Components //! The base unit of Dioxus is the `component`. Components can be easily created from just a function - no traits required: //! ``` //! use dioxus_core::prelude::*; //! //! #[derive(Properties)] //! struct Props { name: String } //! //! fn Example(ctx: &mut Context) -> VNode { //! html! {
"Hello {ctx.props.name}!"
} //! } //! ``` //! Components need to take a "Context" parameter which is generic over some properties. This defines how the component can be used //! and what properties can be used to specify it in the VNode output. Component state in Dioxus is managed by hooks - if you're new //! to hooks, check out the hook guide in the official guide. //! //! Components can also be crafted as static closures, enabling type inference without all the type signature noise: //! ``` //! use dioxus_core::prelude::*; //! //! #[derive(Properties)] //! struct Props { name: String } //! //! static Example: FC = |ctx, props| { //! html! {
"Hello {props.name}!"
} //! } //! ``` //! //! If the properties struct is too noisy for you, we also provide a macro that converts variadic functions into components automatically. //! ``` //! use dioxus_core::prelude::*; //! //! #[fc] //! static Example: FC = |ctx, name: String| { //! html! {
"Hello {name}!"
} //! } //! ``` //! //! ## Hooks //! Dioxus uses hooks for state management. Hooks are a form of state persisted between calls of the function component. Instead of //! using a single struct to store data, hooks use the "use_hook" building block which allows the persistence of data between //! function component renders. //! //! This allows functions to reuse stateful logic between components, simplify large complex components, and adopt more clear context //! subscription patterns to make components easier to read. //! //! ## Supported Renderers //! Instead of being tightly coupled to a platform, browser, or toolkit, Dioxus implements a VirtualDOM object which //! can be consumed to draw the UI. The Dioxus VDOM is reactive and easily consumable by 3rd-party renderers via //! the `Patch` object. See [Implementing a Renderer](docs/8-custom-renderer.md) and the `StringRenderer` classes for information //! on how to implement your own custom renderer. We provide 1st-class support for these renderers: //! - dioxus-desktop (via WebView) //! - dioxus-web (via WebSys) //! - dioxus-ssr (via StringRenderer) //! - dioxus-liveview (SSR + StringRenderer) //! pub mod component; // Logic for extending FC pub mod context; // Logic for providing hook + context functionality to user components pub mod debug_renderer; pub mod patch; // An "edit phase" described by transitions and edit operations // Test harness for validating that lifecycles and diffs work appropriately // pub mod diff; // pub mod patch; // The diffing algorithm that builds the ChangeList pub mod diff; // the diffing algorithm that builds the ChangeList pub mod error; // Error type we expose to the renderers pub mod events; // Manages the synthetic event API pub mod hooks; // Built-in hooks pub mod nodebuilder; // Logic for building VNodes with a direct syntax pub mod nodes; // Logic for the VNodes pub mod scope; // Logic for single components // pub mod validation; // Logic for validating trees pub mod virtual_dom; // Most fun logic starts here, manages the lifecycle and suspense pub mod builder { pub use super::nodebuilder::*; } // types used internally that are important pub(crate) mod innerlude { // pub(crate) use crate::component::Properties; pub(crate) use crate::component::Properties; pub(crate) use crate::context::Context; pub use crate::diff::LifeCycleEvent; pub(crate) use crate::error::Result; pub use crate::events::{EventTrigger, VirtualEvent}; use crate::nodes; pub use crate::component::ScopeIdx; pub use crate::context::hooks::Hook; pub use crate::nodes::VNode; pub(crate) use nodes::*; pub use crate::diff::DiffMachine; pub use crate::patch::{EditList, EditMachine}; // pub use crate::patchdx; // pub use crate::patchtList; // pub use nodes::iterables::IterableNodes; /// This type alias is an internal way of abstracting over the static functions that represent components. pub type FC

= for<'scope> fn(Context<'scope>, &'scope P) -> DomTree; mod fc2 {} // pub type FC<'a, P: 'a> = for<'scope> fn(Context<'scope>, &'scope P) -> DomTree; // pub type FC

= for<'scope, 'r> fn(Context<'scope>, &'scope P) -> DomTree; // pub type FC

= for<'scope, 'r> fn(Context<'scope>, &'r P) -> VNode<'scope>; // pub type FC

= for<'scope, 'r> fn(Context<'scope>, &'r P) -> VNode<'scope>; // pub type FC

= for<'a> fn(Context<'a, P>) -> VNode<'a>; // TODO @Jon, fix this // hack the VNode type until VirtualNode is fixed in the macro crate pub type VirtualNode<'a> = VNode<'a>; // Re-export the FC macro pub use crate as dioxus; pub use crate::nodebuilder as builder; pub use dioxus_core_macro::{html, rsx}; // pub use dioxus_core_macro::{fc, html, rsx}; } /// Re-export common types for ease of development use. /// Essential when working with the html! macro pub mod prelude { pub use crate::component::{fc_to_builder, Properties}; pub use crate::context::Context; use crate::nodes; pub use nodes::*; // pub use nodes::iterables::IterableNodes; /// This type alias is an internal way of abstracting over the static functions that represent components. pub use crate::innerlude::FC; // TODO @Jon, fix this // hack the VNode type until VirtualNode is fixed in the macro crate // expose our bumpalo type pub use bumpalo; pub use bumpalo::Bump; // Re-export the FC macro pub use crate as dioxus; pub use crate::nodebuilder as builder; // pub use dioxus_core_macro::fc; pub use dioxus_core_macro::{format_args_f, html, rsx, Props}; pub use crate::component::ScopeIdx; pub use crate::diff::DiffMachine; pub use crate::debug_renderer::DebugRenderer; pub use crate::hooks::*; }