0
Fork 0
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:
Andrey Antukh 2020-03-25 11:07:50 +01:00
parent 979c7dc2a0
commit 48d7ea4be4
9 changed files with 70 additions and 129 deletions

View file

@ -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)

View file

@ -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]))

View file

@ -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)}])]))

View file

@ -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

View file

@ -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]))

View file

@ -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])))

View file

@ -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

View file

@ -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]

View file

@ -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