hoplon

The :hoplon: ClojureScript Web Framework - http://hoplon.io/
George Ciobanu 2020-06-19T13:31:20.239900Z

That worked for one element! I now stumbled across a different problem with a collection inside a collection. I read all the wiki and i am stumped. I have (defc app-state {:components [{:id "b1" :caption "blah"} {:id "b2" }]}) And (defelem cbutton [att c] (div :id (:id att) (text (:caption att))) I tried both doing loop-tpl [c app-state] and loop-tpl [c (:components app-state)] as well as two loop-tpl: (Loop-tpl [c1 app-state] (Loop-tpl [c2 c1] ... And none of these approaches worked. I'm essentially trying to create a cbutton for each element in :components and then, when I update components I want the button to be updated. For example if I change the caption or if I remove the button from the collection, I want the UI to be updated. Thank you so much and apologies if this is really obvious, I read all the docs and tried multiple ways.

George Ciobanu 2020-06-19T15:26:43.243400Z

If you think this is the wrong way to model the app state I'm glad to listen to any feedback.

flyboarder 2020-06-19T17:05:21.244100Z

@geo.ciobanu you probably want to break the state into much smaller bits and then wire those small bits into a larger bit (if needed)

flyboarder 2020-06-19T17:05:39.244700Z

also loop/for-tpl on a map needs destructuring

flyboarder 2020-06-19T17:06:06.245400Z

you really dont want a large global app state

flyboarder 2020-06-19T17:06:11.245700Z

for many reasons

flyboarder 2020-06-19T17:06:31.246800Z

mostly because a large state with many things watching it will have negative performance impacts on the graph

flyboarder 2020-06-19T17:06:55.247500Z

where small independent bits will have a more localized effect on your application

George Ciobanu 2020-06-19T17:07:10.248200Z

Thank you @flyboarder. I can break it up into subcategories but the components collection for example will have elements added and removed as the user adds/removes items from the GUI.

flyboarder 2020-06-19T17:07:31.248700Z

yeah so I would keep that as a vector in it’s own state

George Ciobanu 2020-06-19T17:07:41.249200Z

Will do.

flyboarder 2020-06-19T17:07:46.249400Z

basically a list of components (defc components [])

George Ciobanu 2020-06-19T17:07:52.249700Z

Yup!

flyboarder 2020-06-19T17:08:03.250Z

that will also make your for-tpl or loop-tpl easier

George Ciobanu 2020-06-19T17:08:26.250900Z

And thanks for the destructuring tip, I can't believe I missed that

flyboarder 2020-06-19T17:08:31.251100Z

also you dont want to nest -tpl blocks

flyboarder 2020-06-19T17:08:58.251800Z

since they return formula cells, you need an element in between them

George Ciobanu 2020-06-19T17:09:09.252300Z

Makes sense.

George Ciobanu 2020-06-19T17:09:13.252500Z

Thank you!

flyboarder 2020-06-19T17:09:21.252700Z

no prob!