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

🐛 Fix incorrect value handling on color-input component.

Related to the bug when the input value of the page color
is not refreshed on page change.
This commit is contained in:
Andrey Antukh 2021-06-17 09:46:32 +02:00 committed by Andrés Moya
parent 41d05d6de0
commit 91425050e4
6 changed files with 73 additions and 74 deletions

View file

@ -14,10 +14,11 @@
### :bug: Bugs fixed ### :bug: Bugs fixed
- Remove unnecesary redirect from history when user goes to workspace from dashboard [Taiga 1820](https://tree.taiga.io/project/penpot/issue/1820). - Remove unnecesary redirect from history when user goes to workspace from dashboard [Taiga #1820](https://tree.taiga.io/project/penpot/issue/1820).
- Fix tooltip position on view application [Taiga 1819](https://tree.taiga.io/project/penpot/issue/1819). - Fix tooltip position on view application [Taiga #1819](https://tree.taiga.io/project/penpot/issue/1819).
- Fix dashboard navigation on moving file to other team [Taiga 1817](https://tree.taiga.io/project/penpot/issue/1817). - Fix dashboard navigation on moving file to other team [Taiga #1817](https://tree.taiga.io/project/penpot/issue/1817).
- Fix workspace header presence styles and invalid link [Taiga 1813](https://tree.taiga.io/project/penpot/issue/1813). - Fix workspace header presence styles and invalid link [Taiga #1813](https://tree.taiga.io/project/penpot/issue/1813).
- Fix color-input wrong behavior (on workspace page color) [Taiga #1795](https://tree.taiga.io/project/penpot/issue/1795).
### :arrow_up: Deps updates ### :arrow_up: Deps updates
### :boom: Breaking changes ### :boom: Breaking changes

View file

@ -22,46 +22,46 @@
{::mf/wrap-props false {::mf/wrap-props false
::mf/forward-ref true} ::mf/forward-ref true}
[props external-ref] [props external-ref]
(let [value (obj/get props "value") (let [value (obj/get props "value")
on-change (obj/get props "onChange") on-change (obj/get props "onChange")
;; We need a ref pointing to the input dom element, but the user ;; We need a ref pointing to the input dom element, but the user
;; of this component may provide one (that is forwarded here). ;; of this component may provide one (that is forwarded here).
;; So we use the external ref if provided, and the local one if not. ;; So we use the external ref if provided, and the local one if not.
local-ref (mf/use-ref) local-ref (mf/use-ref)
ref (or external-ref local-ref) ref (or external-ref local-ref)
parse-value parse-value
(mf/use-callback (mf/use-callback
(mf/deps ref) (mf/deps ref)
(fn [] (fn []
(let [input-node (mf/ref-val ref)] (let [input-node (mf/ref-val ref)]
(try (try
(let [new-value (-> (dom/get-value input-node) (let [new-value (-> (dom/get-value input-node)
(uc/expand-hex) (uc/expand-hex)
(uc/parse-color) (uc/parse-color)
(uc/prepend-hash))] (uc/prepend-hash))]
(dom/set-validity! input-node "") (dom/set-validity! input-node "")
new-value) new-value)
(catch :default _ (catch :default _e
(dom/set-validity! input-node (tr "errors.invalid-color")) (dom/set-validity! input-node (tr "errors.invalid-color"))
nil))))) nil)))))
update-input update-input
(mf/use-callback (mf/use-callback
(mf/deps ref) (mf/deps ref)
(fn [new-value] (fn [new-value]
(let [input-node (mf/ref-val ref)] (let [input-node (mf/ref-val ref)]
(dom/set-value! input-node (uc/remove-hash new-value))))) (dom/set-value! input-node (uc/remove-hash new-value)))))
apply-value apply-value
(mf/use-callback (mf/use-callback
(mf/deps on-change update-input) (mf/deps on-change update-input)
(fn [new-value] (fn [new-value]
(when new-value (when new-value
(when on-change (when on-change
(on-change new-value)) (on-change new-value))
(update-input new-value)))) (update-input new-value))))
handle-key-down handle-key-down
(mf/use-callback (mf/use-callback
@ -79,12 +79,12 @@
handle-blur handle-blur
(mf/use-callback (mf/use-callback
(mf/deps parse-value apply-value update-input) (mf/deps parse-value apply-value update-input)
(fn [event] (fn [event]
(let [new-value (parse-value)] (let [new-value (parse-value)]
(if new-value (if new-value
(apply-value new-value) (apply-value new-value)
(update-input value))))) (update-input value)))))
;; list-id (str "colors-" (uuid/next)) ;; list-id (str "colors-" (uuid/next))
@ -97,6 +97,12 @@
(obj/set! "onKeyDown" handle-key-down) (obj/set! "onKeyDown" handle-key-down)
(obj/set! "onBlur" handle-blur))] (obj/set! "onBlur" handle-blur))]
(mf/use-effect
(mf/deps value)
(fn []
(when-let [node (mf/ref-val ref)]
(dom/set-value! node value))))
[:* [:*
[:> :input props] [:> :input props]
;; FIXME: this causes some weird interactions because of using apply-value ;; FIXME: this causes some weird interactions because of using apply-value

View file

@ -66,7 +66,7 @@
[:div.element-options [:div.element-options
[:& align-options] [:& align-options]
(case (count selected) (case (count selected)
0 [:& page/options {:page-id page-id}] 0 [:& page/options]
1 [:& shape-options {:shape (first shapes) 1 [:& shape-options {:shape (first shapes)
:page-id page-id :page-id page-id
:file-id file-id :file-id file-id

View file

@ -7,46 +7,39 @@
(ns app.main.ui.workspace.sidebar.options.page (ns app.main.ui.workspace.sidebar.options.page
"Page options menu entries." "Page options menu entries."
(:require (:require
[rumext.alpha :as mf] [app.main.data.workspace :as dw]
[okulary.core :as l] [app.main.data.workspace.undo :as dwu]
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.data.workspace :as dw] [app.main.ui.workspace.sidebar.options.rows.color-row :refer [color-row]]
[app.main.data.workspace.common :as dwc] [app.util.i18n :as i18n :refer [tr]]
[app.main.data.workspace.undo :as dwu] [rumext.alpha :as mf]))
[app.util.i18n :as i18n :refer [t]]
[app.main.ui.workspace.sidebar.options.rows.color-row :refer [color-row]]))
(defn use-change-color [page-id]
(mf/use-callback
(mf/deps page-id)
(fn [value]
(st/emit! (dw/change-canvas-color value)))))
(mf/defc options (mf/defc options
[{:keys [page-id] :as props}] {::mf/wrap [mf/memo]}
(let [locale (i18n/use-locale) []
options (mf/deref refs/workspace-page-options) (let [options (mf/deref refs/workspace-page-options)
handle-change-color (use-change-color page-id)
on-change
(fn [value]
(st/emit! (dw/change-canvas-color value)))
on-open on-open
(mf/use-callback (fn []
(mf/deps page-id) (st/emit! (dwu/start-undo-transaction)))
#(st/emit! (dwu/start-undo-transaction)))
on-close on-close
(mf/use-callback (fn []
(mf/deps page-id) (st/emit! (dwu/commit-undo-transaction)))]
#(st/emit! (dwu/commit-undo-transaction)))]
[:div.element-set [:div.element-set
[:div.element-set-title (t locale "workspace.options.canvas-background")] [:div.element-set-title (tr "workspace.options.canvas-background")]
[:div.element-set-content [:div.element-set-content
[:& color-row {:disable-gradient true [:& color-row {:disable-gradient true
:disable-opacity true :disable-opacity true
:color {:color (get options :background "#E8E9EA") :color {:color (get options :background "#E8E9EA")
:opacity 1} :opacity 1}
:on-change handle-change-color :on-change on-change
:on-open on-open :on-open on-open
:on-close on-close}]]])) :on-close on-close}]]]))

View file

@ -6,23 +6,22 @@
(ns app.main.ui.workspace.sidebar.options.rows.color-row (ns app.main.ui.workspace.sidebar.options.rows.color-row
(:require (:require
[rumext.alpha :as mf] [app.common.data :as d]
[cuerdas.core :as str]
[app.common.math :as math] [app.common.math :as math]
[app.common.pages :as cp] [app.common.pages :as cp]
[app.common.data :as d]
[app.util.dom :as dom]
[app.util.data :refer [classnames]]
[app.util.i18n :as i18n :refer [tr]]
[app.util.color :as uc]
[app.main.refs :as refs]
[app.main.data.modal :as modal] [app.main.data.modal :as modal]
[app.main.ui.hooks :as h] [app.main.refs :as refs]
[app.main.ui.icons :as i]
[app.main.ui.context :as ctx]
[app.main.ui.components.color-bullet :as cb] [app.main.ui.components.color-bullet :as cb]
[app.main.ui.components.color-input :refer [color-input]] [app.main.ui.components.color-input :refer [color-input]]
[app.main.ui.components.numeric-input :refer [numeric-input]])) [app.main.ui.components.numeric-input :refer [numeric-input]]
[app.main.ui.context :as ctx]
[app.main.ui.hooks :as h]
[app.main.ui.icons :as i]
[app.util.color :as uc]
[app.util.data :refer [classnames]]
[app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]]
[rumext.alpha :as mf]))
(defn color-picker-callback (defn color-picker-callback
[color disable-gradient disable-opacity handle-change-color handle-open handle-close] [color disable-gradient disable-opacity handle-change-color handle-open handle-close]

View file

@ -128,7 +128,7 @@
(defn set-value! (defn set-value!
[node value] [node value]
(set! (.-value node) value)) (set! (.-value ^js node) value))
(defn select-text! (defn select-text!
[node] [node]