Browse Source

fix block conflicts

Konstantinos Kaloutas 1 year ago
parent
commit
1115df9de0
1 changed files with 48 additions and 59 deletions
  1. 48 59
      src/main/frontend/components/block.cljs

+ 48 - 59
src/main/frontend/components/block.cljs

@@ -2184,69 +2184,58 @@
             shift? (gobj/get e "shiftKey")
             meta? (util/meta-key? e)
             forbidden-edit? (target-forbidden-edit? target)]
-        (when (and (not forbidden-edit?) (contains? #{1 0} button))
-          (util/stop-propagation e)
-          (let [selection-blocks (state/get-selection-blocks)
-                starting-block (state/get-selection-start-block-or-first)]
-            (cond
-              (and meta? shift?)
-              (when-not (empty? selection-blocks)
-                (util/stop e)
-                (editor-handler/highlight-selection-area! block-id true))
-
-              meta?
-              (do
-                (util/stop e)
-                (let [block-dom-element (gdom/getElement block-id)]
-                  (if (some #(= block-dom-element %) selection-blocks)
-                    (state/drop-selection-block! block-dom-element)
-                    (state/conj-selection-block! block-dom-element :down)))
-                (if (empty? (state/get-selection-blocks))
-                  (state/clear-selection!)
-                  (state/set-selection-start-block! block-id)))
-
-              (and shift? starting-block)
-              (do
-                (util/stop e)
+        (if (and meta?
+                 (not (state/get-edit-input-id))
+                 (not (dom/has-class? target "page-ref"))
+                 (not= "A" (gobj/get target "tagName")))
+          (do
+            (util/stop e)
+            (state/conj-selection-block! (gdom/getElement block-id) :down)
+            (when block-id
+              (state/set-selection-start-block! block-id)))
+          (when (contains? #{1 0} button)
+            (when-not forbidden-edit?
+              (cond
+                (and shift? (state/get-selection-start-block-or-first))
+                (do
+                  (util/stop e)
+                  (util/clear-selection!)
+                  (editor-handler/highlight-selection-area! block-id))
+
+                shift?
                 (util/clear-selection!)
-                (editor-handler/highlight-selection-area! block-id))
 
-              shift?
-              (do
-                (util/clear-selection!)
-                (state/set-selection-start-block! block-id))
-
-              :else
-              (do
-                (editor-handler/clear-selection!)
-                (editor-handler/unhighlight-blocks!)
-                (let [f #(let [block (or (db/entity [:block/uuid (:block/uuid block)]) block)
-                               cursor-range (some-> (gdom/getElement block-id)
-                                                    (dom/by-class "block-content-wrapper")
-                                                    first
-                                                    util/caret-range)
-                               {:block/keys [content format]} block
-                               content (if (config/db-based-graph? repo)
-                                         (or (:block/original-name block) content)
-                                         (->> content
-                                              (property-file/remove-built-in-properties-when-file-based
-                                               (state/get-current-repo) format)
-                                              (drawer/remove-logbook)))]
-                           (state/set-editing!
-                            edit-input-id
-                            content
-                            block
-                            cursor-range
-                            {:ref ref
-                             :move-cursor? false}))]
+                :else
+                (do
+                  (editor-handler/clear-selection!)
+                  (editor-handler/unhighlight-blocks!)
+                  (let [f #(let [block (or (db/entity [:block/uuid (:block/uuid block)]) block)
+                                 cursor-range (some-> (gdom/getElement block-id)
+                                                      (dom/by-class "block-content-wrapper")
+                                                      first
+                                                      util/caret-range)
+                                 {:block/keys [content format]} block
+                                 content (if (config/db-based-graph? repo)
+                                           (or (:block/original-name block) content)
+                                           (->> content
+                                                (property-file/remove-built-in-properties-when-file-based
+                                                 (state/get-current-repo) format)
+                                                (drawer/remove-logbook)))]
+                             (state/set-editing!
+                              edit-input-id
+                              content
+                              block
+                              cursor-range
+                              {:ref ref
+                               :move-cursor? false}))]
                    ;; wait a while for the value of the caret range
-                  (p/do!
-                   (state/pub-event! [:editor/save-code-editor])
-                   (if (util/ios?)
-                     (f)
-                     (js/setTimeout f 5)))
+                    (p/do!
+                     (state/pub-event! [:editor/save-code-editor])
+                     (if (util/ios?)
+                       (f)
+                       (js/setTimeout f 5)))
 
-                  (state/set-selection-start-block! block-id))))))))))
+                    (when block-id (state/set-selection-start-block! block-id))))))))))))
 
 (rum/defc dnd-separator-wrapper < rum/reactive
   [block children block-id slide? top? block-content?]