mirror of
https://github.com/adoyle0/leptos-use.git
synced 2025-01-23 00:59: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 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.
|
- 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`).
|
To port please note that `immediate` is the inverse of `manual` (`immediate` = `!manual`).
|
||||||
|
- Added documentation how pass it ergonomically as context.
|
||||||
- `use_color_mode`:
|
- `use_color_mode`:
|
||||||
- The optional `on_changed` handler parameters have changed slightly. Please refer to the docs for more details.
|
- 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.
|
- 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=open_connection disabled=connected>"Open"</button>
|
||||||
/// <button on:click=close_connection disabled=move || !connected()>"Close"</button>
|
/// <button on:click=close_connection disabled=move || !connected()>"Close"</button>
|
||||||
///
|
///
|
||||||
/// <p>"Receive message: " {move || format!("{:?}", message())}</p>
|
/// <p>"Receive message: " {move || format!("{:?}", message.get())}</p>
|
||||||
/// <p>"Receive byte message: " {move || format!("{:?}", message_bytes())}</p>
|
/// <p>"Receive byte message: " {move || format!("{:?}", message_bytes.get())}</p>
|
||||||
/// </div>
|
/// </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 |
|
/// | 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
|
/// ## Server-Side Rendering
|
||||||
///
|
///
|
||||||
/// On the server the returned functions amount to no-ops.
|
/// On the server the returned functions amount to no-ops.
|
||||||
|
|
Loading…
Add table
Reference in a new issue