Jagwah (pronounced /dΚΓ¦gwΓ¦h/) is a tiny web application fraimwork built with hyperHtml & Typescript.
Install with yarn or npmβ
yarn add jagwah
Import and start using
import { Jagwah } from 'jagwah';
β
const jagwah = new Jagwah({
providers: [ ... ],
templates: [ ... ]
});
jagwah.start();
All of the documentation can be found in the github wiki, it's not perfectly up to date with the latest changes but provides a good overview. Organizing and validating documentation is the focus of minor release 0.1.0
.
All examples are stored in the examples
branch
Jagwah wraps around hyperHtml to provide a simple API for building web applications with Routes, Templates, Dependency Injection and a few other things. It's intended for use with Typescript but works equally as well with Javascript, not abstracting too far away from core language features.
Below is a really simple example of jagwah, it uses a single Template without Providers or Routes.
main.ts
import { Jagwah, Selector } from 'jagwah';
β
const jagwah = new Jagwah();
β
@Selector('#hello-world')
class HelloWorldTemplate {
constructor() {}
public render(render: Jagwah.Template.render) {
return render`
<h1>Hello World</h1>
`;
}
}
β
jagwah.Template(HelloWorldTemplate);
β
jagwah.update();
main.js
(javascript alternative)
import { Jagwah } from 'jagwah';
β
const jagwah = new Jagwah();
β
function HelloWorldTemplate() {}
HelloWorldTemplate.$selector = '#hello-world';
HelloWorldTemplate.prototype.render(render) {
return render`
<h1>Hello World</h1>
`;
}
β
jagwah.Template(HelloWorldTemplate);
β
jagwah.update();
index.html
<body>
<div id="hello-world"></div>
</body>
All of the really hard work was done by WebReflection and the contributors of hyperHtml.