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:
commit
07e40e78cd
7 changed files with 52 additions and 33 deletions
|
@ -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",
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)))))))
|
||||||
|
|
|
@ -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])))
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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"
|
||||||
|
|
Loading…
Add table
Reference in a new issue