more conversion to datomic
This commit is contained in:
@@ -4,11 +4,12 @@
|
||||
[clj-time.coerce :as c]
|
||||
[clojure.set :refer [rename-keys]]))
|
||||
|
||||
(defn add-arg [query name value where]
|
||||
(-> query
|
||||
(update :args conj value)
|
||||
(update-in [:query :in] conj name)
|
||||
(update-in [:query :where] conj where)))
|
||||
(defn add-arg [query name value where & rest]
|
||||
(let [query (-> query
|
||||
(update :args conj value)
|
||||
(update-in [:query :in] conj name)
|
||||
(update-in [:query :where] conj where))]
|
||||
(reduce #(update-in %1 [:query :where] conj %2) query rest)))
|
||||
|
||||
(defn raw-graphql [args]
|
||||
(->> (d/query
|
||||
@@ -23,8 +24,14 @@
|
||||
:args [(d/db (d/connect uri))]}
|
||||
println)
|
||||
|
||||
(:client-id args) (add-arg '?client-id (Long/parseLong (:client-id args))
|
||||
'[?e :invoice/client ?client-id])
|
||||
(:client-id args) (add-arg '?client-id (cond-> (:client-id args)
|
||||
(string? (:client-id args))
|
||||
Long/parseLong)
|
||||
'[?e :invoice/client ?client-id])
|
||||
|
||||
(:original-id args) (add-arg '?original-id (cond-> (:original-id args) (string? (:original-id args)) Long/parseLong )
|
||||
'[?e :invoice/client ?c]
|
||||
'[?c :client/original-id ?original-id])
|
||||
(:status args) (add-arg '?status (keyword "invoice-status" (:status args))
|
||||
'[?e :invoice/status ?status])))
|
||||
(map first)
|
||||
|
||||
Reference in New Issue
Block a user