mirror of https://github.com/status-im/reagent.git
71 lines
2.2 KiB
Clojure
71 lines
2.2 KiB
Clojure
(ns demo
|
|
(:require [reagent.core :as reagent :refer [atom]]
|
|
[reagent.interop :as i :refer-macros [.' .! fvar]]
|
|
[clojure.string :as string]
|
|
[reagentdemo.page :as page :refer [page-map page link prefix]]
|
|
[reagentdemo.common :as common :refer [demo-component]]
|
|
[reagentdemo.intro :as intro]
|
|
[reagentdemo.news :as news]
|
|
[reagent.debug :refer-macros [dbg println]]))
|
|
|
|
(i/import-react)
|
|
|
|
(swap! page-map assoc
|
|
"index.html" (fvar intro/main)
|
|
"news/index.html" (fvar news/main))
|
|
|
|
(def github {:href "https://github.com/reagent-project/reagent"})
|
|
|
|
(defn github-badge []
|
|
[:a.github-badge
|
|
github
|
|
[:img {:style {:position "absolute" :top 0 :left 0 :border 0}
|
|
:alt "Fork me on GitHub"
|
|
:src "https://s3.amazonaws.com/github/ribbons/forkme_left_orange_ff7600.png"}]])
|
|
|
|
(defn demo []
|
|
[:div
|
|
[:div.nav
|
|
[:ul.nav
|
|
[:li.brand [link {:href (fvar intro/main)} "Reagent:"]]
|
|
[:li [link {:href (fvar intro/main)} "Intro"]]
|
|
[:li [link {:href (fvar news/main)} "News"]]
|
|
[:li [:a github "GitHub"]]]]
|
|
(let [comp (get @page-map @page (fvar intro/main))]
|
|
[comp])
|
|
[github-badge]])
|
|
|
|
(defn ^:export mountdemo [p]
|
|
(when p (page/set-start-page p))
|
|
(reagent/render-component [demo] (.-body js/document)))
|
|
|
|
(defn gen-page [p timestamp]
|
|
(reset! page p)
|
|
(let [body (reagent/render-component-to-string [demo])
|
|
title @page/title-atom
|
|
load-page (case p "index.html" "" p)]
|
|
(str "<!doctype html>
|
|
<html>
|
|
<head>
|
|
<meta charset='utf-8'>
|
|
<title>" title "</title>
|
|
<meta name='viewport' content='width=device-width, initial-scale=1.0' />
|
|
<link rel='stylesheet' href='" (prefix "assets/demo.css") timestamp "'>
|
|
</head>
|
|
<body>
|
|
" body "
|
|
<script type='text/javascript'
|
|
src='" (prefix "assets/demo.js") timestamp "'></script>
|
|
<script type='text/javascript'>
|
|
setTimeout(function() {demo.mountdemo('" load-page "')}, 200);
|
|
</script>
|
|
</body>
|
|
</html>")))
|
|
|
|
(defn ^:export genpages []
|
|
(let [timestamp (str "?" (.now js/Date))]
|
|
(->> (keys @page-map)
|
|
(map #(vector % (gen-page % timestamp)))
|
|
(into {})
|
|
clj->js)))
|