This is a template for use with the Leptos web framework and the cargo-leptos tool using Axum.
If you don't have cargo-leptos installed you can install it with
cargo install cargo-leptos --lockedThen run
cargo leptos new --git https://github.com/leptos-rs/start-axumto generate a new project template.
cd full_stack_demo (or whatever you named your app)to go to your newly created project.
Feel free to explore the project structure, but the best place to start with your application code is in src/app.rs.
Addtionally, Cargo.toml may need updating as new versions of the dependencies are released, especially if things are not working after a cargo update.
cargo leptos watchBy default, cargo-leptos uses nightly Rust, cargo-generate, and sass. If you run into any trouble, you may need to install one or more of these tools.
rustup toolchain install nightly --allow-downgrade- make sure you have Rust nightlyrustup target add wasm32-unknown-unknown- add the ability to compile Rust to WebAssemblycargo install cargo-generate- installcargo-generatebinary (should be installed automatically in future)npm install -g sass- installdart-sass(should be optional in future- Run
npm installin end2end subdirectory before test
cargo leptos build --releaseWill generate your server binary in target/server/release and your site package in target/site
Playwright will build the project before running tests. No other instance can be running.
Install or update Playwright and related test packages.
cd end2end
npm install
npx playwright install
cd ..Commands below are run from the project root.
cargo leptos end-to-end
cargo leptos end-to-end --releaseCargo-leptos uses Playwright as the end-to-end test tool. Tests are located in end2end/tests directory.
Local aliases (must be configured in OS)
dev = "cargo leptos watch"
release = "cargo leptos build --release"
start = start() {
# Get the project name from current directory
local proj_name=$(basename "$PWD")
# Construct and execute the command
./target/release/$proj_name "$@"
}
e2e-test = "cargo leptos end-to-end"
e2e-release = "cargo leptos end-to-end --release"
e2e-report = "cargo leptos end-to-end --report"
After running a cargo leptos build --release the minimum files needed are:
- The server binary located in
target/server/release - The
sitedirectory and all files within located intarget/site
Copy these files to your remote server. The directory structure should be:
full_stack_demo
site/
Set the following environment variables (updating for your project as needed):
export LEPTOS_OUTPUT_NAME="full_stack_demo"
export LEPTOS_SITE_ROOT="site"
export LEPTOS_SITE_PKG_DIR="pkg"
export LEPTOS_SITE_ADDR="127.0.0.1:3000"
export LEPTOS_RELOAD_PORT="3001"Finally, run the server binary.
This template itself is released under the Unlicense. You should replace the LICENSE for your own application with an appropriate license if you plan to release it publicly.