Expand description
Useful imports.
Re-exports
Modules
Macros
- Alias for
Cow::Borrowed
, because that’s used a million times so shortening it is nice. Makes the code more readable. - Example usage:
- Start the hot reloading server with the current directory as the root
- The rsx! macro makes it easy for developers to write jsx-style markup in their components.
- The rsx! macro makes it easy for developers to write jsx-style markup in their components.
- Create
FooThemeWith
structs without having to deal with the verbose syntax. - A helper macro for using hooks and properties in async environments.
- This macro has three arguments separator by commas.
Structs
AccordionBody
component properties.Accordion
component properties.AccordionSummary
component properties.- Theming properties for the
Accordion
component. - You can use this to change a theme for only one component, with the
theme
property. - Manage the lifecyle of an Animation.
- Theming properties for the
ArrowIcon
component. - You can use this to change a theme for only one component, with the
theme
property. - An attribute on a DOM node, such as
id="my-thing"
orhref="https://example.com"
Body
component properties.- Theming properties for the
Body
component. - You can use this to change a theme for only one component, with the
theme
property. Button
component properties.- Theming properties for the
Button
component. - You can use this to change a theme for only one component, with the
theme
property. Canvas
component properties.- Theming properties for the
Canvas
component. - You can use this to change a theme for only one component, with the
theme
property. - An object that can efficiently compare a value to a set of values.
- CopyValue is a wrapper around a value to make the value mutable and Copy.
CursorArea
component properties.- Desktop renderer for Freya.
DragProvider
component properties.DragZone
component properties.DropZone
component properties.DropdownItem
component properties.- Theming properties for the
DropdownItem
component. - You can use this to change a theme for only one component, with the
theme
property. Dropdown
component properties.- Theming properties for the
Dropdown
component. - You can use this to change a theme for only one component, with the
theme
property. - Create a configuration for a
UseEditable
. - Effects allow you to run code when a signal changes. Effects are run immediately and whenever any signal it reads changes.
- A boundary that will capture any errors from child components
- A wrapper around some generic data that handles the event’s state
- The callback type generated by the
rsx!
macro when anon
field is specified for components. ExternalLink
component properties.- Theming properties for the
ExternalLink
component. - You can use this to change a theme for only one component, with the
theme
property. - Theming properties for Fonts.
- You can use this to change a theme for only one component, with the
theme
property. Theming properties for Fonts. GestureArea
component properties.- A signal that can be accessed from anywhere in the application and created in a static
- A signal that can be accessed from anywhere in the application and created in a static
- Data line for the
Graph
component. Graph
component properties.- Theming properties for the
Graph
component. - You can use this to change a theme for only one component, with the
theme
property. Input
component properties.- Theming properties for the
Input
component. - You can use this to change a theme for only one component, with the
theme
property. - Data of a Keyboard event.
- Launch configuration.
- Configuration Builder.
- A text line from a TextEditor
- Iterator over text lines.
Loader
component properties.- Theming properties for the
Loader
component. - You can use this to change a theme for only one component, with the
theme
property. - A read only signal that has been mapped to a new type.
- Data of a Mouse event.
NetworkImage
component properties.- Theming properties for the
NetworkImage
component. - You can use this to change a theme for only one component, with the
theme
property. - Node layout configuration
- Cached layout results of a Node
- Data of a Mouse event.
ProgressBar
component properties.- Theming properties for the
ProgressBar
component. - You can use this to change a theme for only one component, with the
theme
property. - A signal that can only be read from.
- An iterator over the values of a
Readable<Vec<T>>
. - A 2d Rectangle optionally tagged with a unit.
- A utf8 text rope.
- TextEditor implementing a Rope
- A global runtime that is shared across all scopes that provides the async runtime and context API
- A guard for a new runtime. This must be used to override the current runtime when importing components from a dynamic library that has it’s own runtime.
- A component’s unique identifier.
- A component’s rendered state.
- Theming properties for the
ScrollBar
component. - You can use this to change a theme for only one component, with the
theme
property. ScrollView
component properties.- Theming properties for the
ScrollView
component. Also used byVirtualScrollView
. - You can use this to change a theme for only one component, with the
theme
property. Also used byVirtualScrollView
. - Creates a new Signal. Signals are a Copy state management solution with automatic dependency tracking.
- The data stored for tracking in a signal.
Slider
component properties.- Theming properties for the
Slider
component. - You can use this to change a theme for only one component, with the
theme
property. Switch
component properties.- Theming properties for the
Switch
component. - You can use this to change a theme for only one component, with the
theme
property. - A thread safe storage. This is slower than the unsync storage, but allows you to share the value between threads.
TableBody
component properties.TableCell
component properties.TableHead
component properties.Table
component properties.TableRow
component properties.- Theming properties for the
Table
component. - You can use this to change a theme for only one component, with the
theme
property. - A task’s unique identifier.
- A static layout of a UI tree that describes a set of dynamic and static nodes.
- Holds the position of a cursor in a text
- Events for TextEditor
ThemeProvider
component properties.Tooltip
component properties.- Theming properties for the
Tooltip
component. - You can use this to change a theme for only one component, with the
theme
property. - Data of a Touch event.
- Manage the lifecyle of a collection of transitions.
- The receiving end of an unbounded mpsc channel.
- The transmission end of an unbounded mpsc channel.
- Pass uniform values to a Shader.
- A unsync storage. This is the default storage type.
- Holds a rendering hook callback that allows to render to the Canvas.
- Manage an editable content.
- Manage the focus operations of given Node
- A reference to a template along with any context needed to hydrate it
- A reference to a template along with any context needed to hydrate it
- A virtual node system that progresses user events and diffs UI trees.
VirtualScrollView
component properties.- Data of a Wheel event.
- Configuration for a Window.
- Manager for a Window
- An iterator over the values of a
Writable<Vec<T>>
. - A mutable reference to a signal’s value.
Enums
- Indicates the current status of the accordion.
- Animation mode and configuration.
- Identifies the current status of the Button.
- A clone-on-write smart pointer.
- Group all the custom attribute types
- Current status of the DropdownItem.
- Current status of the Dropdown.
- Events emitted to the
UseEditable
. - How the editable content must behave.
- Gesture emitted by the
GestureArea
component. - Image status.
- Enum to declare is
Input
hidden. - Indicates the current status of the Input.
- Contains the best Root node candidate from where to start measuring
- Describes the current status of the Slider.
- Describes the current status of the Switch.
- An attribute of the TemplateNode, created at compile time
- A statically known node in a layout.
- Configure a
Transition
animation. - Stores the current state for a
Transition
. - Uniform value to be passed to a Shader.
Constants
Traits
- Any component that implements the
ComponentFn
trait can be used as a component. - A trait for giving a type a useful default value.
- A dependency is a trait that can be used to determine if a effect or selector should be re-run.
- A dependency is a trait that can be used to determine if a effect or selector should be re-run.
- A trait for anything that has a dynamic list of attributes
- A value that can be converted into an attribute value
- A trait that allows various items to be converted into a dynamic node for the rsx macro
- Every “Props” used for a component must implement the
Properties
trait. This trait gives some hints to Dioxus on how to memoize the props and some additional optimizations that can be made. We strongly encourage using the derive macro to implement theProperties
trait automatically as guarantee that your memoization strategy is safe. - A trait for states that can be read from like
crate::Signal
,crate::GlobalSignal
, orcrate::ReadOnlySignal
. You may choose to accept this trait as a parameter instead of the concrete type to allow for more flexibility in your API. For example, instead of creating two functions, one that accepts acrate::Signal
and one that accepts acrate::GlobalSignal
, you can create one function that accepts aReadable
type. - An extension trait for Readable<Option
> that provides some convenience methods. - An extension trait for Readable<Vec
> that provides some convenience methods. - A trait for a storage backing type. (RefCell, RwLock, etc.)
- A enhanced version of the
From
trait that allows with more flexibility. - A enhanced version of the
Into
trait that allows with more flexibility. - Common trait for editable texts
- A trait to allow results to be thrown upwards to the nearest Error Boundary
- A trait for states that can be read from like
crate::Signal
, orcrate::GlobalSignal
. You may choose to accept this trait as a parameter instead of the concrete type to allow for more flexibility in your API. For example, instead of creating two functions, one that accepts acrate::Signal
and one that accepts acrate::GlobalSignal
, you can create one function that accepts aWritable
type. - An extension trait for Writable<Option
> that provides some convenience methods. - An extension trait for Writable<Vec
> that provides some convenience methods.
Functions
Accordion
component.AccordionBody
component.AccordionSummary
component.Body
component.Button
component.- Draw anything inside of this canvas.
CursorArea
component.- Make the inner children draggable to other
DropZone
. - Elements from
DragZone
s can be dropped here. Dropdown
component.DropdownItem
component.- Create a new error boundary component.
Link
for external locations, e.g websites.- Create inline fragments using Component syntax.
GestureArea
component.- Graph component.
Input
component.Loader
component.NetworkImage
component.ProgressBar
component.ScrollView
component.- Controlled
Slider
component. - Controlled
Switch
component. Table
component.TableBody
component.TableCell
component.TableHead
component.TableRow
component.- Provides a
Theme
for all its children. Tooltip
componentVirtualScrollView
component.- Transform some bytes (e.g: raw image, raw svg) into attribute data
- Consume context from the current scope
- Consume context from the current scope
- Get the current scope id
- This utility function launches the builder method so rsx! and html! macros can use the typed-builder pattern to initialize a component’s props.
- Get the current render since the inception of this component
- Check if the current scope has a context
- Mark the current scope as dirty, causing it to re-render
- Get the parent of the current scope if it exists
- Provide context to the current scope
- Provide a context to the root scope
- Informs the scheduler that this task is no longer needed and should be removed.
- Calculate some chained operations with a given value. This value could be for example the width of a node’s parent area.
- Schedule an update for the current component
- Schedule an update for any component given its
ScopeId
. - Spawns the future but does not return the [
TaskId
] - Spawn a future that Dioxus won’t clean up when this component is unmounted
- Suspends the current component
- Consume context from the current scope
- Consume some context in the tree, providing a sharable handle to the value
- Run animations.
- Run a group of animated transitions.
- Register a rendering hook to gain access to the Canvas.
- Creates a new Comparer which efficiently tracks when a value changes to check if it is equal to a set of values.
- Consume some context in the tree, providing a sharable handle to the value
- Provide some context via the tree and return a reference to it
- Maintain a handle over a future that can be paused, resumed, and canceled.
- Get a handle to a coroutine higher in the tree
- Creates a callback that will be run before the component is removed. This can be used to clean up side effects from the component (created with
use_effect
). - Create a virtual text editor with it’s own cursor and rope.
- Create a new effect. The effect will be run immediately and whenever any signal it reads changes. The signal will be owned by the current component and will be dropped when the component is dropped.
- Provide an error boundary to catch errors from child components
- Create a focus manager for a node.
- A hook that allows you to spawn a future
- Store a value between renders. The foundational hook for all other hooks.
- Sync both the Focus shared state and the platform accessibility focus
- Provide the default
Theme
. - Create a focus provider.
- Provide a custom
Theme
. - Creates a new Selector that may be sync. The selector will be run immediately and whenever any signal it reads changes.
- Creates a new Selector that may be sync with some local dependencies. The selector will be run immediately and whenever any signal it reads or any dependencies it tracks changes
- Creates a new unsync Selector. The selector will be run immediately and whenever any signal it reads changes.
- Creates a new unsync Selector with some local dependencies. The selector will be run immediately and whenever any signal it reads or any dependencies it tracks changes
- Subscribe to a Node layout changes.
- Get a signal to read the latest layout from a Node.
- use_on_unmountDeprecated
- A future that resolves to a value.
- Creates a new Signal. Signals are a Copy state management solution with automatic dependency tracking.
- Creates a new `Send + Sync`` Signal. Signals are a Copy state management solution with automatic dependency tracking.
- Subscribe to
Theme
changes.
Type Aliases
- A signal that can safely shared between threads.
Attribute Macros
- Streamlines component creation. This is the recommended way of creating components, though you might want lower-level control with more advanced uses.
- Derive props for a component within the component definition.
Derive Macros
- Derive macro generating an impl of the trait
Default
.