mirror of
https://github.com/penpot/penpot.git
synced 2025-01-24 23:49:45 -05:00
✨ Make the attrs procesing of shapes uniform.
This commit is contained in:
parent
979c7dc2a0
commit
48d7ea4be4
9 changed files with 70 additions and 129 deletions
|
@ -2,58 +2,15 @@
|
|||
;; License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
;; file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
;;
|
||||
;; Copyright (c) 2016-2017 Andrey Antukh <niwi@niwi.nz>
|
||||
;; This Source Code Form is "Incompatible With Secondary Licenses", as
|
||||
;; defined by the Mozilla Public License, v. 2.0.
|
||||
;;
|
||||
;; Copyright (c) 2016-2020 UXBOX Labs SL
|
||||
|
||||
(ns uxbox.main.ui.shapes.attrs
|
||||
(:require
|
||||
[cuerdas.core :as str]
|
||||
[uxbox.util.interop :as interop]))
|
||||
|
||||
|
||||
;; (defn camel-case
|
||||
;; "Returns camel case version of the key, e.g. :http-equiv becomes :httpEquiv."
|
||||
;; [k]
|
||||
;; (if (or (keyword? k)
|
||||
;; (string? k)
|
||||
;; (symbol? k))
|
||||
;; (let [[first-word & words] (str/split (name k) #"-")]
|
||||
;; (if (or (empty? words)
|
||||
;; (= "aria" first-word)
|
||||
;; (= "data" first-word))
|
||||
;; k
|
||||
;; (-> (map str/capital words)
|
||||
;; (conj first-word)
|
||||
;; str/join
|
||||
;; keyword)))
|
||||
;; k))
|
||||
|
||||
(defn- process-key
|
||||
[k]
|
||||
(if (keyword? k)
|
||||
(cond
|
||||
(keyword-identical? k :stroke-color) :stroke
|
||||
(keyword-identical? k :fill-color) :fill
|
||||
(str/includes? (name k) "-") (str/camel k)
|
||||
:else k)))
|
||||
|
||||
(defn- process-attrs
|
||||
[m]
|
||||
(persistent!
|
||||
(reduce-kv (fn [m k v]
|
||||
(assoc! m (process-key k) v))
|
||||
(transient {})
|
||||
m)))
|
||||
|
||||
(def shape-style-attrs
|
||||
#{:fill-color
|
||||
:fill-opacity
|
||||
:stroke-color
|
||||
:stroke-opacity
|
||||
:stroke-width
|
||||
:stroke-style
|
||||
:opacity
|
||||
:rx
|
||||
:ry})
|
||||
[uxbox.util.interop :as itr]))
|
||||
|
||||
(defn- stroke-type->dasharray
|
||||
[style]
|
||||
|
@ -63,34 +20,15 @@
|
|||
:dashed "10,10"
|
||||
nil))
|
||||
|
||||
(defn- transform-stroke-attrs
|
||||
[{:keys [stroke-style] :or {stroke-style :none} :as attrs}]
|
||||
(case stroke-style
|
||||
:none (dissoc attrs :stroke-style :stroke-width :stroke-opacity :stroke-color)
|
||||
:solid (dissoc attrs :stroke-style)
|
||||
(-> attrs
|
||||
(assoc :stroke-dasharray (stroke-type->dasharray stroke-style))
|
||||
(dissoc :stroke-style))))
|
||||
|
||||
(defn extract-style-attrs
|
||||
"Extract predefinet attrs from shapes."
|
||||
[shape]
|
||||
(-> (select-keys shape shape-style-attrs)
|
||||
(transform-stroke-attrs)
|
||||
(process-attrs)))
|
||||
|
||||
|
||||
;; TODO: migrate all the code to use this function and then, rename.
|
||||
|
||||
(defn extract-style-attrs2
|
||||
[shape]
|
||||
(let [stroke-style (:stroke-style shape :none)
|
||||
attrs #js {:fill (:fill-color shape nil)
|
||||
:opacity (:opacity shape nil)
|
||||
:fillOpacity (:fill-opacity shape nil)
|
||||
:rx (:rx shape nil)
|
||||
:ry (:ry shape nil)}]
|
||||
(when (not= :none stroke-style)
|
||||
(interop/obj-assign! attrs
|
||||
(itr/obj-assign! attrs
|
||||
#js {:stroke (:stroke-color shape nil)
|
||||
:strokeWidth (:stroke-width shape nil)
|
||||
:strokeOpacity (:stroke-opacity shape nil)
|
||||
|
|
|
@ -11,7 +11,7 @@
|
|||
[uxbox.main.refs :as refs]
|
||||
[uxbox.main.ui.shapes.attrs :as attrs]
|
||||
[uxbox.main.ui.shapes.common :as common]
|
||||
[uxbox.util.data :refer [classnames normalize-props]]
|
||||
[uxbox.util.interop :as itr]
|
||||
[uxbox.util.geom.matrix :as gmt]
|
||||
[uxbox.util.geom.point :as gpt]))
|
||||
|
||||
|
@ -50,11 +50,11 @@
|
|||
(gmt/rotate rotation center))))
|
||||
|
||||
props (-> (attrs/extract-style-attrs shape)
|
||||
(assoc :cx cx
|
||||
(itr/obj-assign!
|
||||
#js {:cx cx
|
||||
:cy cy
|
||||
:rx rx
|
||||
:ry ry
|
||||
:transform transform
|
||||
:id (str "shape-" id)
|
||||
))]
|
||||
[:& "ellipse" props]))
|
||||
:id (str "shape-" id)}))]
|
||||
[:> "ellipse" props]))
|
||||
|
|
|
@ -25,8 +25,8 @@
|
|||
[uxbox.main.ui.shapes.path :as path]
|
||||
[uxbox.main.ui.shapes.rect :as rect]
|
||||
[uxbox.main.ui.shapes.text :as text]
|
||||
[uxbox.util.data :refer [parse-int]]
|
||||
[uxbox.util.dom :as dom]
|
||||
[uxbox.util.interop :as itr]
|
||||
[uxbox.util.geom.matrix :as gmt]
|
||||
[uxbox.util.geom.point :as gpt]))
|
||||
|
||||
|
@ -43,7 +43,7 @@
|
|||
(= n-shape o-shape))))))
|
||||
|
||||
(mf/defc shape-wrapper
|
||||
{:wrap [wrap-memo-shape]}
|
||||
{::mf/wrap [wrap-memo-shape]}
|
||||
[{:keys [shape] :as props}]
|
||||
(when (and shape (not (:hidden shape)))
|
||||
(case (:type shape)
|
||||
|
@ -85,7 +85,7 @@
|
|||
|
||||
|
||||
(mf/defc frame-wrapper
|
||||
{:wrap [wrap-memo-frame]}
|
||||
{::mf/wrap [wrap-memo-frame]}
|
||||
[{:keys [shape objects] :as props}]
|
||||
(when (and shape (not (:hidden shape)))
|
||||
(let [selected-iref (-> (mf/deps (:id shape))
|
||||
|
@ -121,17 +121,16 @@
|
|||
{:keys [id x y width height]} shape
|
||||
|
||||
props (-> (attrs/extract-style-attrs shape)
|
||||
(assoc :x 0
|
||||
(itr/obj-assign!
|
||||
#js {:x 0
|
||||
:y 0
|
||||
:id (str "shape-" id)
|
||||
:width width
|
||||
:height height
|
||||
))
|
||||
:height height}))
|
||||
|
||||
translate #(translate-to-frame % ds-modifier (gpt/point (- x) (- y)))
|
||||
]
|
||||
translate #(translate-to-frame % ds-modifier (gpt/point (- x) (- y)))]
|
||||
[:svg {:x x :y y :width width :height height}
|
||||
[:& "rect" props]
|
||||
[:> "rect" props]
|
||||
(for [item (reverse childs)]
|
||||
[:& shape-wrapper {:shape (translate item) :key (:id item)}])]))
|
||||
|
||||
|
|
|
@ -12,7 +12,7 @@
|
|||
[uxbox.main.refs :as refs]
|
||||
[uxbox.main.ui.shapes.attrs :as attrs]
|
||||
[uxbox.main.ui.shapes.common :as common]
|
||||
[uxbox.util.data :refer [classnames normalize-props]]
|
||||
[uxbox.util.interop :as itr]
|
||||
[uxbox.util.geom.matrix :as gmt]
|
||||
[uxbox.util.geom.point :as gpt]))
|
||||
|
||||
|
@ -52,7 +52,8 @@
|
|||
view-box (apply str (interpose " " (:view-box metadata)))
|
||||
|
||||
props (-> (attrs/extract-style-attrs shape)
|
||||
(assoc :x x
|
||||
(itr/obj-assign!
|
||||
#js {:x x
|
||||
:y y
|
||||
:transform transform
|
||||
:id (str "shape-" id)
|
||||
|
@ -60,10 +61,11 @@
|
|||
:height height
|
||||
:viewBox view-box
|
||||
:preserveAspectRatio "none"
|
||||
:dangerouslySetInnerHTML #js {:__html content}
|
||||
))]
|
||||
:dangerouslySetInnerHTML #js {:__html content}}))]
|
||||
|
||||
|
||||
[:g {:transform transform}
|
||||
[:& "svg" props]]))
|
||||
[:> "svg" props]]))
|
||||
|
||||
;; --- Icon SVG
|
||||
|
||||
|
|
|
@ -14,6 +14,7 @@
|
|||
[uxbox.main.store :as st]
|
||||
[uxbox.main.ui.shapes.attrs :as attrs]
|
||||
[uxbox.main.ui.shapes.common :as common]
|
||||
[uxbox.util.interop :as itr]
|
||||
[uxbox.util.geom.matrix :as gmt]))
|
||||
|
||||
;; --- Image Wrapper
|
||||
|
@ -54,12 +55,13 @@
|
|||
|
||||
|
||||
props (-> (attrs/extract-style-attrs shape)
|
||||
(assoc :x x
|
||||
(itr/obj-assign!
|
||||
#js {:x x
|
||||
:y y
|
||||
:transform transform
|
||||
:id (str "shape-" id)
|
||||
:preserveAspectRatio "none"
|
||||
:xlinkHref uri
|
||||
:transform transform
|
||||
:width width
|
||||
:height height))]
|
||||
[:& "image" props]))
|
||||
:height height}))]
|
||||
[:> "image" props]))
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
[uxbox.main.store :as st]
|
||||
[uxbox.main.ui.shapes.attrs :as attrs]
|
||||
[uxbox.main.ui.shapes.common :as common]
|
||||
[uxbox.util.data :refer [classnames normalize-props]]
|
||||
[uxbox.util.interop :as itr]
|
||||
[uxbox.util.geom.matrix :as gmt]))
|
||||
|
||||
;; --- Path Wrapper
|
||||
|
@ -79,14 +79,15 @@
|
|||
|
||||
pdata (render-path shape)
|
||||
props (-> (attrs/extract-style-attrs shape)
|
||||
(assoc :transform transform
|
||||
(itr/obj-assign!
|
||||
#js {:transform transform
|
||||
:id (str "shape-" id)
|
||||
:d pdata))]
|
||||
:d pdata}))]
|
||||
(if background?
|
||||
[:g
|
||||
[:path {:stroke "transparent"
|
||||
:fill "transparent"
|
||||
:stroke-width "20px"
|
||||
:d pdata}]
|
||||
[:& "path" props]]
|
||||
[:& "path" props])))
|
||||
[:> "path" props]]
|
||||
[:> "path" props])))
|
||||
|
|
|
@ -12,7 +12,7 @@
|
|||
[uxbox.main.refs :as refs]
|
||||
[uxbox.main.ui.shapes.attrs :as attrs]
|
||||
[uxbox.main.ui.shapes.common :as common]
|
||||
[uxbox.util.interop :as interop]
|
||||
[uxbox.util.interop :as itr]
|
||||
[uxbox.util.geom.matrix :as gmt]
|
||||
[uxbox.util.geom.point :as gpt]))
|
||||
|
||||
|
@ -51,8 +51,8 @@
|
|||
(+ x (/ width 2))
|
||||
(+ y (/ height 2))))
|
||||
|
||||
props (-> (attrs/extract-style-attrs2 shape)
|
||||
(interop/obj-assign!
|
||||
props (-> (attrs/extract-style-attrs shape)
|
||||
(itr/obj-assign!
|
||||
#js {:x x
|
||||
:y y
|
||||
:transform transform
|
||||
|
|
|
@ -15,7 +15,6 @@
|
|||
[uxbox.main.geom :as geom]
|
||||
[uxbox.main.refs :as refs]
|
||||
[uxbox.main.store :as st]
|
||||
[uxbox.main.ui.shapes.attrs :as attrs]
|
||||
[uxbox.main.ui.shapes.common :as common]
|
||||
[uxbox.util.color :as color]
|
||||
[uxbox.util.dom :as dom]
|
||||
|
|
|
@ -55,13 +55,13 @@
|
|||
i/image]
|
||||
[:li.tooltip.tooltip-right
|
||||
{:alt "Pencil tool"
|
||||
:class (when (= selected-drawtool :path) "selected")
|
||||
:on-click (partial select-drawtool :path)}
|
||||
:class (when (= selected-drawtool :curve) "selected")
|
||||
:on-click (partial select-drawtool :curve)}
|
||||
i/pencil]
|
||||
[:li.tooltip.tooltip-right
|
||||
{:alt "Curves tool"
|
||||
:class (when (= selected-drawtool :curve) "selected")
|
||||
:on-click (partial select-drawtool :curve)}
|
||||
:class (when (= selected-drawtool :path) "selected")
|
||||
:on-click (partial select-drawtool :path)}
|
||||
i/curve]]
|
||||
|
||||
[:ul.left-toolbar-options.panels
|
||||
|
|
Loading…
Add table
Reference in a new issue