This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2019-04-05
Channels
- # announcements (1)
- # beginners (72)
- # boot (4)
- # calva (35)
- # cider (8)
- # clara (13)
- # cljdoc (31)
- # cljs-dev (34)
- # clojure (64)
- # clojure-europe (1)
- # clojure-finland (3)
- # clojure-italy (23)
- # clojure-losangeles (3)
- # clojure-nl (35)
- # clojure-uk (19)
- # clojurescript (26)
- # cursive (19)
- # datomic (12)
- # duct (5)
- # editors (7)
- # emacs (25)
- # fulcro (40)
- # funcool (5)
- # jobs (2)
- # leiningen (3)
- # luminus (2)
- # lumo (3)
- # off-topic (19)
- # pathom (3)
- # planck (2)
- # reagent (6)
- # remote-jobs (4)
- # rum (1)
- # shadow-cljs (23)
- # spacemacs (6)
- # tools-deps (12)
Hey, I have been playing with Fulcro/Pathom most evenings this week when I had time and I feel I am getting close but there are areas I simply still don't understand. I have this very simple setup so far (code snippet) but I am really having trouble writing my UI queries. I can see with Fulcro Inspect the data is in the DB but how would I write the Root and TodoList query so I can see todos for 2019-04-01?
I'm really new to Fulcro as well so I'm not sure if this is the issue but your root query has ":todo-list/by-id" instead of ":todo-list/by-date" as I think you intended
I think this is due to what you have in the store. Currently it seems like your store doesn't have any initial state, so that query cannot resolve to anything. The defined resolvers can find fields based on data present in the system, as none of them are global. So currently if you query for :todo/title
, that can be resolved alongside any :todo/id
entry in your state.
I believe you want a :todos/by-id
entry in your store that has those todos organized by id, and a resolver that takes :todos/by-id
as an input, and returns :todos/by-date
as an output after reorganizing the by-id
selection.
@andrew513 not sure how I missed that, I can even see that I tried that earlier but now I get {[:todo-list/by-date 2019-04-01] {:todo-list/by-date 2019-04-01, :todos [{:todo/id 1, :todo/title Mow the lawn, :todo/planned 2019-04-01} {:todo/id 2, :todo/title Wash dishes, :todo/planned 2019-04-01}]}}
where before I just got {[:todo-list/by-date 2019-04-01] {}}
so I wonder what I have changed since
Then you can have a top level query [{[:todo-list/by-date "2019-04-01"] (prim/get-query TodoList)}]
that can join to your by-date
entry and fetch a list of todos from that entry.
@U1RUG108P this is what my store (I assume Fulcro store) looks like
@U1RUG108P I'm not sure how that resolver todo/by-id
-> todo/by-date
would look like, wouldn't the input mean one specific todo or is that the entire map (basically a subset of my todo-database)?
the input is the value corresponding to the key specified as input. So an input of :todos/by-id
gives you that entry in the map.
This for example gets the todos [{[:todo-list/by-date "2019-04-01"] [{:todos [:todo/title]}]}]
(in Fulcro Inspect's Query)
@mail228 @denis-v @andrew513 So I would not suggest you encode these kinds of things into you UI queries at all.
You UI query model is about the general shape of the data, not the specific content.
Your todo lists (with a pathom model, which is recommended) should be purely by ID, and should be encoded as :todolist/id
. The book is a bit out of date …sorry, very busy.
the idea of showing the items for some date perhaps has an encoding that is a bit different, depending on what you actually mean. What your encoding is more like a “global view of a filtered list of items”…I’d use a component like GlobalFilteredTodoItems
(I’m being intentionally overly verbose for demo purposes), and that (IMO) would be some kind of singleton with a “current set of settings and content”
(defsc GFTodoItems [this props]
{:query ...
:ident (fn [] [:gfti :singleton])})
...
e.g. [:ui/start-date :ui/end-date :ui/pattern {:list/current-items (prim/get-query TodoItem)}]
thus a real UI for a given todo list in table :todolist/id
would also point to some subset of the overall :item/id
items.
Then you have options for populating this new beast: local mutations, full-stack loads, or a combo
If all of your todo lists are pre-loaded, then a local mutation can look at the current settings of the GFTI component to see what to look for, scan the local table of :item/id
, and fill in :list/current-items
with the matching list of local item idents.
If not, then you probably just implement a server query to load them like this:
(df/load this :server/filtered-todo-items TodoItem {:target [:gfti :singleton :list/current-items] :params {:matches pattern :start-date s :end-date e}})
which would load all of those items, normalized them (updating ones that were already there), and targets the correct filterted list of idents into the correct component
or some combo…maybe you load all items, target them, THEN do a post-mutation that does the local-only filtering
Summary: It should be very very rare to ever use an ident with a specific ID in a component query
idents in component queries are typically for looking up something at the root level at a pre-defined key (current locale, logged in user) such as :current/locale :en-US
or :current-user [:user/id 32]
where the respective queries might be [:current/locale '_]
or {[:current-user '_] (prim/get-query User)]}
Thanks, the help and your time is appreciated. I think I understand the gist of how to approach this with your GFTI example but I have really been struggling reading the book and applying the knowledge, not sure if because I'm unfamiliar with Clojure(Script) or the concepts are just really foreign to me. I also watched most of the videos (except UI/routing and the workflow ones). I'm determined to learn Fulcro because it seems like a good fit and provides nice abstractions but there's been a lot to take in with Fulcro and Pathom and it's not clicking for me yet
The use of queries, idents, initial state, mutations, resolvers, defsc, prim, df/load etc, it's just a lot of terms to learn and understand how to build with
I totally understand your pain. New approaches are hard simply because they are foreign, even when they are simple 🙂
You’re dealing with a number of things at once: syntax, new language semantics, a new database format, etc.etc.
Like when you first learn to program with mutable variables…things like “a = a + 1” look totally insane (if you know algebra)
Yep, that's true, I wonder for that reasons if functional languages actually make more sense for new people than your typical OO language (Java or Python typically)