PoC on porting electron.core to cmd

Also added dev:build-publishing
pull/9061/head
Gabriel Horner 2023-03-14 16:52:48 -04:00 committed by Tienson Qin
parent 9bf867e9ff
commit a748b4f6b3
3 changed files with 89 additions and 1 deletions

3
bb.edn
View File

@ -31,6 +31,9 @@
dev:app-watch
logseq.tasks.dev.mobile/app-watch
dev:build-publishing
logseq.tasks.dev/build-publishing
dev:npx-cap-run-ios
logseq.tasks.dev.mobile/npx-cap-run-ios

View File

@ -1,7 +1,8 @@
(ns logseq.tasks.dev
"Tasks for general development. For desktop or mobile development see their
namespaces"
(:require [babashka.tasks :refer [shell]]
(:require [babashka.process :refer [shell]]
[babashka.fs :as fs]
[clojure.java.io :as io]
[clojure.pprint :as pp]
[clojure.edn :as edn]))
@ -35,3 +36,10 @@
(let [config (with-out-str
(pp/pprint (edn/read-string (:out (shell {:out :string} "node ./static/gen-malli-kondo-config.js")))))]
(spit config-edn config))))
(defn build-publishing
[]
(if-let [_files (seq (set (fs/modified-since (fs/file "static/js/publishing/main.js")
(fs/glob "." "src/main/**"))))]
(shell "clojure -M:cljs release publishing")
(println "publishing assets are up to date")))

View File

@ -0,0 +1,77 @@
(ns logseq.tasks.dev.publish
(:require [promesa.core :as p]
["path" :as path]
["fs-extra$default" :as fs]))
(defn- handle-export-publish-assets
[html custom-css-path export-css-path repo-path asset-filenames output-path]
(let [app-path "static"
root-dir output-path
static-dir (path/join root-dir "static")
assets-from-dir (path/join repo-path "assets")
assets-to-dir (path/join root-dir "assets")
index-html-path (path/join root-dir "index.html")]
(p/let [_ (. fs ensureDir static-dir)
_ (. fs ensureDir assets-to-dir)
_ (p/all (concat
[(. fs writeFile index-html-path html)
(. fs copy (path/join app-path "404.html") (path/join root-dir "404.html"))]
(map
(fn [filename]
(-> (. fs copy (path/join assets-from-dir filename) (path/join assets-to-dir filename))
(p/catch
(fn [e]
;; TODO: Make into a callback
(println "Failed to copy"
(str {:from (path/join assets-from-dir filename)
:to (path/join assets-to-dir filename)})
e)))))
asset-filenames)
(map
(fn [part]
(. fs copy (path/join app-path part) (path/join static-dir part)))
["css" "fonts" "icons" "img" "js"])))
export-css (if (fs/existsSync export-css-path) (. fs readFile export-css-path) "")
_ (. fs writeFile (path/join static-dir "css" "export.css") export-css)
custom-css (if (fs/existsSync custom-css-path) (. fs readFile custom-css-path) "")
_ (. fs writeFile (path/join static-dir "css" "custom.css") custom-css)
js-files ["main.js" "code-editor.js" "excalidraw.js" "tldraw.js"]
_ (p/all (map (fn [file]
(. fs removeSync (path/join static-dir "js" file)))
js-files))
_ (p/all (map (fn [file]
(. fs moveSync
(path/join static-dir "js" "publishing" file)
(path/join static-dir "js" file)))
js-files))
_ (. fs removeSync (path/join static-dir "js" "publishing"))
;; remove source map files
;; TODO: ugly, replace with ls-files and filter with ".map"
_ (p/all (map (fn [file]
(. fs removeSync (path/join static-dir "js" (str file ".map"))))
["main.js" "code-editor.js" "excalidraw.js"]))]
;; TODO: Make into a callback
(println
:notification
{:type "success"
:payload (str "Export public pages and publish assets to " root-dir " successfully 🎉")}))))
(defn -main
[args]
(let [repo-path (or (first args)
(throw (ex-info "GRAPH DIR required" {})))
output-path (or (second args)
(throw (ex-info "OUT DIR required" {})))
html "WOOHOO"
custom-css-path (path/join repo-path "logseq" "custom.css")
export-css-path (path/join repo-path "logseq" "export.css")
;; TODO: Read from repo-path
asset-filenames []]
(handle-export-publish-assets html custom-css-path export-css-path repo-path asset-filenames output-path)))
(-main *command-line-args*)