mirror of
https://github.com/penpot/penpot.git
synced 2025-03-30 00:21:19 -05:00
Merge remote-tracking branch 'origin/staging' into develop
This commit is contained in:
commit
f47991fa9c
10 changed files with 42 additions and 28 deletions
common/src/app/common/types
frontend/src/app/main
data
ui
components
dashboard
workspace
|
@ -509,6 +509,7 @@
|
||||||
(every? nil?)))]
|
(every? nil?)))]
|
||||||
(or
|
(or
|
||||||
;;We don't want to change the structure of component copies
|
;;We don't want to change the structure of component copies
|
||||||
|
(ctk/in-component-copy? parent)
|
||||||
(has-any-copy-parent? objects parent)
|
(has-any-copy-parent? objects parent)
|
||||||
;; If we are moving something containing a main instance the container can't be part of a component (neither main nor copy)
|
;; If we are moving something containing a main instance the container can't be part of a component (neither main nor copy)
|
||||||
(and selected-main-instance? parent-in-component?)
|
(and selected-main-instance? parent-in-component?)
|
||||||
|
|
|
@ -682,12 +682,12 @@
|
||||||
|
|
||||||
(defn end-rename-shape
|
(defn end-rename-shape
|
||||||
"End the ongoing shape rename process"
|
"End the ongoing shape rename process"
|
||||||
([] (end-rename-shape nil))
|
([] (end-rename-shape nil nil))
|
||||||
([name]
|
([shape-id name]
|
||||||
(ptk/reify ::end-rename-shape
|
(ptk/reify ::end-rename-shape
|
||||||
ptk/WatchEvent
|
ptk/WatchEvent
|
||||||
(watch [_ state _]
|
(watch [_ state _]
|
||||||
(when-let [shape-id (dm/get-in state [:workspace-local :shape-for-rename])]
|
(when-let [shape-id (d/nilv shape-id (dm/get-in state [:workspace-local :shape-for-rename]))]
|
||||||
(let [shape (wsh/lookup-shape state shape-id)
|
(let [shape (wsh/lookup-shape state shape-id)
|
||||||
name (str/trim name)
|
name (str/trim name)
|
||||||
clean-name (cfh/clean-path name)
|
clean-name (cfh/clean-path name)
|
||||||
|
|
|
@ -602,9 +602,11 @@
|
||||||
(update-in state [:stops stop] (fn [data] (->> changes
|
(update-in state [:stops stop] (fn [data] (->> changes
|
||||||
(merge data)
|
(merge data)
|
||||||
(materialize-color-components))))
|
(materialize-color-components))))
|
||||||
|
|
||||||
(-> state
|
(-> state
|
||||||
(dissoc :gradient :stops :editing-stop)
|
(dissoc :gradient :stops :editing-stop)
|
||||||
(assoc :type :color)))))))
|
(cond-> (not= :image (:type state))
|
||||||
|
(assoc :type :color))))))))
|
||||||
ptk/WatchEvent
|
ptk/WatchEvent
|
||||||
(watch [_ state _]
|
(watch [_ state _]
|
||||||
(when add-recent?
|
(when add-recent?
|
||||||
|
|
|
@ -387,7 +387,7 @@
|
||||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
|
||||||
(defn update-shape-flags
|
(defn update-shape-flags
|
||||||
[ids {:keys [blocked hidden transforming undo-group] :as flags}]
|
[ids {:keys [blocked hidden undo-group] :as flags}]
|
||||||
(dm/assert!
|
(dm/assert!
|
||||||
"expected valid coll of uuids"
|
"expected valid coll of uuids"
|
||||||
(every? uuid? ids))
|
(every? uuid? ids))
|
||||||
|
@ -403,15 +403,14 @@
|
||||||
(fn [obj]
|
(fn [obj]
|
||||||
(cond-> obj
|
(cond-> obj
|
||||||
(boolean? blocked) (assoc :blocked blocked)
|
(boolean? blocked) (assoc :blocked blocked)
|
||||||
(boolean? hidden) (assoc :hidden hidden)
|
(boolean? hidden) (assoc :hidden hidden)))
|
||||||
(boolean? transforming) (assoc :transforming transforming)))
|
|
||||||
objects (wsh/lookup-page-objects state)
|
objects (wsh/lookup-page-objects state)
|
||||||
;; We have change only the hidden behaviour, to hide only the
|
;; We have change only the hidden behaviour, to hide only the
|
||||||
;; selected shape, block behaviour remains the same.
|
;; selected shape, block behaviour remains the same.
|
||||||
ids (if (boolean? blocked)
|
ids (if (boolean? blocked)
|
||||||
(into ids (->> ids (mapcat #(cfh/get-children-ids objects %))))
|
(into ids (->> ids (mapcat #(cfh/get-children-ids objects %))))
|
||||||
ids)]
|
ids)]
|
||||||
(rx/of (dch/update-shapes ids update-fn {:attrs #{:blocked :hidden :transforming} :undo-group undo-group}))))))
|
(rx/of (dch/update-shapes ids update-fn {:attrs #{:blocked :hidden} :undo-group undo-group}))))))
|
||||||
|
|
||||||
(defn toggle-visibility-selected
|
(defn toggle-visibility-selected
|
||||||
[]
|
[]
|
||||||
|
|
|
@ -28,7 +28,6 @@
|
||||||
[app.main.data.workspace.collapse :as dwc]
|
[app.main.data.workspace.collapse :as dwc]
|
||||||
[app.main.data.workspace.modifiers :as dwm]
|
[app.main.data.workspace.modifiers :as dwm]
|
||||||
[app.main.data.workspace.selection :as dws]
|
[app.main.data.workspace.selection :as dws]
|
||||||
[app.main.data.workspace.shapes :as dwsh]
|
|
||||||
[app.main.data.workspace.state-helpers :as wsh]
|
[app.main.data.workspace.state-helpers :as wsh]
|
||||||
[app.main.data.workspace.undo :as dwu]
|
[app.main.data.workspace.undo :as dwu]
|
||||||
[app.main.snap :as snap]
|
[app.main.snap :as snap]
|
||||||
|
@ -291,10 +290,10 @@
|
||||||
ptk/WatchEvent
|
ptk/WatchEvent
|
||||||
(watch [_ _ stream]
|
(watch [_ _ stream]
|
||||||
(rx/concat
|
(rx/concat
|
||||||
(rx/of (dwsh/update-shape-flags ids {:transforming true}))
|
(rx/of #(assoc-in % [:workspace-local :transform] :move))
|
||||||
(->> (rx/timer 1000)
|
(->> (rx/timer 1000)
|
||||||
(rx/map (fn []
|
(rx/map (fn []
|
||||||
(dwsh/update-shape-flags ids {:transforming false})))
|
#(assoc-in % [:workspace-local :transform] nil)))
|
||||||
(rx/take-until
|
(rx/take-until
|
||||||
(rx/filter (ptk/type? ::trigger-bounding-box-cloaking) stream)))))))
|
(rx/filter (ptk/type? ::trigger-bounding-box-cloaking) stream)))))))
|
||||||
|
|
||||||
|
|
|
@ -20,12 +20,8 @@
|
||||||
color: var(--input-foreground-color-active);
|
color: var(--input-foreground-color-active);
|
||||||
}
|
}
|
||||||
|
|
||||||
.editable-label {
|
.editable-label.is-hidden {
|
||||||
display: flex;
|
display: none;
|
||||||
|
|
||||||
&.is-hidden {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.editable-label-close {
|
.editable-label-close {
|
||||||
|
|
|
@ -85,6 +85,9 @@
|
||||||
line-height: 0.8;
|
line-height: 0.8;
|
||||||
color: var(--title-foreground-color-hover);
|
color: var(--title-foreground-color-hover);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
height: $s-16;
|
||||||
|
display: inline-flex;
|
||||||
|
align-items: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.info-wrapper {
|
.info-wrapper {
|
||||||
|
|
|
@ -51,21 +51,21 @@
|
||||||
|
|
||||||
accept-edit
|
accept-edit
|
||||||
(mf/use-fn
|
(mf/use-fn
|
||||||
(mf/deps on-stop-edit)
|
(mf/deps shape-id on-stop-edit)
|
||||||
(fn []
|
(fn []
|
||||||
(let [name-input (mf/ref-val ref)
|
(let [name-input (mf/ref-val ref)
|
||||||
name (str/trim (dom/get-value name-input))]
|
name (str/trim (dom/get-value name-input))]
|
||||||
(on-stop-edit)
|
(on-stop-edit)
|
||||||
(reset! edition* false)
|
(reset! edition* false)
|
||||||
(st/emit! (dw/end-rename-shape name)))))
|
(st/emit! (dw/end-rename-shape shape-id name)))))
|
||||||
|
|
||||||
cancel-edit
|
cancel-edit
|
||||||
(mf/use-fn
|
(mf/use-fn
|
||||||
(mf/deps on-stop-edit)
|
(mf/deps shape-id on-stop-edit)
|
||||||
(fn []
|
(fn []
|
||||||
(on-stop-edit)
|
(on-stop-edit)
|
||||||
(reset! edition* false)
|
(reset! edition* false)
|
||||||
(st/emit! (dw/end-rename-shape nil))))
|
(st/emit! (dw/end-rename-shape shape-id nil))))
|
||||||
|
|
||||||
on-key-down
|
on-key-down
|
||||||
(mf/use-fn
|
(mf/use-fn
|
||||||
|
|
|
@ -113,8 +113,7 @@
|
||||||
(defn- show-outline?
|
(defn- show-outline?
|
||||||
[shape]
|
[shape]
|
||||||
(and (not (:hidden shape))
|
(and (not (:hidden shape))
|
||||||
(not (:blocked shape))
|
(not (:blocked shape))))
|
||||||
(not (:transforming shape))))
|
|
||||||
|
|
||||||
(mf/defc shape-outlines
|
(mf/defc shape-outlines
|
||||||
{::mf/wrap-props false}
|
{::mf/wrap-props false}
|
||||||
|
|
|
@ -36,6 +36,8 @@
|
||||||
(def selection-rect-width 1)
|
(def selection-rect-width 1)
|
||||||
(def min-selrect-side 10)
|
(def min-selrect-side 10)
|
||||||
(def small-selrect-side 30)
|
(def small-selrect-side 30)
|
||||||
|
(def min-selrect-width 10)
|
||||||
|
(def min-selrect-height 10)
|
||||||
|
|
||||||
(mf/defc selection-rect
|
(mf/defc selection-rect
|
||||||
{::mf/wrap-props false}
|
{::mf/wrap-props false}
|
||||||
|
@ -43,12 +45,27 @@
|
||||||
(let [x (dm/get-prop rect :x)
|
(let [x (dm/get-prop rect :x)
|
||||||
y (dm/get-prop rect :y)
|
y (dm/get-prop rect :y)
|
||||||
width (dm/get-prop rect :width)
|
width (dm/get-prop rect :width)
|
||||||
height (dm/get-prop rect :height)]
|
height (dm/get-prop rect :height)
|
||||||
|
|
||||||
|
;; This is a calculation to create a "minimum" interactable rect
|
||||||
|
;; Is necesary so that small shapes in x/y (like lines) can be moved
|
||||||
|
;; better
|
||||||
|
[x width]
|
||||||
|
(if (< width (/ min-selrect-width zoom))
|
||||||
|
(let [width' (/ min-selrect-width zoom)]
|
||||||
|
[(- x (/ (- width' width) 2)) width'])
|
||||||
|
[x width])
|
||||||
|
|
||||||
|
[y height]
|
||||||
|
(if (< height (/ min-selrect-height zoom))
|
||||||
|
(let [height' (/ min-selrect-height zoom)]
|
||||||
|
[(- y (/ (- height' height) 2)) height'])
|
||||||
|
[y height])]
|
||||||
[:rect.main.viewport-selrect
|
[:rect.main.viewport-selrect
|
||||||
{:x x
|
{:x x
|
||||||
:y y
|
:y y
|
||||||
:width width
|
:width (max width (/ 10 zoom))
|
||||||
:height height
|
:height (max height (/ 10 zoom))
|
||||||
:transform (str transform)
|
:transform (str transform)
|
||||||
:on-pointer-down on-move-selected
|
:on-pointer-down on-move-selected
|
||||||
:on-context-menu on-context-menu
|
:on-context-menu on-context-menu
|
||||||
|
@ -304,7 +321,6 @@
|
||||||
transform (gsh/transform-str shape)]
|
transform (gsh/transform-str shape)]
|
||||||
|
|
||||||
(when (and (some? selrect)
|
(when (and (some? selrect)
|
||||||
(not (:transforming shape))
|
|
||||||
(not (or (= transform-type :move)
|
(not (or (= transform-type :move)
|
||||||
(= transform-type :rotate))))
|
(= transform-type :rotate))))
|
||||||
[:g.controls {:pointer-events (if ^boolean disable-handlers "none" "visible")}
|
[:g.controls {:pointer-events (if ^boolean disable-handlers "none" "visible")}
|
||||||
|
@ -339,7 +355,6 @@
|
||||||
(and flip-y (not flip-x)))]
|
(and flip-y (not flip-x)))]
|
||||||
|
|
||||||
(when (and (not ^boolean read-only?)
|
(when (and (not ^boolean read-only?)
|
||||||
(not (:transforming shape))
|
|
||||||
(not (or (= transform-type :move)
|
(not (or (= transform-type :move)
|
||||||
(= transform-type :rotate))))
|
(= transform-type :rotate))))
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue