Browse Source

fix: creating a choice with keyboard

always displays invalid warning. This happened because Enter was
causing a 2nd click, upsert and then the message to display.
Fixes https://test.logseq.com/#/page/67f52d87-3858-4b06-a26b-f601b0c4c1ef
Gabriel Horner 6 months ago
parent
commit
6cb93386ae

+ 5 - 4
deps/shui/src/logseq/shui/base/core.cljs

@@ -43,10 +43,11 @@
         children (if (map? props) children (cons props children))
         children (if (map? props) children (cons props children))
         props (assoc (if (map? props) props {})
         props (assoc (if (map? props) props {})
                      :on-key-up (fn [^js e]
                      :on-key-up (fn [^js e]
-                             ;; TODO: return value
-                                  (when (fn? on-key-up') (on-key-up' e))
-                                  (when (= "Enter" (.-key e))
-                                    (some-> (.-target e) (.click)))))]
+                                  ;; If on-key-up is provided, it should be able to control Enter behavior
+                                  (if (fn? on-key-up')
+                                    (on-key-up' e)
+                                    (when (= "Enter" (.-key e))
+                                      (some-> (.-target e) (.click))))))]
     (apply button-base props children)))
     (apply button-base props children)))
 
 
 (defn button-icon
 (defn button-icon

+ 1 - 0
src/main/frontend/components/property/config.cljs

@@ -234,6 +234,7 @@
       (let [dirty? (not= (rum/deref *form-data) form-data)]
       (let [dirty? (not= (rum/deref *form-data) form-data)]
         (shui/button {:size "sm"
         (shui/button {:size "sm"
                       :disabled (not dirty?)
                       :disabled (not dirty?)
+                      :on-key-up util/stop
                       :on-click (fn []
                       :on-click (fn []
                                   (-> (<upsert-closed-value! own-property
                                   (-> (<upsert-closed-value! own-property
                                                              (cond-> form-data uuid (assoc :id uuid)))
                                                              (cond-> form-data uuid (assoc :id uuid)))