mirror of
https://github.com/penpot/penpot.git
synced 2025-01-21 22:22:43 -05:00
Add themes modal dialog
This commit is contained in:
parent
1ed6d92d87
commit
b62722bdbb
4 changed files with 90 additions and 15 deletions
|
@ -8,6 +8,7 @@
|
||||||
(:require-macros [app.main.style :as stl])
|
(:require-macros [app.main.style :as stl])
|
||||||
(:require
|
(:require
|
||||||
[app.main.data.modal :as modal]
|
[app.main.data.modal :as modal]
|
||||||
|
[app.main.ui.workspace.tokens.modals.themes :as wtmt]
|
||||||
[app.main.refs :as refs]
|
[app.main.refs :as refs]
|
||||||
[app.main.ui.workspace.tokens.form :refer [form]]
|
[app.main.ui.workspace.tokens.form :refer [form]]
|
||||||
[okulary.core :as l]
|
[okulary.core :as l]
|
||||||
|
@ -37,7 +38,7 @@
|
||||||
(-> (calculate-position vport position x y)
|
(-> (calculate-position vport position x y)
|
||||||
(clj->js))))
|
(clj->js))))
|
||||||
|
|
||||||
(mf/defc modal
|
(mf/defc token-update-create-modal
|
||||||
{::mf/wrap-props false}
|
{::mf/wrap-props false}
|
||||||
[{:keys [x y position token token-type] :as _args}]
|
[{:keys [x y position token token-type] :as _args}]
|
||||||
(let [wrapper-style (use-viewport-position-style x y position)]
|
(let [wrapper-style (use-viewport-position-style x y position)]
|
||||||
|
@ -47,82 +48,88 @@
|
||||||
[:& form {:token token
|
[:& form {:token token
|
||||||
:token-type token-type}]]))
|
:token-type token-type}]]))
|
||||||
|
|
||||||
|
(mf/defc token-themes-modal
|
||||||
|
{::mf/register modal/components
|
||||||
|
::mf/register-as :tokens/themes}
|
||||||
|
[args]
|
||||||
|
[:& wtmt/modal args])
|
||||||
|
|
||||||
;; Modals ----------------------------------------------------------------------
|
;; Modals ----------------------------------------------------------------------
|
||||||
|
|
||||||
(mf/defc boolean-modal
|
(mf/defc boolean-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/boolean}
|
::mf/register-as :tokens/boolean}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc border-radius-modal
|
(mf/defc border-radius-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/border-radius}
|
::mf/register-as :tokens/border-radius}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc stroke-width-modal
|
(mf/defc stroke-width-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/stroke-width}
|
::mf/register-as :tokens/stroke-width}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc box-shadow-modal
|
(mf/defc box-shadow-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/box-shadow}
|
::mf/register-as :tokens/box-shadow}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc sizing-modal
|
(mf/defc sizing-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/sizing}
|
::mf/register-as :tokens/sizing}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc dimensions-modal
|
(mf/defc dimensions-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/dimensions}
|
::mf/register-as :tokens/dimensions}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc numeric-modal
|
(mf/defc numeric-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/numeric}
|
::mf/register-as :tokens/numeric}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc opacity-modal
|
(mf/defc opacity-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/opacity}
|
::mf/register-as :tokens/opacity}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc other-modal
|
(mf/defc other-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/other}
|
::mf/register-as :tokens/other}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc rotation-modal
|
(mf/defc rotation-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/rotation}
|
::mf/register-as :tokens/rotation}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc spacing-modal
|
(mf/defc spacing-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/spacing}
|
::mf/register-as :tokens/spacing}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc string-modal
|
(mf/defc string-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/string}
|
::mf/register-as :tokens/string}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
||||||
(mf/defc typography-modal
|
(mf/defc typography-modal
|
||||||
{::mf/register modal/components
|
{::mf/register modal/components
|
||||||
::mf/register-as :tokens/typography}
|
::mf/register-as :tokens/typography}
|
||||||
[properties]
|
[properties]
|
||||||
[:& modal properties])
|
[:& token-update-create-modal properties])
|
||||||
|
|
28
frontend/src/app/main/ui/workspace/tokens/modals/themes.cljs
Normal file
28
frontend/src/app/main/ui/workspace/tokens/modals/themes.cljs
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
;; 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.workspace.tokens.modals.themes
|
||||||
|
(:require-macros [app.main.style :as stl])
|
||||||
|
(:require
|
||||||
|
[rumext.v2 :as mf]
|
||||||
|
[app.main.data.modal :as modal]
|
||||||
|
[app.main.store :as st]
|
||||||
|
[app.main.ui.icons :as i]))
|
||||||
|
|
||||||
|
(def ^:private close-icon
|
||||||
|
(i/icon-xref :close (stl/css :close-icon)))
|
||||||
|
|
||||||
|
(mf/defc modal
|
||||||
|
{::mf/wrap-props false}
|
||||||
|
[{:keys [] :as _args}]
|
||||||
|
(let [handle-close-dialog (mf/use-callback #(st/emit! (modal/hide)))]
|
||||||
|
[:div {:class (stl/css :modal-overlay)}
|
||||||
|
[:div {:class (stl/css :modal-dialog)}
|
||||||
|
[:button {:class (stl/css :close-btn) :on-click handle-close-dialog} close-icon]
|
||||||
|
[:div {:class (stl/css :modal-title)} "Themes"]
|
||||||
|
|
||||||
|
[:div {:class (stl/css :modal-content)}
|
||||||
|
"Themes"]]]))
|
34
frontend/src/app/main/ui/workspace/tokens/modals/themes.scss
Normal file
34
frontend/src/app/main/ui/workspace/tokens/modals/themes.scss
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
// 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
|
||||||
|
|
||||||
|
@import "refactor/common-refactor.scss";
|
||||||
|
|
||||||
|
.modal-overlay {
|
||||||
|
@extend .modal-overlay-base;
|
||||||
|
}
|
||||||
|
|
||||||
|
.modal-dialog {
|
||||||
|
@extend .modal-container-base;
|
||||||
|
display: grid;
|
||||||
|
grid-template-rows: auto 1fr auto;
|
||||||
|
width: 100%;
|
||||||
|
max-width: $s-640;
|
||||||
|
}
|
||||||
|
|
||||||
|
.modal-title {
|
||||||
|
@include headlineMediumTypography;
|
||||||
|
margin-block-end: $s-32;
|
||||||
|
color: var(--modal-title-foreground-color);
|
||||||
|
}
|
||||||
|
|
||||||
|
.modal-content {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
.close-btn {
|
||||||
|
@extend .modal-close-btn-base;
|
||||||
|
}
|
|
@ -107,6 +107,7 @@
|
||||||
(let [{:keys [key fields]} modal]
|
(let [{:keys [key fields]} modal]
|
||||||
(dom/stop-propagation event)
|
(dom/stop-propagation event)
|
||||||
(st/emit! (dt/set-token-type-section-open type true))
|
(st/emit! (dt/set-token-type-section-open type true))
|
||||||
|
(js/console.log "key" key)
|
||||||
(modal/show! key {:x (.-clientX ^js event)
|
(modal/show! key {:x (.-clientX ^js event)
|
||||||
:y (.-clientY ^js event)
|
:y (.-clientY ^js event)
|
||||||
:position :right
|
:position :right
|
||||||
|
@ -190,7 +191,12 @@
|
||||||
:collapsed (not @open?)
|
:collapsed (not @open?)
|
||||||
:all-clickable true
|
:all-clickable true
|
||||||
:title "THEMES"
|
:title "THEMES"
|
||||||
:on-collapsed #(swap! open? not)}]]
|
:on-collapsed #(swap! open? not)}]
|
||||||
|
[:button {:class (stl/css :add-set)
|
||||||
|
:on-click (fn [event]
|
||||||
|
(modal/show! :tokens/themes {:x (.-clientX ^js event)
|
||||||
|
:y (.-clientY ^js event)}))}
|
||||||
|
i/add]]
|
||||||
(when @open?
|
(when @open?
|
||||||
[:div
|
[:div
|
||||||
[:style
|
[:style
|
||||||
|
|
Loading…
Add table
Reference in a new issue