Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/thheller/shadow-grove

A ClojureScript system to build browser based frontends
https://github.com/thheller/shadow-grove

browser clojurescript dom

Last synced: 2 days ago
JSON representation

A ClojureScript system to build browser based frontends

Awesome Lists containing this project

README

        

# shadow-grove

[![Clojars Project](https://img.shields.io/clojars/v/com.thheller/shadow-grove.svg)](https://clojars.org/com.thheller/shadow-grove)

`shadow-grove` is a combination of pieces required to build performant DOM-driven user interfaces, scaling from small to very large. The goal is to have something written in ClojureScript with no extra dependencies and excellent performance out of the box.

Try it live in your browser via the [shadow-grove Playground](https://code.thheller.com/shadow-grove-playground/0.4.0/).

### Current Status

`shadow.grove` is far from finished but usable. Performance is [excellent](https://github.com/thheller/js-framework-shadow-grove). I have been using this for a few years now. Documentation is still in a terrible state though.

The [shadow-cljs UI](https://github.com/thheller/shadow-cljs/tree/master/src/main/shadow/cljs/ui) is sort of a reference application for all of this. You can experience it live at http://localhost:9630 if you have shadow-cljs running locally.

## Examples

- [shadow-cljs UI](https://github.com/thheller/shadow-cljs/tree/master/src/main/shadow/cljs/ui)
- [shadow-grove devtools](https://github.com/thheller/shadow-grove/blob/master/src/main/shadow/grove/devtools.cljs)
- [shadow-stack-mvp](https://github.com/thheller/shadow-stack-mvp) minimum viable project example ([compiled demo](https://code.thheller.com/demos/shadow-stack-mvp/))
- [grove-todo](https://github.com/thheller/grove-todo) grove implementation of todomvc ([compiled demo](https://code.thheller.com/demos/todomvc/))