0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-24 23:49:45 -05:00

🎉 Select main instance when selecting a component

This commit is contained in:
Andrés Moya 2022-08-22 16:29:13 +02:00
parent f0e521b8d5
commit e8990caefb
2 changed files with 46 additions and 3 deletions

View file

@ -65,6 +65,7 @@
[beicon.core :as rx] [beicon.core :as rx]
[cljs.spec.alpha :as s] [cljs.spec.alpha :as s]
[cuerdas.core :as str] [cuerdas.core :as str]
[linked.core :as lks]
[potok.core :as ptk])) [potok.core :as ptk]))
(s/def ::shape-attrs ::cts/shape-attrs) (s/def ::shape-attrs ::cts/shape-attrs)
@ -961,7 +962,6 @@
:graphics #{} :graphics #{}
:colors #{} :colors #{}
:typographies #{}})))) :typographies #{}}))))
(defn go-to-component (defn go-to-component
[component-id] [component-id]
(ptk/reify ::go-to-component (ptk/reify ::go-to-component
@ -984,6 +984,31 @@
(let [wrapper-id (str "component-shape-id-" component-id)] (let [wrapper-id (str "component-shape-id-" component-id)]
(tm/schedule-on-idle #(dom/scroll-into-view-if-needed! (dom/get-element wrapper-id))))))) (tm/schedule-on-idle #(dom/scroll-into-view-if-needed! (dom/get-element wrapper-id)))))))
(defn go-to-main-instance
[page-id shape-id on-page-selected]
(us/verify ::us/uuid page-id)
(us/verify ::us/uuid shape-id)
(ptk/reify ::go-to-main-instance
ptk/WatchEvent
(watch [_ state stream]
(let [current-page-id (:current-page-id state)]
(if (= page-id current-page-id)
(do
(on-page-selected)
(rx/of (dws/select-shapes (lks/set shape-id))))
(let [project-id (:current-project-id state)
file-id (:current-file-id state)
pparams {:file-id file-id :project-id project-id}
qparams {:page-id page-id :layout :assets}]
(rx/merge
(rx/of (rt/nav :workspace pparams qparams))
(->> stream
(rx/filter (ptk/type? ::dwv/initialize-viewport))
(rx/take 1)
(rx/mapcat #(do
(on-page-selected)
(rx/of (dws/select-shapes (lks/set shape-id)))))))))))))
(def go-to-file (def go-to-file
(ptk/reify ::go-to-file (ptk/reify ::go-to-file
ptk/WatchEvent ptk/WatchEvent

View file

@ -370,6 +370,24 @@
dragging? (mf/use-state false) dragging? (mf/use-state false)
unselect-all
(mf/use-callback
(fn []
(st/emit! (dw/unselect-all-assets))))
on-component-click
(mf/use-callback
(mf/deps component selected-components)
(fn [event]
(dom/stop-propagation event)
(let [main-instance-id (:main-instance-id component)
main-instance-page (:main-instance-page component)]
(if (and main-instance-id main-instance-page)
(st/emit! (dw/go-to-main-instance main-instance-page main-instance-id
#(on-asset-click event (:id component) unselect-all)))
;; This may occur when :components-v2 is disabled
(on-asset-click event (:id component) unselect-all)))))
on-drop on-drop
(mf/use-callback (mf/use-callback
(mf/deps component dragging? selected-components selected-components-full selected-components-paths) (mf/deps component dragging? selected-components selected-components-full selected-components-paths)
@ -405,7 +423,7 @@
:enum-item (not @listing-thumbs?)) :enum-item (not @listing-thumbs?))
:id (str "component-shape-id-" (:id component)) :id (str "component-shape-id-" (:id component))
:draggable true :draggable true
:on-click #(on-asset-click % (:id component) nil) :on-click on-component-click
:on-context-menu (on-context-menu (:id component)) :on-context-menu (on-context-menu (:id component))
:on-drag-start on-component-drag-start :on-drag-start on-component-drag-start
:on-drag-enter on-drag-enter :on-drag-enter on-drag-enter
@ -1973,7 +1991,7 @@
on-asset-click on-asset-click
(mf/use-callback (mf/use-callback
(mf/deps extend-selected-assets selected-assets) (mf/deps selected-assets)
(fn [asset-type asset-groups event asset-id default-click] (fn [asset-type asset-groups event asset-id default-click]
(cond (cond
(kbd/mod? event) (kbd/mod? event)