Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/NiklasEi/cinnog
Experimental static site generator using Leptos with Bevy ECS as a data layer
https://github.com/NiklasEi/cinnog
bevy-ecs jamstack leptos rust static-site-generator
Last synced: 3 months ago
JSON representation
Experimental static site generator using Leptos with Bevy ECS as a data layer
- Host: GitHub
- URL: https://github.com/NiklasEi/cinnog
- Owner: NiklasEi
- License: apache-2.0
- Created: 2023-12-17T18:46:14.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-08-02T13:54:06.000Z (6 months ago)
- Last Synced: 2024-10-30T14:24:30.933Z (3 months ago)
- Topics: bevy-ecs, jamstack, leptos, rust, static-site-generator
- Language: Rust
- Homepage:
- Size: 89.8 KB
- Stars: 42
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE-APACHE
Awesome Lists containing this project
- awesome-leptos - cinnog
README
# Cinnog
A static site generator using [Leptos] with [Bevy ECS] as a data layer
**There is an [example app] which is hosted at https://cinnog.netlify.app/**
Cinnog uses the [island mode] of Leptos. Normal Leptos components are static and will be served as HTML. Only islands will be compiled to WASM and render client side.
Blog post introducing Cinnog: https://www.nikl.me/blog/2024/bevy_ecs_as_data_layer_in_leptos_ssg/
## The Data layer
[Bevy ECS] is used as data layer while the static site generation is handled by Leptos. The idea is similar to what Gatsby does with GraphQL using a Bevy ECS World as an in-memory database. The API of Bevy ECS is very nice to work with as a user. It removes any need of an extra syntax for data queries.
Users can fill the data layer with content from the file system, external APIs, or anywhere else. When all data is loaded and processed, Cinnog can build a given Leptos app and will supply the data layer in a context. Inside components, you can run [Systems][bevy_systems] against the data layer (think GraphQL query in Gatsby) and use [Resources][bevy_resources].
## Improvements
(not in any specific order)
- Bevy ECS and Leptos have some namespace clashes that would be helpful to resolve (ECS Component vs Leptos Component)
- Could we get rid of the `frontend` crate in user code?
- In Leptos components, it should be easy to get the "current entity". Going via the path parameters directly seems odd and involves multiple steps.
- Maybe this just needs a well working pattern using contexts in user space?
- Or some automatic mapping of path params and Entities + a context?
- Extend example with routes generated from ECS (should already be possible since the App component has access to the data layer)## MSRV
Since this project relies on Bevy, it has the same MSRV policy: latest stable Rust.
## License
Dual-licensed under either of
- Apache License, Version 2.0, ([LICENSE-APACHE](/LICENSE-APACHE) or https://www.apache.org/licenses/LICENSE-2.0)
- MIT license ([LICENSE-MIT](/LICENSE-MIT) or https://opensource.org/licenses/MIT)at your option.
## Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any
additional terms or conditions.[Bevy ECS]: https://github.com/bevyengine/bevy/tree/main/crates/bevy_ecs
[Leptos]: https://github.com/leptos-rs/leptos
[bevy_systems]: https://bevy-cheatbook.github.io/programming/systems.html?highlight=system#systems
[bevy_resources]: https://bevy-cheatbook.github.io/programming/res.html
[example app]: https://github.com/NiklasEi/cinnog_example
[island mode]: https://book.leptos.dev/islands.html