This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2021-04-19
Channels
- # announcements (24)
- # asami (25)
- # babashka (17)
- # beginners (99)
- # bitcoin (1)
- # calva (2)
- # cider (6)
- # cljs-dev (4)
- # clojure (88)
- # clojure-australia (3)
- # clojure-europe (23)
- # clojure-france (6)
- # clojure-nl (5)
- # clojure-uk (31)
- # clojured (1)
- # clojurescript (6)
- # clojureverse-ops (1)
- # datomic (28)
- # depstar (18)
- # emacs (11)
- # events (1)
- # fulcro (21)
- # graalvm (4)
- # graphql (7)
- # heroku (1)
- # jackdaw (18)
- # joker (3)
- # kaocha (1)
- # lsp (1)
- # malli (13)
- # meander (4)
- # off-topic (12)
- # pathom (14)
- # pedestal (2)
- # podcasts-discuss (1)
- # re-frame (37)
- # reagent (17)
- # reitit (9)
- # shadow-cljs (44)
- # xtdb (17)
I don’t fully understand the question. In lacinia, you can just mark a field as having type (list :Thing)
, then you can just return a list from your resolver
You just return a list of things. So say that you have a type Product { }
, that has a field Product#items
, which has type (list :Item)
, you can create a resolver that returns that list of items
So, typically, your root query resolver can hit a DB and pull a record that includes an id of some kind. The query document selects fields from that data, but will also pass it (not the selected map, the raw map as returned from your own code) down a level; that can extract the id and run a new query that returns a list of child objects. It's right in the name: a graph of objects. Complexities hidden on the server, client is free to navigate that graph all in one go (rather than REST where you either get too much data, or have to make multiple queries). Of course, nothing is free, but more advanced Lacinia users can mitigate costs by pre-selecting data.