This library provides collections of useful hooks for shadow-cljs:
shadow-cljs-hooks.index
- generatingindex.html
shadow-cljs-hooks.fulcro-css
- generating CSS file for Fulcro3
Add the following dependency to your deps.edn
file:
org.clojars.beetleman/shadow-cljs-hooks {:mvn/version "current version from clojars"}
Add some build hook to shadow-cljs.edn
, eg. shadow-cljs-hooks.index/hook
:
{...
:builds
{:app {:target ...
:build-hooks
[(shadow-cljs-hooks.index/hook)]
...}}}}
checkout fulcro3 example or re-frame example to seeing it in action.
Generate index.html
based on provided options, works with :module-hash-names true
.
:path
- (optional, default: generated from:output-dir
and:asset-path
) whereindex.html
should be located:lang
- (optional, default:"en"
')<html lang=...>
:title
- (optional, default:"ClojureScript 🥳🏆"
)<title>...</title>
:scripts
- (optional, default:[]
) list of included.js
files:entry-point
- (optional, default:nil
) entry point for application, eg.:app/init
. Optional because:init-fn
in modules configuration can handle it:links
- (optional, default:[]
) list of included.css
files
[(shadow-cljs-hooks.index/hook {:links ["https://cdn.jsdelivr.net/npm/[email protected]/dist/semantic.min.css"]
:scripts ["https://cdn.jsdelivr.net/npm/[email protected]/dist/semantic.min.js"]})]
Used in More in re-frame example and fulcro3 example
Generate CSS
files from fulcro3 project. Works with index
hook.
:output-dir
(required) the directory to use for garden output:asset-path
(required) the relative path from web server’s root to the resources in:output-dir
:component
(required)Root
component from whichCSS
will be generated:garden-flags
(optional, default{:pretty-print? false}
) garden flags
[(shadow-cljs-hooks.fulcro-css/hook {:component app.main/Root
:output-dir "public/css"
:asset-path "/css"})
(shadow-cljs-hooks.index/hook)]
More in fulcro3 example
Generate CSS
files from garden compatible vector. Works with index
hook as well.
:output-dir
(required) the directory to use for garden output:asset-path
(required) the relative path from web server’s root to the resources in:output-dir
:css
(required) symbol with definition of styles:garden-flags
(optional, default{:pretty-print? false}
) garden flags
[(shadow-cljs-hooks.garden/hook {:css app.css/css
:output-dir "public/css"
:asset-path "/css"})
(shadow-cljs-hooks.index/hook)]
More in re-frame example
- pure garden hook
- reagent/reframe example
- code cleanup