0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-24 15:39:50 -05:00

Merge pull request #5304 from penpot/niwinz-minor-improvements-renderer

 Make workspace and features system aware of render.wasm loading
This commit is contained in:
Alejandro 2024-11-14 11:40:01 +01:00 committed by GitHub
commit 07e40e78cd
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
7 changed files with 52 additions and 33 deletions

View file

@ -20,6 +20,7 @@
"build:app:assets": "node ./scripts/build-app-assets.js", "build:app:assets": "node ./scripts/build-app-assets.js",
"build:storybook": "yarn run build:storybook:assets && yarn run build:storybook:cljs && storybook build", "build:storybook": "yarn run build:storybook:assets && yarn run build:storybook:cljs && storybook build",
"build:storybook:assets": "node ./scripts/build-storybook-assets.js", "build:storybook:assets": "node ./scripts/build-storybook-assets.js",
"build:wasm": "../render-wasm/build",
"build:storybook:cljs": "clojure -M:dev:shadow-cljs compile storybook", "build:storybook:cljs": "clojure -M:dev:shadow-cljs compile storybook",
"build:app:libs": "node ./scripts/build-libs.js", "build:app:libs": "node ./scripts/build-libs.js",
"build:app:main": "clojure -M:dev:shadow-cljs release main worker", "build:app:main": "clojure -M:dev:shadow-cljs release main worker",

View file

@ -20,6 +20,7 @@ yarn install || exit 1;
rm -rf resources/public; rm -rf resources/public;
rm -rf target/dist; rm -rf target/dist;
yarn run build:wasm || exit 1;
yarn run build:app:main --config-merge "{:release-version \"${CURRENT_HASH}-${TS}\"}" $EXTRA_PARAMS || exit 1 yarn run build:app:main --config-merge "{:release-version \"${CURRENT_HASH}-${TS}\"}" $EXTRA_PARAMS || exit 1
yarn run build:app:libs || exit 1; yarn run build:app:libs || exit 1;
yarn run build:app:assets || exit 1; yarn run build:app:assets || exit 1;

View file

@ -76,6 +76,7 @@
[app.main.repo :as rp] [app.main.repo :as rp]
[app.main.streams :as ms] [app.main.streams :as ms]
[app.main.worker :as uw] [app.main.worker :as uw]
[app.render-wasm :as render.wasm]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.globals :as ug] [app.util.globals :as ug]
[app.util.http :as http] [app.util.http :as http]
@ -264,14 +265,21 @@
(watch [_ _ stream] (watch [_ _ stream]
(->> (rp/cmd! :get-project {:id project-id}) (->> (rp/cmd! :get-project {:id project-id})
(rx/mapcat (fn [project] (rx/mapcat (fn [project]
(->> (rp/cmd! :get-team {:id (:team-id project)}) (rx/concat
(rx/mapcat (fn [team] ;; Wait the wasm module to be loaded or failed to
(let [bundle {:team team ;; load. We need to wait the promise to be resolved
:project project ;; before continue with the next workspace loading
:file-id file-id ;; steps
:project-id project-id}] (->> (rx/from render.wasm/module)
(rx/of (du/set-current-team team) (rx/ignore))
(ptk/data-event ::bundle-stage-1 bundle)))))))) (->> (rp/cmd! :get-team {:id (:team-id project)})
(rx/mapcat (fn [team]
(let [bundle {:team team
:project project
:file-id file-id
:project-id project-id}]
(rx/of (du/set-current-team team)
(ptk/data-event ::bundle-stage-1 bundle)))))))))
(rx/take-until (rx/take-until
(rx/filter (ptk/type? ::fetch-bundle) stream)))))) (rx/filter (ptk/type? ::fetch-bundle) stream))))))
@ -354,13 +362,12 @@
(let [stoper-s (rx/filter (ptk/type? ::finalize-file) stream)] (let [stoper-s (rx/filter (ptk/type? ::finalize-file) stream)]
(rx/merge (rx/merge
(rx/of (ntf/hide) (rx/of (ntf/hide)
;; We initialize the features without knowning the
;; team specific features in this step.
(features/initialize) (features/initialize)
(dcm/retrieve-comment-threads file-id) (dcm/retrieve-comment-threads file-id)
(fetch-bundle project-id file-id)) (fetch-bundle project-id file-id))
;; (when (contains? cf/flags :renderer-v2)
;; (rx/of (renderer/init)))
(->> stream (->> stream
(rx/filter dch/commit?) (rx/filter dch/commit?)
(rx/map deref) (rx/map deref)

View file

@ -12,6 +12,7 @@
[app.common.logging :as log] [app.common.logging :as log]
[app.config :as cf] [app.config :as cf]
[app.main.store :as st] [app.main.store :as st]
[app.render-wasm :as render.wasm]
[beicon.v2.core :as rx] [beicon.v2.core :as rx]
[clojure.set :as set] [clojure.set :as set]
[cuerdas.core :as str] [cuerdas.core :as str]
@ -120,6 +121,11 @@
ptk/EffectEvent ptk/EffectEvent
(effect [_ state _] (effect [_ state _]
(let [features (get-team-enabled-features state)]
(if (contains? features "render-wasm/v1")
(render.wasm/initialize true)
(render.wasm/initialize false)))
(log/trc :hint "initialized features" (log/trc :hint "initialized features"
:team (str/join "," (:features-team state)) :team (str/join "," (:features-team state))
:runtime (str/join "," (:features-runtime state))))))) :runtime (str/join "," (:features-runtime state)))))))

View file

@ -51,7 +51,6 @@
[app.main.ui.workspace.viewport.utils :as utils] [app.main.ui.workspace.viewport.utils :as utils]
[app.main.ui.workspace.viewport.viewport-ref :refer [create-viewport-ref]] [app.main.ui.workspace.viewport.viewport-ref :refer [create-viewport-ref]]
[app.main.ui.workspace.viewport.widgets :as widgets] [app.main.ui.workspace.viewport.widgets :as widgets]
[app.render-wasm :as render.wasm]
[app.util.debug :as dbg] [app.util.debug :as dbg]
[beicon.v2.core :as rx] [beicon.v2.core :as rx]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
@ -657,6 +656,7 @@
(mf/defc viewport (mf/defc viewport
[props] [props]
(if ^boolean render.wasm/enabled? (let [wasm-renderer-enabled? (features/use-feature "render-wasm/v1")]
[:& viewport.wasm/viewport props] (if ^boolean wasm-renderer-enabled?
[:& viewport-classic props])) [:& viewport.wasm/viewport props]
[:& viewport-classic props])))

View file

@ -11,15 +11,12 @@
[app.common.data.macros :as dm] [app.common.data.macros :as dm]
[app.common.types.shape.impl :as ctsi] [app.common.types.shape.impl :as ctsi]
[app.common.uuid :as uuid] [app.common.uuid :as uuid]
[app.main.features :as features]
[app.main.store :as st]
[app.util.object :as obj] [app.util.object :as obj]
[promesa.core :as p])) [promesa.core :as p]))
(def enabled? (defn initialize
(features/active-feature? @st/state "render-wasm/v1")) [enabled?]
(set! app.common.types.shape.impl/enabled-wasm-ready-shape enabled?))
(set! app.common.types.shape.impl/enabled-wasm-ready-shape enabled?)
(defonce internal-module #js {}) (defonce internal-module #js {})
@ -139,16 +136,18 @@
(obj/set! js/window "shape_list" (fn [] ((unchecked-get internal-module "_shape_list")))))) (obj/set! js/window "shape_list" (fn [] ((unchecked-get internal-module "_shape_list"))))))
(defonce module (defonce module
(->> (js/dynamicImport "/js/render_wasm.js") (if (exists? js/dynamicImport)
(p/mcat (fn [module] (->> (js/dynamicImport "/js/render_wasm.js")
(let [default (unchecked-get module "default")] (p/mcat (fn [module]
(default)))) (let [default (unchecked-get module "default")]
(p/fmap (fn [module] (default))))
(set! internal-module module) (p/fmap (fn [module]
true)) (set! internal-module module)
(p/merr (fn [cause] true))
(js/console.error cause) (p/merr (fn [cause]
(p/resolved false))))) (js/console.error cause)
(p/resolved false))))
(p/resolved false)))
(set! app.common.types.shape.impl/wasm-create-shape create-shape) (set! app.common.types.shape.impl/wasm-create-shape create-shape)
(set! app.common.types.shape.impl/wasm-use-shape use-shape) (set! app.common.types.shape.impl/wasm-use-shape use-shape)

View file

@ -1,6 +1,11 @@
#!/usr/bin/env bash #!/usr/bin/env bash
export _BUILD_MODE=${1:-debug};
if [ "$NODE_ENV" = "production" ]; then
export _BUILD_MODE="release";
else
export _BUILD_MODE=${1:-debug};
fi
export EMSDK_QUIET=1 export EMSDK_QUIET=1
export EMCC_CFLAGS="--no-entry -s ERROR_ON_UNDEFINED_SYMBOLS=0 -s MAX_WEBGL_VERSION=2 -s MODULARIZE=1 -s EXPORT_NAME=createRustSkiaModule -s EXPORTED_RUNTIME_METHODS=GL -s ENVIRONMENT=web -s EXPORT_ES6=1 -sMODULARIZE" export EMCC_CFLAGS="--no-entry -s ERROR_ON_UNDEFINED_SYMBOLS=0 -s MAX_WEBGL_VERSION=2 -s MODULARIZE=1 -s EXPORT_NAME=createRustSkiaModule -s EXPORTED_RUNTIME_METHODS=GL -s ENVIRONMENT=web -s EXPORT_ES6=1 -sMODULARIZE"