This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2017-01-23
Channels
- # arachne (3)
- # aws (1)
- # bangalore-clj (2)
- # beginners (19)
- # boot (151)
- # cider (72)
- # cljs-dev (9)
- # cljsjs (7)
- # cljsrn (37)
- # clojure (215)
- # clojure-austin (1)
- # clojure-denmark (2)
- # clojure-dev (68)
- # clojure-india (1)
- # clojure-ireland (2)
- # clojure-italy (4)
- # clojure-mke (1)
- # clojure-nl (4)
- # clojure-russia (4)
- # clojure-serbia (1)
- # clojure-spec (29)
- # clojure-uk (23)
- # clojurescript (23)
- # cursive (24)
- # datomic (71)
- # emacs (5)
- # events (1)
- # gsoc (11)
- # hoplon (20)
- # klipse (4)
- # lambdaisland (2)
- # leiningen (3)
- # luminus (3)
- # off-topic (30)
- # om (40)
- # om-next (1)
- # onyx (15)
- # pedestal (19)
- # perun (7)
- # planck (23)
- # proton (1)
- # protorepl (2)
- # re-frame (35)
- # reagent (21)
- # ring-swagger (38)
- # rum (19)
- # spacemacs (9)
- # untangled (11)
- # vim (5)
- # yada (4)
Is there an easy way to convert from reagent server version to reagent-frontend version?
@artur just trying to get clarification to your question. It sounds like you are referring to the two reagent-project templates. If not, have you seen this? https://github.com/reagent-project/reagent-frontend-template
In any case, unfortunately cant provide guidance on how to migrate an existing app. But if you havent seen that, it's a good place to start
What I have done is created an app with the server version of the reagent template but really wanted the front-end template version since all I want is deploy single js file.
Yeah probably a good idea. The cljs source should be about the same. By using the frontend template you'll blast the clj source and add an index.html file and dramatically reduce the size of your project.clj file
I have a component which I want to render which includes a button and when I click on it, I want to update that component's state. For some reason, when I click on the button, the render function of the component is called again but only once. If I click on the button again it doesn't call the render function any more. Second problem: If I render this component multiple times and click on one button, the state is the same on all buttons instead of just one. Am I missing something?
@artur 1) the component is re-rendered once because the ratom is not changed the second time the button is clicked (it's already set to "Foo") 2) if all your components deref the same global ratom than it's an expected behavior I guess
Any ideas how to write this in Reagent: return <RTListItem caption={props.title} rightActions={rightActions} />; This is the context: https://github.com/Podlas29/todoy/blob/f47f3e82bfccdbfb47487b5b2f124c31261b6c59/src/front/components/List/ListItem.tsx#L17
It's an array with a react component in it. I tried [[rt/icon-button {:id "button" :icon "refresh"}]] but I get this error: js_dependencies.js:283 Uncaught Invariant Violation: Objects are not valid as a React child (found: object with keys {name, id, class}). If you meant to render a collection of children, use an array instead or wrap the object using createFragment(object) from the React add-ons. Check the render method of ListItemActions
.
@pupeno, (r/as-element [:> js/RTListIte {:caption ... :right-actions ...}])
I started to use r/track
a lot, kind of following composable subscriptions in re-frame
, it was a very good addition thanks!
I use it frequently as well!
@pesterhazy I am kind of new to it and I wonder if this is good usage:
(defn get-relationships [state]
..fetch relationships from state...))
(defn get-indexed-relationships [state]
(let [rels @(r/track get-relationships state)]
...create index...
))
looks good to me
thanks for confirming