Files
logseq/src/main/frontend/handler/common/developer.cljs

82 lines
3.1 KiB
Clojure

(ns frontend.handler.common.developer
"Common fns for developer related functionality"
(:require [frontend.db :as db]
[cljs.pprint :as pprint]
[frontend.state :as state]
[frontend.handler.notification :as notification]
[frontend.ui :as ui]
[frontend.util.page :as page-util]
[frontend.handler.db-based.property.util :as db-pu]
[frontend.format.mldoc :as mldoc]
[frontend.config :as config]
[frontend.persist-db :as persist-db]
[promesa.core :as p]))
;; Fns used between menus and commands
(defn show-entity-data
[& pull-args]
(let [result* (apply db/pull pull-args)
result (cond-> result*
(and (seq (:block/properties result*)) (config/db-based-graph? (state/get-current-repo)))
(assoc :block.debug/properties (update-keys (:block/properties result*) db-pu/get-property-name)))
pull-data (with-out-str (pprint/pprint result))]
(println pull-data)
(notification/show!
[:div
[:pre.code pull-data]
[:br]
(ui/button "Copy to clipboard"
:on-click #(.writeText js/navigator.clipboard pull-data))]
:success
false)))
(defn show-content-ast
[content format]
(let [ast-data (-> (mldoc/->edn content format)
pprint/pprint
with-out-str)]
(println ast-data)
(notification/show!
[:div
;; Show clipboard at top since content is really long for pages
(ui/button "Copy to clipboard"
:on-click #(.writeText js/navigator.clipboard ast-data))
[:br]
[:pre.code ast-data]]
:success
false)))
;; Public Commands
(defn ^:export show-block-data []
;; Use editor state to locate most recent block
(if-let [block-uuid (:block-id (first (state/get-editor-args)))]
(show-entity-data [:block/uuid block-uuid])
(notification/show! "No block found" :warning)))
(defn ^:export show-block-ast []
(if-let [{:block/keys [content format]} (:block (first (state/get-editor-args)))]
(show-content-ast content format)
(notification/show! "No block found" :warning)))
(defn ^:export show-page-data []
(if-let [page-id (page-util/get-current-page-id)]
(show-entity-data page-id)
(notification/show! "No page found" :warning)))
(defn ^:export show-page-ast []
(if (config/db-based-graph? (state/get-current-repo))
(notification/show! "Command not available yet for DB graphs" :warning)
(let [page-data (db/pull '[:block/format {:block/file [:file/content]}]
(page-util/get-current-page-id))]
(if (get-in page-data [:block/file :file/content])
(show-content-ast (get-in page-data [:block/file :file/content]) (:block/format page-data))
(notification/show! "No page found" :warning)))))
(defn import-chosen-graph
[repo]
(p/let [_ (persist-db/<unsafe-delete repo)
_ (persist-db/<fetch-init-data repo)]
(notification/show! "Graph updated!" :success)))
(defn ^:export replace-graph-with-db-file []
(state/set-state! :ui/open-select :db-graph-replace))