2014-02-22 08:21:21 +01:00
|
|
|
|
(ns reagentdemo.news.undodemo
|
2015-07-31 09:58:07 +02:00
|
|
|
|
(:require [reagent.core :as r]
|
2014-11-29 18:30:24 +01:00
|
|
|
|
[reagent.interop :refer-macros [.' .!]]
|
2014-02-03 14:50:35 +01:00
|
|
|
|
[reagent.debug :refer-macros [dbg println]]
|
2015-02-09 21:02:31 +01:00
|
|
|
|
[reagentdemo.syntax :as s]
|
2015-09-07 23:01:33 +02:00
|
|
|
|
[sitetools.core :as tools :refer [dispatch link]]
|
|
|
|
|
[secretary.core :as secretary :refer-macros [defroute]]
|
2014-02-03 14:50:35 +01:00
|
|
|
|
[reagentdemo.common :as common :refer [demo-component]]
|
2015-02-10 14:18:56 +01:00
|
|
|
|
[todomvc.core :as todomvc]))
|
2014-02-03 14:50:35 +01:00
|
|
|
|
|
2015-09-07 23:01:33 +02:00
|
|
|
|
;; (def url "news/cloact-reagent-undo-demo.html")
|
2014-11-29 19:51:45 +01:00
|
|
|
|
(def title "Cloact becomes Reagent: Undo is trivial")
|
2014-11-29 18:30:24 +01:00
|
|
|
|
|
2015-09-07 23:01:33 +02:00
|
|
|
|
(declare main)
|
|
|
|
|
(defroute path "/news/cloact-reagent-undo-demo.html" []
|
2015-09-08 18:07:29 +02:00
|
|
|
|
(dispatch [:set-content [#'main] title]))
|
2015-09-07 23:01:33 +02:00
|
|
|
|
(tools/reg-page (path))
|
|
|
|
|
|
|
|
|
|
|
2015-07-31 09:58:07 +02:00
|
|
|
|
(def ns-src (s/syntaxed "(ns example
|
|
|
|
|
(:require [reagent.core :as r]))"))
|
|
|
|
|
|
2014-02-03 14:50:35 +01:00
|
|
|
|
(def state todomvc/todos)
|
|
|
|
|
|
2015-07-31 09:58:07 +02:00
|
|
|
|
(def undo-list (r/atom nil))
|
2014-02-03 14:50:35 +01:00
|
|
|
|
|
|
|
|
|
(defn undo []
|
|
|
|
|
(let [undos @undo-list]
|
|
|
|
|
(when-let [old (first undos)]
|
|
|
|
|
(reset! state old)
|
|
|
|
|
(reset! undo-list (rest undos)))))
|
|
|
|
|
|
|
|
|
|
(defn undo-button []
|
|
|
|
|
(let [n (count @undo-list)]
|
|
|
|
|
[:input {:type "button" :on-click undo
|
|
|
|
|
:disabled (zero? n)
|
|
|
|
|
:value (str "Undo (" n ")")}]))
|
|
|
|
|
|
|
|
|
|
(defn todomvc-with-undo []
|
|
|
|
|
(add-watch state ::undo-watcher
|
|
|
|
|
(fn [_ _ old-state _]
|
|
|
|
|
(swap! undo-list conj old-state)))
|
|
|
|
|
[:div
|
|
|
|
|
[undo-button]
|
|
|
|
|
[todomvc/todo-app]])
|
|
|
|
|
|
|
|
|
|
(defn undo-demo []
|
|
|
|
|
[demo-component {:comp todomvc-with-undo
|
2015-07-31 09:58:07 +02:00
|
|
|
|
:src [:pre ns-src
|
|
|
|
|
(s/src-of [:state :undo-list :undo :save-state
|
|
|
|
|
:undo-button :todomvc-with-undo])]}])
|
2014-02-03 14:50:35 +01:00
|
|
|
|
|
|
|
|
|
(def undo-demo-cleanup
|
|
|
|
|
(with-meta undo-demo {:component-will-unmount
|
|
|
|
|
(fn []
|
|
|
|
|
(reset! undo-list nil)
|
|
|
|
|
(remove-watch state ::undo-watcher))}))
|
|
|
|
|
|
|
|
|
|
(defn main [{:keys [summary]}]
|
2014-11-29 19:51:45 +01:00
|
|
|
|
(let [head title]
|
2014-02-03 14:50:35 +01:00
|
|
|
|
[:div.reagent-demo
|
2015-09-07 23:01:33 +02:00
|
|
|
|
[:h1 [link {:href (path)} head]]
|
2014-02-03 14:50:35 +01:00
|
|
|
|
[:div.demo-text
|
|
|
|
|
[:h2 "(reset! cloact-name \"Reagent\")"]
|
2014-04-01 19:50:28 +02:00
|
|
|
|
|
2014-02-03 14:50:35 +01:00
|
|
|
|
[:p "It turns out that ”Cloact” was a really, really bad
|
|
|
|
|
name. It made some people think about birds’ behinds, in
|
|
|
|
|
possibly unhealthy ways, which even Google suggested they
|
|
|
|
|
should."]
|
|
|
|
|
|
|
|
|
|
[:p "The new name is " [:strong "Reagent"] ", which hopefully
|
|
|
|
|
doesn’t bring with it the same disgusting connotations."]
|
|
|
|
|
|
|
|
|
|
[:p "The API is otherwise unchanged, so a simple
|
|
|
|
|
search-and-replace should suffice."]
|
|
|
|
|
|
|
|
|
|
(if summary
|
2015-09-07 23:01:33 +02:00
|
|
|
|
[link {:href (path)
|
2014-02-03 14:50:35 +01:00
|
|
|
|
:class 'news-read-more} "Read more"]
|
|
|
|
|
[:div.demo-text
|
|
|
|
|
|
|
|
|
|
[:h2 "Undo the easy way"]
|
|
|
|
|
|
|
|
|
|
[:p "To celebrate the undoing of the apparently disgusting
|
|
|
|
|
name, here is an example of how easy it is to add undo
|
|
|
|
|
functionality to Reagent components."]
|
|
|
|
|
|
|
|
|
|
[:p "It simply saves the old state whenever it changes, and
|
|
|
|
|
restores it when the button is clicked."]
|
|
|
|
|
|
|
|
|
|
[:p "The really nice thing about ClojureScript is that not
|
|
|
|
|
only is this easy and safe to do, courtesy of immutable data
|
|
|
|
|
structures, it is also efficient. ClojureScript figures out
|
|
|
|
|
how to represent ”changes” to maps and vectors efficiently,
|
|
|
|
|
so that you won’t have to."]
|
|
|
|
|
|
|
|
|
|
[undo-demo-cleanup]])]]))
|
|
|
|
|
|
2015-09-07 23:01:33 +02:00
|
|
|
|
;; (tools/register-page url [main] title)
|