mirror of
https://github.com/penpot/penpot.git
synced 2025-07-30 07:48:36 +02:00
* 🐛 Fix title toggle arrow without content * 🐛 Fix export dropdowns * 🐛 Fix colorpicker eyedrop * 🐛 Fix hover state on color row * 🐛 Fix color bullet on color row * 🐛 Fix some css errors in new UI * 🐛 Fix text and typography component * 🐛 Fix some icons * 💄 Update ui in feedback page, webhooks page and access token page
60 lines
2 KiB
Clojure
60 lines
2 KiB
Clojure
;; This Source Code Form is subject to the terms of the Mozilla Public
|
|
;; 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) KALEIDOS INC
|
|
|
|
(ns app.main.ui.components.search-bar
|
|
(:require-macros [app.main.style :refer [css]])
|
|
(:require
|
|
[app.main.ui.icons :as i]
|
|
[app.util.dom :as dom]
|
|
[app.util.keyboard :as kbd]
|
|
[rumext.v2 :as mf]))
|
|
|
|
(mf/defc search-bar
|
|
{::mf/wrap-props false}
|
|
[props]
|
|
(let [children (unchecked-get props "children")
|
|
on-change (unchecked-get props "on-change")
|
|
value (unchecked-get props "value")
|
|
on-clear (unchecked-get props "clear-action")
|
|
placeholder (unchecked-get props "placeholder")
|
|
icon (unchecked-get props "icon")
|
|
|
|
handle-change
|
|
(mf/use-fn
|
|
(mf/deps on-change)
|
|
(fn [event]
|
|
(let [value (dom/get-target-val event)]
|
|
(on-change value event))))
|
|
|
|
handle-clear
|
|
(mf/use-fn
|
|
(mf/deps on-clear on-change)
|
|
(fn [event]
|
|
(if on-clear
|
|
(on-clear event)
|
|
(on-change "" event))))
|
|
|
|
handle-key-down
|
|
(mf/use-fn
|
|
(fn [event]
|
|
(let [enter? (kbd/enter? event)
|
|
esc? (kbd/esc? event)
|
|
node (dom/get-target event)]
|
|
(when ^boolean enter? (dom/blur! node))
|
|
(when ^boolean esc? (dom/blur! node)))))]
|
|
[:span {:class (dom/classnames (css :search-box) true
|
|
(css :has-children) (some? children))}
|
|
children
|
|
[:div {:class (dom/classnames (css :search-input-wrapper) true)}
|
|
icon
|
|
[:input {:on-change handle-change
|
|
:value value
|
|
:placeholder placeholder
|
|
:on-key-down handle-key-down}]
|
|
(when (not= "" value)
|
|
[:button {:class (dom/classnames (css :clear) true)
|
|
:on-click handle-clear}
|
|
i/delete-text-refactor])]]))
|