mirror of
https://github.com/penpot/penpot.git
synced 2025-01-10 08:50:57 -05:00
Merge pull request #4788 from penpot/alotor-plugins-2
Fix problem with plugins initialization
This commit is contained in:
commit
b9e40b4d82
5 changed files with 37 additions and 16 deletions
|
@ -105,8 +105,7 @@
|
||||||
(rx/map deref)
|
(rx/map deref)
|
||||||
(rx/filter du/is-authenticated?)
|
(rx/filter du/is-authenticated?)
|
||||||
(rx/take 1)
|
(rx/take 1)
|
||||||
(rx/map #(ws/initialize))
|
(rx/map #(ws/initialize)))))))
|
||||||
(rx/tap #(plugins/init!)))))))
|
|
||||||
|
|
||||||
(defn ^:export init
|
(defn ^:export init
|
||||||
[]
|
[]
|
||||||
|
@ -116,7 +115,8 @@
|
||||||
(cur/init-styles)
|
(cur/init-styles)
|
||||||
(thr/init!)
|
(thr/init!)
|
||||||
(init-ui)
|
(init-ui)
|
||||||
(st/emit! (initialize)))
|
(st/emit! (plugins/initialize)
|
||||||
|
(initialize)))
|
||||||
|
|
||||||
(defn ^:export reinit
|
(defn ^:export reinit
|
||||||
([]
|
([]
|
||||||
|
|
|
@ -131,7 +131,7 @@
|
||||||
(rx/merge-map svg->clj)
|
(rx/merge-map svg->clj)
|
||||||
(rx/tap on-svg)))))
|
(rx/tap on-svg)))))
|
||||||
|
|
||||||
(defn- process-blobs
|
(defn process-blobs
|
||||||
[{:keys [file-id local? name blobs force-media on-image on-svg]}]
|
[{:keys [file-id local? name blobs force-media on-image on-svg]}]
|
||||||
(letfn [(svg-blob? [blob]
|
(letfn [(svg-blob? [blob]
|
||||||
(and (not force-media)
|
(and (not force-media)
|
||||||
|
|
|
@ -16,15 +16,20 @@
|
||||||
[beicon.v2.core :as rx]
|
[beicon.v2.core :as rx]
|
||||||
[potok.v2.core :as ptk]))
|
[potok.v2.core :as ptk]))
|
||||||
|
|
||||||
(defn init!
|
(defn init-plugins-runtime!
|
||||||
[]
|
[]
|
||||||
(->> st/stream
|
|
||||||
(rx/filter (ptk/type? ::features/initialize))
|
|
||||||
(rx/take 1)
|
|
||||||
;; We need to wait to the init event to finish
|
|
||||||
(rx/observe-on :async)
|
|
||||||
(rx/subs!
|
|
||||||
(fn []
|
|
||||||
(when (features/active-feature? @st/state "plugins/runtime")
|
|
||||||
(when-let [init-runtime (obj/get global "initPluginsRuntime")]
|
(when-let [init-runtime (obj/get global "initPluginsRuntime")]
|
||||||
(init-runtime (fn [plugin-id] (api/create-context plugin-id)))))))))
|
(init-runtime (fn [plugin-id] (api/create-context plugin-id)))))
|
||||||
|
|
||||||
|
(defn initialize
|
||||||
|
[]
|
||||||
|
(ptk/reify ::initialize
|
||||||
|
ptk/WatchEvent
|
||||||
|
(watch [_ _ stream]
|
||||||
|
(->> stream
|
||||||
|
(rx/filter (ptk/type? ::features/initialize))
|
||||||
|
(rx/observe-on :async)
|
||||||
|
(rx/filter #(features/active-feature? @st/state "plugins/runtime"))
|
||||||
|
(rx/take 1)
|
||||||
|
(rx/tap init-plugins-runtime!)
|
||||||
|
(rx/ignore)))))
|
||||||
|
|
|
@ -124,6 +124,22 @@
|
||||||
(rx/take 1)
|
(rx/take 1)
|
||||||
(rx/subs! resolve reject)))))))
|
(rx/subs! resolve reject)))))))
|
||||||
|
|
||||||
|
(uploadMediaData
|
||||||
|
[_ name data mime-type]
|
||||||
|
(let [file-id (:current-file-id @st/state)]
|
||||||
|
(p/create
|
||||||
|
(fn [resolve reject]
|
||||||
|
(->> (dwm/process-blobs
|
||||||
|
{:file-id file-id
|
||||||
|
:local? false
|
||||||
|
:name name
|
||||||
|
:blobs [(js/Blob. #js [data] #js {:type mime-type})]
|
||||||
|
:on-image identity
|
||||||
|
:on-svg identity})
|
||||||
|
(rx/take 1)
|
||||||
|
(rx/map u/to-js)
|
||||||
|
(rx/subs! resolve reject))))))
|
||||||
|
|
||||||
(group
|
(group
|
||||||
[_ shapes]
|
[_ shapes]
|
||||||
(cond
|
(cond
|
||||||
|
|
|
@ -27,6 +27,6 @@
|
||||||
|
|
||||||
(defn ^:export plugins []
|
(defn ^:export plugins []
|
||||||
(st/emit! (features/enable-feature "plugins/runtime"))
|
(st/emit! (features/enable-feature "plugins/runtime"))
|
||||||
(plugins/init!)
|
(plugins/init-plugins-runtime!)
|
||||||
nil)
|
nil)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue