This is a Janet utility library for building web applications using the Datastar hypermedia framework. It primarily contains helper functions for the various attributes, actions, and event types that Datastar is offering. It is meant to be used together with Janet's spork library (htmlgen
and http
modules).
Important
This library is not yet stable. Even though it probably contains functions for the majority of the functionality that Datastar is offering they have not all been tested yet, at least not well enough. Expect changes. I'll start adding semantic version tags once things stabilise.
The library is split into multiple modules:
datastar
contains middleware and other stuff that doesn't exactly fit into any of the submodules.datastar/attributes
contains helper functions for Datastar's HTML attributes, such asdata-on
.datastar/actions
contains helper functions for Datastar's actions, such as@get()
.datastar/events
contains helper functions for all the SSE response types (events) Datastar is supporting, such asdatastar-merge-fragments
ordatastar-remove-signals
.datastar/server
contains a slightly customized HTTP server implementation fromspork/http
, because the original does not (yet) support everything that'd be needed for it to work well with the Datastar framework.
See the API reference for details.
The library can be installed with jpm using jpm install https://github.com/rokf/janet-datastar
or by adding the following line into your project's dependency tuple:
{ :url "https://github.com/rokf/janet-datastar" :tag "main" }
An example can be found in the example
folder. It requires the following dependencies:
- https://github.com/ianthehenry/pat
- https://github.com/janet-lang/spork
- https://github.com/rokf/janet-redka
The folder contains a Docker Compose specification which can be used to spin up a properly configured Redka instance (see compose.yaml
).
See the contents of the test
folder. The tests require judge. Make sure that it's installed on your machine before you run them with judge test
.
MIT - see the LICENSE
file at the root of the repository for details.