mirror of
https://github.com/adoyle0/leptos-use.git
synced 2025-01-22 16:49:22 -05:00
added websocket docs for use in context
This commit is contained in:
parent
5eaa63f422
commit
7e988c42ea
2 changed files with 103 additions and 2 deletions
|
@ -35,6 +35,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||
- The options `reconnect_limit` and `reconnect_interval` now take a `u64` instead of `Option<u64>` to improve DX.
|
||||
- The option `manual` has been renamed to `immediate` to make it more consistent with other functions.
|
||||
To port please note that `immediate` is the inverse of `manual` (`immediate` = `!manual`).
|
||||
- Added documentation how pass it ergonomically as context.
|
||||
- `use_color_mode`:
|
||||
- The optional `on_changed` handler parameters have changed slightly. Please refer to the docs for more details.
|
||||
- Throttled or debounced functions cannot be `FnOnce` anymore.
|
||||
|
|
|
@ -67,8 +67,8 @@ use web_sys::{BinaryType, CloseEvent, Event, MessageEvent, WebSocket};
|
|||
/// <button on:click=open_connection disabled=connected>"Open"</button>
|
||||
/// <button on:click=close_connection disabled=move || !connected()>"Close"</button>
|
||||
///
|
||||
/// <p>"Receive message: " {move || format!("{:?}", message())}</p>
|
||||
/// <p>"Receive byte message: " {move || format!("{:?}", message_bytes())}</p>
|
||||
/// <p>"Receive message: " {move || format!("{:?}", message.get())}</p>
|
||||
/// <p>"Receive byte message: " {move || format!("{:?}", message_bytes.get())}</p>
|
||||
/// </div>
|
||||
/// }
|
||||
/// # }
|
||||
|
@ -87,6 +87,106 @@ use web_sys::{BinaryType, CloseEvent, Event, MessageEvent, WebSocket};
|
|||
/// | https://example.com/some/where | //otherdomain.com/api/ws | wss://otherdomain.com/api/ws |
|
||||
///
|
||||
///
|
||||
/// ## Usage with `provide_context`
|
||||
///
|
||||
/// The return value of `use_websocket` utilizes several type parameters which can make it
|
||||
/// cumbersome to use with `provide_context` + `expect_context`.
|
||||
/// The following example shows how to avoid type parameters with dynamic dispatch.
|
||||
/// This sacrifices a little bit of performance for the sake of ergonomics. However,
|
||||
/// compared to network transmission speeds this loss of performance is negligible.
|
||||
///
|
||||
/// First we define the `struct` that is going to be passed around as context.
|
||||
///
|
||||
/// ```
|
||||
/// # use leptos::*;
|
||||
/// use std::rc::Rc;
|
||||
///
|
||||
/// #[derive(Clone)]
|
||||
/// pub struct WebsocketContext {
|
||||
/// pub message: Signal<Option<String>>,
|
||||
/// send: Rc<dyn Fn(&str)>, // use Rc to make it easily cloneable
|
||||
/// }
|
||||
///
|
||||
/// impl WebsocketContext {
|
||||
/// pub fn new(message: Signal<Option<String>>, send: Rc<dyn Fn(&str)>) -> Self {
|
||||
/// Self {
|
||||
/// message,
|
||||
/// send,
|
||||
/// }
|
||||
/// }
|
||||
///
|
||||
/// // create a method to avoid having to use parantheses around the field
|
||||
/// #[inline(always)]
|
||||
/// pub fn send(&self, message: &str) {
|
||||
/// (self.send)(message)
|
||||
/// }
|
||||
/// }
|
||||
/// ```
|
||||
///
|
||||
/// Now you can provide the context like the following.
|
||||
///
|
||||
/// ```
|
||||
/// # use leptos::*;
|
||||
/// # use leptos_use::{use_websocket, UseWebsocketReturn};
|
||||
/// # use std::rc::Rc;
|
||||
/// # #[derive(Clone)]
|
||||
/// # pub struct WebsocketContext {
|
||||
/// # pub message: Signal<Option<String>>,
|
||||
/// # send: Rc<dyn Fn(&str)>,
|
||||
/// # }
|
||||
/// #
|
||||
/// # impl WebsocketContext {
|
||||
/// # pub fn new(message: Signal<Option<String>>, send: Rc<dyn Fn(&str)>) -> Self {
|
||||
/// # Self {
|
||||
/// # message,
|
||||
/// # send,
|
||||
/// # }
|
||||
/// # }
|
||||
/// # }
|
||||
///
|
||||
/// # #[component]
|
||||
/// # fn Demo() -> impl IntoView {
|
||||
/// let UseWebsocketReturn {
|
||||
/// message,
|
||||
/// send,
|
||||
/// ..
|
||||
/// } = use_websocket("ws:://some.websocket.io");
|
||||
///
|
||||
/// provide_context(WebsocketContext::new(message, Rc::new(send.clone())));
|
||||
/// #
|
||||
/// # view! {}
|
||||
/// # }
|
||||
/// ```
|
||||
///
|
||||
/// Finally let's use the context:
|
||||
///
|
||||
/// ```
|
||||
/// # use leptos::*;
|
||||
/// # use leptos_use::{use_websocket, UseWebsocketReturn};
|
||||
/// # use std::rc::Rc;
|
||||
/// # #[derive(Clone)]
|
||||
/// # pub struct WebsocketContext {
|
||||
/// # pub message: Signal<Option<String>>,
|
||||
/// # send: Rc<dyn Fn(&str)>,
|
||||
/// # }
|
||||
/// #
|
||||
/// # impl WebsocketContext {
|
||||
/// # #[inline(always)]
|
||||
/// # pub fn send(&self, message: &str) {
|
||||
/// # (self.send)(message)
|
||||
/// # }
|
||||
/// # }
|
||||
///
|
||||
/// # #[component]
|
||||
/// # fn Demo() -> impl IntoView {
|
||||
/// let websocket = expect_context::<WebsocketContext>();
|
||||
///
|
||||
/// websocket.send("Hello World!");
|
||||
/// #
|
||||
/// # view! {}
|
||||
/// # }
|
||||
/// ```
|
||||
///
|
||||
/// ## Server-Side Rendering
|
||||
///
|
||||
/// On the server the returned functions amount to no-ops.
|
||||
|
|
Loading…
Add table
Reference in a new issue