Skip to content

Commit

Permalink
Render main styesheet with reagent, not dom interop
Browse files Browse the repository at this point in the history
Fixes #410
  • Loading branch information
kimo-k committed Feb 4, 2024
1 parent e91ea89 commit 1562ccf
Show file tree
Hide file tree
Showing 5 changed files with 16 additions and 18 deletions.
15 changes: 9 additions & 6 deletions src/day8/re_frame_10x.cljs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@
[day8.re-frame-10x.components.re-com :as rc]
[day8.re-frame-10x.navigation.views :as container]
[day8.re-frame-10x.panels.settings.subs :as settings.subs]
[day8.re-frame-10x.panels.settings.events :as settings.events]))
[day8.re-frame-10x.panels.settings.events :as settings.events])
(:require-macros [day8.re-frame-10x.components.re-com :refer [inline-resource]]))

(goog-define debug? false)

Expand Down Expand Up @@ -128,15 +129,17 @@
(defn ^:export handle-keys! [handle-keys?]
(rf/dispatch [::settings.events/handle-keys? handle-keys?]))

(defn create-shadow-root [css-str]
(tools.shadow-dom/shadow-root js/document "--re-frame-10x--" css-str))
(defn create-shadow-root []
(tools.shadow-dom/shadow-root js/document "--re-frame-10x--"))

(defn create-style-container [shadow-root]
[spade.react/with-style-container
(spade.dom/create-container shadow-root)
[devtools-outer
{:panel-type :inline
:debug? debug?}]])
[:<>
[:style (inline-resource "day8/re_frame_10x/style.css")]
[devtools-outer
{:panel-type :inline
:debug? debug?}]]])

(defn patch!
"Sets up any initial state that needs to be there for tracing. Does not enable tracing."
Expand Down
4 changes: 3 additions & 1 deletion src/day8/re_frame_10x/navigation/views.cljs
Original file line number Diff line number Diff line change
Expand Up @@ -434,5 +434,7 @@
:component-will-unmount unmount
:reagent-render (fn []
[spade.react/with-style-container spade-container
[devtools-inner {:panel-type :popup}]])})]
[:<>
[:style (inline-resource "day8/re_frame_10x/style.css")]
[devtools-inner {:panel-type :popup}]]])})]
shadow-root)))
5 changes: 2 additions & 3 deletions src/day8/re_frame_10x/preload/react_17.cljs
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,7 @@
[day8.re-frame-10x :as re-frame-10x]
[day8.re-frame-10x.inlined-deps.reagent.v1v2v0.reagent.dom :as rdom]
[day8.re-frame-10x.inlined-deps.re-frame.v1v3v0.re-frame.core :as rf]
[day8.re-frame-10x.events :as events])
(:require-macros [day8.re-frame-10x.components.re-com :refer [inline-resource]]))
[day8.re-frame-10x.events :as events]))

(let [react-major-version (first (str/split react/version #"\."))]
(when-not (= "17" react-major-version)
Expand All @@ -26,7 +25,7 @@

(rf/clear-subscription-cache!)

(def shadow-root (re-frame-10x/create-shadow-root (inline-resource "day8/re_frame_10x/style.css")))
(def shadow-root (re-frame-10x/create-shadow-root))

(rdom/render (re-frame-10x/create-style-container shadow-root)
shadow-root)
2 changes: 1 addition & 1 deletion src/day8/re_frame_10x/preload/react_18.cljs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@

(rf/clear-subscription-cache!)

(def shadow-root (re-frame-10x/create-shadow-root (inline-resource "day8/re_frame_10x/style.css")))
(def shadow-root (re-frame-10x/create-shadow-root))

(rdc/render (rdc/create-root shadow-root)
(re-frame-10x/create-style-container shadow-root))
8 changes: 1 addition & 7 deletions src/day8/re_frame_10x/tools/shadow_dom.cljs
Original file line number Diff line number Diff line change
@@ -1,21 +1,15 @@
(ns day8.re-frame-10x.tools.shadow-dom)

(defn attach-stylesheet [shadow-root css-str]
(let [stylesheet (js/CSSStyleSheet.)
_ (.replaceSync stylesheet css-str)]
(set! (.-adoptedStyleSheets shadow-root) (js/Array. stylesheet))))

(defn shadow-root
"Creates a new div element with the id attached to the js-document <body>,
attaches a shadow DOM tree and returns a reference to its ShadowRoot."
[js-document id css-str]
[js-document id]
(let [container (.getElementById js-document id)]
(if container
(.-shadowRoot container)
(let [body (.-body js-document)
container (.createElement js-document "div")
shadow-root (.attachShadow container #js {:mode "open"})]
(attach-stylesheet shadow-root css-str)
(.setAttribute container "id" id)
(.appendChild body container)
(js/window.focus container)
Expand Down

0 comments on commit 1562ccf

Please sign in to comment.