Kaynağa Gözat

fix: use name to detect default theme

Yue Yang 2 yıl önce
ebeveyn
işleme
a842818ab6

+ 1 - 1
src/main/frontend/components/theme.cljs

@@ -27,7 +27,7 @@
           (.add cls "dark")
           (.add cls "dark")
           (.remove cls "dark"))
           (.remove cls "dark"))
         (ui/apply-custom-theme-effect! theme)
         (ui/apply-custom-theme-effect! theme)
-        (plugin-handler/hook-plugin-app :theme-mode-changed {:mode theme} nil))
+        (plugin-handler/hook-plugin-app :theme-mode-changed {:mode theme}))
      [theme])
      [theme])
 
 
     (rum/use-effect!
     (rum/use-effect!

+ 2 - 2
src/main/frontend/handler/plugin.cljs

@@ -632,8 +632,8 @@
                                                           (when mode
                                                           (when mode
                                                             (state/set-custom-theme! mode theme)
                                                             (state/set-custom-theme! mode theme)
                                                             (state/set-theme-mode! mode))
                                                             (state/set-theme-mode! mode))
-                                                          (hook-plugin-app :theme-changed theme)
-                                                          (state/set-state! :plugin/selected-theme url))))
+                                                          (state/set-state! :plugin/selected-theme url)
+                                                          (hook-plugin-app :theme-changed theme))))
 
 
                                 (.on "reset-custom-theme" (fn [^js themes]
                                 (.on "reset-custom-theme" (fn [^js themes]
                                                             (let [themes       (bean/->clj themes)
                                                             (let [themes       (bean/->clj themes)

+ 5 - 3
src/main/frontend/ui.cljs

@@ -366,10 +366,12 @@
 (defn apply-custom-theme-effect! [theme]
 (defn apply-custom-theme-effect! [theme]
   (when config/lsp-enabled?
   (when config/lsp-enabled?
     (when-let [custom-theme (state/sub [:ui/custom-theme (keyword theme)])]
     (when-let [custom-theme (state/sub [:ui/custom-theme (keyword theme)])]
-      (when-let [url (:url custom-theme)]
+      ;; If the name is nil, the user has not set a custom theme (initially {:mode light/dark}).
+      ;; The url is not used because the default theme does not have an url.
+      (when-let [name (:name custom-theme)]
         (js/LSPluginCore.selectTheme (bean/->js custom-theme)
         (js/LSPluginCore.selectTheme (bean/->js custom-theme)
-                                     (bean/->js {:emit true}))
-        (state/set-state! :plugin/selected-theme url)))))
+                                     (bean/->js {:emit false}))
+        (state/set-state! :plugin/selected-theme (:url custom-theme))))))
 
 
 (defn setup-system-theme-effect!
 (defn setup-system-theme-effect!
   []
   []

+ 3 - 3
yarn.lock

@@ -1617,9 +1617,9 @@ caniuse-api@^3.0.0:
     lodash.uniq "^4.5.0"
     lodash.uniq "^4.5.0"
 
 
 caniuse-lite@^1.0.0, caniuse-lite@^1.0.30001109, caniuse-lite@^1.0.30001370:
 caniuse-lite@^1.0.0, caniuse-lite@^1.0.30001109, caniuse-lite@^1.0.30001370:
-  version "1.0.30001393"
-  resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001393.tgz#1aa161e24fe6af2e2ccda000fc2b94be0b0db356"
-  integrity sha512-N/od11RX+Gsk+1qY/jbPa0R6zJupEa0lxeBG598EbrtblxVCTJsQwbRBm6+V+rxpc5lHKdsXb9RY83cZIPLseA==
+  version "1.0.30001431"
+  resolved "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001431.tgz"
+  integrity sha512-zBUoFU0ZcxpvSt9IU66dXVT/3ctO1cy4y9cscs1szkPlcWb6pasYM144GqrUygUbT+k7cmUCW61cvskjcv0enQ==
 
 
 caniuse-lite@^1.0.30001400, caniuse-lite@^1.0.30001426:
 caniuse-lite@^1.0.30001400, caniuse-lite@^1.0.30001426:
   version "1.0.30001431"
   version "1.0.30001431"