Skip to content
This repository has been archived by the owner on Dec 12, 2022. It is now read-only.

district0x/district-ui-reagent-render

Repository files navigation

district-ui-reagent-render

CircleCI

Clojurescript re-mount module, that facilitates root reagent UI component mounting.

Installation

Add [district0x/district-ui-reagent-render "1.0.1"] into your project.clj.
Include [district.ui.reagent-render] in your CLJS file, where you use mount/start.

Usage

Warning: district0x modules are still in early stages of development, therefore API can change in the future.

This namespace contains district-ui-reagent-render mount module as well as a special utility function rerender.

The district-ui-reagent-render module takes a map of opts as an argument:

  • :target The html element where the root component of you app will be injected or :id, a string with the identifier of the root component.
  • :component-var The reference (a Var) to the function which returns the root component.

The validity of the args passed to the module will be checked at runtime if you have set the clojure.spec.check-asserts system property to true.

(ns my-district
  (:require [cljs.spec.alpha :as s]
            [district.ui.other-component]
            [district.ui.reagent-render]
            [district.ui.reagent-render.events :as events]
            [mount.core :as mount]))

(def main-panel []
  [:div "HOME"])

(defn ^:export init []
  (s/check-asserts true)
  (-> (mount/with-args {:reagent-render {:id "app"
                                         :component-var #'main-panel}
                        :other-component {:fu "bar"}})
      (mount/start)))

The :target argument can be passed like this:

{:reagent-render {:target (.getElementById js/document "app")
                  :component-var #'main-panel}}

Next call the resulting JS function in your index.html file to bootstrap the application::

<!doctype html>
<html lang="en">
  <head>
    <meta charset='utf-8'>
  </head>
  <body>
    <div id="app"></div>
    <script src="js/compiled/app.js"></script>
    <script>my_district.init();</script>
  </body>
</html>

This namespace contains re-frame events provided by this module.

Note: In typical applications you won't be needing to use the provided events, it is enough to just call mount/start on the underlying mount module provided by the district.ui.reagent-render namespace. None of the events below do any sort of input checking.

This is the handler for the underlying event dispatched synchronously when mount/start is invoked. It takes the same arguments as the district.ui.reagent-render mount module and dispatches a :render event.

This is just a book-keeping event to make sure that effectful event handler render-fx is called only once all other synchronously dispatched events from other modules have already happened. It takes the same arguments as the district.ui.reagent-render mount module.

This event handler performs the actual work of rendering the root component. It takes the same arguments as the district.ui.reagent-render mount module.

specs provided by this module:

Spec for the options passed to the module. You can toggle whether this spec is checked at runtime, see district.ui.reagent-render.

Development

  1. Run test suite:
  • npx shadow-cljs watch test-browser
  • open https://d0x-vm:6502
  • tests refresh automatically on code change
  1. Build
  • on merging pull request to master on GitHub, CI builds & publishes new version automatically
  • update version in build.clj
  • to build: clj -T:build jar
  • to release: clj -T:build deploy (needs CLOJARS_USERNAME and CLOJARS_PASSWORD env vars to be set)

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •