A simple web app to help us figure out what to what next out of all the series we currently are enjoying
Find a file
Thomas Gideon 878d3fa59b Build a view pane
- Use techniques from refactor of user list, to work with suspense and
  error boundary from the start.
- Add in necessary migration and query.
- Extract out some common view factories for fallback.
- Extract a field display function.
2024-09-07 19:50:48 -04:00
end2end Initial commit 2024-09-02 14:34:30 -04:00
migrations Add delete, error handling 2024-09-07 16:44:00 -04:00
public Initial commit 2024-09-02 14:34:30 -04:00
sql Build a view pane 2024-09-07 19:50:48 -04:00
src Build a view pane 2024-09-07 19:50:48 -04:00
style Initial commit 2024-09-02 14:34:30 -04:00
.gitignore Wire in a database 2024-09-02 17:49:36 -04:00
Cargo.lock Wire in a database 2024-09-02 17:49:36 -04:00
Cargo.toml Wire in a database 2024-09-02 17:49:36 -04:00
docker-compose.yml Wire in a database 2024-09-02 17:49:36 -04:00
LICENSE Initial commit 2024-09-02 14:34:30 -04:00
README.md Initial commit 2024-09-02 14:34:30 -04:00
rust-toolchain.toml Initial commit 2024-09-02 14:34:30 -04:00
rust.toml Initial commit 2024-09-02 14:34:30 -04:00

Leptos Logo

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

cargo install cargo-leptos --locked

Then run

cargo leptos new --git leptos-rs/start-axum

to generate a new project template.

cd watch

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.

Running your project

cargo leptos watch

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.

  1. rustup toolchain install nightly --allow-downgrade - make sure you have Rust nightly
  2. rustup target add wasm32-unknown-unknown - add the ability to compile Rust to WebAssembly
  3. cargo install cargo-generate - install cargo-generate binary (should be installed automatically in future)
  4. npm install -g sass - install dart-sass (should be optional in future

Compiling for Release

cargo leptos build --release

Will generate your server binary in target/server/release and your site package in target/site

Testing Your Project

cargo leptos end-to-end
cargo leptos end-to-end --release

Cargo-leptos uses Playwright as the end-to-end test tool.
Tests are located in end2end/tests directory.

Executing a Server on a Remote Machine Without the Toolchain

After running a cargo leptos build --release the minimum files needed are:

  1. The server binary located in target/server/release
  2. The site directory and all files within located in target/site

Copy these files to your remote server. The directory structure should be:

watch
site/

Set the following environment variables (updating for your project as needed):

LEPTOS_OUTPUT_NAME="watch"
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.