Selaa lähdekoodia

enhance: add "Open page backups directory"

Tienson Qin 3 vuotta sitten
vanhempi
sitoutus
f9a9fac6e3

+ 24 - 13
src/electron/electron/handler.cljs

@@ -1,5 +1,5 @@
 (ns electron.handler
-  (:require ["electron" :refer [ipcMain dialog app autoUpdater]]
+  (:require ["electron" :refer [ipcMain dialog app autoUpdater shell]]
             [cljs-bean.core :as bean]
             ["fs" :as fs]
             ["buffer" :as buffer]
@@ -64,27 +64,33 @@
     (some (fn [a] (= -1 (first a))) result)))
 
 (defn- truncate-old-versioned-files!
-  [file-path]
-  (let [dir (path/dirname file-path)
-        files (fs/readdirSync dir (clj->js {:withFileTypes true}))
+  [dir]
+  (let [files (fs/readdirSync dir (clj->js {:withFileTypes true}))
         files (map #(.-name %) files)
-        prefix (str (path/basename file-path) ".")
-        versioned-files (filter #(string/starts-with? % prefix) files)
-        old-versioned-files (drop 3 (reverse (sort versioned-files)))]
+        old-versioned-files (drop 3 (reverse (sort files)))]
     (doseq [file old-versioned-files]
       (fs-extra/removeSync (path/join dir file)))))
 
-(defn backup-file
-  [repo path content]
+(defn- get-backup-dir
+  [repo path]
   (let [path (string/replace path repo "")
         bak-dir (str repo "/logseq/bak")
         path (str bak-dir path)
-        new-path (str path "." (string/replace (.toISOString (js/Date.)) ":" "_"))
-        dir (path/dirname new-path)]
-    (fs-extra/ensureDirSync dir)
+        parsed-path (path/parse path)]
+    (path/join (.-dir parsed-path)
+               (.-name parsed-path))))
+
+(defn backup-file
+  [repo path content]
+  (let [path-dir (get-backup-dir repo path)
+        ext (path/extname path)
+        new-path (path/join path-dir
+                            (str (string/replace (.toISOString (js/Date.)) ":" "_")
+                                 ext))]
+    (fs-extra/ensureDirSync path-dir)
     (fs/writeFileSync new-path content)
     (fs/statSync new-path)
-    (truncate-old-versioned-files! path)
+    (truncate-old-versioned-files! path-dir)
     new-path))
 
 (defmethod handle :backupDbFile [_window [_ repo path db-content new-content]]
@@ -93,6 +99,11 @@
              (string-some-deleted? db-content new-content))
     (backup-file repo path db-content)))
 
+(defmethod handle :openFileBackupDir [_window [_ repo path]]
+  (when (string? path)
+    (let [dir (get-backup-dir repo path)]
+      (.openPath shell dir))))
+
 (defmethod handle :readFile [_window [_ path]]
   (utils/read-file path))
 

+ 12 - 3
src/main/frontend/components/page_menu.cljs

@@ -12,7 +12,9 @@
             [frontend.util :as util]
             [frontend.handler.shell :as shell]
             [frontend.handler.plugin :as plugin-handler]
-            [frontend.mobile.util :as mobile-util]))
+            [frontend.mobile.util :as mobile-util]
+            [electron.ipc :as ipc]
+            [frontend.config :as config]))
 
 (defn- delete-page!
   [page-name]
@@ -65,7 +67,8 @@
           favorites (:favorites (state/sub-graph-config))
           favorited? (contains? (set (map util/page-name-sanity-lc favorites))
                                 page-name)
-          developer-mode? (state/sub [:ui/developer-mode?])]
+          developer-mode? (state/sub [:ui/developer-mode?])
+          file-path (when (util/electron?) (page-handler/get-page-file-path))]
       (when (and page (not block?))
         (->>
          [{:title   (if favorited?
@@ -90,7 +93,7 @@
           ;; (such as open-in-finder & open-with-default-app) into a sub-menu of
           ;; this one. However this component doesn't yet exist. PRs are welcome!
           ;; Details: https://github.com/logseq/logseq/pull/3003#issuecomment-952820676
-          (when-let [file-path (and (util/electron?) (page-handler/get-page-file-path))]
+          (when file-path
             [{:title   (t :page/open-in-finder)
               :options {:on-click #(js/window.apis.showItemInFolder file-path)}}
              {:title   (t :page/open-with-default-app)
@@ -121,6 +124,12 @@
                        (fn []
                          (shell/get-file-latest-git-log page 100))}})
 
+          (when (and (util/electron?) file-path)
+            {:title   (t :page/open-backup-directory)
+             :options {:on-click
+                       (fn []
+                         (ipc/ipc "openFileBackupDir" (config/get-local-dir repo) file-path))}})
+
           (when plugin-handler/lsp-enabled?
             (for [[_ {:keys [label] :as cmd} action pid] (state/get-plugins-commands-with-type :page-menu-item)]
               {:title label

+ 3 - 1
src/main/frontend/dicts.cljs

@@ -167,6 +167,7 @@
         :page/action-publish "Publish"
         :page/make-public "Make it public for publishing"
         :page/version-history "Check page history"
+        :page/open-backup-directory "Open page backups directory"
         :page/make-private "Make it private"
         :page/delete "Delete page"
         :page/publish "Publish this page on Logseq"
@@ -1066,6 +1067,7 @@
            :page/action-publish "发布"
            :page/make-public "导出 HTML 时发布本页面"
            :page/version-history "查看页面历史记录"
+           :page/open-backup-directory "打开页面备份文件夹"
            :page/make-private "导出 HTML 时取消发布本页面"
            :page/delete "删除本页"
            :page/publish "将本页发布至 Logseq"
@@ -3209,7 +3211,7 @@
         :plugin/marketplace-tips "Se o plugin não funcionar corretamente quando instalado pela 1ª vez, tente reiniciar o Logseq."
         :plugin/up-to-date "Está atualizado"
         :plugin/custom-js-alert "Ficheiro custom.js encontrado, quer executá-lo? (Se não compreender o conteúdo do ficheiro, é melhor não executá-lo, pois há certos riscos de segurança ao fazê-lo.)"
-        
+
         :pdf/copy-ref "Copiar referência"
         :pdf/copy-text "Copiar texto"
         :pdf/linked-ref "Referências ligadas"