Browse Source

fix key duplicates caused by key case when insert page property (#5889)

* fix key duplicates caused by key case when insert page property

* use lower-cased property key
llcc 3 years ago
parent
commit
6f395175d5
1 changed files with 5 additions and 2 deletions
  1. 5 2
      src/main/frontend/util/page_property.cljs

+ 5 - 2
src/main/frontend/util/page_property.cljs

@@ -13,13 +13,16 @@
     (let [key (if (string? key) (keyword key) key)
     (let [key (if (string? key) (keyword key) key)
           key-part (util/format (case format
           key-part (util/format (case format
                                   :org "#+%s: "
                                   :org "#+%s: "
-                                  "%s:: ") (name key))
+                                  "%s:: ") (string/lower-case (name key)))
           new-property-line (str key-part value)
           new-property-line (str key-part value)
           lines (string/split-lines content)
           lines (string/split-lines content)
           key-exists? (atom false)
           key-exists? (atom false)
           lines (doall
           lines (doall
                  (map (fn [line]
                  (map (fn [line]
-                        (if (and (string/starts-with? line key-part) (not @key-exists?)) ; only replace the first match
+                        (if (and (string/starts-with?
+                                  (string/lower-case line)
+                                  (string/lower-case key-part))
+                                 (not @key-exists?)) ; only replace the first match
                           (do
                           (do
                             (reset! key-exists? true)
                             (reset! key-exists? true)
                             new-property-line)
                             new-property-line)