0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-26 00:19:07 -05:00

Resizable color palette

This commit is contained in:
alonso.torres 2022-02-01 16:52:36 +01:00
parent 8d4612c683
commit b26cbeccca
14 changed files with 181 additions and 110 deletions

View file

@ -5,30 +5,26 @@
// Copyright (c) UXBOX Labs SL // Copyright (c) UXBOX Labs SL
.color-cell { .color-cell {
display: grid;
grid-template-columns: 100%;
grid-template-rows: 1fr auto;
height: 100%;
justify-items: center;
width: 65px;
.color-bullet { .color-bullet {
// Creates strange artifacts
border: 2px solid $color-gray-60; border: 2px solid $color-gray-60;
// box-shadow: 0 0 0 2px $color-gray-60; position: relative;
border-radius: 50%; width: var(--bullet-size);
height: var(--bullet-size);
&:hover { &:hover {
border-color: $color-primary; border-color: $color-primary;
} }
} }
&.cell-big .color-bullet { & > * {
width: 50px; overflow: hidden;
height: 50px;
}
&.cell-small .color-bullet {
width: 40px;
height: 40px;
}
.color-bullet.color-big {
width: 50px;
height: 50px;
} }
} }
@ -38,10 +34,10 @@
} }
} }
ul.palette-menu .color-bullet { ul.palette-menu .color-bullet {
width: 20px; width: 20px;
height: 20px; height: 20px;
border-radius: 12px;
border: 1px solid $color-gray-10; border: 1px solid $color-gray-10;
margin-right: 5px; margin-right: 5px;
background-size: 8px; background-size: 8px;
@ -67,14 +63,12 @@ ul.palette-menu .color-bullet {
grid-area: color; grid-area: color;
width: 20px; width: 20px;
height: 20px; height: 20px;
border-radius: 12px;
border: 1px solid $color-gray-10; border: 1px solid $color-gray-10;
background-size: 8px; background-size: 8px;
} }
.asset-section .asset-list-item .color-bullet { .asset-section .asset-list-item .color-bullet {
border: 1px solid $color-gray-20; border: 1px solid $color-gray-20;
border-radius: 10px;
height: 20px; height: 20px;
margin-right: $size-1; margin-right: $size-1;
width: 20px; width: 20px;
@ -91,38 +85,29 @@ ul.palette-menu .color-bullet {
.color-bullet { .color-bullet {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
background: url("") border-radius: 50%;
left center;
background-color: $color-white;
& > * { & .color-bullet-wrapper {
background: url("") left center;
background-color: $color-white;
clip-path: circle(50%);
display: flex;
flex-direction: row;
height: 100%;
width: 100%;
}
&.is-gradient {
background: url("") left center;
background-color: $color-white;
}
& .color-bullet-wrapper > * {
width: 100%; width: 100%;
height: 100%; height: 100%;
} }
} }
.color-bullet.is-library-color .color-bullet-left,
.selected-colors .color-bullet .color-bullet-left {
border-radius: 10px 0 0 10px;
}
.color-bullet.is-library-color .color-bullet-right,
.selected-colors .color-bullet .color-bullet-right {
border-radius: 0 10px 10px 0;
}
.color-palette .color-bullet .color-bullet-left {
border-radius: 25px 0 0 25px;
}
.color-palette .color-bullet .color-bullet-right {
border-radius: 0 25px 25px 0;
}
.color-data .color-bullet.is-library-color {
border-radius: 50%;
}
.color-data .color-bullet.multiple { .color-data .color-bullet.multiple {
background: transparent; background: transparent;
@ -133,7 +118,7 @@ ul.palette-menu .color-bullet {
.color-data .color-bullet { .color-data .color-bullet {
border: 1px solid $color-gray-30; border: 1px solid $color-gray-30;
border-radius: $br-small; border-radius: 50%;
cursor: pointer; cursor: pointer;
display: flex; display: flex;
align-items: center; align-items: center;
@ -144,10 +129,6 @@ ul.palette-menu .color-bullet {
margin: 5px 4px 0 0; margin: 5px 4px 0 0;
width: 20px; width: 20px;
&.color-name {
border-radius: 10px;
}
&.palette-th { &.palette-th {
align-items: center; align-items: center;
border: 1px solid $color-gray-30; border: 1px solid $color-gray-30;
@ -198,3 +179,11 @@ ul.palette-menu .color-bullet {
fill: $color-black; fill: $color-black;
} }
} }
.color-data .color-bullet.is-not-library-color {
border-radius: $br-small;
& .color-bullet-wrapper {
clip-path: none;
}
}

View file

@ -122,6 +122,7 @@
overflow: hidden; overflow: hidden;
width: 100%; width: 100%;
padding: 0.25rem; padding: 0.25rem;
height: 100%;
&.size-small { &.size-small {
height: 3.5rem; height: 3.5rem;
@ -135,6 +136,7 @@
transition: all 0.6s ease; transition: all 0.6s ease;
width: 100%; width: 100%;
scroll-behavior: smooth; scroll-behavior: smooth;
height: 100%;
} }
.color-cell { .color-cell {
@ -145,24 +147,21 @@
flex-shrink: 0; flex-shrink: 0;
position: relative; position: relative;
&.cell-big {
flex-basis: 66px;
}
&.cell-small {
flex-basis: 52px;
}
.color-text { .color-text {
color: $color-gray-20; color: $color-gray-20;
font-size: $fs12; font-size: $fs12;
white-space: nowrap; white-space: nowrap;
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
width: 66px; width: 65px;
text-align: center; text-align: center;
margin-top: 0.25rem; margin-top: 0.25rem;
.no-text & {
display: none;
}
} }
&.current { &.current {
.color-text { .color-text {
color: $color-gray-50; color: $color-gray-50;

View file

@ -231,15 +231,23 @@
.asset-grid { .asset-grid {
display: grid; display: grid;
grid-template-columns: 1fr 1fr 1fr 1fr; grid-template-columns: repeat(4, 1fr);
grid-auto-rows: 6vh; grid-auto-rows: 6vh;
column-gap: 0.5rem; column-gap: 0.5rem;
row-gap: 0.5rem; row-gap: 0.5rem;
&.big { &.big {
grid-template-columns: 1fr 1fr; grid-template-columns: repeat(2, 1fr);
grid-auto-rows: 10vh; grid-auto-rows: 10vh;
.three-row & {
grid-template-columns: repeat(3, 1fr);
}
.four-row & {
grid-template-columns: repeat(4, 1fr);
}
.grid-cell { .grid-cell {
padding: $size-1; padding: $size-1;

View file

@ -207,6 +207,11 @@ span.element-name {
margin-left: auto; margin-left: auto;
position: relative; position: relative;
width: 32px; width: 32px;
right: 20px;
&.is-parent {
right: 0;
}
svg { svg {
height: 13px; height: 13px;
@ -242,7 +247,7 @@ span.element-name {
} }
.toggle-content { .toggle-content {
margin-left: auto; margin-left: 8px;
width: 12px; width: 12px;
svg { svg {

View file

@ -432,6 +432,15 @@
stored stored
(d/concat-set flags))))))) (d/concat-set flags)))))))
(defn remove-layout-flags
[& flags]
(ptk/reify ::remove-layout-flags
ptk/UpdateEvent
(update [_ state]
(update state :workspace-layout
(fn [stored]
(reduce disj stored (d/concat-set flags)))))))
;; --- Set element options mode ;; --- Set element options mode
(defn set-options-mode (defn set-options-mode

View file

@ -17,6 +17,7 @@
[app.main.data.workspace.transforms :as dwt] [app.main.data.workspace.transforms :as dwt]
[app.main.data.workspace.undo :as dwu] [app.main.data.workspace.undo :as dwu]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.hooks.resize :as r]
[app.util.dom :as dom])) [app.util.dom :as dom]))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
@ -38,9 +39,17 @@
:command (ds/a-mod "h") :command (ds/a-mod "h")
:fn #(st/emit! (dw/go-to-layout :document-history))} :fn #(st/emit! (dw/go-to-layout :document-history))}
:toggle-palette {:tooltip (ds/alt "P") :toggle-colorpalette {:tooltip (ds/alt "P")
:command (ds/a-mod "p") :command (ds/a-mod "p")
:fn #(st/emit! (dw/toggle-layout-flags :colorpalette))} :fn #(do (r/set-resize-type! :bottom)
(st/emit! (dw/remove-layout-flags :textpalette)
(dw/toggle-layout-flags :colorpalette)))}
:toggle-textpalette {:tooltip (ds/alt "T")
:command (ds/a-mod "t")
:fn #(do (r/set-resize-type! :bottom)
(st/emit! (dw/remove-layout-flags :colorpalette)
(dw/toggle-layout-flags :textpalette)))}
:toggle-rules {:tooltip (ds/meta-shift "R") :toggle-rules {:tooltip (ds/meta-shift "R")
:command (ds/c-mod "shift+r") :command (ds/c-mod "shift+r")

View file

@ -7,6 +7,7 @@
(ns app.main.ui.components.color-bullet (ns app.main.ui.components.color-bullet
(:require (:require
[app.util.color :as uc] [app.util.color :as uc]
[app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[rumext.alpha :as mf])) [rumext.alpha :as mf]))
@ -21,17 +22,18 @@
[:div.color-bullet.multiple {:on-click #(when on-click (on-click %))}] [:div.color-bullet.multiple {:on-click #(when on-click (on-click %))}]
;; No multiple selection ;; No multiple selection
(let [color (if (string? color) {:color color :opacity 1} color) (let [color (if (string? color) {:color color :opacity 1} color)]
background (if (:gradient color) (uc/color->background color) "auto")] [:div.color-bullet.tooltip.tooltip-right
[:div.color-bullet.tooltip.tooltip-right {:class (if (:id color) "is-library-color" "is-not-library-color") {:class (dom/classnames :is-library-color (some? (:id color))
:on-click #(when on-click (on-click %)) :is-not-library-color (nil? (:id color))
:alt (or (:name color) (:color color) (gradient-type->string (:type (:gradient color)))) :is-gradient (some? (:gradient color)))
:style {:background background}} :on-click #(when on-click (on-click %))
(when (not(:gradient color)) :alt (or (:name color) (:color color) (gradient-type->string (:type (:gradient color))))}
[:* (if (:gradient color)
[:div.color-bullet-wrapper {:style {:background (uc/color->background color)}}]
[:div.color-bullet-wrapper
[:div.color-bullet-left {:style {:background (uc/color->background (assoc color :opacity 1))}}] [:div.color-bullet-left {:style {:background (uc/color->background (assoc color :opacity 1))}}]
[:div.color-bullet-right {:style {:background (uc/color->background color)}}]] [:div.color-bullet-right {:style {:background (uc/color->background color)}}]])])))
)])))
(mf/defc color-name [{:keys [color size on-click on-double-click]}] (mf/defc color-name [{:keys [color size on-click on-double-click]}]
(let [color (if (string? color) {:color color :opacity 1} color) (let [color (if (string? color) {:color color :opacity 1} color)

View file

@ -22,6 +22,7 @@
[app.main.ui.workspace.left-toolbar :refer [left-toolbar]] [app.main.ui.workspace.left-toolbar :refer [left-toolbar]]
[app.main.ui.workspace.libraries] [app.main.ui.workspace.libraries]
[app.main.ui.workspace.sidebar :refer [left-sidebar right-sidebar]] [app.main.ui.workspace.sidebar :refer [left-sidebar right-sidebar]]
[app.main.ui.workspace.textpalette :refer [textpalette]]
[app.main.ui.workspace.viewport :refer [viewport]] [app.main.ui.workspace.viewport :refer [viewport]]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
@ -41,7 +42,10 @@
{:keys [options-mode]} local {:keys [options-mode]} local
file (obj/get props "file") file (obj/get props "file")
layout (obj/get props "layout") layout (obj/get props "layout")
colorpalette? (:colorpalette layout) colorpalette? (:colorpalette layout)
textpalette? (:textpalette layout)
hide-ui? (:hide-ui layout)
on-resize on-resize
(mf/use-callback (mf/use-callback
@ -52,7 +56,11 @@
node-ref (use-resize-observer on-resize)] node-ref (use-resize-observer on-resize)]
[:* [:*
(when colorpalette? [:& colorpalette]) (when (and colorpalette? (not hide-ui?))
[:& colorpalette])
(when (and textpalette? (not hide-ui?))
[:& textpalette])
[:section.workspace-content {:ref node-ref} [:section.workspace-content {:ref node-ref}
[:section.workspace-viewport [:section.workspace-viewport
@ -64,7 +72,7 @@
:selected selected :selected selected
:layout layout}]]] :layout layout}]]]
(when-not (:hide-ui layout) (when-not hide-ui?
[:* [:*
[:& left-toolbar {:layout layout}] [:& left-toolbar {:layout layout}]
(if (:collapse-left-sidebar layout) (if (:collapse-left-sidebar layout)

View file

@ -6,6 +6,7 @@
(ns app.main.ui.workspace.colorpalette (ns app.main.ui.workspace.colorpalette
(:require (:require
[app.common.data :as d]
[app.common.math :as mth] [app.common.math :as mth]
[app.main.data.workspace.colors :as mdc] [app.main.data.workspace.colors :as mdc]
[app.main.refs :as refs] [app.main.refs :as refs]
@ -15,6 +16,7 @@
[app.main.ui.hooks.resize :refer [use-resize-hook]] [app.main.ui.hooks.resize :refer [use-resize-hook]]
[app.main.ui.icons :as i] [app.main.ui.icons :as i]
[app.util.color :as uc] [app.util.color :as uc]
[app.util.dom :as dom]
[app.util.i18n :refer [tr]] [app.util.i18n :refer [tr]]
[app.util.keyboard :as kbd] [app.util.keyboard :as kbd]
[app.util.object :as obj] [app.util.object :as obj]
@ -39,7 +41,7 @@
;; --- Components ;; --- Components
(mf/defc palette-item (mf/defc palette-item
[{:keys [color size]}] [{:keys [color]}]
(let [ids-with-children (map :id (mf/deref refs/selected-shapes-with-children)) (let [ids-with-children (map :id (mf/deref refs/selected-shapes-with-children))
select-color select-color
(fn [event] (fn [event]
@ -47,10 +49,9 @@
(st/emit! (mdc/change-stroke ids-with-children (merge uc/empty-color color))) (st/emit! (mdc/change-stroke ids-with-children (merge uc/empty-color color)))
(st/emit! (mdc/change-fill ids-with-children (merge uc/empty-color color)))))] (st/emit! (mdc/change-fill ids-with-children (merge uc/empty-color color)))))]
[:div.color-cell {:class (str "cell-"(name size)) [:div.color-cell {:on-click select-color}
:on-click select-color}
[:& cb/color-bullet {:color color}] [:& cb/color-bullet {:color color}]
[:& cb/color-name {:color color :size size}]])) [:& cb/color-name {:color color}]]))
(mf/defc palette (mf/defc palette
[{:keys [current-colors recent-colors file-colors shared-libs selected]}] [{:keys [current-colors recent-colors file-colors shared-libs selected]}]
@ -116,7 +117,9 @@
(events/unlistenByKey key1)))) (events/unlistenByKey key1))))
[:div.color-palette {:ref parent-ref [:div.color-palette {:ref parent-ref
:style #js {"--height" (str size "px")}} :class (dom/classnames :no-text (< size 72))
:style #js {"--height" (str size "px")
"--bullet-size" (str (if (< size 72) (- size 15) (- size 30)) "px")}}
[:div.resize-area {:on-pointer-down on-pointer-down [:div.resize-area {:on-pointer-down on-pointer-down
:on-lost-pointer-capture on-lost-pointer-capture :on-lost-pointer-capture on-lost-pointer-capture
:on-mouse-move on-mouse-move}] :on-mouse-move on-mouse-move}]
@ -155,31 +158,18 @@
(for [[idx color] (map-indexed vector (take 7 (reverse recent-colors))) ] (for [[idx color] (map-indexed vector (take 7 (reverse recent-colors))) ]
[:& cb/color-bullet {:key (str "color-" idx) [:& cb/color-bullet {:key (str "color-" idx)
:color color}])]] :color color}])]]
]]
[:hr.dropdown-separator]
[:li
{:on-click #(st/emit! (mdc/change-palette-size :big))}
(when (= size :big) i/tick)
(tr "workspace.libraries.colors.big-thumbnails")]
[:li
{:on-click #(st/emit! (mdc/change-palette-size :small))}
(when (= size :small) i/tick)
(tr "workspace.libraries.colors.small-thumbnails")]]]
[:div.color-palette-actions [:div.color-palette-actions
{:on-click #(swap! state assoc :show-menu true)} {:on-click #(swap! state assoc :show-menu true)}
[:div.color-palette-actions-button i/actions]] [:div.color-palette-actions-button i/actions]]
[:span.left-arrow {:on-click on-left-arrow-click} i/arrow-slide] [:span.left-arrow {:on-click on-left-arrow-click} i/arrow-slide]
[:div.color-palette-content {:class (if (= size :big) "size-big" "size-small") [:div.color-palette-content {:ref container :on-wheel on-scroll}
:ref container :on-wheel on-scroll}
[:div.color-palette-inside {:style {:position "relative" [:div.color-palette-inside {:style {:position "relative"
:right (str (* 66 offset) "px")}} :right (str (* 66 offset) "px")}}
(for [[idx item] (map-indexed vector current-colors)] (for [[idx item] (map-indexed vector current-colors)]
[:& palette-item {:color item [:& palette-item {:color item :key idx}])]]
:key idx}])]]
[:span.right-arrow {:on-click on-right-arrow-click} i/arrow-slide]])) [:span.right-arrow {:on-click on-right-arrow-click} i/arrow-slide]]))

View file

@ -18,6 +18,7 @@
[app.main.repo :as rp] [app.main.repo :as rp]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.dropdown :refer [dropdown]] [app.main.ui.components.dropdown :refer [dropdown]]
[app.main.ui.hooks.resize :as r]
[app.main.ui.icons :as i] [app.main.ui.icons :as i]
[app.main.ui.workspace.presence :refer [active-sessions]] [app.main.ui.workspace.presence :refer [active-sessions]]
[app.util.dom :as dom] [app.util.dom :as dom]
@ -297,12 +298,25 @@
(tr "workspace.header.menu.show-layers"))] (tr "workspace.header.menu.show-layers"))]
[:span.shortcut (sc/get-tooltip :toggle-layers)]] [:span.shortcut (sc/get-tooltip :toggle-layers)]]
[:li {:on-click #(st/emit! (dw/toggle-layout-flags :colorpalette))} [:li {:on-click (fn []
(r/set-resize-type! :bottom)
(st/emit! (dw/remove-layout-flags :textpalette)
(dw/toggle-layout-flags :colorpalette)))}
[:span [:span
(if (contains? layout :colorpalette) (if (contains? layout :colorpalette)
(tr "workspace.header.menu.hide-palette") (tr "workspace.header.menu.hide-colorpalette")
(tr "workspace.header.menu.show-palette"))] (tr "workspace.header.menu.show-colorpalette"))]
[:span.shortcut (sc/get-tooltip :toggle-palette)]] [:span.shortcut (sc/get-tooltip :toggle-colorpalette)]]
[:li {:on-click (fn []
(r/set-resize-type! :bottom)
(st/emit! (dw/remove-layout-flags :colorpalette)
(dw/toggle-layout-flags :textpalette)))}
[:span
(if (contains? layout :textpalette)
(tr "workspace.header.menu.hide-textpalette")
(tr "workspace.header.menu.show-textpalette"))]
[:span.shortcut (sc/get-tooltip :toggle-textpalette)]]
[:li {:on-click #(st/emit! (dw/toggle-layout-flags :assets))} [:li {:on-click #(st/emit! (dw/toggle-layout-flags :assets))}
[:span [:span

View file

@ -120,17 +120,19 @@
[:ul.left-toolbar-options.panels [:ul.left-toolbar-options.panels
[:li.tooltip.tooltip-right [:li.tooltip.tooltip-right
{;;:alt (tr "workspace.toolbar.color-palette" (sc/get-tooltip :toggle-textpalette)) {:alt (tr "workspace.toolbar.text-palette" (sc/get-tooltip :toggle-textpalette))
:class (when (contains? layout :textpalette) "selected") :class (when (contains? layout :textpalette) "selected")
:on-click (do :on-click (fn []
(r/set-resize-type! :bottom) (r/set-resize-type! :bottom)
(st/emitf (dw/toggle-layout-flags :textpalette)))} (st/emit! (dw/remove-layout-flags :colorpalette)
i/palette] (dw/toggle-layout-flags :textpalette)))}
"Ag"]
[:li.tooltip.tooltip-right [:li.tooltip.tooltip-right
{:alt (tr "workspace.toolbar.color-palette" (sc/get-tooltip :toggle-palette)) {:alt (tr "workspace.toolbar.color-palette" (sc/get-tooltip :toggle-colorpalette))
:class (when (contains? layout :colorpalette) "selected") :class (when (contains? layout :colorpalette) "selected")
:on-click (do :on-click (fn []
(r/set-resize-type! :bottom) (r/set-resize-type! :bottom)
(st/emitf (dw/toggle-layout-flags :colorpalette)))} (st/emit! (dw/remove-layout-flags :textpalette)
(dw/toggle-layout-flags :colorpalette)))}
i/palette]]]])) i/palette]]]]))

View file

@ -18,6 +18,7 @@
[app.main.ui.workspace.sidebar.layers :refer [layers-toolbox]] [app.main.ui.workspace.sidebar.layers :refer [layers-toolbox]]
[app.main.ui.workspace.sidebar.options :refer [options-toolbox]] [app.main.ui.workspace.sidebar.options :refer [options-toolbox]]
[app.main.ui.workspace.sidebar.sitemap :refer [sitemap]] [app.main.ui.workspace.sidebar.sitemap :refer [sitemap]]
[app.util.dom :as dom]
[app.util.object :as obj] [app.util.object :as obj]
[rumext.alpha :as mf])) [rumext.alpha :as mf]))
@ -37,6 +38,10 @@
(st/emit! (dw/toggle-layout-flags :collapse-left-sidebar)))] (st/emit! (dw/toggle-layout-flags :collapse-left-sidebar)))]
[:aside.settings-bar.settings-bar-left {:ref parent-ref [:aside.settings-bar.settings-bar-left {:ref parent-ref
:class (dom/classnames
:two-row (<= size 300)
:three-row (and (> size 300) (<= size 400))
:four-row (> size 400))
:style #js {"--width" (str size "px")}} :style #js {"--width" (str size "px")}}
[:div.resize-area {:on-pointer-down on-pointer-down [:div.resize-area {:on-pointer-down on-pointer-down
:on-lost-pointer-capture on-lost-pointer-capture :on-lost-pointer-capture on-lost-pointer-capture

View file

@ -213,7 +213,7 @@
:on-start-edit #(reset! disable-drag true) :on-start-edit #(reset! disable-drag true)
:on-stop-edit #(reset! disable-drag false)}] :on-stop-edit #(reset! disable-drag false)}]
[:div.element-actions [:div.element-actions {:class (when (:shapes item) "is-parent")}
[:div.toggle-element {:class (when (:hidden item) "selected") [:div.toggle-element {:class (when (:hidden item) "selected")
:on-click toggle-visibility} :on-click toggle-visibility}
(if (:hidden item) i/eye-closed i/eye)] (if (:hidden item) i/eye-closed i/eye)]

View file

@ -0,0 +1,31 @@
;; 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) UXBOX Labs SL
(ns app.main.ui.workspace.textpalette
(:require
#_[app.util.dom :as dom]
#_[app.common.data :as d]
#_[app.common.math :as mth]
#_[app.main.data.workspace.colors :as mdc]
#_[app.main.refs :as refs]
#_[app.main.store :as st]
#_[app.main.ui.components.color-bullet :as cb]
#_[app.main.ui.components.dropdown :refer [dropdown]]
#_[app.main.ui.hooks.resize :refer [use-resize-hook]]
#_[app.main.ui.icons :as i]
#_[app.util.color :as uc]
#_[app.util.i18n :refer [tr]]
#_[app.util.keyboard :as kbd]
#_[app.util.object :as obj]
#_[cuerdas.core :as str]
#_[goog.events :as events]
#_[okulary.core :as l]
[rumext.alpha :as mf]
))
(mf/defc textpalette
[]
[:div])