Leptos Axum Starter Template
This is a template for use with the Leptos web framework and the cargo-leptos tool using Axum.
Creating your template repo
If you don't have cargo-leptos
installed you can install it with
Then run
to generate a new project template.
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
.
Additionally, Cargo.toml may need updating as new versions of the dependencies are released, especially if things are not working after a cargo update
.
Islands support
Note that for islands to work correctly, you need to have a use app;
in your frontend lib.rs
otherwise rustc / wasm_bindgen gets confused.
To prevent clippy from complaining, at the top of the frontend/lib.rs
file place:
use app;
Running your project
Installing Additional Tools
By 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 default nightly
- setup nightly as default, or you can use rust-toolchain file later onrustup target add wasm32-unknown-unknown
- add the ability to compile Rust to WebAssemblycargo install cargo-generate
- installcargo-generate
binary (should be installed automatically in future)npm install -g sass
- installdart-sass
(should be optional in future
Compiling for Release
Will generate your server binary in target/server/release and your site package in target/site
Testing Your Project
Cargo-leptos uses (https://playwright.dev)[Playwright] as the end-to-end test tool.
Prior to the first run of the end-to-end tests run Playwright must be installed.
In the project's end2end
directory run npm install -D playwright @playwright/test
to install playwright and browser specific APIs.
To run the tests during development in the project root run:
To run tests for release in the project root run:
There are some examples tests are located in end2end/tests
directory that pass tests with the sample Leptos app.
A web-based report on tests is available by running npx playwright show-report
in the end2end
directory.
Executing a Server on a Remote Machine Without the Toolchain
After running a cargo leptos build --release
the minimum files needed are:
- The server binary located in
target/server/release
- The
site
directory and all files within located intarget/site
Copy these files to your remote server. The directory structure should be:
start-axum-workspace
site/
Set the following environment variables (updating for your project as needed):
LEPTOS_OUTPUT_NAME="start-axum-workspace"
LEPTOS_SITE_ROOT="site"
LEPTOS_SITE_PKG_DIR="pkg"
LEPTOS_SITE_ADDR="127.0.0.1:3000"
LEPTOS_RELOAD_PORT="3001"
Finally, run the server binary.
Licensing
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.