7 unstable releases
0.4.0 | May 15, 2021 |
---|---|
0.3.2 | Sep 8, 2020 |
0.3.1 | Aug 16, 2020 |
0.3.0 | Jun 30, 2020 |
0.1.1 | Nov 11, 2019 |
#14 in #html-macro
1,790 downloads per month
Used in 5 crates
690KB
15K
SLoC
Yewtil
A utility crate for the Yew frontend web framework.
This crate used to contain a domain specific language which made it possible to create components without use of the
html!
macro, but this has now been moved into a different crate (yew-dsl
).
Purpose
To provide a place for utilities which are commonly used with Yew to reside without having to include them in the core Yew crate.
Because of this the Yew crate can make breaking changes which will cause yewtil
to become incompatible with Yew.
Features
Currently, this crate supports the following features in a "stable" capacity:
NeqAssign
- makes assigning props and returning a relevant value forShouldRender
easier.- Pure Components - implement pure components using the
PureComponent
trait and thePure
Component adaptor. This should make it much easier to define simple components that don't hold state.- Function components - a macro that takes a function that returns
Html
and converts it to a pure component.
- Function components - a macro that takes a function that returns
Mrc
/Irc
smart pointers - Rc-like pointers that are more ergonomic to use within Yew.History
- A wrapper that holds the history of values that have been assigned to it.Effect
- A way to update component state by defining what to change inside ofhtml!
callbacks instead of handling messages inComponent::update()
. (Deprecated)
This crate also has feature flags which will enable the following experimental features:
Lrc
smart pointer - an Rc-like pointer implemented on top of a linked list which allows for novel state update mechanics and traversal over linked shared pointers. (This needs to be fuzz tested to make sure it doesn't leak.) (Deprecated)
These experimental features are either not sufficiently vetted and may change significantly or be removed.
Example Projects
There are examples showing how to use every stable feature in this crate.
Check out the Pure Components example to see how Pure Components work.
Example usages
neq_assign:
fn change(&mut self, props: Self::Properties) -> ShouldRender {
self.props.neq_assign(props)
}
Pure Components:
pub type Button = Pure<PureButton>;
#[derive(PartialEq, Clone, Properties)]
pub struct PureButton {
pub callback: Callback<Msg>,
#[prop_or_default]
pub text: String,
}
impl PureComponent for PureButton {
fn render(&self) -> VNode {
html! {
<button onclick=&self.callback>{ &self.text }</button>
}
}
}
History
pub struct Model {
text: History<String>,
}
// ...
fn update(&mut self, msg: Self::Message) -> ShouldRender {
match msg {
Msg::SetText(text) => self.text.neq_set(text),
Msg::Reset => self.text.reset(),
Msg::Forget => {
self.text.forget();
false
}
}
}
Update Schedule
This crate will target stable Yew.
As new idioms are introduced to Yew, this crate may see some updates, but given the rarity of those, this crate may sit unaltered for some time.
Scope
This crate has less stringent requirements for its code than the main Yew crate; if you have a function, type, or trait you would like to include, please open a pull request or an issue.
Components are welcome as well, but they must not have external dependencies, should solve some problem encountered by many users of Yew, and should allow for theming if possible, like an auto-scrolling wrapper, a RecyclerView/Infinite-scrolling component, or possibly a comprehensive input component.
Common UI elements like modals or dropdowns are best be left to component libraries, as they are often coupled to external CSS used to display them. The Yewtify crate is one such component library.
Stability
Since this crate aims to provide a variety of helper types, traits, and functions, where the utility of each may be unknown at the time the feature is added, newer additions may be not be included in the default feature set, and may be kept behind a feature flag.
While in early development, features marked as experimental
may be changed frequently or even entirely removed, while those marked as stable
will not be removed and can be relied upon to not change significantly.
Dependencies
~2.6–6.5MB
~116K SLoC