| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 | 
							- (ns publishing
 
-   "Basic script for publishing from CLI"
 
-   (:require ["fs" :as fs]
 
-             ["path" :as node-path]
 
-             [clojure.edn :as edn]
 
-             [datascript.core :as d]
 
-             [logseq.db.common.sqlite-cli :as sqlite-cli]
 
-             [logseq.db.sqlite.util :as sqlite-util]
 
-             [logseq.graph-parser.cli :as gp-cli]
 
-             [logseq.publishing :as publishing]
 
-             [nbb.core :as nbb]))
 
- (defn- get-db [graph-dir]
 
-   (let [{:keys [conn]} (gp-cli/parse-graph graph-dir {:verbose false})] @conn))
 
- (defn- publish-file-graph [static-dir graph-dir output-path options]
 
-   (let [repo-config (-> (node-path/join graph-dir "logseq" "config.edn") fs/readFileSync str edn/read-string)]
 
-     (publishing/export (get-db graph-dir)
 
-                        static-dir
 
-                        graph-dir
 
-                        output-path
 
-                        (merge options {:repo (node-path/basename graph-dir)
 
-                                        :repo-config repo-config
 
-                                        :ui/theme "dark"
 
-                                        :ui/radix-color :purple}))))
 
- (defn- publish-db-graph [static-dir graph-dir output-path opts]
 
-   (let [db-name (node-path/basename graph-dir)
 
-         conn (sqlite-cli/open-db! (node-path/dirname graph-dir) db-name)
 
-         repo-config (-> (d/q '[:find ?content
 
-                                :where [?b :file/path "logseq/config.edn"] [?b :file/content ?content]]
 
-                              @conn)
 
-                         ffirst
 
-                         edn/read-string)]
 
-     (publishing/export @conn
 
-                        static-dir
 
-                        graph-dir
 
-                        output-path
 
-                        (merge opts {:repo (str sqlite-util/db-version-prefix db-name)
 
-                                     :repo-config repo-config
 
-                                     :db-graph? true
 
-                                     :ui/theme "dark"
 
-                                     :ui/radix-color :cyan}))))
 
- (defn- resolve-path
 
-   "If relative path, resolve with $ORIGINAL_PWD"
 
-   [path]
 
-   (if (node-path/isAbsolute path)
 
-     path
 
-     (node-path/join (or js/process.env.ORIGINAL_PWD ".") path)))
 
- (defn -main
 
-   [args]
 
-   (when (< (count args) 3)
 
-     (println "Usage: $0 STATIC-DIR GRAPH-DIR OUT-DIR")
 
-     (js/process.exit 1))
 
-   (let [[static-dir graph-dir output-path] (map resolve-path args)
 
-         options {:dev? (contains? (set args) "--dev")}]
 
-     (if (sqlite-cli/db-graph-directory? graph-dir)
 
-       (publish-db-graph static-dir graph-dir output-path options)
 
-       (publish-file-graph static-dir graph-dir output-path options))))
 
- (when (= nbb/*file* (nbb/invoked-file))
 
-   (-main *command-line-args*))
 
 
  |