diff --git a/common/app/common/pages.cljc b/common/app/common/pages.cljc
index f9b0c8e5cd..6a947ec779 100644
--- a/common/app/common/pages.cljc
+++ b/common/app/common/pages.cljc
@@ -869,7 +869,7 @@
(defmethod process-change :mod-color
[data {:keys [color]}]
- (d/update-in-when data [:colors (:id color)] merge color))
+ (d/assoc-in-when data [:colors (:id color)] color))
(defmethod process-change :del-color
[data {:keys [id]}]
@@ -965,3 +965,4 @@
(ex/raise :type :not-implemented
:code :operation-not-implemented
:context {:type (:type op)}))
+
diff --git a/frontend/resources/images/icons/picker-ramp.svg b/frontend/resources/images/icons/picker-ramp.svg
index 0e078a017e..815b3a9449 100644
--- a/frontend/resources/images/icons/picker-ramp.svg
+++ b/frontend/resources/images/icons/picker-ramp.svg
@@ -1 +1,3 @@
-
+
diff --git a/frontend/resources/styles/main/partials/color-bullet.scss b/frontend/resources/styles/main/partials/color-bullet.scss
index a8045591c4..ba0d980c35 100644
--- a/frontend/resources/styles/main/partials/color-bullet.scss
+++ b/frontend/resources/styles/main/partials/color-bullet.scss
@@ -68,7 +68,6 @@ ul.palette-menu .color-bullet {
grid-area: color;
width: 20px;
height: 20px;
- background-color: rgba(var(--color));
border-radius: 12px;
border: 1px solid $color-gray-10;
background-size: 8px;
@@ -95,6 +94,7 @@ ul.palette-menu .color-bullet {
overflow: hidden;
background: url("") left center;
+ background-color: $color-white;
& > * {
width: 100%;
diff --git a/frontend/resources/styles/main/partials/colorpicker.scss b/frontend/resources/styles/main/partials/colorpicker.scss
index e65658d937..05cf8370d6 100644
--- a/frontend/resources/styles/main/partials/colorpicker.scss
+++ b/frontend/resources/styles/main/partials/colorpicker.scss
@@ -443,13 +443,10 @@
.colorpicker-tabs {
display: flex;
- margin-top: 0.25rem;
+ margin: 0.5rem 0;
+ border-radius: 5px;
+ border: 1px solid $color-gray-10;
height: 2rem;
- background-color: $color-gray-10;
-
- .active {
- background-color: $color-white;
- }
.colorpicker-tab {
cursor: pointer;
@@ -461,9 +458,21 @@
svg {
width: 16px;
height: 16px;
- fill: $color-gray-30;
+ fill: $color-gray-20;
}
}
+
+ .active {
+ background-color: $color-gray-10;
+ svg {
+ fill: $color-gray-60;
+ }
+ }
+
+ :hover svg {
+ fill: $color-primary;
+ }
+
}
}
diff --git a/frontend/src/app/main/data/workspace/libraries.cljs b/frontend/src/app/main/data/workspace/libraries.cljs
index 344e483b54..a949430995 100644
--- a/frontend/src/app/main/data/workspace/libraries.cljs
+++ b/frontend/src/app/main/data/workspace/libraries.cljs
@@ -36,7 +36,12 @@
(defn add-color
[color]
(let [id (uuid/next)
- color (assoc color :id id)]
+ color (assoc color
+ :id id
+ :name (or (:color color)
+ (case (get-in color [:gradient :type])
+ :linear "Linear gradient"
+ :radial "Radial gradient")))]
(us/assert ::cp/color color)
(ptk/reify ::add-color
ptk/WatchEvent
diff --git a/frontend/src/app/main/ui/shapes/attrs.cljs b/frontend/src/app/main/ui/shapes/attrs.cljs
index 4c8a4d9e7d..6db6b6f272 100644
--- a/frontend/src/app/main/ui/shapes/attrs.cljs
+++ b/frontend/src/app/main/ui/shapes/attrs.cljs
@@ -25,7 +25,7 @@
:ry (:ry shape)}))
(defn add-fill [attrs shape]
- (let [fill-color-gradient-id (str "fill-color-gradient_" (:id shape))]
+ (let [fill-color-gradient-id (str "fill-color-gradient_" (:render-id shape))]
(if (:fill-color-gradient shape)
(obj/merge! attrs #js {:fill (str/format "url(#%s)" fill-color-gradient-id)})
(obj/merge! attrs #js {:fill (or (:fill-color shape) "transparent")
@@ -33,7 +33,7 @@
(defn add-stroke [attrs shape]
(let [stroke-style (:stroke-style shape :none)
- stroke-color-gradient-id (str "stroke-color-gradient_" (:id shape))]
+ stroke-color-gradient-id (str "stroke-color-gradient_" (:render-id shape))]
(if (not= stroke-style :none)
(if (:stroke-color-gradient shape)
(obj/merge! attrs
diff --git a/frontend/src/app/main/ui/shapes/gradients.cljs b/frontend/src/app/main/ui/shapes/gradients.cljs
index 621f7e278c..a1c216b46c 100644
--- a/frontend/src/app/main/ui/shapes/gradients.cljs
+++ b/frontend/src/app/main/ui/shapes/gradients.cljs
@@ -49,8 +49,8 @@
scale-factor-x (* scale-factor-y (:width gradient))
scale-vec (gpt/point (* scale-factor-y (/ height 2))
- (* scale-factor-x (/ width 2))
- )
+ (* scale-factor-x (/ width 2)))
+
tr-translate (str/fmt "translate(%s, %s)" (:x translate-vec) (:y translate-vec))
tr-rotate (str/fmt "rotate(%s)" angle)
tr-scale (str/fmt "scale(%s, %s)" (:x scale-vec) (:y scale-vec))
@@ -72,8 +72,9 @@
[props]
(let [attr (obj/get props "attr")
shape (obj/get props "shape")
+ render-id (obj/get props "render-id")
- id (str (name attr) "_" (:id shape))
+ id (str (name attr) "_" render-id)
gradient (get shape attr)
gradient-props #js {:id id
:gradient gradient
diff --git a/frontend/src/app/main/ui/workspace/colorpicker.cljs b/frontend/src/app/main/ui/workspace/colorpicker.cljs
index dd7df33e5c..04be286240 100644
--- a/frontend/src/app/main/ui/workspace/colorpicker.cljs
+++ b/frontend/src/app/main/ui/workspace/colorpicker.cljs
@@ -306,16 +306,15 @@
:on-change handle-change-color}]
[:& libraries {:current-color current-color
- :on-select-color on-select-library-color}]]
+ :on-select-color on-select-library-color}]
- (when on-accept
- [:div.actions
- [:button.btn-primary.btn-large
- {:on-click (fn []
- ;; TODO: REVIEW FOR GRADIENTS
- #_(on-accept @value-ref)
- (modal/hide!))}
- (t locale "workspace.libraries.colors.save-color")]])])
+ (when on-accept
+ [:div.actions
+ [:button.btn-primary.btn-large
+ {:on-click (fn []
+ (on-accept (state->data @state))
+ (modal/hide!))}
+ (t locale "workspace.libraries.colors.save-color")]])]])
)
(defn calculate-position
diff --git a/frontend/src/app/main/ui/workspace/colorpicker/ramp.cljs b/frontend/src/app/main/ui/workspace/colorpicker/ramp.cljs
index ab68a5e578..f88794bab5 100644
--- a/frontend/src/app/main/ui/workspace/colorpicker/ramp.cljs
+++ b/frontend/src/app/main/ui/workspace/colorpicker/ramp.cljs
@@ -25,9 +25,9 @@
[app.main.data.modal :as modal]
[app.main.ui.icons :as i]
[app.util.i18n :as i18n :refer [t]]
+ [app.main.ui.components.color-bullet :refer [color-bullet]]
[app.main.ui.workspace.colorpicker.slider-selector :refer [slider-selector]]))
-
(mf/defc value-saturation-selector [{:keys [hue saturation value on-change]}]
(let [dragging? (mf/use-state false)
calculate-pos
@@ -50,7 +50,8 @@
(mf/defc ramp-selector [{:keys [color disable-opacity on-change]}]
- (let [{hue :h saturation :s value :v alpha :alpha} color
+ (let [{hex :hex
+ hue :h saturation :s value :v alpha :alpha} color
on-change-value-saturation
(fn [new-saturation new-value]
@@ -80,7 +81,8 @@
:on-change on-change-value-saturation}]
[:div.shade-selector
- [:div.color-bullet]
+ [:& color-bullet {:color {:color hex
+ :opacity alpha}}]
[:& slider-selector {:class "hue"
:max-value 360
:value hue
diff --git a/frontend/src/app/main/ui/workspace/shapes/common.cljs b/frontend/src/app/main/ui/workspace/shapes/common.cljs
index 762469b14c..62c3466199 100644
--- a/frontend/src/app/main/ui/workspace/shapes/common.cljs
+++ b/frontend/src/app/main/ui/workspace/shapes/common.cljs
@@ -73,22 +73,24 @@
on-context-menu (mf/use-callback
(mf/deps shape)
#(on-context-menu % shape))
- filter-id (mf/use-memo filters/get-filter-id)]
+ render-id (mf/use-memo #(str (uuid/next)))]
[:g.shape {:on-mouse-down on-mouse-down
:on-context-menu on-context-menu
- :filter (filters/filter-str filter-id shape)}
+ :filter (filters/filter-str (str "filter_" render-id) shape)}
- [:& filters/filters {:filter-id filter-id :shape shape}]
+ [:& filters/filters {:filter-id (str "filter_" render-id) :shape shape}]
(when (:fill-color-gradient shape)
[:& grad/gradient {:attr :fill-color-gradient
+ :render-id render-id
:shape shape}])
(when (:stroke-color-gradient shape)
[:& grad/gradient {:attr :stroke-color-gradient
+ :render-id render-id
:shape shape}])
- [:& component {:shape shape}]])))
+ [:& component {:shape (assoc shape :render-id render-id)}]])))
diff --git a/frontend/src/app/main/ui/workspace/sidebar/assets.cljs b/frontend/src/app/main/ui/workspace/sidebar/assets.cljs
index 5cc267d926..9596bad092 100644
--- a/frontend/src/app/main/ui/workspace/sidebar/assets.cljs
+++ b/frontend/src/app/main/ui/workspace/sidebar/assets.cljs
@@ -217,8 +217,9 @@
(st/emit! (dwl/update-color (assoc color :name name))))
edit-color
- (fn [value]
- (st/emit! (dwl/update-color (assoc color :color value))))
+ (fn [new-color]
+ (let [updated-color (merge new-color (select-keys color [:id :file-id :name]))]
+ (st/emit! (dwl/update-color updated-color))))
delete-color
(fn []
@@ -253,7 +254,6 @@
:y (.-clientY event)
:on-accept edit-color
:data color
- :disable-opacity true
:position :right}))
on-context-menu
@@ -321,8 +321,8 @@
{:x (.-clientX event)
:y (.-clientY event)
:on-accept add-color
- :value "#406280"
- :disable-opacity true
+ :data {:color "#406280"
+ :opacity 1}
:position :right})))]
[:div.asset-group
[:div.group-title {:class (when (not open?) "closed")}
@@ -334,7 +334,12 @@
[:div.group-list
(for [color colors]
[:& color-item {:key (:id color)
- :color color
+ :color (if (:value color)
+ (-> color
+ (assoc :color (:value color)
+ :opacity 1)
+ (dissoc :value))
+ color)
:file-id file-id
:local? local?
:locale locale}])])]))