Skip to content

Commit

Permalink
Merge branch 'main' into axum_7
Browse files Browse the repository at this point in the history
  • Loading branch information
dgsantana committed Nov 28, 2023
2 parents e096e73 + b578660 commit 3b841de
Show file tree
Hide file tree
Showing 41 changed files with 266 additions and 139 deletions.
28 changes: 14 additions & 14 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,22 +26,22 @@ members = [
exclude = ["benchmarks", "examples"]

[workspace.package]
version = "0.5.2"
version = "0.5.3"

[workspace.dependencies]
leptos = { path = "./leptos", version = "0.5.2" }
leptos_dom = { path = "./leptos_dom", version = "0.5.2" }
leptos_hot_reload = { path = "./leptos_hot_reload", version = "0.5.2" }
leptos_macro = { path = "./leptos_macro", version = "0.5.2" }
leptos_reactive = { path = "./leptos_reactive", version = "0.5.2" }
leptos_server = { path = "./leptos_server", version = "0.5.2" }
server_fn = { path = "./server_fn", version = "0.5.2" }
server_fn_macro = { path = "./server_fn_macro", version = "0.5.2" }
server_fn_macro_default = { path = "./server_fn/server_fn_macro_default", version = "0.5.2" }
leptos_config = { path = "./leptos_config", version = "0.5.2" }
leptos_router = { path = "./router", version = "0.5.2" }
leptos_meta = { path = "./meta", version = "0.5.2" }
leptos_integration_utils = { path = "./integrations/utils", version = "0.5.2" }
leptos = { path = "./leptos", version = "0.5.3" }
leptos_dom = { path = "./leptos_dom", version = "0.5.3" }
leptos_hot_reload = { path = "./leptos_hot_reload", version = "0.5.3" }
leptos_macro = { path = "./leptos_macro", version = "0.5.3" }
leptos_reactive = { path = "./leptos_reactive", version = "0.5.3" }
leptos_server = { path = "./leptos_server", version = "0.5.3" }
server_fn = { path = "./server_fn", version = "0.5.3" }
server_fn_macro = { path = "./server_fn_macro", version = "0.5.3" }
server_fn_macro_default = { path = "./server_fn/server_fn_macro_default", version = "0.5.3" }
leptos_config = { path = "./leptos_config", version = "0.5.3" }
leptos_router = { path = "./router", version = "0.5.3" }
leptos_meta = { path = "./meta", version = "0.5.3" }
leptos_integration_utils = { path = "./integrations/utils", version = "0.5.3" }

[profile.release]
codegen-units = 1
Expand Down
4 changes: 4 additions & 0 deletions examples/animated_show/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,3 +8,7 @@ CSS.
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/counter/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example creates a simple counter in a client side rendered app with Rust an
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/counter_isomorphic/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example demonstrates how to use a function isomorphically, to run a server
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/counter_url_query/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example creates a simple counter whose state is persisted and synced in the
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/counter_without_macros/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example is the same like the `counter` but it's written without using macro
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/counters/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example showcases a basic leptos app with many counters. It is a good examp
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/counters_stable/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example showcases a basic Leptos app with many counters. It is a good examp
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
6 changes: 5 additions & 1 deletion examples/directives/README.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,11 @@
# Leptos Directives Example

This example showcases a basic leptos app that shows how to write and use directives.
This example showcases a basic leptos app that shows how to write and use directives.

## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/error_boundary/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,7 @@ See the [Examples README](../README.md) for setup and run instructions.
## Testing

This project is configured to run start and stop of processes for integration tests wihtout the use of Cargo Leptos or Node.

## Quick Start

Run `trunk serve --open` to run this example.
6 changes: 5 additions & 1 deletion examples/fetch/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,4 +4,8 @@ This example shows how to fetch data from the client in WebAssembly.

## Getting Started

See the [Examples README](../README.md) for setup and run instructions.
See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/hackernews/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example creates a basic clone of the Hacker News site. It showcases Leptos'
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` or `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/hackernews_axum/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example creates a basic clone of the Hacker News site. It showcases Leptos'
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` or `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/hackernews_islands_axum/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example creates a basic clone of the Hacker News site. It showcases Leptos'
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/js-framework-benchmark/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,3 +6,7 @@ This example creates a large table with randomized entries, it also shows usage
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/parent_child/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,7 @@ This example highlights four different ways that child components can communicat
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/portal/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example showcases a basic leptos app with a portal.
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/router/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example demonstrates how Leptos’s router works for client side routing.
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/session_auth_axum/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example creates a basic todo app with an Axum backend that uses Leptos' ser
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/slots/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example shows how to use Slots in Leptos.
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
25 changes: 16 additions & 9 deletions examples/ssr_modes/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,18 +9,25 @@ See the [Examples README](../README.md) for setup and run instructions.
## Server-Side Rendering Modes

1. **Synchronous**: Serve an HTML shell that includes `fallback` for any `Suspense`. Load data on the client, replacing `fallback` once they're loaded.
- *Pros*: App shell appears very quickly: great TTFB (time to first byte).
- *Cons*: Resources load relatively slowly; you need to wait for JS + Wasm to load before even making a request.

- _Pros_: App shell appears very quickly: great TTFB (time to first byte).
- _Cons_: Resources load relatively slowly; you need to wait for JS + Wasm to load before even making a request.

2. **Out-of-order streaming**: Serve an HTML shell that includes `fallback` for any `Suspense`. Load data on the **server**, streaming it down to the client as it resolves, and streaming down HTML for `Suspense` nodes.
- *Pros*: Combines the best of **synchronous** and **`async`**, with a very fast shell and resources that begin loading on the server.
- *Cons*: Requires JS for suspended fragments to appear in correct order. Weaker meta tag support when it depends on data that's under suspense (has already streamed down `<head>`)

- _Pros_: Combines the best of **synchronous** and **`async`**, with a very fast shell and resources that begin loading on the server.
- _Cons_: Requires JS for suspended fragments to appear in correct order. Weaker meta tag support when it depends on data that's under suspense (has already streamed down `<head>`)

3. **In-order streaming**: Walk through the tree, returning HTML synchronously as in synchronous rendering and out-of-order streaming until you hit a `Suspense`. At that point, wait for all its data to load, then render it, then the rest of the tree.
- *Pros*: Does not require JS for HTML to appear in correct order.
- *Cons*: Loads the shell more slowly than out-of-order streaming or synchronous rendering because it needs to pause at every `Suspense`. Cannot begin hydration until the entire page has loaded, so earlier pieces
of the page will not be interactive until the suspended chunks have loaded.

- _Pros_: Does not require JS for HTML to appear in correct order.
- _Cons_: Loads the shell more slowly than out-of-order streaming or synchronous rendering because it needs to pause at every `Suspense`. Cannot begin hydration until the entire page has loaded, so earlier pieces
of the page will not be interactive until the suspended chunks have loaded.

4. **`async`**: Load all resources on the server. Wait until all data are loaded, and render HTML in one sweep.
- *Pros*: Better handling for meta tags (because you know async data even before you render the `<head>`). Faster complete load than **synchronous** because async resources begin loading on server.
- *Cons*: Slower load time/TTFB: you need to wait for all async resources to load before displaying anything on the client.
- _Pros_: Better handling for meta tags (because you know async data even before you render the `<head>`). Faster complete load than **synchronous** because async resources begin loading on server.
- _Cons_: Slower load time/TTFB: you need to wait for all async resources to load before displaying anything on the client.

## Quick Start

Run `cargo leptos watch` to run this example.
24 changes: 15 additions & 9 deletions examples/ssr_modes_axum/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,19 +9,25 @@ See the [Examples README](../README.md) for setup and run instructions.
## Server-Side Rendering Modes

1. **Synchronous**: Serve an HTML shell that includes `fallback` for any `Suspense`. Load data on the client, replacing `fallback` once they're loaded.
- *Pros*: App shell appears very quickly: great TTFB (time to first byte).
- *Cons*: Resources load relatively slowly; you need to wait for JS + Wasm to load before even making a request.

- _Pros_: App shell appears very quickly: great TTFB (time to first byte).
- _Cons_: Resources load relatively slowly; you need to wait for JS + Wasm to load before even making a request.

2. **Out-of-order streaming**: Serve an HTML shell that includes `fallback` for any `Suspense`. Load data on the **server**, streaming it down to the client as it resolves, and streaming down HTML for `Suspense` nodes.
- *Pros*: Combines the best of **synchronous** and **`async`**, with a very fast shell and resources that begin loading on the server.
- *Cons*: Requires JS for suspended fragments to appear in correct order. Weaker meta tag support when it depends on data that's under suspense (has already streamed down `<head>`)

- _Pros_: Combines the best of **synchronous** and **`async`**, with a very fast shell and resources that begin loading on the server.
- _Cons_: Requires JS for suspended fragments to appear in correct order. Weaker meta tag support when it depends on data that's under suspense (has already streamed down `<head>`)

3. **In-order streaming**: Walk through the tree, returning HTML synchronously as in synchronous rendering and out-of-order streaming until you hit a `Suspense`. At that point, wait for all its data to load, then render it, then the rest of the tree.
- *Pros*: Does not require JS for HTML to appear in correct order.
- *Cons*: Loads the shell more slowly than out-of-order streaming or synchronous rendering because it needs to pause at every `Suspense`. Cannot begin hydration until the entire page has loaded, so earlier pieces
of the page will not be interactive until the suspended chunks have loaded.

- _Pros_: Does not require JS for HTML to appear in correct order.
- _Cons_: Loads the shell more slowly than out-of-order streaming or synchronous rendering because it needs to pause at every `Suspense`. Cannot begin hydration until the entire page has loaded, so earlier pieces
of the page will not be interactive until the suspended chunks have loaded.

4. **`async`**: Load all resources on the server. Wait until all data are loaded, and render HTML in one sweep.
- *Pros*: Better handling for meta tags (because you know async data even before you render the `<head>`). Faster complete load than **synchronous** because async resources begin loading on server.
- *Cons*: Slower load time/TTFB: you need to wait for all async resources to load before displaying anything on the client.
- _Pros_: Better handling for meta tags (because you know async data even before you render the `<head>`). Faster complete load than **synchronous** because async resources begin loading on server.
- _Cons_: Slower load time/TTFB: you need to wait for all async resources to load before displaying anything on the client.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/suspense_tests/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,7 @@ See the [Examples README](../README.md) for setup and run instructions.
## Test Strategy

See the [E2E README](./e2e/README.md) to learn about the web testing strategy for this project.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/tailwind_axum/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This is a template demonstrating how to integrate [TailwindCSS](https://tailwind
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/tailwind_csr/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -51,3 +51,7 @@ Allow vscode Ports forward: 3000, 3001.
### Attribution

Many thanks to GreatGreg for putting together this guide. You can find the original, with added details, [here](https://github.com/leptos-rs/leptos/discussions/125).

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/timer/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This example creates a simple timer based on `setInterval` in a client side rend
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
4 changes: 4 additions & 0 deletions examples/todo_app_sqlite/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,3 +13,7 @@ See the [E2E README](./e2e/README.md) for more information about the testing str
## Rendering

See the [SSR Notes](../SSR_NOTES.md) for more information about Server Side Rendering.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/todo_app_sqlite_axum/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,3 +13,7 @@ See the [E2E README](./e2e/README.md) for more information about the testing str
## Rendering

See the [SSR Notes](../SSR_NOTES.md) for more information about Server Side Rendering.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/todo_app_sqlite_csr/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,3 +13,7 @@ See the [E2E README](./e2e/README.md) for more information about the testing str
## Rendering

See the [SSR Notes](../SSR_NOTES.md) for more information about Server Side Rendering.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/todo_app_sqlite_viz/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,7 @@ See the [Examples README](../README.md) for setup and run instructions.
## Rendering

See the [SSR Notes](../SSR_NOTES.md) for more information about Server Side Rendering.

## Quick Start

Run `cargo leptos watch` to run this example.
4 changes: 4 additions & 0 deletions examples/todomvc/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,7 @@ This is a Leptos implementation of the TodoMVC example common to many frameworks
## Getting Started

See the [Examples README](../README.md) for setup and run instructions.

## Quick Start

Run `trunk serve --open` to run this example.
2 changes: 1 addition & 1 deletion integrations/axum/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
//! To run in this environment, you need to disable the default feature set and enable
//! the `wasm` feature on `leptos_axum` in your `Cargo.toml`.
//! ```toml
//! leptos_axum = { version = "0.5.2", default-features = false, features = ["wasm"] }
//! leptos_axum = { version = "0.5.3", default-features = false, features = ["wasm"] }
//! ```
//!
//! ## Features
Expand Down
3 changes: 2 additions & 1 deletion leptos_dom/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,8 @@ ssr = ["leptos_reactive/ssr"]
nightly = ["leptos_reactive/nightly"]
nonce = ["dep:base64", "dep:getrandom", "dep:rand"]
experimental-islands = ["leptos_reactive/experimental-islands"]
trace-component-props = []

[package.metadata.cargo-all-features]
denylist = ["nightly"]
denylist = ["nightly", "trace-component-props"]
skip_feature_sets = [["web", "ssr"]]
1 change: 1 addition & 0 deletions leptos_dom/src/macro_helpers/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ mod into_attribute;
mod into_class;
mod into_property;
mod into_style;
#[cfg(feature = "trace-component-props")]
#[doc(hidden)]
pub mod tracing_property;
pub use into_attribute::*;
Expand Down
3 changes: 2 additions & 1 deletion leptos_macro/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,8 @@ ssr = ["server_fn_macro/ssr"]
nightly = ["server_fn_macro/nightly"]
tracing = []
experimental-islands = []
trace-component-props = []

[package.metadata.cargo-all-features]
denylist = ["nightly", "tracing"]
denylist = ["nightly", "tracing", "trace-component-props"]
skip_feature_sets = [["csr", "hydrate"], ["hydrate", "csr"], ["hydrate", "ssr"]]
Loading

0 comments on commit 3b841de

Please sign in to comment.