浏览代码

feat: mod+a to select parent up to the whole page (#7803)

mod+a to select parent up to the whole page
Tienson Qin 2 年之前
父节点
当前提交
1206d54c86

+ 44 - 5
src/main/frontend/handler/editor.cljs

@@ -3223,9 +3223,10 @@
     [{:block a :level 1}
     [{:block a :level 1}
      {:block b :level 2}
      {:block b :level 2}
      {:block e :level 2}]"
      {:block e :level 2}]"
-  [{:keys [collapse? expanded? incremental? root-block]
+  [{:keys [collapse? expanded? incremental? root-block page]
     :or {collapse? false expanded? false incremental? true root-block nil}}]
     :or {collapse? false expanded? false incremental? true root-block nil}}]
-  (when-let [page (or (state/get-current-page)
+  (when-let [page (or page
+                      (state/get-current-page)
                       (date/today))]
                       (date/today))]
     (let [block-id (or root-block (parse-uuid page))
     (let [block-id (or root-block (parse-uuid page))
           blocks (if block-id
           blocks (if block-id
@@ -3411,15 +3412,53 @@
       (expand-all! block-id))))
       (expand-all! block-id))))
 
 
 (defn select-all-blocks!
 (defn select-all-blocks!
-  []
+  [{:keys [page]}]
   (if-let [current-input-id (state/get-edit-input-id)]
   (if-let [current-input-id (state/get-edit-input-id)]
     (let [input (gdom/getElement current-input-id)
     (let [input (gdom/getElement current-input-id)
           blocks-container (util/rec-get-blocks-container input)
           blocks-container (util/rec-get-blocks-container input)
           blocks (dom/by-class blocks-container "ls-block")]
           blocks (dom/by-class blocks-container "ls-block")]
       (state/exit-editing-and-set-selected-blocks! blocks))
       (state/exit-editing-and-set-selected-blocks! blocks))
-    (->> (all-blocks-with-level {:collapse? true})
+    (->> (all-blocks-with-level {:page page
+                                 :collapse? true})
          (map (comp gdom/getElementByClass str :block/uuid))
          (map (comp gdom/getElementByClass str :block/uuid))
-         state/exit-editing-and-set-selected-blocks!)))
+         state/exit-editing-and-set-selected-blocks!))
+  (state/set-state! :selection/selected-all? true))
+
+(defn select-parent [e]
+  (let [edit-input (some-> (state/get-edit-input-id) gdom/getElement)
+        edit-block (state/get-edit-block)]
+    (cond
+      ;; editing block fully selected
+      (and edit-block edit-input
+           (= (util/get-selected-text) (.-value edit-input)))
+      (do
+        (util/stop e)
+        (state/exit-editing-and-set-selected-blocks!
+         [(gdom/getElementByClass (str (:block/uuid edit-block)))]))
+
+      edit-block
+      nil
+
+      :else
+      (do
+        (util/stop e)
+        (when-not (:selection/selected-all? @state/state)
+          (if-let [block-id (some-> (first (state/get-selection-blocks))
+                                    (dom/attr "blockid")
+                                    uuid)]
+            (when-let [block (db/entity [:block/uuid block-id])]
+              (let [parent (:block/parent block)]
+                (cond
+                  (= (state/get-current-page) (str (:block/uuid block)))
+                  nil
+
+                  (and parent (:block/parent parent))
+                  (state/exit-editing-and-set-selected-blocks! [(gdom/getElementByClass (:block/uuid parent))])
+
+                  (:block/name parent)
+                  ;; page block
+                  (select-all-blocks! {:page (:block/name parent)}))))
+            (select-all-blocks! {})))))))
 
 
 (defn escape-editing
 (defn escape-editing
   ([]
   ([]

+ 6 - 0
src/main/frontend/modules/shortcut/config.cljs

@@ -241,6 +241,9 @@
    :editor/select-all-blocks       {:binding "mod+shift+a"
    :editor/select-all-blocks       {:binding "mod+shift+a"
                                     :fn      editor-handler/select-all-blocks!}
                                     :fn      editor-handler/select-all-blocks!}
 
 
+   :editor/select-parent           {:binding "mod+a"
+                                    :fn      editor-handler/select-parent}
+
    :editor/zoom-in                 {:binding (if mac? "mod+." "alt+right")
    :editor/zoom-in                 {:binding (if mac? "mod+." "alt+right")
                                     :fn      editor-handler/zoom-in!}
                                     :fn      editor-handler/zoom-in!}
 
 
@@ -518,6 +521,7 @@
                           :editor/open-edit
                           :editor/open-edit
                           :editor/select-block-up
                           :editor/select-block-up
                           :editor/select-block-down
                           :editor/select-block-down
+                          :editor/select-parent
                           :editor/delete-selection
                           :editor/delete-selection
                           :editor/expand-block-children
                           :editor/expand-block-children
                           :editor/collapse-block-children
                           :editor/collapse-block-children
@@ -601,6 +605,7 @@
     :editor/indent
     :editor/indent
     :editor/outdent
     :editor/outdent
     :editor/select-all-blocks
     :editor/select-all-blocks
+    :editor/select-parent
     :go/search
     :go/search
     :go/search-in-page
     :go/search-in-page
     :go/electron-find-in-page
     :go/electron-find-in-page
@@ -678,6 +683,7 @@
    :shortcut.category/block-selection
    :shortcut.category/block-selection
    [:editor/open-edit
    [:editor/open-edit
     :editor/select-all-blocks
     :editor/select-all-blocks
+    :editor/select-parent
     :editor/select-block-up
     :editor/select-block-up
     :editor/select-block-down
     :editor/select-block-down
     :editor/delete-selection]
     :editor/delete-selection]

+ 1 - 0
src/main/frontend/modules/shortcut/dicts.cljc

@@ -75,6 +75,7 @@
    :editor/redo                    "Redo"
    :editor/redo                    "Redo"
    :editor/insert-link             "HTML Link"
    :editor/insert-link             "HTML Link"
    :editor/select-all-blocks       "Select all blocks"
    :editor/select-all-blocks       "Select all blocks"
+   :editor/select-parent           "Select parent block"
    :editor/zoom-in                 "Zoom in editing block / Forwards otherwise"
    :editor/zoom-in                 "Zoom in editing block / Forwards otherwise"
    :editor/zoom-out                "Zoom out editing block / Backwards otherwise"
    :editor/zoom-out                "Zoom out editing block / Backwards otherwise"
    :ui/toggle-brackets             "Toggle whether to display brackets"
    :ui/toggle-brackets             "Toggle whether to display brackets"

+ 6 - 2
src/main/frontend/state.cljs

@@ -145,6 +145,7 @@
      ;; either :up or :down, defaults to down
      ;; either :up or :down, defaults to down
      ;; used to determine selection direction when two or more blocks are selected
      ;; used to determine selection direction when two or more blocks are selected
      :selection/direction                   :down
      :selection/direction                   :down
+     :selection/selected-all?               false
      :custom-context-menu/show?             false
      :custom-context-menu/show?             false
      :custom-context-menu/links             nil
      :custom-context-menu/links             nil
      :custom-context-menu/position          nil
      :custom-context-menu/position          nil
@@ -633,6 +634,7 @@ Similar to re-frame subscriptions"
 (defn- get-selected-block-ids
 (defn- get-selected-block-ids
   [blocks]
   [blocks]
   (->> blocks
   (->> blocks
+       (remove nil?)
        (keep #(when-let [id (dom/attr % "blockid")]
        (keep #(when-let [id (dom/attr % "blockid")]
                 (uuid id)))
                 (uuid id)))
        (distinct)))
        (distinct)))
@@ -966,11 +968,13 @@ Similar to re-frame subscriptions"
          :selection/mode false
          :selection/mode false
          :selection/blocks nil
          :selection/blocks nil
          :selection/direction :down
          :selection/direction :down
-         :selection/start-block nil))
+         :selection/start-block nil
+         :selection/selected-all? false))
 
 
 (defn get-selection-blocks
 (defn get-selection-blocks
   []
   []
-  (:selection/blocks @state))
+  (->> (:selection/blocks @state)
+       (remove nil?)))
 
 
 (defn get-selection-block-ids
 (defn get-selection-block-ids
   []
   []