♻️ Replace some components with DS ones

This commit is contained in:
Luis de Dios 2025-12-22 00:07:59 +01:00 committed by Andrey Antukh
parent a71baa5a78
commit 6879f54e5d
95 changed files with 2010 additions and 2651 deletions

View File

@ -198,10 +198,10 @@ export class WorkspacePage extends BaseWebSocketPage {
`[id="shape-00000000-0000-0000-0000-000000000000"]`, `[id="shape-00000000-0000-0000-0000-000000000000"]`,
); );
this.toolbarOptions = page.getByTestId("toolbar-options"); this.toolbarOptions = page.getByTestId("toolbar-options");
this.rectShapeButton = page.getByRole("button", { name: "Rectangle (R)" }); this.rectShapeButton = page.getByTestId("toolbar-options").getByRole("button", { name: "Rectangle" });
this.ellipseShapeButton = page.getByRole("button", { name: "Ellipse (E)" }); this.ellipseShapeButton = page.getByTestId("toolbar-options").getByRole("button", { name: "Ellipse" });
this.moveButton = page.getByRole("button", { name: "Move (V)" }); this.moveButton = page.getByTestId("toolbar-options").getByRole("button", { name: "Move" });
this.boardButton = page.getByRole("button", { name: "Board (B)" }); this.boardButton = page.getByTestId("toolbar-options").getByRole("button", { name: "Board" });
this.toggleToolbarButton = page.getByRole("button", { this.toggleToolbarButton = page.getByRole("button", {
name: "Toggle toolbar", name: "Toggle toolbar",
}); });

View File

@ -189,8 +189,8 @@ test("BUG 7760 - Layout losing properties when changing parents", async ({
await workspacePage.clickLeafLayer("Flex Board"); await workspacePage.clickLeafLayer("Flex Board");
// Move the first board into the second // Move the first board into the second
const hAuto = await workspacePage.page.getByTitle("Fit content (Horizontal)"); const hAuto = await workspacePage.page.getByTestId("behaviour-h-auto");
const vAuto = await workspacePage.page.getByTitle("Fit content (Vertical)"); const vAuto = await workspacePage.page.getByTestId("behaviour-v-auto");
await expect(vAuto.locator("input")).toBeChecked(); await expect(vAuto.locator("input")).toBeChecked();
await expect(hAuto.locator("input")).toBeChecked(); await expect(hAuto.locator("input")).toBeChecked();

View File

@ -2418,10 +2418,12 @@ test.describe("Tokens: Apply token", () => {
await nameField.fill(newTokenTitle); await nameField.fill(newTokenTitle);
const referenceTabButton = const referenceTabButton =
tokensUpdateCreateModal.getByTestId("reference-opt"); tokensUpdateCreateModal.getByRole('button', { name: 'Use a reference' });
referenceTabButton.click(); referenceTabButton.click();
const referenceField = tokensUpdateCreateModal.getByLabel("Reference"); const referenceField = tokensUpdateCreateModal.getByRole('textbox', {
name: 'Reference'
});
await referenceField.fill("{Full}"); await referenceField.fill("{Full}");
const submitButton = tokensUpdateCreateModal.getByRole("button", { const submitButton = tokensUpdateCreateModal.getByRole("button", {

View File

@ -332,24 +332,33 @@ test("Copy/paste properties", async ({ page, context }) => {
await page.getByText("Copy/Paste as").hover(); await page.getByText("Copy/Paste as").hover();
await page.getByText("Paste properties").click(); await page.getByText("Paste properties").click();
await page.getByText("Rectangle").first().click({ button: "right" }); await page
await page.getByText("Copy/Paste as").hover(); .getByTestId("layer-item")
await page.getByText("Paste properties").click(); .getByText("Rectangle")
.first()
await page.getByText("Board").nth(2).click({ button: "right" }); .click({ button: "right" });
await page.getByText("Copy/Paste as").hover(); await page.getByText("Copy/Paste as").hover();
await page.getByText("Paste properties").click(); await page.getByText("Paste properties").click();
await page await page
.getByTestId("layer-item") .getByTestId("layer-item")
.locator("div") .getByText("Board")
.filter({ hasText: "Path" })
.nth(1) .nth(1)
.click({ button: "right" }); .click({ button: "right" });
await page.getByText("Copy/Paste as").hover(); await page.getByText("Copy/Paste as").hover();
await page.getByText("Paste properties").click(); await page.getByText("Paste properties").click();
await page.getByText("Ellipse").click({ button: "right" }); await page
.getByTestId("layer-item")
.getByText("Path")
.click({ button: "right" });
await page.getByText("Copy/Paste as").hover();
await page.getByText("Paste properties").click();
await page
.getByTestId("layer-item")
.getByText("Ellipse")
.click({ button: "right" });
await page.getByText("Copy/Paste as").hover(); await page.getByText("Copy/Paste as").hover();
await page.getByText("Paste properties").click(); await page.getByText("Paste properties").click();
}); });

View File

@ -245,13 +245,6 @@
--assets-component-second-border-selected: var(--color-background-primary); --assets-component-second-border-selected: var(--color-background-primary);
--assets-component-hightlight: var(--color-accent-secondary); --assets-component-hightlight: var(--color-accent-secondary);
--radio-btns-background-color: var(--color-background-tertiary);
--radio-btn-background-color-selected: var(--color-background-quaternary);
--radio-btn-foreground-color: var(--color-foreground-secondary);
--radio-btn-foreground-color-selected: var(--color-accent-primary);
--radio-btn-border-color: var(--color-background-tertiary);
--radio-btn-border-color-selected: var(--color-background-quaternary);
--library-name-foreground-color: var(--color-foreground-primary); --library-name-foreground-color: var(--color-foreground-primary);
--library-content-foreground-color: var(--color-foreground-secondary); --library-content-foreground-color: var(--color-foreground-secondary);
@ -424,13 +417,6 @@
--tab-border-color: var(--color-background-tertiary); --tab-border-color: var(--color-background-tertiary);
--tab-border-color-selected: var(--color-background-secondary); --tab-border-color-selected: var(--color-background-secondary);
--radio-btns-background-color: var(--color-background-tertiary);
--radio-btn-background-color-selected: var(--color-background-primary);
--radio-btn-foreground-color: var(--color-foreground-secondary);
--radio-btn-foreground-color-selected: var(--color-accent-primary);
--radio-btn-border-color: var(--color-background-tertiary);
--radio-btn-border-color-selected: var(--color-background-secondary);
--button-icon-background-color-selected: var(--color-background-primary); --button-icon-background-color-selected: var(--color-background-primary);
--button-icon-border-color-selected: var(--color-background-secondary); --button-icon-border-color-selected: var(--color-background-secondary);

View File

@ -10,9 +10,9 @@
[app.util.dom :as dom] [app.util.dom :as dom]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(mf/defc file-uploader (mf/defc file-uploader*
{::mf/forward-ref true} {::mf/forward-ref true}
[{:keys [accept multi label-text label-class input-id on-selected data-testid] :as props} input-ref] [{:keys [accept multi label-text label-class input-id on-selected data-testid]} input-ref]
(let [opt-pick-one #(if multi % (first %)) (let [opt-pick-one #(if multi % (first %))
on-files-selected on-files-selected

View File

@ -1,107 +0,0 @@
;; 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.radio-buttons
(:require-macros [app.main.style :as stl])
(:require
[app.common.data :as d]
[app.common.data.macros :as dm]
[app.main.ui.ds.foundations.assets.icon :refer [icon*]]
[app.main.ui.formats :as fmt]
[app.util.dom :as dom]
[rumext.v2 :as mf]))
(def context
(mf/create-context nil))
(mf/defc radio-button
{::mf/props :obj}
[{:keys [icon id value disabled title icon-class type]}]
(let [context (mf/use-ctx context)
allow-empty (unchecked-get context "allow-empty")
type (if ^boolean type
type
(if ^boolean allow-empty
"checkbox"
"radio"))
on-change (unchecked-get context "on-change")
selected (unchecked-get context "selected")
name (unchecked-get context "name")
encode-fn (unchecked-get context "encode-fn")
checked? (= selected value)
value (encode-fn value)]
[:label {:html-for id
:data-testid id
:title title
:class (stl/css-case
:radio-icon true
:checked checked?
:disabled disabled)}
(if (some? icon)
[:> icon* {:icon-id icon :class icon-class :aria-hidden true}]
[:span {:class (stl/css :title-name)} value])
[:input {:id id
:on-change on-change
:type type
:name name
:disabled disabled
:value value
:default-checked checked?}]]))
(mf/defc radio-buttons
{::mf/props :obj}
[{:keys [name children on-change selected class wide encode-fn decode-fn allow-empty] :as props}]
(let [encode-fn (d/nilv encode-fn identity)
decode-fn (d/nilv decode-fn identity)
nitems (if (array? children)
(count (keep identity children))
1)
;; FIXME: we should handle this with CSS
width (mf/with-memo [nitems]
(if (= wide true)
"unset"
(fmt/format-pixels
(+ (* 4 (- nitems 1))
(* 32 nitems)))))
on-change'
(mf/use-fn
(mf/deps selected on-change)
(fn [event]
(let [input (dom/get-target event)
value (dom/get-target-val event)
;; Only allow null values when the "allow-empty" prop is true
value (when (or (not allow-empty)
(not= value selected)) value)]
(when (fn? on-change)
(on-change (decode-fn value) event))
(dom/blur! input))))
context-value
(mf/spread-object props
;; We pass a special metadata for disable
;; key casing transformation in this
;; concrete case, because this component
;; uses legacy mode and props are in
;; kebab-case style
^{::mf/transform false}
{:on-change on-change'
:encode-fn encode-fn
:decode-fn decode-fn})]
[:& (mf/provider context) {:value context-value}
[:div {:class (dm/str class " " (stl/css :radio-btn-wrapper))
:style {:width width}
:key (dm/str name "-" selected)}
children]]))

View File

@ -1,79 +0,0 @@
// 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
@use "refactor/common-refactor.scss" as deprecated;
.radio-btn-wrapper {
@include deprecated.flexCenter;
border-radius: deprecated.$br-8;
height: deprecated.$s-32;
background-color: var(--input-background-color);
gap: deprecated.$s-4;
}
.radio-icon {
--radio-icon-border-color: var(--radio-btn-border-color);
@include deprecated.buttonStyle;
@include deprecated.flexCenter;
@include deprecated.focusRadio;
height: deprecated.$s-32;
flex-grow: 1;
border-radius: deprecated.$s-8;
box-sizing: border-box;
border: deprecated.$br-2 solid var(--radio-icon-border-color);
input {
display: none;
}
svg {
@extend .button-icon;
stroke: var(--radio-btn-foreground-color);
}
.title-name {
@include deprecated.uppercaseTitleTipography;
color: var(--radio-btn-foreground-color);
}
&:hover {
svg {
stroke: var(--radio-btn-foreground-color-selected);
}
}
}
.checked {
--radio-icon-border-color: var(--radio-btn-border-color-selected);
background-color: var(--radio-btn-background-color-selected);
svg {
stroke: var(--radio-btn-foreground-color-selected);
}
.title-name {
color: var(--radio-btn-foreground-color-selected);
}
}
.disabled {
cursor: default;
background-color: transparent;
border: deprecated.$s-2 solid transparent;
svg {
stroke: var(--button-foreground-color-disabled);
}
.title-name {
color: var(--button-foreground-color-disabled);
}
&:hover {
background-color: transparent;
border: deprecated.$s-2 solid transparent;
svg {
stroke: var(--button-foreground-color-disabled);
}
.title-name {
color: var(--button-foreground-color-disabled);
}
}
}

View File

@ -17,7 +17,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.context-menu-a11y :refer [context-menu*]] [app.main.ui.components.context-menu-a11y :refer [context-menu*]]
[app.main.ui.components.file-uploader :refer [file-uploader]] [app.main.ui.components.file-uploader :refer [file-uploader*]]
[app.main.ui.ds.product.empty-placeholder :refer [empty-placeholder*]] [app.main.ui.ds.product.empty-placeholder :refer [empty-placeholder*]]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.main.ui.notifications.context-notification :refer [context-notification]] [app.main.ui.notifications.context-notification :refer [context-notification]]
@ -184,7 +184,7 @@
:on-click on-click :on-click on-click
:tab-index "0"} :tab-index "0"}
[:span (tr "labels.add-custom-font")] [:span (tr "labels.add-custom-font")]
[:& file-uploader {:input-id "font-upload" [:> file-uploader* {:input-id "font-upload"
:accept accept-font-types :accept accept-font-types
:multi true :multi true
:ref input-ref :ref input-ref

View File

@ -16,7 +16,7 @@
[app.main.data.notifications :as ntf] [app.main.data.notifications :as ntf]
[app.main.errors :as errors] [app.main.errors :as errors]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.file-uploader :refer [file-uploader]] [app.main.ui.components.file-uploader :refer [file-uploader*]]
[app.main.ui.ds.product.loader :refer [loader*]] [app.main.ui.ds.product.loader :refer [loader*]]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.main.ui.notifications.context-notification :refer [context-notification]] [app.main.ui.notifications.context-notification :refer [context-notification]]
@ -58,7 +58,7 @@
[{:keys [project-id on-finish-import]} external-ref] [{:keys [project-id on-finish-import]} external-ref]
(let [on-file-selected (use-import-file project-id on-finish-import)] (let [on-file-selected (use-import-file project-id on-finish-import)]
[:form.import-file {:aria-hidden "true"} [:form.import-file {:aria-hidden "true"}
[:& file-uploader {:accept ".penpot,.zip" [:> file-uploader* {:accept ".penpot,.zip"
:multi true :multi true
:ref external-ref :ref external-ref
:on-selected on-file-selected}]])) :on-selected on-file-selected}]]))

View File

@ -19,7 +19,7 @@
[app.main.refs :as refs] [app.main.refs :as refs]
[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.components.file-uploader :refer [file-uploader]] [app.main.ui.components.file-uploader :refer [file-uploader*]]
[app.main.ui.components.forms :as fm] [app.main.ui.components.forms :as fm]
[app.main.ui.dashboard.change-owner] [app.main.ui.dashboard.change-owner]
[app.main.ui.dashboard.subscription :refer [members-cta* [app.main.ui.dashboard.subscription :refer [members-cta*
@ -1315,7 +1315,7 @@
[:img {:class (stl/css :team-image) [:img {:class (stl/css :team-image)
:src (cfg/resolve-team-photo-url team)}] :src (cfg/resolve-team-photo-url team)}]
(when can-edit (when can-edit
[:& file-uploader {:accept "image/jpeg,image/png" [:> file-uploader* {:accept "image/jpeg,image/png"
:multi false :multi false
:ref finput :ref finput
:on-selected on-file-selected}])] :on-selected on-file-selected}])]

View File

@ -11,8 +11,10 @@
[app.main.data.modal :as modal] [app.main.data.modal :as modal]
[app.main.repo :as rp] [app.main.repo :as rp]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.ds.notifications.context-notification :refer [context-notification*]] [app.main.ui.ds.notifications.context-notification :refer [context-notification*]]
[app.main.ui.icons :as deprecated-icon]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[app.util.keyboard :as k] [app.util.keyboard :as k]
@ -97,8 +99,11 @@
[:div {:class (stl/css :modal-container)} [:div {:class (stl/css :modal-container)}
[:div {:class (stl/css :modal-header)} [:div {:class (stl/css :modal-header)}
[:h2 {:class (stl/css :modal-title)} title] [:h2 {:class (stl/css :modal-title)} title]
[:button {:class (stl/css :modal-close-btn) [:> icon-button* {:variant "ghost"
:on-click cancel-fn} deprecated-icon/close]] :class (stl/css :modal-close-btn)
:icon i/close
:aria-label (tr "labels.close")
:on-click cancel-fn}]]
[:div {:class (stl/css :modal-content)} [:div {:class (stl/css :modal-content)}
(when (and (string? subtitle) (not= subtitle "")) (when (and (string? subtitle) (not= subtitle ""))
@ -124,14 +129,10 @@
[:div {:class (stl/css :modal-footer)} [:div {:class (stl/css :modal-footer)}
[:div {:class (stl/css :action-buttons)} [:div {:class (stl/css :action-buttons)}
(when-not (= cancel-label :omit) (when-not (= cancel-label :omit)
[:input {:class (stl/css :cancel-button) [:> button* {:variant "secondary"
:type "button" :on-click cancel-fn}
:value cancel-label cancel-label])
:on-click cancel-fn}])
[:input {:class (stl/css-case :accept-btn true [:> button* {:variant (if (= accept-style :danger) "destructive" "primary")
:danger (= accept-style :danger) :on-click accept-fn}
:primary (= accept-style :primary)) accept-label]]]]]))
:type "button"
:value accept-label
:on-click accept-fn}]]]]]))

View File

@ -33,7 +33,9 @@
} }
.modal-close-btn { .modal-close-btn {
@extend .modal-close-btn-base; position: absolute;
top: var(--sp-s);
right: var(--sp-s);
} }
.modal-content { .modal-content {
@ -53,17 +55,6 @@
@extend .modal-action-btns; @extend .modal-action-btns;
} }
.cancel-button {
@extend .modal-cancel-btn;
}
.accept-btn {
@extend .modal-accept-btn;
&.danger {
@extend .modal-danger-btn;
}
}
.modal-scd-msg { .modal-scd-msg {
margin-block: 0; margin-block: 0;
} }

View File

@ -12,6 +12,7 @@
[app.main.ui.ds.controls.combobox :refer [combobox*]] [app.main.ui.ds.controls.combobox :refer [combobox*]]
[app.main.ui.ds.controls.input :refer [input*]] [app.main.ui.ds.controls.input :refer [input*]]
[app.main.ui.ds.controls.numeric-input :refer [numeric-input*]] [app.main.ui.ds.controls.numeric-input :refer [numeric-input*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.controls.select :refer [select*]] [app.main.ui.ds.controls.select :refer [select*]]
[app.main.ui.ds.controls.switch :refer [switch*]] [app.main.ui.ds.controls.switch :refer [switch*]]
[app.main.ui.ds.controls.utilities.hint-message :refer [hint-message*]] [app.main.ui.ds.controls.utilities.hint-message :refer [hint-message*]]
@ -63,6 +64,7 @@
:Select select* :Select select*
:Switch switch* :Switch switch*
:Checkbox checkbox* :Checkbox checkbox*
:RadioButtons radio-buttons*
:Combobox combobox* :Combobox combobox*
:Text text* :Text text*
:TabSwitcher tab-switcher* :TabSwitcher tab-switcher*

View File

@ -15,6 +15,7 @@
display: inline-flex; display: inline-flex;
align-items: center; align-items: center;
justify-content: center;
column-gap: var(--sp-xs); column-gap: var(--sp-xs);
} }

View File

@ -0,0 +1,107 @@
;; 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.ds.controls.radio-buttons
(:require-macros
[app.main.style :as stl])
(:require
[app.common.data :as d]
[app.common.data.macros :as dm]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :refer [icon-list]]
[app.util.dom :as dom]
[rumext.v2 :as mf]
[rumext.v2.util :as mfu]))
(def ^:private schema:radio-button
[:map
[:id :string]
[:icon {:optional true}
[:and :string [:fn #(contains? icon-list %)]]]
[:label :string]
[:value [:or :keyword :string]]
[:disabled {:optional true} :boolean]])
(def ^:private schema:radio-buttons
[:map
[:class {:optional true} :string]
[:variant {:optional true}
[:maybe [:enum "primary" "secondary" "ghost" "destructive" "action"]]]
[:extended {:optional true} :boolean]
[:name {:optional true} :string]
[:selected {:optional true}
[:maybe [:or :keyword :string]]]
[:allow-empty {:optional true} :boolean]
[:options [:vector {:min 1} schema:radio-button]]
[:on-change {:optional true} fn?]])
(mf/defc radio-buttons*
{::mf/schema schema:radio-buttons}
[{:keys [class variant extended name selected allow-empty options on-change] :rest props}]
(let [options (if (array? options)
(mfu/bean options)
options)
type (if allow-empty "checkbox" "radio")
variant (d/nilv variant "secondary")
handle-click
(mf/use-fn
(fn [event]
(let [target (dom/get-target event)
label (dom/get-parent-with-data target "label")]
(dom/prevent-default event)
(dom/stop-propagation event)
(dom/click label))))
handle-change
(mf/use-fn
(mf/deps selected on-change)
(fn [event]
(let [input (dom/get-target event)
value (dom/get-target-val event)]
(when (fn? on-change)
(on-change value event))
(dom/blur! input))))
props
(mf/spread-props props {:key (dm/str name "-" selected)
:class [class (stl/css-case :wrapper true
:extended extended)]})]
[:> :div props
(for [[idx {:keys [id class value label icon disabled]}] (d/enumerate options)]
(let [checked? (= selected value)]
[:label {:key idx
:html-for id
:data-label true
:data-testid id
:class [class (stl/css-case :label true
:extended extended)]}
(if (some? icon)
[:> icon-button* {:variant variant
:on-click handle-click
:aria-pressed checked?
:aria-label label
:icon icon
:disabled disabled}]
[:> button* {:variant variant
:on-click handle-click
:aria-pressed checked?
:class (stl/css-case :button true
:extended extended)
:disabled disabled}
label])
[:input {:id id
:class (stl/css :input)
:on-change handle-change
:type type
:name name
:disabled disabled
:value value
:default-checked checked?}]]))]))

View File

@ -0,0 +1,97 @@
{ /* 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 { Canvas, Meta } from '@storybook/addon-docs/blocks';
import * as RadioButtons from "./radio_buttons.stories";
<Meta title="Controls/Radio Buttons" />
# Radio Buttons
The `radio-buttons*` component allows users to switch between two or more options that are mutually exclusive.
## Variants
Radio buttons with text only. The label will be the text of the button.
<Canvas of={RadioButtons.Default} />
```clj
[:> radio-buttons* {:selected "left"
:on-change handle-change
:name "alignment"
:extended false
:allow-empty false
:options [{:id "align-left"
:label "Left"
:value "left"}
{:id "align-center"
:label "Center"
:value "center"}
{:id "align-right"
:label "Right"
:value "right"}]}]
```
Radio buttons with icons only. In this case, the label will act as the tooltip of each button.
<Canvas of={RadioButtons.WithIcons} />
```clj
(ns app.main.ui.foo
(:require
[app.main.ui.ds.foundations.assets.icon :as i]))
[:> radio-buttons* {:selected "left"
:on-change handle-change
:name "alignment"
:extended false
:allow-empty false
:options [{:id "align-left"
:icon i/text-align-left
:label "Left align"
:value "left"}
{:id "align-center"
:icon i/text-align-center
:label "Center align"
:value "center"}
{:id "align-right"
:icon i/text-align-right
:label "Right align"
:value "right"}]}]
```
## Anatomy
Under the hood, each option is represented by
- a button, which is the visible and clickable element. It may be either an icon button or a text button.
- a radio input, which is not visible but retains the current state of the option.
A radio group is defined by giving each of radio buttons in the group the same name. Once a radio group is established,
selecting any radio button in that group automatically deselects any currently-selected radio button in the same group.
The `selected` parameter should be set to the value of the option that is to be active. Otherwise, no option will be selected.
If the parameter `allow-empty` is enabled, then the component will work with checkboxes instead of radio buttons,
and therefore the selected option can be deselected. However, it will still only be possible to select one option.
The `extended` parameter allows the component to use all the available space from the parent and distribute it equally
among all elements.
Any option can be individually disabled using the `disabled` parameter.
## Usage Guidelines
### When to Use
- For multiple choice settings that take effect immediately.
- In preference panels and configuration screens.
### When Not to Use
- For boolean settings (use switch or checkbox instead).
- For actions that require confirmation (use buttons instead).
- For temporary states that need explicit "Apply" action.

View File

@ -0,0 +1,40 @@
// 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
@use "ds/_borders.scss" as *;
@use "ds/spacing.scss" as *;
.wrapper {
display: flex;
justify-content: flex-start;
align-items: center;
width: fit-content;
border-radius: $br-8;
background-color: var(--color-background-tertiary);
gap: var(--sp-xs);
&.extended {
width: 100%;
display: flex;
}
}
.label {
&.extended {
display: flex;
flex: 1 1 0;
}
}
.button {
&.extended {
flex-grow: 1;
}
}
.input {
display: none;
}

View File

@ -0,0 +1,72 @@
// 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 * as React from "react";
import Components from "@target/components";
const { RadioButtons } = Components;
const options = [
{id: "left", label: "Left", value: "left" },
{id: "center", label: "Center", value: "center" },
{id: "right", label: "Right", value: "right" },
];
const optionsIcon = [
{id: "left", label: "Left align", value: "left", icon: "text-align-left" },
{id: "center", label: "Center align", value: "center", icon: "text-align-center" },
{id: "right", label: "Right align", value: "right", icon: "text-align-right" },
];
export default {
title: "Controls/Radio Buttons",
component: RadioButtons,
argTypes: {
name: {
control: { type: "text" },
description: "Whether the checkbox is checked",
},
selected: {
control: { type: "select" },
options: ["", "left", "center", "right"],
description: "Whether the checkbox is checked",
},
extended: {
control: { type: "boolean" },
description: "Whether the checkbox is checked",
},
allowEmpty: {
control: { type: "boolean" },
description: "Whether the checkbox is checked",
},
disabled: {
control: { type: "boolean" },
description: "Whether the checkbox is disabled",
},
},
args: {
name: "alignment",
selected: "left",
extended: false,
allowEmpty: false,
options: options,
disabled: false,
},
parameters: {
controls: {
exclude: ["options", "on-change"],
},
},
render: ({ ...args }) => <RadioButtons {...args} />,
};
export const Default = {};
export const WithIcons = {
args: {
options: optionsIcon,
},
};

View File

@ -208,7 +208,7 @@
;; FIXME: deprecated, should be refactored in two components and use ;; FIXME: deprecated, should be refactored in two components and use
;; the generic progress reporter ;; the generic progress reporter
(mf/defc progress-widget (mf/defc progress-widget*
{::mf/wrap [mf/memo]} {::mf/wrap [mf/memo]}
[] []
(let [state (mf/deref refs/export) (let [state (mf/deref refs/export)

View File

@ -19,7 +19,10 @@
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.code-block :refer [code-block]] [app.main.ui.components.code-block :refer [code-block]]
[app.main.ui.components.copy-button :refer [copy-button*]] [app.main.ui.components.copy-button :refer [copy-button*]]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]] [app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.hooks.resize :refer [use-resize-hook]] [app.main.ui.hooks.resize :refer [use-resize-hook]]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.main.ui.shapes.text.fontfaces :refer [shapes->fonts]] [app.main.ui.shapes.text.fontfaces :refer [shapes->fonts]]
@ -260,7 +263,8 @@
[:div {:class (stl/css-case :element-options true [:div {:class (stl/css-case :element-options true
:viewer-code-block (= :viewer from))} :viewer-code-block (= :viewer from))}
[:div {:class (stl/css :attributes-block)} [:div {:class (stl/css :attributes-block)}
[:button {:class (stl/css :download-button) [:> button* {:variant "secondary"
:class (stl/css :download-button)
:on-click handle-copy-all-code} :on-click handle-copy-all-code}
"Copy all code"]] "Copy all code"]]
@ -288,10 +292,10 @@
;; :options [{:label "CSS" :value "css"}]}] ;; :options [{:label "CSS" :value "css"}]}]
[:div {:class (stl/css :action-btns)} [:div {:class (stl/css :action-btns)}
[:button {:class (stl/css :expand-button) [:> icon-button* {:variant "ghost"
:on-click on-expand} :aria-label "Expand"
deprecated-icon/code] :on-click on-expand
:icon i/code}]
[:> copy-button* {:data copy-css-fn [:> copy-button* {:data copy-css-fn
:class (stl/css :css-copy-btn) :class (stl/css :css-copy-btn)
:on-copied on-style-copied}]]] :on-copied on-style-copied}]]]
@ -318,21 +322,21 @@
:rotated collapsed-markup?)} :rotated collapsed-markup?)}
deprecated-icon/arrow]] deprecated-icon/arrow]]
[:& radio-buttons {:selected markup-type [:> radio-buttons* {:selected markup-type
:on-change set-markup :on-change set-markup
:class (stl/css :code-lang-options) :name "listing-style"
:wide true :options [{:id "html"
:name "listing-style"} :label "HTML"
[:& radio-button {:value "html" :value "html"}
:id :html}] {:id "svg"
[:& radio-button {:value "svg" :label "SVG"
:id :svg}]] :value "svg"}]}]
[:div {:class (stl/css :action-btns)} [:div {:class (stl/css :action-btns)}
[:button {:class (stl/css :expand-button) [:> icon-button* {:variant "ghost"
:on-click on-expand} :aria-label "Expand"
deprecated-icon/code] :on-click on-expand
:icon i/code}]
[:> copy-button* {:data copy-html-fn [:> copy-button* {:data copy-html-fn
:class (stl/css :html-copy-btn) :class (stl/css :html-copy-btn)
:on-copied on-markup-copied}]]] :on-copied on-markup-copied}]]]

View File

@ -17,16 +17,18 @@
padding-inline: var(--sp-m); padding-inline: var(--sp-m);
} }
.attributes-block {
display: flex;
flex-direction: column;
row-gap: 12px;
}
.viewer-code-block { .viewer-code-block {
height: calc(100vh - #{deprecated.$s-108}); // TODO: Fix this hardcoded value height: calc(100vh - #{deprecated.$s-108}); // TODO: Fix this hardcoded value
} }
.download-button { .download-button {
@extend .button-secondary; margin: var(--sp-s) 0;
@include deprecated.uppercaseTitleTipography;
height: deprecated.$s-32;
width: 100%;
margin: deprecated.$s-8 0;
} }
.code-block { .code-block {
@ -73,7 +75,6 @@
gap: deprecated.$s-4; gap: deprecated.$s-4;
} }
.expand-button,
.css-copy-btn, .css-copy-btn,
.html-copy-btn { .html-copy-btn {
@extend .button-tertiary; @extend .button-tertiary;
@ -85,9 +86,6 @@
} }
} }
.code-lang-options {
max-width: deprecated.$s-108;
}
.code-lang-select { .code-lang-select {
@include deprecated.uppercaseTitleTipography; @include deprecated.uppercaseTitleTipography;
width: deprecated.$s-72; width: deprecated.$s-72;

View File

@ -14,7 +14,7 @@
[app.main.data.profile :as du] [app.main.data.profile :as du]
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.file-uploader :refer [file-uploader]] [app.main.ui.components.file-uploader :refer [file-uploader*]]
[app.main.ui.components.forms :as fm] [app.main.ui.components.forms :as fm]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
@ -110,7 +110,7 @@
[:span {:class (stl/css :update-overlay) [:span {:class (stl/css :update-overlay)
:on-click on-image-click} (tr "labels.update")] :on-click on-image-click} (tr "labels.update")]
[:img {:src photo}] [:img {:src photo}]
[:& file-uploader {:accept "image/jpeg,image/png" [:> file-uploader* {:accept "image/jpeg,image/png"
:multi false :multi false
:ref input-ref :ref input-ref
:on-selected on-file-selected :on-selected on-file-selected

View File

@ -27,9 +27,8 @@
[okulary.core :as l] [okulary.core :as l]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(mf/defc comments-menu (mf/defc comments-menu*
{::mf/props :obj {::mf/memo true}
::mf/memo true}
[] []
(let [state (mf/deref refs/comments-local) (let [state (mf/deref refs/comments-local)
cmode (:mode state) cmode (:mode state)

View File

@ -14,10 +14,13 @@
[app.main.data.viewer.shortcuts :as sc] [app.main.data.viewer.shortcuts :as sc]
[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.exports.assets :refer [progress-widget]] [app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.exports.assets :refer [progress-widget*]]
[app.main.ui.formats :as fmt] [app.main.ui.formats :as fmt]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.main.ui.viewer.comments :refer [comments-menu]] [app.main.ui.viewer.comments :refer [comments-menu*]]
[app.main.ui.viewer.interactions :refer [flows-menu* interactions-menu*]] [app.main.ui.viewer.interactions :refer [flows-menu* interactions-menu*]]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :refer [tr]] [app.util.i18n :refer [tr]]
@ -33,20 +36,12 @@
[] []
(modal/show! :login-register {})) (modal/show! :login-register {}))
(mf/defc zoom-widget (mf/defc zoom-widget*
{::mf/memo true {::mf/memo true}
::mf/props :obj} [{:keys [zoom on-increase on-decrease on-zoom-reset on-fullscreen on-zoom-fit on-zoom-fill]}]
[{:keys [zoom
on-increase
on-decrease
on-zoom-reset
on-fullscreen
on-zoom-fit
on-zoom-fill]
:as props}]
(let [open* (mf/use-state false) (let [open* (mf/use-state false)
open? (deref open*) open? (deref open*)
open-dropdown open-dropdown
(mf/use-fn (mf/use-fn
(fn [event] (fn [event]
@ -75,7 +70,7 @@
[:div {:class (stl/css-case :zoom-widget true [:div {:class (stl/css-case :zoom-widget true
:selected open?) :selected open?)
:on-click open-dropdown :on-click (if open? close-dropdown open-dropdown)
:title (tr "workspace.header.zoom")} :title (tr "workspace.header.zoom")}
[:span {:class (stl/css :label)} (fmt/format-percent zoom)] [:span {:class (stl/css :label)} (fmt/format-percent zoom)]
[:& dropdown {:show open? [:& dropdown {:show open?
@ -83,17 +78,17 @@
[:ul {:class (stl/css :dropdown)} [:ul {:class (stl/css :dropdown)}
[:li {:class (stl/css :basic-zoom-bar)} [:li {:class (stl/css :basic-zoom-bar)}
[:span {:class (stl/css :zoom-btns)} [:span {:class (stl/css :zoom-btns)}
[:button {:class (stl/css :zoom-btn) [:> icon-button* {:variant "ghost"
:on-click on-decrease} :aria-label (tr "shortcuts.decrease-zoom")
[:span {:class (stl/css :zoom-icon)} :on-click on-decrease
deprecated-icon/remove-icon]] :icon i/remove}]
[:p {:class (stl/css :zoom-text)} [:p {:class (stl/css :zoom-text)}
(fmt/format-percent zoom)] (fmt/format-percent zoom)]
[:button {:class (stl/css :zoom-btn) [:> icon-button* {:variant "ghost"
:on-click on-increase} :aria-label (tr "shortcuts.increase-zoom")
[:span {:class (stl/css :zoom-icon)} :on-click on-increase
deprecated-icon/add]]] :icon i/add}]]
[:button {:class (stl/css :reset-btn) [:> button* {:variant "ghost"
:on-click on-zoom-reset} :on-click on-zoom-reset}
(tr "workspace.header.reset-zoom")]] (tr "workspace.header.reset-zoom")]]
@ -119,7 +114,7 @@
[:span {:class (stl/css :shortcut-key) [:span {:class (stl/css :shortcut-key)
:key (dm/str "zoom-fullscreen-" sc)} sc])]]]]])) :key (dm/str "zoom-fullscreen-" sc)} sc])]]]]]))
(mf/defc header-options (mf/defc header-options*
[{:keys [section zoom page file index permissions interactions-mode share]}] [{:keys [section zoom page file index permissions interactions-mode share]}]
(let [fullscreen? (mf/deref fullscreen-ref) (let [fullscreen? (mf/deref fullscreen-ref)
@ -159,6 +154,7 @@
handle-zoom-fit handle-zoom-fit
(mf/use-fn (mf/use-fn
#(st/emit! dv/zoom-to-fit))] #(st/emit! dv/zoom-to-fit))]
(mf/with-effect [permissions share] (mf/with-effect [permissions share]
(when (and (when (and
(:in-team permissions) (:in-team permissions)
@ -167,7 +163,7 @@
(open-share-dialog))) (open-share-dialog)))
[:div {:class (stl/css :options-zone)} [:div {:class (stl/css :options-zone)}
[:& progress-widget] [:> progress-widget*]
(case section (case section
:interactions [:* :interactions [:*
@ -175,11 +171,10 @@
[:> flows-menu* {:page page :index index}]) [:> flows-menu* {:page page :index index}])
[:> interactions-menu* [:> interactions-menu*
{:interactions-mode interactions-mode}]] {:interactions-mode interactions-mode}]]
:comments [:& comments-menu] :comments [:> comments-menu*]
[:div {:class (stl/css :view-options)}]) [:div {:class (stl/css :view-options)}])
[:& zoom-widget [:> zoom-widget* {:zoom zoom
{:zoom zoom
:on-increase handle-increase :on-increase handle-increase
:on-decrease handle-decrease :on-decrease handle-decrease
:on-zoom-reset handle-zoom-reset :on-zoom-reset handle-zoom-reset
@ -188,27 +183,29 @@
:on-fullscreen toggle-fullscreen}] :on-fullscreen toggle-fullscreen}]
(when (:in-team permissions) (when (:in-team permissions)
[:span {:on-click go-to-workspace [:> icon-button* {:variant "ghost"
:class (stl/css :edit-btn)} :aria-label (tr "viewer.header.edit-in-workspace")
deprecated-icon/curve]) :on-click go-to-workspace
:icon i/curve}])
[:span {:title (tr "viewer.header.fullscreen") [:> icon-button* {:variant "ghost"
:class (stl/css-case :fullscreen-btn true :aria-pressed fullscreen?
:selected fullscreen?) :aria-label (tr "viewer.header.fullscreen")
:on-click toggle-fullscreen} :on-click toggle-fullscreen
deprecated-icon/expand] :icon i/expand}]
(when (:in-team permissions) (when (:in-team permissions)
[:button {:on-click open-share-dialog [:> button* {:variant "primary"
:class (stl/css :share-btn)} :class (stl/css :share-btn)
:on-click open-share-dialog}
(tr "labels.share")]) (tr "labels.share")])
(when-not (:is-logged permissions) (when-not (:is-logged permissions)
[:span {:on-click open-login-dialog [:span {:on-click open-login-dialog
:class (stl/css :go-log-btn)} (tr "labels.log-or-sign")])])) :class (stl/css :go-log-btn)} (tr "labels.log-or-sign")])]))
(mf/defc header-sitemap (mf/defc header-sitemap*
[{:keys [project file page frame toggle-thumbnails] :as props}] [{:keys [project file page frame toggle-thumbnails]}]
(let [project-name (:name project) (let [project-name (:name project)
file-name (:name file) file-name (:name file)
page-name (:name page) page-name (:name page)
@ -317,7 +314,7 @@
:pointer-events (when-not (:in-team permissions) "none")}} :pointer-events (when-not (:in-team permissions) "none")}}
penpot-logo-icon] penpot-logo-icon]
[:& header-sitemap {:project project [:> header-sitemap* {:project project
:file file :file file
:page page :page page
:frame frame :frame frame
@ -325,32 +322,32 @@
:index index}]] :index index}]]
[:div {:class (stl/css :mode-zone)} [:div {:class (stl/css :mode-zone)}
[:button {:on-click navigate [:> icon-button* {:variant "ghost"
:aria-pressed (= section :interactions)
:aria-label (tr "viewer.header.interactions-section" (sc/get-tooltip :open-interactions))
:data-value "interactions" :data-value "interactions"
:class (stl/css-case :mode-zone-btn true :on-click navigate
:selected (= section :interactions)) :icon i/play}]
:title (tr "viewer.header.interactions-section" (sc/get-tooltip :open-interactions))}
deprecated-icon/play]
(when (or (:in-team permissions) (when (or (:in-team permissions)
(= (:who-comment permissions) "all")) (= (:who-comment permissions) "all"))
[:button {:on-click navigate [:> icon-button* {:variant "ghost"
:aria-pressed (= section :comments)
:aria-label (tr "viewer.header.comments-section" (sc/get-tooltip :open-comments))
:data-value "comments" :data-value "comments"
:class (stl/css-case :mode-zone-btn true :on-click navigate
:selected (= section :comments)) :icon i/comments}])
:title (tr "viewer.header.comments-section" (sc/get-tooltip :open-comments))}
deprecated-icon/comments])
(when (or (:in-team permissions) (when (or (:in-team permissions)
(and (= (:type permissions) :share-link) (and (= (:type permissions) :share-link)
(= (:who-inspect permissions) "all"))) (= (:who-inspect permissions) "all")))
[:button {:on-click go-to-inspect [:> icon-button* {:variant "ghost"
:class (stl/css-case :mode-zone-btn true :aria-pressed (= section :inspect)
:selected (= section :inspect)) :aria-label (tr "viewer.header.inspect-section" (sc/get-tooltip :open-inspect))
:title (tr "viewer.header.inspect-section" (sc/get-tooltip :open-inspect))} :on-click go-to-inspect
deprecated-icon/code])] :icon i/code}])]
[:& header-options {:section section [:> header-options* {:section section
:permissions permissions :permissions permissions
:page page :page page
:file file :file file

View File

@ -12,7 +12,7 @@
grid-column: 1 / span 1; grid-column: 1 / span 1;
grid-row: 1 / span 1; grid-row: 1 / span 1;
display: grid; display: grid;
grid-template-columns: 1fr deprecated.$s-92 1fr; grid-template-columns: 1fr auto 1fr;
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
height: deprecated.$s-48; height: deprecated.$s-48;
@ -130,23 +130,9 @@
// SECTION BUTTONS // SECTION BUTTONS
.mode-zone { .mode-zone {
@include deprecated.flexRow; display: flex;
height: 100%; flex-direction: row;
} gap: var(--sp-xs);
.mode-zone-btn {
@extend .button-tertiary;
@include deprecated.flexCenter;
height: deprecated.$s-32;
width: deprecated.$s-28;
padding: 0;
svg {
@extend .button-icon;
}
}
.selected {
@extend .button-icon-selected;
} }
// OPTION AREA // OPTION AREA
@ -165,33 +151,8 @@
cursor: pointer; cursor: pointer;
} }
.fullscreen-btn {
@extend .button-tertiary;
@include deprecated.flexCenter;
height: deprecated.$s-32;
width: deprecated.$s-28;
svg {
@extend .button-icon;
stroke: var(--icon-foreground);
}
}
.share-btn { .share-btn {
@extend .button-primary; margin-left: var(--sp-xs);
height: deprecated.$s-32;
min-width: deprecated.$s-72;
margin-left: deprecated.$s-4;
}
.edit-btn {
@extend .button-tertiary;
@include deprecated.flexCenter;
height: deprecated.$s-32;
width: deprecated.$s-28;
svg {
@extend .button-icon;
stroke: var(--icon-foreground);
}
} }
.go-log-btn { .go-log-btn {
@ -245,43 +206,15 @@
display: flex; display: flex;
} }
.zoom-btn {
@extend .button-tertiary;
height: deprecated.$s-28;
width: deprecated.$s-28;
border-radius: deprecated.$br-8;
.zoom-icon {
@include deprecated.flexCenter;
width: deprecated.$s-24;
height: deprecated.$s-32;
svg {
@extend .button-icon;
stroke: var(--icon-foreground);
}
}
&:hover {
.zoom-icon svg {
stroke: var(--button-tertiary-foreground-color-hover);
}
}
}
.zoom-text { .zoom-text {
@include deprecated.flexCenter; @include deprecated.flexCenter;
height: 100%; height: 100%;
min-width: deprecated.$s-64; min-width: deprecated.$s-48;
padding: 0; padding: 0;
margin: 0 deprecated.$s-2; margin: 0 deprecated.$s-2;
color: var(--modal-title-foreground-color); color: var(--modal-title-foreground-color);
} }
.reset-btn {
@extend .button-tertiary;
color: var(--button-tertiary-foreground-color-hover);
height: deprecated.$s-28;
border-radius: deprecated.$br-8;
}
.zoom-option { .zoom-option {
@extend .menu-item-base; @extend .menu-item-base;
.shortcuts { .shortcuts {

View File

@ -20,6 +20,9 @@
[app.main.router :as rt] [app.main.router :as rt]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.select :refer [select]] [app.main.ui.components.select :refer [select]]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.util.clipboard :as clipboard] [app.util.clipboard :as clipboard]
[app.util.dom :as dom] [app.util.dom :as dom]
@ -171,10 +174,11 @@
[:div {:class (stl/css :share-link-header)} [:div {:class (stl/css :share-link-header)}
[:h2 {:class (stl/css :share-link-title)} [:h2 {:class (stl/css :share-link-title)}
(tr "common.share-link.title")] (tr "common.share-link.title")]
[:button {:class (stl/css :modal-close-button) [:> icon-button* {:variant "ghost"
:class (stl/css :modal-close-button)
:aria-label (tr "labels.close")
:on-click on-close :on-click on-close
:title (tr "labels.close")} :icon i/close}]]
deprecated-icon/close]]
[:div {:class (stl/css :modal-content)} [:div {:class (stl/css :modal-content)}
[:div {:class (stl/css :share-link-section)} [:div {:class (stl/css :share-link-section)}
(when (and (not confirm?) (some? current-link)) (when (and (not confirm?) (some? current-link))
@ -185,10 +189,10 @@
:placeholder (tr "common.share-link.placeholder") :placeholder (tr "common.share-link.placeholder")
:read-only true}] :read-only true}]
[:button {:class (stl/css :copy-button) [:> icon-button* {:variant "ghost"
:title (tr "viewer.header.share.copy-link") :aria-label (tr "viewer.header.share.copy-link")
:on-click copy-link} :on-click copy-link
deprecated-icon/clipboard]]) :icon i/clipboard}]])
[:div {:class (stl/css :hint-wrapper)} [:div {:class (stl/css :hint-wrapper)}
(when (not ^boolean confirm?) (when (not ^boolean confirm?)
@ -199,28 +203,22 @@
[:div {:class (stl/css :description)} [:div {:class (stl/css :description)}
(tr "common.share-link.confirm-deletion-link-description")] (tr "common.share-link.confirm-deletion-link-description")]
[:div {:class (stl/css :actions)} [:div {:class (stl/css :actions)}
[:input {:type "button" [:> button* {:variant "secondary"
:class (stl/css :button-cancel) :on-click #(reset! confirm* false)}
:on-click #(reset! confirm* false) (tr "labels.cancel")]
:value (tr "labels.cancel")}] [:> button* {:variant "destructive"
[:input {:type "button" :on-click delete-link}
:class (stl/css :button-danger) (tr "common.share-link.destroy-link")]]]
:on-click delete-link
:value (tr "common.share-link.destroy-link")}]]]
(some? current-link) (some? current-link)
[:input [:> button* {:variant "destructive"
{:type "button" :on-click try-delete-link}
:class (stl/css :button-danger) (tr "common.share-link.destroy-link")]
:on-click try-delete-link
:value (tr "common.share-link.destroy-link")}]
:else :else
[:input [:> button* {:variant "primary"
{:type "button" :on-click create-link}
:class (stl/css :button-active) (tr "common.share-link.get-link")])]]
:on-click create-link
:value (tr "common.share-link.get-link")}])]]
(when (not ^boolean confirm?) (when (not ^boolean confirm?)
@ -305,6 +303,7 @@
:options [{:value "team" :label (tr "common.share-link.team-members")} :options [{:value "team" :label (tr "common.share-link.team-members")}
{:value "all" :label (tr "common.share-link.all-users")}] {:value "all" :label (tr "common.share-link.all-users")}]
:on-change on-comment-change}]]] :on-change on-comment-change}]]]
[:div {:class (stl/css :inspect-mode)} [:div {:class (stl/css :inspect-mode)}
[:div {:class (stl/css :subtitle)} [:div {:class (stl/css :subtitle)}
(tr "common.share-link.permissions-can-inspect")] (tr "common.share-link.permissions-can-inspect")]
@ -315,6 +314,3 @@
:options [{:value "team" :label (tr "common.share-link.team-members")} :options [{:value "team" :label (tr "common.share-link.team-members")}
{:value "all" :label (tr "common.share-link.all-users")}] {:value "all" :label (tr "common.share-link.all-users")}]
:on-change on-inspect-change}]]]])])]]])) :on-change on-inspect-change}]]]])])]]]))

View File

@ -30,7 +30,9 @@
} }
.modal-close-button { .modal-close-button {
@extend .modal-close-btn-base; position: absolute;
top: var(--sp-s);
right: var(--sp-s);
} }
.modal-content { .modal-content {
@ -74,18 +76,6 @@
} }
} }
.copy-button {
@extend .button-secondary;
@include deprecated.flexRow;
gap: deprecated.$s-8;
height: deprecated.$s-32;
width: deprecated.$s-28;
svg {
@extend .button-icon;
stroke: var(--icon-foreground-hover);
}
}
.description { .description {
@include deprecated.bodySmallTypography; @include deprecated.bodySmallTypography;
color: var(--modal-text-foreground-color); color: var(--modal-text-foreground-color);
@ -97,18 +87,6 @@
justify-content: flex-end; justify-content: flex-end;
} }
.button-active {
@extend .modal-accept-btn;
}
.button-cancel {
@extend .modal-cancel-btn;
}
.button-danger {
@extend .modal-danger-btn;
}
.permissions-section { .permissions-section {
@include deprecated.flexColumn; @include deprecated.flexColumn;
gap: deprecated.$s-8; gap: deprecated.$s-8;

View File

@ -25,10 +25,11 @@
[app.main.features :as features] [app.main.features :as features]
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.file-uploader :refer [file-uploader]] [app.main.ui.components.file-uploader :refer [file-uploader*]]
[app.main.ui.components.numeric-input :refer [numeric-input*]] [app.main.ui.components.numeric-input :refer [numeric-input*]]
[app.main.ui.components.radio-buttons :refer [radio-buttons radio-button]]
[app.main.ui.components.select :refer [select]] [app.main.ui.components.select :refer [select]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.ds.layout.tab-switcher :refer [tab-switcher*]] [app.main.ui.ds.layout.tab-switcher :refer [tab-switcher*]]
[app.main.ui.hooks :as hooks] [app.main.ui.hooks :as hooks]
@ -415,24 +416,25 @@
:on-change handle-change-mode}]]) :on-change handle-change-mode}]])
(when (and (= origin :sidebar) show-tokens? token-color) (when (and (= origin :sidebar) show-tokens? token-color)
[:& radio-buttons {:selected color-style [:> radio-buttons* {:selected color-style
:on-change toggle-token-color :on-change toggle-token-color
:name "color-style"} :name "color-style"
[:& radio-button {:icon i/swatches :options [{:id "swap-opt-list"
:value :direct-color :icon i/swatches
:title (tr "labels.color") :label (tr "labels.color")
:id "opt-color"}] :value :direct-color}
[:& radio-button {:icon i/tokens {:id "swap-opt-grid"
:value :token-color :icon i/tokens
:title (tr "workspace.colorpicker.color-tokens") :label (tr "workspace.colorpicker.color-tokens")
:id "opt-token-color"}]])] :value :token-color}]}])]
(when (and (not= selected-mode :image) (when (and (not= selected-mode :image)
(= color-style :direct-color)) (= color-style :direct-color))
[:button {:class (stl/css-case :picker-btn true [:> icon-button* {:variant "ghost"
:selected picking-color?) :aria-label (tr "workspace.colorpicker.get-color")
:on-click handle-click-picker} :aria-pressed picking-color?
deprecated-icon/picker]) :on-click handle-click-picker
:icon i/picker}])
(when (= color-style :token-color) (when (= color-style :token-color)
[:div {:class (stl/css :token-color-title)} [:div {:class (stl/css :token-color-title)}
@ -483,8 +485,7 @@
:aria-label (tr "media.choose-image") :aria-label (tr "media.choose-image")
:on-click on-fill-image-click} :on-click on-fill-image-click}
(tr "media.choose-image") (tr "media.choose-image")
[:& file-uploader [:> file-uploader* {:input-id "fill-image-upload"
{:input-id "fill-image-upload"
:accept "image/jpeg,image/png" :accept "image/jpeg,image/png"
:multi false :multi false
:ref fill-image-ref :ref fill-image-ref

View File

@ -46,52 +46,6 @@
width: px2rem(68); width: px2rem(68);
} }
// TODO: change to DS button component
.picker-btn {
display: flex;
justify-content: center;
align-items: center;
border: none;
background: none;
cursor: pointer;
border-radius: $br-8;
background-color: transparent;
border: $b-1 solid transparent;
height: var(--sp-xl);
width: var(--sp-xl);
border-radius: $br-4;
padding: 0;
margin-top: var(--sp-xs);
svg {
@extend .button-icon;
stroke: var(--button-tertiary-foreground-color-rest);
}
&:hover {
svg {
stroke: var(--button-tertiary-foreground-color-focus);
}
}
&:focus,
&:focus-visible {
outline: none;
svg {
stroke: var(--button-secondary-foreground-color-hover);
}
}
&:active {
outline: none;
border: $b-1 solid transparent;
svg {
stroke: var(--button-tertiary-foreground-color-active);
}
}
&.selected {
svg {
stroke: var(--button-tertiary-foreground-color-active);
}
}
}
.gradient-buttons { .gradient-buttons {
display: flex; display: flex;
align-items: center; align-items: center;

View File

@ -30,6 +30,7 @@
[app.main.ui.components.search-bar :refer [search-bar*]] [app.main.ui.components.search-bar :refer [search-bar*]]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.context :as ctx] [app.main.ui.context :as ctx]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.ds.layout.tab-switcher :refer [tab-switcher*]] [app.main.ui.ds.layout.tab-switcher :refer [tab-switcher*]]
@ -44,12 +45,6 @@
[cuerdas.core :as str] [cuerdas.core :as str]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(def ^:private close-icon
(deprecated-icon/icon-xref :close (stl/css :close-icon)))
(def ^:private add-icon
(deprecated-icon/icon-xref :add (stl/css :add-icon)))
(defn- get-library-summary (defn- get-library-summary
"Given a library data return a summary representation of this library" "Given a library data return a summary representation of this library"
[data] [data]
@ -168,12 +163,10 @@
[:div {:class (stl/css :sample-library-item) [:div {:class (stl/css :sample-library-item)
:key (dm/str id)} :key (dm/str id)}
[:div {:class (stl/css :sample-library-item-name)} (:name library)] [:div {:class (stl/css :sample-library-item-name)} (:name library)]
[:input {:class (stl/css-case :sample-library-button true [:> button* {:variant "secondary"
:sample-library-add (nil? importing?) :on-click import-library
:sample-library-adding (some? importing?)) :disabled (some? importing?)}
:type "button" (if (= importing? id) (tr "labels.adding") (tr "labels.add"))]]))
:value (if (= importing? id) (tr "labels.adding") (tr "labels.add"))
:on-click import-library}]]))
(defn- empty-library? (defn- empty-library?
"Check if currentt library summary has elements or not" "Check if currentt library summary has elements or not"
@ -322,14 +315,12 @@
[:> library-description* {:summary summary}]]] [:> library-description* {:summary summary}]]]
(if ^boolean is-shared (if ^boolean is-shared
[:input {:class (stl/css :item-unpublish) [:> button* {:variant "secondary"
:type "button" :on-click unpublish}
:value (tr "common.unpublish") (tr "common.unpublish")]
:on-click unpublish}] [:> button* {:variant "primary"
[:input {:class (stl/css :item-publish) :on-click publish}
:type "button" (tr "common.publish")])]
:value (tr "common.publish")
:on-click publish}])]
(for [{:keys [id name data connected-to connected-to-names] :as library} linked-libraries] (for [{:keys [id name data connected-to connected-to-names] :as library} linked-libraries]
(let [disabled? (some #(contains? linked-libraries-ids %) connected-to)] (let [disabled? (some #(contains? linked-libraries-ids %) connected-to)]
@ -377,12 +368,11 @@
(let [summary (-> (:library-summary library) (let [summary (-> (:library-summary library)
(adapt-backend-summary))] (adapt-backend-summary))]
[:> library-description* {:summary summary}])]] [:> library-description* {:summary summary}])]]
[:> icon-button* {:variant "secondary"
[:button {:class (stl/css :item-button-shared) :aria-label (tr "workspace.libraries.shared-library-btn")
:icon i/add
:data-library-id (dm/str id) :data-library-id (dm/str id)
:title (tr "workspace.libraries.shared-library-btn") :on-click link-library}]])]
:on-click link-library}
add-icon]])]
(when (empty? shared-libraries) (when (empty? shared-libraries)
[:div {:class (stl/css :section-list-empty)} [:div {:class (stl/css :section-list-empty)}
@ -647,11 +637,13 @@
:on-click close-dialog-outside :on-click close-dialog-outside
:data-testid "libraries-modal"} :data-testid "libraries-modal"}
[:div {:class (stl/css :modal-dialog)} [:div {:class (stl/css :modal-dialog)}
[:button {:class (stl/css :close-btn) [:> icon-button* {:variant "ghost"
:on-click close-dialog :class (stl/css :close-btn)
:icon i/close
:aria-label (tr "labels.close") :aria-label (tr "labels.close")
:data-testid "close-libraries"} :data-testid "close-libraries"
close-icon] :on-click close-dialog}]
[:div {:class (stl/css :modal-title)} [:div {:class (stl/css :modal-title)}
(tr "workspace.libraries.libraries")] (tr "workspace.libraries.libraries")]

View File

@ -33,7 +33,7 @@
background-color: var(--modal-background-color); background-color: var(--modal-background-color);
border: $b-2 solid var(--modal-border-color); border: $b-2 solid var(--modal-border-color);
display: grid; display: grid;
grid-template-rows: auto 1fr; grid-template-rows: 0 auto 1fr;
min-width: $sz-364; min-width: $sz-364;
min-height: $sz-192; min-height: $sz-192;
height: $sz-520; height: $sz-520;
@ -42,21 +42,10 @@
max-width: $sz-712; max-width: $sz-712;
} }
// TODO: Remove this extended creating modal component
.close-btn { .close-btn {
@extend .modal-close-btn-base; position: absolute;
} top: var(--sp-s);
right: var(--sp-s);
.close-icon {
display: flex;
justify-content: center;
align-items: center;
height: $sz-16;
width: $sz-16;
color: transparent;
fill: none;
stroke-width: $b-1;
stroke: var(--icon-foreground);
} }
.modal-title { .modal-title {
@ -120,46 +109,6 @@
height: fit-content; height: fit-content;
} }
.item-publish,
.item-unpublish {
// TODO: remove this extended by using DS button component
@extend .button-primary;
@include t.use-typography("headline-small");
height: $sz-32;
min-width: px2rem(92);
padding: var(--sp-s) var(--sp-xxl);
margin: 0;
border-radius: $br-8;
}
.item-unpublish {
// TODO: remove this extended by using DS button component
@extend .button-secondary;
}
.item-button,
.item-button-shared {
// TODO: remove this extended by using DS button component
@extend .button-secondary;
height: $sz-32;
width: $sz-32;
margin-inline-start: var(--sp-xxs);
padding: var(--sp-s);
}
.detach-icon,
.add-icon {
display: flex;
justify-content: center;
align-items: center;
height: $sz-16;
width: $sz-16;
color: transparent;
fill: none;
stroke-width: $b-1;
stroke: var(--icon-foreground);
}
.section-list-shared { .section-list-shared {
max-height: px2rem(272); max-height: px2rem(272);
} }
@ -170,26 +119,6 @@
color: var(--title-foreground-color); color: var(--title-foreground-color);
} }
.search-icon {
display: flex;
justify-content: center;
align-items: center;
width: px2rem(20);
padding: 0 0 0 var(--sp-s);
svg {
display: flex;
justify-content: center;
align-items: center;
color: transparent;
fill: none;
height: px2rem(12);
width: px2rem(12);
stroke-width: 1.33px;
stroke: var(--icon-foreground);
}
}
// empty state // empty state
.section-list-empty { .section-list-empty {
display: grid; display: grid;
@ -428,24 +357,3 @@
text-overflow: ellipsis; text-overflow: ellipsis;
max-width: px2rem(232); max-width: px2rem(232);
} }
// TODO: Remove this extended using a DS component
.sample-library-add {
@extend .button-secondary;
}
// TODO: Remove this extended using a DS component
.sample-library-adding {
@extend .button-disabled;
}
.sample-library-button {
@include t.use-typography("headline-small");
height: $sz-32;
width: px2rem(80);
margin: 0;
border-radius: $br-8;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}

View File

@ -853,8 +853,9 @@
[:* [:*
[:> icon-button* {:variant "ghost" [:> icon-button* {:variant "ghost"
:aria-pressed show-menu?
:aria-label (tr "shortcut-subsection.main-menu") :aria-label (tr "shortcut-subsection.main-menu")
:on-click open-menu :on-click (if show-menu? close-all-menus open-menu)
:icon i/menu}] :icon i/menu}]
[:> dropdown-menu* {:show show-menu? [:> dropdown-menu* {:show show-menu?

View File

@ -18,9 +18,10 @@
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.context :as ctx] [app.main.ui.context :as ctx]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.hooks :as h] [app.main.ui.hooks :as h]
[app.main.ui.hooks.resize :as r] [app.main.ui.hooks.resize :as r]
[app.main.ui.icons :as deprecated-icon]
[app.main.ui.workspace.color-palette :refer [color-palette*]] [app.main.ui.workspace.color-palette :refer [color-palette*]]
[app.main.ui.workspace.color-palette-ctx-menu :refer [color-palette-ctx-menu*]] [app.main.ui.workspace.color-palette-ctx-menu :refer [color-palette-ctx-menu*]]
[app.main.ui.workspace.text-palette :refer [text-palette]] [app.main.ui.workspace.text-palette :refer [text-palette]]
@ -178,27 +179,27 @@
[:ul {:class (dm/str size-classname " " (stl/css-case :palette-btn-list true [:ul {:class (dm/str size-classname " " (stl/css-case :palette-btn-list true
:hidden-bts hide-palettes?))} :hidden-bts hide-palettes?))}
[:li {:class (stl/css :palette-item)} [:li {:class (stl/css :palette-item)}
[:button {:title (tr "workspace.toolbar.color-palette" (sc/get-tooltip :toggle-colorpalette)) [:> icon-button* {:variant "ghost"
:aria-pressed (some? color-palette?)
:aria-label (tr "workspace.toolbar.color-palette" (sc/get-tooltip :toggle-colorpalette)) :aria-label (tr "workspace.toolbar.color-palette" (sc/get-tooltip :toggle-colorpalette))
:class (stl/css-case :palette-btn true :on-click on-select-color-palette
:selected color-palette?) :icon i/drop}]]
:on-click on-select-color-palette}
deprecated-icon/drop-icon]]
[:li {:class (stl/css :palette-item)} [:li {:class (stl/css :palette-item)}
[:button {:title (tr "workspace.toolbar.text-palette" (sc/get-tooltip :toggle-textpalette)) [:> icon-button* {:variant "ghost"
:aria-pressed (some? text-palette?)
:aria-label (tr "workspace.toolbar.text-palette" (sc/get-tooltip :toggle-textpalette)) :aria-label (tr "workspace.toolbar.text-palette" (sc/get-tooltip :toggle-textpalette))
:class (stl/css-case :palette-btn true :on-click on-select-text-palette
:selected text-palette?) :icon i/text-palette}]]]
:on-click on-select-text-palette}
deprecated-icon/text-palette]]]
(if any-palette? (if any-palette?
[:* [:*
[:button {:class (stl/css :palette-actions) [:div {:class (stl/css :menu-btn)}
:on-click #(swap! state* update :show-menu not)} [:> icon-button* {:variant "ghost"
deprecated-icon/menu] :aria-pressed show-menu?
:aria-label (tr "labels.options")
:on-click #(swap! state* update :show-menu not)
:icon i/menu}]]
[:div {:class (stl/css :palette) [:div {:class (stl/css :palette)
:ref container} :ref container}
(when text-palette? (when text-palette?

View File

@ -49,7 +49,6 @@
&.wide { &.wide {
width: 100%; width: 100%;
} }
.resize-area { .resize-area {
grid-area: resize; grid-area: resize;
height: deprecated.$s-8; height: deprecated.$s-8;
@ -72,49 +71,22 @@
&.small-palette { &.small-palette {
display: flex; display: flex;
} }
.palette-item {
@include deprecated.flexCenter;
border-radius: deprecated.$br-8;
opacity: deprecated.$op-10;
transition: opacity 1s ease;
.palette-btn {
@extend .button-tertiary;
height: deprecated.$s-32;
width: deprecated.$s-32;
border-radius: deprecated.$br-8;
background-clip: padding-box;
padding: 0;
svg {
@extend .button-icon-small;
stroke: var(--icon-foreground);
}
&.selected {
@extend .button-icon-selected;
}
}
}
}
.palette-actions {
@extend .button-tertiary;
grid-area: actions;
height: calc(var(--height) - deprecated.$s-16);
width: deprecated.$s-32;
padding: 0;
margin-left: deprecated.$s-4;
border-radius: deprecated.$br-8;
background-color: var(--palette-background-color);
z-index: deprecated.$z-index-2;
svg {
@extend .button-icon;
stroke: var(--icon-foreground);
}
} }
.palette { .palette {
grid-area: palette; grid-area: palette;
width: 100%; width: 100%;
min-width: 0; min-width: 0;
} }
.palette-item {
display: flex;
align-items: center;
}
}
.menu-btn {
display: flex;
align-items: center;
margin-left: var(--sp-s);
} }
.handler { .handler {

View File

@ -29,7 +29,7 @@
:style {:background-color color} :style {:background-color color}
:src (cfg/resolve-profile-photo-url profile)}]])) :src (cfg/resolve-profile-photo-url profile)}]]))
(mf/defc active-sessions (mf/defc active-sessions*
{::mf/memo true} {::mf/memo true}
[] []
(let [profiles (mf/deref refs/profiles) (let [profiles (mf/deref refs/profiles)

View File

@ -20,23 +20,19 @@
[app.main.ui.components.dropdown :refer [dropdown]] [app.main.ui.components.dropdown :refer [dropdown]]
[app.main.ui.context :as ctx] [app.main.ui.context :as ctx]
[app.main.ui.dashboard.team] [app.main.ui.dashboard.team]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.exports.assets :refer [progress-widget]] [app.main.ui.exports.assets :refer [progress-widget*]]
[app.main.ui.formats :as fmt] [app.main.ui.formats :as fmt]
[app.main.ui.icons :as deprecated-icon] [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]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[okulary.core :as l]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(def ref:persistence-status
(l/derived :status refs/persistence))
;; --- Zoom Widget ;; --- Zoom Widget
(mf/defc zoom-widget-workspace (mf/defc zoom-widget-workspace*
{::mf/wrap [mf/memo] {::mf/wrap [mf/memo]
::mf/wrap-props false} ::mf/wrap-props false}
[{:keys [zoom on-increase on-decrease on-zoom-reset on-zoom-fit on-zoom-selected]}] [{:keys [zoom on-increase on-decrease on-zoom-reset on-zoom-fit on-zoom-selected]}]
@ -72,11 +68,12 @@
zoom (fmt/format-percent zoom {:precision 0})] zoom (fmt/format-percent zoom {:precision 0})]
[:* [:*
[:div {:on-click open-dropdown [:div {:on-click (if open? close-dropdown open-dropdown)
:class (stl/css-case :zoom-widget true :class (stl/css-case :zoom-widget true
:selected open?) :selected open?)
:title (tr "workspace.header.zoom")} :title (tr "workspace.header.zoom")}
[:span {:class (stl/css :label)} zoom]] [:span {:class (stl/css :label)} zoom]]
[:& dropdown {:show open? :on-close close-dropdown} [:& dropdown {:show open? :on-close close-dropdown}
[:ul {:class (stl/css :dropdown)} [:ul {:class (stl/css :dropdown)}
[:li {:class (stl/css :basic-zoom-bar)} [:li {:class (stl/css :basic-zoom-bar)}
@ -90,9 +87,10 @@
:aria-label (tr "shortcuts.increase-zoom") :aria-label (tr "shortcuts.increase-zoom")
:on-click on-increase :on-click on-increase
:icon i/add}]] :icon i/add}]]
[:button {:class (stl/css :reset-btn) [:> button* {:variant "ghost"
:on-click on-zoom-reset} :on-click on-zoom-reset}
(tr "workspace.header.reset-zoom")]] (tr "workspace.header.reset-zoom")]]
[:li {:class (stl/css :zoom-option) [:li {:class (stl/css :zoom-option)
:on-click on-zoom-fit} :on-click on-zoom-fit}
(tr "workspace.header.zoom-fit-all") (tr "workspace.header.zoom-fit-all")
@ -100,6 +98,7 @@
(for [sc (scd/split-sc (sc/get-tooltip :fit-all))] (for [sc (scd/split-sc (sc/get-tooltip :fit-all))]
[:span {:class (stl/css :shortcut-key) [:span {:class (stl/css :shortcut-key)
:key (str "zoom-fit-" sc)} sc])]] :key (str "zoom-fit-" sc)} sc])]]
[:li {:class (stl/css :zoom-option) [:li {:class (stl/css :zoom-option)
:on-click on-zoom-selected} :on-click on-zoom-selected}
(tr "workspace.header.zoom-selected") (tr "workspace.header.zoom-selected")
@ -198,51 +197,43 @@
[:div {:class (stl/css :workspace-header-right)} [:div {:class (stl/css :workspace-header-right)}
[:div {:class (stl/css :users-section)} [:div {:class (stl/css :users-section)}
[:& active-sessions]] [:> active-sessions*]]
[:& progress-widget] [:> progress-widget*]
[:div {:class (stl/css :separator)}] [:div {:class (stl/css :separator)}]
[:div {:class (stl/css :zoom-section)} [:div {:class (stl/css :zoom-section)}
[:& zoom-widget-workspace [:> zoom-widget-workspace* {:zoom zoom
{:zoom zoom
:on-increase on-increase :on-increase on-increase
:on-decrease on-decrease :on-decrease on-decrease
:on-zoom-reset on-zoom-reset :on-zoom-reset on-zoom-reset
:on-zoom-fit on-zoom-fit :on-zoom-fit on-zoom-fit
:on-zoom-selected on-zoom-selected}]] :on-zoom-selected on-zoom-selected}]]
[:div {:class (stl/css :comments-section)} [:div {:class (stl/css :comments-button-wrapper)}
[:button {:title (tr "workspace.toolbar.comments" (sc/get-tooltip :add-comment)) [:> icon-button* {:variant "ghost"
:aria-pressed (= selected-drawtool :comments)
:aria-label (tr "workspace.toolbar.comments" (sc/get-tooltip :add-comment)) :aria-label (tr "workspace.toolbar.comments" (sc/get-tooltip :add-comment))
:class (stl/css-case :comments-btn true
:selected (= selected-drawtool :comments))
:on-click toggle-comments :on-click toggle-comments
:data-tool "comments" :icon i/comments}]
:style {:position "relative"}}
deprecated-icon/comments
(when ^boolean has-unread-comments? (when ^boolean has-unread-comments?
[:div {:class (stl/css :unread)}])]] [:div {:class (stl/css :unread)}])]
(when-not ^boolean read-only? (when-not ^boolean read-only?
[:div {:class (stl/css :history-section)} [:> icon-button* {:variant "ghost"
[:button :aria-pressed (contains? layout :document-history)
{:title (tr "workspace.sidebar.history")
:aria-label (tr "workspace.sidebar.history") :aria-label (tr "workspace.sidebar.history")
:class (stl/css-case :selected (contains? layout :document-history) :on-click toggle-history
:history-button true) :icon i/history}])
:on-click toggle-history}
deprecated-icon/history]])
(when display-share-button? (when display-share-button?
[:a {:class (stl/css :viewer-btn) [:> icon-button* {:variant "ghost"
:title (tr "workspace.header.share") :aria-label (tr "workspace.header.share")
:on-click open-share-dialog} :on-click open-share-dialog
deprecated-icon/share]) :icon i/to-corner}])
[:a {:class (stl/css :viewer-btn)
:title (tr "workspace.header.viewer" (sc/get-tooltip :open-viewer))
:on-click nav-to-viewer}
deprecated-icon/play]]))
[:> icon-button* {:variant "ghost"
:aria-label (tr "workspace.header.viewer" (sc/get-tooltip :open-viewer))
:on-click nav-to-viewer
:icon i/play}]]))

View File

@ -11,8 +11,8 @@
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
min-width: deprecated.$s-256; min-width: deprecated.$s-256;
padding: deprecated.$s-8; padding: deprecated.$s-8 deprecated.$s-12;
gap: deprecated.$s-8; gap: deprecated.$s-4;
background-color: var(--panel-background-color); background-color: var(--panel-background-color);
} }
@ -28,19 +28,14 @@
} }
.zoom-widget { .zoom-widget {
@include deprecated.buttonStyle;
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
height: deprecated.$s-28;
max-width: deprecated.$s-48;
width: deprecated.$s-48; width: deprecated.$s-48;
border-radius: deprecated.$br-8; height: deprecated.$s-32;
.label { .label {
@include deprecated.bodySmallTypography; @include deprecated.bodySmallTypography;
height: 100%;
padding: deprecated.$s-8 0;
color: var(--button-tertiary-foreground-color-rest); color: var(--button-tertiary-foreground-color-rest);
} }
@ -84,13 +79,6 @@
color: var(--modal-title-foreground-color); color: var(--modal-title-foreground-color);
} }
.reset-btn {
@extend .button-tertiary;
color: var(--button-tertiary-foreground-color-hover);
height: deprecated.$s-28;
border-radius: deprecated.$br-8;
}
.zoom-option { .zoom-option {
@extend .menu-item-base; @extend .menu-item-base;
@ -113,127 +101,11 @@
} }
} }
.comments-btn { .comments-button-wrapper {
@extend .button-tertiary; position: relative;
border-radius: deprecated.$br-8;
margin: 0;
height: deprecated.$s-28;
width: deprecated.$s-28;
border: none;
svg {
@extend .button-icon;
stroke: var(--icon-foreground);
height: deprecated.$s-16;
width: deprecated.$s-16;
}
&:hover {
background-color: transparent;
border: none;
}
&.selected {
background-color: var(--button-tertiary-background-color-selected);
svg {
stroke: var(--button-tertiary-foreground-color-active);
}
}
} }
.history-button { .comments-button-unread {
@extend .button-tertiary;
border-radius: deprecated.$br-8;
margin: 0;
height: deprecated.$s-28;
width: deprecated.$s-28;
border: none;
svg {
@extend .button-icon;
stroke: var(--icon-foreground);
height: deprecated.$s-16;
width: deprecated.$s-16;
}
&:hover {
background-color: transparent;
border: none;
}
&.selected {
background-color: var(--button-tertiary-background-color-selected);
svg {
stroke: var(--button-tertiary-foreground-color-active);
}
}
}
.persistence-status-widget {
@include deprecated.flexCenter;
width: deprecated.$s-28;
height: deprecated.$s-28;
}
.status-icon {
@include deprecated.flexCenter;
width: deprecated.$s-24;
height: deprecated.$s-24;
margin: 0;
border-radius: deprecated.$br-circle;
svg {
@extend .button-icon;
stroke: var(--status-widget-icon-foreground-color);
}
}
.pending-status {
background-color: var(--status-widget-background-color-warning);
}
.saving-status {
background-color: var(--status-widget-background-color-pending);
svg {
animation: spin-animation 1s infinite;
animation-timing-function: linear;
}
}
.saved-status {
background-color: var(--status-widget-background-color-success);
}
.error-status {
background-color: var(--status-widget-background-color-error);
}
.share-btn,
.viewer-btn {
@extend .button-tertiary;
border-radius: deprecated.$br-8;
margin: 0;
width: deprecated.$s-28;
height: deprecated.$s-28;
border: none;
svg {
@extend .button-icon;
height: deprecated.$s-16;
width: deprecated.$s-16;
stroke: var(--icon-foreground);
}
&:hover {
background-color: transparent;
border: none;
}
}
.unread {
position: absolute; position: absolute;
width: 8px; width: 8px;
height: 8px; height: 8px;

View File

@ -17,8 +17,9 @@
[app.main.ui.components.context-menu-a11y :refer [context-menu*]] [app.main.ui.components.context-menu-a11y :refer [context-menu*]]
[app.main.ui.components.search-bar :refer [search-bar*]] [app.main.ui.components.search-bar :refer [search-bar*]]
[app.main.ui.context :as ctx] [app.main.ui.context :as ctx]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.workspace.sidebar.assets.common :as cmm] [app.main.ui.workspace.sidebar.assets.common :as cmm]
[app.main.ui.workspace.sidebar.assets.file-library :refer [file-library*]] [app.main.ui.workspace.sidebar.assets.file-library :refer [file-library*]]
[app.util.dom :as dom] [app.util.dom :as dom]
@ -165,30 +166,27 @@
[:div {:class (stl/css :assets-header)} [:div {:class (stl/css :assets-header)}
(when-not ^boolean read-only? (when-not ^boolean read-only?
(if (and (= num-libs 1) (empty? components)) (if (and (= num-libs 1) (empty? components))
[:button {:class (stl/css :add-library-button) [:> button* {:variant "primary"
:on-click show-libraries-dialog :on-click show-libraries-dialog
:data-testid "libraries"} :data-testid "libraries"}
(tr "workspace.assets.add-library")] (tr "workspace.assets.add-library")]
[:> button* {:variant "secondary"
[:button {:class (stl/css :libraries-button)
:on-click show-libraries-dialog :on-click show-libraries-dialog
:data-testid "libraries"} :data-testid "libraries"}
(tr "workspace.assets.manage-library")])) (tr "workspace.assets.manage-library")]))
[:div {:class (stl/css :search-wrapper)} [:div {:class (stl/css :search-wrapper)}
[:> search-bar* {:on-change on-search-term-change [:> search-bar* {:on-change on-search-term-change
:value term :value term
:placeholder (tr "workspace.assets.search")} :placeholder (tr "workspace.assets.search")}
[:button [:> icon-button* {:variant "secondary"
{:on-click on-open-menu :icon i/filter
:title (tr "workspace.assets.filter") :class (stl/css :filter-button)
:class (stl/css-case :section-button true :aria-pressed menu-open?
:opened menu-open?)} :aria-label (tr "workspace.assets.filter")
deprecated-icon/filter-icon]] :on-click on-open-menu}]]
[:> context-menu* [:> context-menu* {:on-close on-menu-close
{:on-close on-menu-close
:selectable true :selectable true
:selected section :selected section
:show menu-open? :show menu-open?

View File

@ -17,89 +17,14 @@
padding-top: deprecated.$s-8; padding-top: deprecated.$s-8;
} }
.libraries-button { .assets-header {
@extend .button-secondary; display: flex;
@include deprecated.uppercaseTitleTipography; flex-direction: column;
gap: deprecated.$s-2; gap: var(--sp-xxs);
height: deprecated.$s-32;
width: 100%;
margin-bottom: deprecated.$s-4;
border-radius: deprecated.$s-8;
&:hover {
background-color: var(--button-secondary-background-color-hover);
color: var(--button-secondary-foreground-color-hover);
border: deprecated.$s-1 solid var(--button-secondary-border-color-hover);
}
&:focus {
background-color: var(--button-secondary-background-color-focus);
color: var(--button-secondary-foreground-color-focus);
border: deprecated.$s-1 solid var(--button-secondary-border-color-focus);
}
} }
.add-library-button { .filter-button {
@extend .button-primary; border-radius: deprecated.$br-8 0 0 deprecated.$br-8;
@include deprecated.uppercaseTitleTipography;
gap: deprecated.$s-2;
height: deprecated.$s-32;
width: 100%;
margin-bottom: deprecated.$s-4;
border-radius: deprecated.$s-8;
}
.section-button {
@include deprecated.flexCenter;
@include deprecated.buttonStyle;
height: deprecated.$s-32;
width: deprecated.$s-32;
margin: 0;
border: deprecated.$s-1 solid var(--input-border-color-rest);
border-radius: deprecated.$br-8 deprecated.$br-2 deprecated.$br-2 deprecated.$br-8;
background-color: var(--input-background-color-rest);
svg {
height: deprecated.$s-16;
width: deprecated.$s-16;
stroke: var(--icon-foreground);
}
&:focus {
border: deprecated.$s-1 solid var(--input-border-color-focus);
outline: 0;
background-color: var(--input-background-color-focus);
color: var(--input-foreground-color-focus);
svg {
background-color: var(--input-background-color-focus);
}
}
&:hover {
border: deprecated.$s-1 solid var(--input-border-color-hover);
background-color: var(--input-background-color-hover);
svg {
background-color: var(--input-background-color-hover);
stroke: var(--button-foreground-hover);
}
&:focus {
border: deprecated.$s-1 solid var(--input-border-color-focus);
outline: 0;
background-color: var(--input-background-color-focus);
color: var(--input-foreground-color-focus);
svg {
background-color: var(--input-background-color-focus);
}
}
}
&.opened {
@extend .button-icon-selected;
}
} }
.sections-container { .sections-container {
@ -125,10 +50,6 @@
border-radius: deprecated.$br-8; border-radius: deprecated.$br-8;
} }
.section-btn {
@include deprecated.buttonStyle;
}
.assets-header { .assets-header {
padding: 0 0 deprecated.$s-24 deprecated.$s-12; padding: 0 0 deprecated.$s-24 deprecated.$s-12;
} }

View File

@ -22,10 +22,10 @@
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.editable-label :refer [editable-label*]] [app.main.ui.components.editable-label :refer [editable-label*]]
[app.main.ui.components.file-uploader :refer [file-uploader]] [app.main.ui.components.file-uploader :refer [file-uploader*]]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.context :as ctx] [app.main.ui.context :as ctx]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :refer [icon*] :as i] [app.main.ui.ds.foundations.assets.icon :refer [icon*] :as i]
[app.main.ui.hooks :as h] [app.main.ui.hooks :as h]
[app.main.ui.workspace.sidebar.assets.common :as cmm] [app.main.ui.workspace.sidebar.assets.common :as cmm]
@ -563,24 +563,24 @@
[:> cmm/asset-section-block* {:role :title-button} [:> cmm/asset-section-block* {:role :title-button}
(when ^boolean is-open (when ^boolean is-open
[:div [:div
[:& radio-buttons {:selected (if is-listing-thumbs "grid" "list") [:> radio-buttons* {:selected (if is-listing-thumbs "grid" "list")
:on-change toggle-list-style :on-change toggle-list-style
:name "listing-style"} :name "listing-style"
[:& radio-button {:icon i/view-as-list :options [{:id "opt-list"
:value "list" :icon i/view-as-list
:title (tr "workspace.assets.list-view") :label (tr "workspace.assets.list-view")
:id "opt-list"}] :value "list"}
[:& radio-button {:icon i/flex-grid {:id "opt-grid"
:value "grid" :icon i/flex-grid
:title (tr "workspace.assets.grid-view") :label (tr "workspace.assets.grid-view")
:id "opt-grid"}]]]) :value "grid"}]}]])
(when (and (not read-only?) is-local) (when (and (not read-only?) is-local)
[:> icon-button* {:variant "ghost" [:> icon-button* {:variant "ghost"
:aria-label (tr "workspace.assets.components.add-component") :aria-label (tr "workspace.assets.components.add-component")
:on-click add-component :on-click add-component
:icon i/add} :icon i/add}
[:& file-uploader {:accept dwm/accept-image-types [:> file-uploader* {:accept dwm/accept-image-types
:multi true :multi true
:ref input-ref :ref input-ref
:on-selected on-file-selected}]])] :on-selected on-file-selected}]])]

View File

@ -23,7 +23,7 @@
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.workspace.sidebar.assets.common :as cmm] [app.main.ui.workspace.sidebar.assets.common :as cmm]
[app.main.ui.workspace.sidebar.assets.groups :as grp] [app.main.ui.workspace.sidebar.assets.groups :as grp]
[app.main.ui.workspace.sidebar.options.menus.typography :refer [typography-entry]] [app.main.ui.workspace.sidebar.options.menus.typography :refer [typography-entry*]]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[cuerdas.core :as str] [cuerdas.core :as str]
@ -113,8 +113,7 @@
:on-drag-over dom/prevent-default :on-drag-over dom/prevent-default
:on-drop on-drop} :on-drop on-drop}
[:& typography-entry [:> typography-entry* {:file-id file-id
{:file-id file-id
:typography typography :typography typography
:local? local? :local? local?
:selected? (contains? selected typography-id) :selected? (contains? selected typography-id)

View File

@ -291,13 +291,12 @@
:value current-search :value current-search
:on-clear clear-search-text :on-clear clear-search-text
:placeholder (tr "workspace.sidebar.layers.search")} :placeholder (tr "workspace.sidebar.layers.search")}
[:button {:on-click on-toggle-filters-click [:> icon-button* {:variant "secondary"
:class (stl/css-case :class (stl/css :filter-button)
:filter-button true :aria-pressed show-menu?
:opened show-menu? :aria-label (tr "workspace.sidebar.layers.filter")
:active active?)} :on-click on-toggle-filters-click
[:> icon* {:icon-id i/filter}]]] :icon i/filter}]]
[:> icon-button* {:variant "ghost" [:> icon-button* {:variant "ghost"
:aria-label (tr "labels.close") :aria-label (tr "labels.close")
:on-click toggle-search :on-click toggle-search

View File

@ -19,39 +19,7 @@
padding: 0 deprecated.$s-12 0 deprecated.$s-8; padding: 0 deprecated.$s-12 0 deprecated.$s-8;
gap: deprecated.$s-4; gap: deprecated.$s-4;
.filter-button { .filter-button {
@include deprecated.flexCenter; border-radius: deprecated.$br-8 0 0 deprecated.$br-8;
@include deprecated.buttonStyle;
height: deprecated.$s-32;
width: deprecated.$s-32;
margin: 0;
border: deprecated.$s-1 solid var(--color-background-tertiary);
border-radius: deprecated.$br-8 deprecated.$br-2 deprecated.$br-2 deprecated.$br-8;
background-color: var(--color-background-tertiary);
svg {
height: deprecated.$s-16;
width: deprecated.$s-16;
stroke: var(--icon-foreground);
}
&:focus {
border: deprecated.$s-1 solid var(--input-border-color-focus);
outline: 0;
background-color: var(--input-background-color-active);
color: var(--input-foreground-color-active);
svg {
background-color: var(--input-background-color-active);
}
}
&:hover {
border: deprecated.$s-1 solid var(--input-border-color-hover);
background-color: var(--input-background-color-hover);
svg {
background-color: var(--input-background-color-hover);
stroke: var(--button-foreground-hover);
}
}
&.opened {
@extend .button-icon-selected;
}
} }
} }
} }
@ -143,7 +111,7 @@
.filters-container { .filters-container {
@extend .menu-dropdown; @extend .menu-dropdown;
position: absolute; position: absolute;
left: deprecated.$s-20; left: deprecated.$s-16;
width: deprecated.$s-192; width: deprecated.$s-192;
.filter-menu-item { .filter-menu-item {
@include deprecated.bodySmallTypography; @include deprecated.bodySmallTypography;

View File

@ -12,7 +12,7 @@
[app.main.data.workspace.drawing :as dwd] [app.main.data.workspace.drawing :as dwd]
[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.components.radio-buttons :refer [radio-button radio-buttons]] [app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.util.dom :as dom] [app.util.dom :as dom]
@ -95,15 +95,15 @@
(when preset-match (when preset-match
[:span {:class (stl/css :check-icon)} deprecated-icon/tick])])))]]] [:span {:class (stl/css :check-icon)} deprecated-icon/tick])])))]]]
[:& radio-buttons {:selected (or (d/name orientation) "") [:> radio-buttons* {:class (stl/css :radio-buttons)
:selected (or (d/name orientation) "")
:on-change on-orientation-change :on-change on-orientation-change
:name "frame-orientation" :name "frame-orientation"
:wide true :options [{:id "size-vertical"
:class (stl/css :radio-buttons)} :icon i/size-vertical
[:& radio-button {:icon i/size-vertical :label (tr "workspace.options.orientation.vertical")
:value "vertical" :value "vertical"}
:id "size-vertical"}] {:id "size-horizontal"
[:& radio-button {:icon i/size-horizontal :icon i/size-horizontal
:value "horizontal" :label (tr "workspace.options.orientation.horizontal")
:id "size-horizontal"}]]])) :value "horizontal"}]}]]))

View File

@ -10,7 +10,8 @@
[app.main.data.workspace :as dw] [app.main.data.workspace :as dw]
[app.main.data.workspace.shortcuts :as sc] [app.main.data.workspace.shortcuts :as sc]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
@ -42,68 +43,59 @@
(when-not (and disabled-align disabled-distribute) (when-not (and disabled-align disabled-distribute)
[:div {:class (stl/css :align-options)} [:div {:class (stl/css :align-options)}
[:div {:class (stl/css :align-group-horizontal)} [:div {:class (stl/css :align-group-horizontal)}
[:button {:class (stl/css-case :align-button true [:> icon-button* {:variant "ghost"
:disabled disabled-align) :icon i/align-left
:disabled disabled-align :aria-label (tr "workspace.align.hleft" (sc/get-tooltip :align-left))
:title (tr "workspace.align.hleft" (sc/get-tooltip :align-left)) :on-click align-objects
:data-value "hleft" :data-value "hleft"
:on-click align-objects} :disabled disabled-align}]
deprecated-icon/align-left]
[:button {:class (stl/css-case :align-button true [:> icon-button* {:variant "ghost"
:disabled disabled-align) :icon i/align-horizontal-center
:disabled disabled-align :aria-label (tr "workspace.align.hcenter" (sc/get-tooltip :align-hcenter))
:title (tr "workspace.align.hcenter" (sc/get-tooltip :align-hcenter)) :on-click align-objects
:data-value "hcenter" :data-value "hcenter"
:on-click align-objects} :disabled disabled-align}]
deprecated-icon/align-horizontal-center]
[:button {:class (stl/css-case :align-button true [:> icon-button* {:variant "ghost"
:disabled disabled-align) :icon i/align-right
:disabled disabled-align :aria-label (tr "workspace.align.hright" (sc/get-tooltip :align-right))
:title (tr "workspace.align.hright" (sc/get-tooltip :align-right)) :on-click align-objects
:data-value "hright" :data-value "hright"
:on-click align-objects} :disabled disabled-align}]
deprecated-icon/align-right]
[:button {:class (stl/css-case :align-button true [:> icon-button* {:variant "ghost"
:disabled disabled-distribute) :icon i/distribute-horizontally
:disabled disabled-distribute :aria-label (tr "workspace.align.hdistribute" (sc/get-tooltip :h-distribute))
:title (tr "workspace.align.hdistribute" (sc/get-tooltip :h-distribute)) :on-click distribute-objects
:data-value "horizontal" :data-value "horizontal"
:on-click distribute-objects} :disabled disabled-distribute}]]
deprecated-icon/distribute-horizontally]]
[:div {:class (stl/css :align-group-vertical)} [:div {:class (stl/css :align-group-vertical)}
[:button {:class (stl/css-case :align-button true [:> icon-button* {:variant "ghost"
:disabled disabled-align) :icon i/align-top
:disabled disabled-align :aria-label (tr "workspace.align.vtop" (sc/get-tooltip :align-top))
:title (tr "workspace.align.vtop" (sc/get-tooltip :align-top)) :on-click align-objects
:data-value "vtop" :data-value "vtop"
:on-click align-objects} :disabled disabled-align}]
deprecated-icon/align-top]
[:button {:class (stl/css-case :align-button true [:> icon-button* {:variant "ghost"
:disabled disabled-align) :icon i/align-vertical-center
:disabled disabled-align :aria-label (tr "workspace.align.vcenter" (sc/get-tooltip :align-vcenter))
:title (tr "workspace.align.vcenter" (sc/get-tooltip :align-vcenter)) :on-click align-objects
:data-value "vcenter" :data-value "vcenter"
:on-click align-objects} :disabled disabled-align}]
deprecated-icon/align-vertical-center]
[:button {:class (stl/css-case :align-button true [:> icon-button* {:variant "ghost"
:disabled disabled-align) :icon i/align-bottom
:disabled disabled-align :aria-label (tr "workspace.align.vbottom" (sc/get-tooltip :align-bottom))
:title (tr "workspace.align.vbottom" (sc/get-tooltip :align-bottom)) :on-click align-objects
:data-value "vbottom" :data-value "vbottom"
:on-click align-objects} :disabled disabled-align}]
deprecated-icon/align-bottom]
[:button {:title (tr "workspace.align.vdistribute" (sc/get-tooltip :v-distribute)) [:> icon-button* {:variant "ghost"
:class (stl/css-case :align-button true :icon i/distribute-vertical-spacing
:disabled disabled-distribute) :aria-label (tr "workspace.align.vdistribute" (sc/get-tooltip :v-distribute))
:disabled disabled-distribute :on-click distribute-objects
:data-value "vertical" :data-value "vertical"
:on-click distribute-objects} :disabled disabled-distribute}]]])))
deprecated-icon/distribute-vertical-spacing]]])))

View File

@ -4,12 +4,10 @@
// //
// Copyright (c) KALEIDOS INC // Copyright (c) KALEIDOS INC
@use "refactor/common-refactor.scss" as deprecated;
@use "../../../sidebar/common/sidebar.scss" as sidebar; @use "../../../sidebar/common/sidebar.scss" as sidebar;
.align-options { .align-options {
@include sidebar.option-grid-structure; @include sidebar.option-grid-structure;
height: deprecated.$s-32;
} }
.align-group-horizontal, .align-group-horizontal,
.align-group-vertical { .align-group-vertical {
@ -26,27 +24,3 @@
.align-group-vertical { .align-group-vertical {
grid-column: 5 / span 4; grid-column: 5 / span 4;
} }
.align-button {
@extend .button-tertiary;
height: deprecated.$s-32;
width: deprecated.$s-32;
padding: 0;
border-radius: deprecated.$br-8;
svg {
@extend .button-icon;
stroke: var(--icon-foreground);
}
&.disabled {
cursor: default;
svg {
stroke: var(--button-foreground-color-disabled);
}
&:hover {
background-color: var(--panel-background-color);
svg {
stroke: var(--button-foreground-color-disabled);
}
}
}
}

View File

@ -15,7 +15,6 @@
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.icons :as deprecated-icon]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
@ -103,10 +102,12 @@
[:div {:class (stl/css-case :first-row true [:div {:class (stl/css-case :first-row true
:hidden hidden?)} :hidden hidden?)}
[:div {:class (stl/css :blur-info)} [:div {:class (stl/css :blur-info)}
[:button {:class (stl/css-case :show-more true [:> icon-button* {:variant "secondary"
:selected more-options?) :class (stl/css :show-more)
:on-click toggle-more-options} :aria-label (tr "labels.options")
deprecated-icon/menu] :aria-pressed more-options?
:on-click toggle-more-options
:icon i/menu}]
[:span {:class (stl/css :label)} [:span {:class (stl/css :label)}
(tr "workspace.options.blur-options.title")]] (tr "workspace.options.blur-options.title")]]
[:div {:class (stl/css :actions)} [:div {:class (stl/css :actions)}

View File

@ -37,21 +37,7 @@
border-radius: deprecated.$br-8; border-radius: deprecated.$br-8;
background-color: var(--input-details-color); background-color: var(--input-details-color);
.show-more { .show-more {
@extend .button-secondary;
height: deprecated.$s-32;
width: deprecated.$s-28;
border-radius: deprecated.$br-8 0 0 deprecated.$br-8; border-radius: deprecated.$br-8 0 0 deprecated.$br-8;
box-sizing: border-box;
border: deprecated.$s-1 solid var(--button-secondary-background-color-rest);
svg {
@extend .button-icon;
}
&.selected {
background-color: var(--button-radio-background-color-active);
svg {
stroke: var(--button-radio-foreground-color-active);
}
}
} }
.label { .label {
@include deprecated.bodySmallTypography; @include deprecated.bodySmallTypography;

View File

@ -15,15 +15,12 @@
[app.main.data.workspace.shortcuts :as sc] [app.main.data.workspace.shortcuts :as sc]
[app.main.features :as features] [app.main.features :as features]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.icons :as deprecated-icon]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(def ^:private flatten-icon
(deprecated-icon/icon-xref :boolean-flatten (stl/css :flatten-icon)))
(mf/defc bool-options* (mf/defc bool-options*
[{:keys [total-selected shapes shapes-with-children]}] [{:keys [total-selected shapes shapes-with-children]}]
(let [head (first shapes) (let [head (first shapes)
@ -70,41 +67,40 @@
(st/emit! (dwb/change-bool-type head-id bool-type))))))) (st/emit! (dwb/change-bool-type head-id bool-type)))))))
flatten-objects flatten-objects
(mf/use-fn #(st/emit! (dwps/convert-selected-to-path)))] (mf/use-fn
#(st/emit! (dwps/convert-selected-to-path)))]
(when (not (and disabled-bool-btns disabled-flatten)) (when (not (and disabled-bool-btns disabled-flatten))
[:div {:class (stl/css :boolean-options)} [:div {:class (stl/css :boolean-options)}
[:div {:class (stl/css :bool-group)} [:div {:class (stl/css :boolean-group)}
[:& radio-buttons {:selected (d/name head-bool-type) [:> radio-buttons* {:class (stl/css :boolean-radio-btn)
:class (stl/css :boolean-radio-btn) :variant "ghost"
:selected (d/name head-bool-type)
:on-change on-change :on-change on-change
:name "bool-options"} :name "bool-options"
[:& radio-button {:icon i/boolean-union :options [{:id "bool-opt-union"
:icon i/boolean-union
:label (str (tr "workspace.shape.menu.union") " (" (sc/get-tooltip :bool-union) ")")
:value "union" :value "union"
:disabled disabled-bool-btns :disabled disabled-bool-btns}
:title (str (tr "workspace.shape.menu.union") " (" (sc/get-tooltip :bool-union) ")") {:id "bool-opt-differente"
:id "bool-opt-union"}] :icon i/boolean-difference
[:& radio-button {:icon i/boolean-difference :label (str (tr "workspace.shape.menu.difference") " (" (sc/get-tooltip :bool-difference) ")")
:value "difference" :value "difference"
:disabled disabled-bool-btns :disabled disabled-bool-btns}
:title (str (tr "workspace.shape.menu.difference") " (" (sc/get-tooltip :bool-difference) ")") {:id "bool-opt-intersection"
:id "bool-opt-differente"}] :icon i/boolean-intersection
[:& radio-button {:icon i/boolean-intersection :label (str (tr "workspace.shape.menu.intersection") " (" (sc/get-tooltip :bool-intersection) ")")
:value "intersection" :value "intersection"
:disabled disabled-bool-btns :disabled disabled-bool-btns}
:title (str (tr "workspace.shape.menu.intersection") " (" (sc/get-tooltip :bool-intersection) ")") {:id "bool-opt-exclude"
:id "bool-opt-intersection"}] :icon i/boolean-exclude
[:& radio-button {:icon i/boolean-exclude :label (str (tr "workspace.shape.menu.exclude") " (" (sc/get-tooltip :bool-exclude) ")")
:value "exclude" :value "exclude"
:disabled disabled-bool-btns :disabled disabled-bool-btns}]}]]
:title (str (tr "workspace.shape.menu.exclude") " (" (sc/get-tooltip :bool-exclude) ")")
:id "bool-opt-exclude"}]]]
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.shape.menu.flatten") :icon i/boolean-flatten
:class (stl/css-case :aria-label (tr "workspace.shape.menu.flatten")
:flatten-button true :on-click flatten-objects
:disabled disabled-flatten) :disabled disabled-flatten}]])))
:disabled disabled-flatten
:on-click flatten-objects}
flatten-icon]])))

View File

@ -4,45 +4,18 @@
// //
// Copyright (c) KALEIDOS INC // Copyright (c) KALEIDOS INC
@use "refactor/common-refactor.scss" as deprecated;
@use "../../../sidebar/common/sidebar.scss" as sidebar; @use "../../../sidebar/common/sidebar.scss" as sidebar;
.boolean-options { .boolean-options {
@include sidebar.option-grid-structure; @include sidebar.option-grid-structure;
height: var(--sp-xxxl);
} }
.bool-group { .boolean-group {
display: grid; display: grid;
grid-template-columns: subgrid; grid-template-columns: subgrid;
grid-column: 1 / span 4; grid-column: 1 / span 4;
} }
.flatten-button {
@extend .button-tertiary;
height: deprecated.$s-32;
width: deprecated.$s-32;
border-radius: deprecated.$br-8;
grid-column: 5 / span 1;
--flatten-icon-foreground-color: var(--icon-foreground);
&.disabled {
cursor: default;
--flatten-icon-foreground-color: var(--button-foreground-color-disabled);
&:hover {
background-color: var(--panel-background-color);
--flatten-icon-foreground-color: var(--button-foreground-color-disabled);
}
}
}
.flatten-icon {
@extend .button-icon;
stroke: var(--flatten-icon-foreground-color);
}
.boolean-radio-btn { .boolean-radio-btn {
background-color: transparent; background-color: transparent;
gap: var(--sp-xs);
} }

View File

@ -145,9 +145,9 @@
:on-change on-radius-r3-change :on-change on-radius-r3-change
:value (:r3 values)}]]]) :value (:r3 values)}]]])
[:> icon-button* {:class (stl/css-case :selected radius-expanded) [:> icon-button* {:variant "ghost"
:variant "ghost"
:on-click toggle-radius-mode :on-click toggle-radius-mode
:aria-pressed radius-expanded
:aria-label (if radius-expanded :aria-label (if radius-expanded
(tr "workspace.options.radius.hide-all-corners") (tr "workspace.options.radius.hide-all-corners")
(tr "workspace.options.radius.show-single-corners")) (tr "workspace.options.radius.show-single-corners"))

View File

@ -28,12 +28,6 @@
@include deprecated.bodySmallTypography; @include deprecated.bodySmallTypography;
} }
.selected {
border-color: var(--button-icon-border-color-selected);
background-color: var(--button-icon-background-color-selected);
color: var(--button-icon-foreground-color-selected);
}
.icon { .icon {
margin-inline: deprecated.$s-4; margin-inline: deprecated.$s-4;
} }

View File

@ -13,6 +13,7 @@
[app.main.data.workspace.tokens.application :as dwta] [app.main.data.workspace.tokens.application :as dwta]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.workspace.sidebar.options.rows.color-row :refer [color-row*]] [app.main.ui.workspace.sidebar.options.rows.color-row :refer [color-row*]]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
@ -217,7 +218,7 @@
:origin :color-selection :origin :color-selection
:on-close on-close}])) :on-close on-close}]))
(when (and (false? @expand-lib-color) (< 3 (count library-colors))) (when (and (false? @expand-lib-color) (< 3 (count library-colors)))
[:button {:class (stl/css :more-colors-btn) [:> button* {:variant "secondary"
:on-click #(reset! expand-lib-color true)} :on-click #(reset! expand-lib-color true)}
(tr "workspace.options.more-lib-colors")])] (tr "workspace.options.more-lib-colors")])]
@ -235,7 +236,7 @@
:on-close on-close}]) :on-close on-close}])
(when (and (false? @expand-color) (< 3 (count colors))) (when (and (false? @expand-color) (< 3 (count colors)))
[:button {:class (stl/css :more-colors-btn) [:> button* {:variant "secondary"
:on-click #(reset! expand-color true)} :on-click #(reset! expand-color true)}
(tr "workspace.options.more-colors")])] (tr "workspace.options.more-colors")])]
@ -259,6 +260,6 @@
(when (and (false? @expand-token-color) (when (and (false? @expand-token-color)
(< 3 (count token-colors))) (< 3 (count token-colors)))
[:button {:class (stl/css :more-colors-btn) [:> button* {:variant "secondary"
:on-click #(reset! expand-token-color true)} :on-click #(reset! expand-token-color true)}
(tr "workspace.options.more-token-colors")])]])])) (tr "workspace.options.more-token-colors")])]])]))

View File

@ -40,7 +40,5 @@
} }
.more-colors-btn { .more-colors-btn {
@extend .button-secondary; justify-content: center;
@include deprecated.uppercaseTitleTipography;
height: deprecated.$s-32;
} }

View File

@ -28,7 +28,6 @@
[app.main.refs :as refs] [app.main.refs :as refs]
[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.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.components.reorder-handler :refer [reorder-handler*]] [app.main.ui.components.reorder-handler :refer [reorder-handler*]]
[app.main.ui.components.search-bar :refer [search-bar*]] [app.main.ui.components.search-bar :refer [search-bar*]]
[app.main.ui.components.select :refer [select]] [app.main.ui.components.select :refer [select]]
@ -37,6 +36,7 @@
[app.main.ui.ds.buttons.button :refer [button*]] [app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.combobox :refer [combobox*]] [app.main.ui.ds.controls.combobox :refer [combobox*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.controls.select :refer [select*]] [app.main.ui.ds.controls.select :refer [select*]]
[app.main.ui.ds.controls.switch :refer [switch*]] [app.main.ui.ds.controls.switch :refer [switch*]]
[app.main.ui.ds.foundations.assets.icon :refer [icon*] :as i] [app.main.ui.ds.foundations.assets.icon :refer [icon*] :as i]
@ -794,15 +794,17 @@
[:div {:class (stl/css :swap-library)} [:div {:class (stl/css :swap-library)}
[:div {:class (stl/css :swap-library-title)} [:div {:class (stl/css :swap-library-title)}
[:div {:class (stl/css :swap-library-name)} current-lib-name] [:div {:class (stl/css :swap-library-name)} current-lib-name]
[:& radio-buttons {:selected (if (:listing-thumbs? filters) "grid" "list") [:> radio-buttons* {:selected (if (:listing-thumbs? filters) "grid" "list")
:on-change toggle-list-style :on-change toggle-list-style
:name "swap-listing-style"} :name "swap-listing-style"
[:& radio-button {:icon i/view-as-list :options [{:id "swap-opt-list"
:value "list" :icon i/view-as-list
:id "swap-opt-list"}] :label (tr "workspace.assets.list-view")
[:& radio-button {:icon i/flex-grid :value "list"}
:value "grid" {:id "swap-opt-grid"
:id "swap-opt-grid"}]]] :icon i/flex-grid
:label (tr "workspace.assets.grid-view")
:value "grid"}]}]]
(when-not (or search? (str/empty? (:path filters))) (when-not (or search? (str/empty? (:path filters)))
[:button {:class (stl/css :swap-library-back) [:button {:class (stl/css :swap-library-back)
@ -897,11 +899,13 @@
(when menu-entries? (when menu-entries?
[:div {:class (stl/css :pill-actions)} [:div {:class (stl/css :pill-actions)}
[:button {:class (stl/css-case :pill-actions-btn true [:> icon-button* {:variant "secondary"
:selected menu-open?) :class (stl/css-case :pill-actions-btn true
:on-click on-menu-click} :extended subtext)
[:> icon* {:icon-id i/menu}]] :aria-pressed menu-open?
:aria-label (tr "labels.options")
:on-click on-menu-click
:icon i/menu}]
[:& dropdown {:show menu-open? [:& dropdown {:show menu-open?
:on-close on-menu-close} :on-close on-menu-close}
[:ul {:class (stl/css-case :pill-actions-dropdown true [:ul {:class (stl/css-case :pill-actions-dropdown true

View File

@ -587,14 +587,9 @@
} }
.pill-actions-btn { .pill-actions-btn {
@extend .button-secondary;
cursor: unset;
block-size: 100%;
inline-size: 100%;
border-radius: 0 $br-8 $br-8 0; border-radius: 0 $br-8 $br-8 0;
&.extended {
&.selected { block-size: $sz-48;
@extend .button-icon-selected;
} }
} }

View File

@ -16,7 +16,7 @@
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.select :refer [select]] [app.main.ui.components.select :refer [select]]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.ds.controls.checkbox :refer [checkbox*]]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[cuerdas.core :as str] [cuerdas.core :as str]
@ -61,6 +61,7 @@
constraints-h (or (get values :constraints-h) (gsh/default-constraints-h values)) constraints-h (or (get values :constraints-h) (gsh/default-constraints-h values))
constraints-v (or (get values :constraints-v) (gsh/default-constraints-v values)) constraints-v (or (get values :constraints-v) (gsh/default-constraints-v values))
fixed-scroll? (d/nilv (:fixed-scroll values) false)
on-constraint-button-clicked on-constraint-button-clicked
(mf/use-fn (mf/use-fn
@ -218,16 +219,8 @@
:options options-v :options options-v
:on-change on-constraint-v-select-changed}]] :on-change on-constraint-v-select-changed}]]
(when first-level? (when first-level?
[:div {:class (stl/css :checkbox)} [:> checkbox* {:id "fixed-on-scroll"
:class (stl/css :checkbox)
[:label {:for "fixed-on-scroll" :label (tr "workspace.options.constraints.fix-when-scrolling")
:class (stl/css-case :checked (:fixed-scroll values))} :checked fixed-scroll?
[:span {:class (stl/css-case :check-mark true :on-change on-fixed-scroll-clicked}])]])])))
:checked (:fixed-scroll values))}
(when (:fixed-scroll values)
deprecated-icon/status-tick)]
(tr "workspace.options.constraints.fix-when-scrolling")
[:input {:type "checkbox"
:id "fixed-on-scroll"
:checked (:fixed-scroll values)
:on-change on-fixed-scroll-clicked}]]])]])])))

View File

@ -137,36 +137,4 @@
margin-bottom: deprecated.$s-8; margin-bottom: deprecated.$s-8;
margin-top: deprecated.$s-8; margin-top: deprecated.$s-8;
padding-left: 0; padding-left: 0;
input {
margin: 0;
}
label {
@include deprecated.bodySmallTypography;
display: flex;
align-items: center;
gap: deprecated.$s-2;
cursor: pointer;
color: var(--input-checkbox-text-foreground-color);
.check-mark {
@include deprecated.flexCenter;
width: deprecated.$s-16;
height: deprecated.$s-16;
border-radius: deprecated.$br-6;
background-color: var(--input-checkbox-inactive-background-color);
&.checked {
background-color: var(--input-checkbox-background-color-active);
svg {
@extend .button-icon-small;
stroke: var(--input-details-color);
}
}
&:hover {
border-color: var(--input-checkbox-border-color-hover);
}
&:focus {
border-color: var(--input-checkbox-border-color-focus);
}
}
}
} }

View File

@ -14,6 +14,7 @@
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.select :refer [select]] [app.main.ui.components.select :refer [select]]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.exports.assets] [app.main.ui.exports.assets]
@ -263,11 +264,9 @@
:icon i/remove}]])]) :icon i/remove}]])])
(when (or (= :multiple exports) (seq exports)) (when (or (= :multiple exports) (seq exports))
[:button [:> button* {:variant "secondary"
{:on-click (when-not in-progress? on-download) :class (stl/css :export-btn)
:class (stl/css-case :on-click (when-not in-progress? on-download)
:export-btn true
:btn-disabled in-progress?)
:disabled in-progress?} :disabled in-progress?}
(if in-progress? (if in-progress?
(tr "workspace.options.exporting-object") (tr "workspace.options.exporting-object")

View File

@ -27,7 +27,7 @@
.multiple-exports { .multiple-exports {
@include deprecated.flexRow; @include deprecated.flexRow;
grid-column: 1 / span 9; grid-column: 1 / span 8;
.label { .label {
@extend .mixed-bar; @extend .mixed-bar;
} }
@ -76,8 +76,6 @@
} }
.export-btn { .export-btn {
@extend .button-secondary; grid-column: 1 / span 8;
@include deprecated.uppercaseTitleTipography; justify-content: center;
grid-column: 1 / span 9;
height: deprecated.$s-32;
} }

View File

@ -17,9 +17,9 @@
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.checkbox :refer [checkbox*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.hooks :as h] [app.main.ui.hooks :as h]
[app.main.ui.icons :as deprecated-icon]
[app.main.ui.workspace.sidebar.options.rows.color-row :refer [color-row*]] [app.main.ui.workspace.sidebar.options.rows.color-row :refer [color-row*]]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
@ -252,16 +252,9 @@
(when (or (= type :frame) (when (or (= type :frame)
(and (= type :multiple) (and (= type :multiple)
(some? hide-on-export))) (some? hide-on-export)))
[:div {:class (stl/css :fill-checkbox)} [:> checkbox* {:ref checkbox-ref
[:label {:for "show-fill-on-export"
:class (stl/css-case :global/checked (not hide-on-export))}
[:span {:class (stl/css-case :check-mark true
:checked (not hide-on-export))}
(when (not hide-on-export)
deprecated-icon/status-tick)]
(tr "workspace.options.show-fill-on-export")
[:input {:type "checkbox"
:id "show-fill-on-export" :id "show-fill-on-export"
:ref checkbox-ref :class (stl/css :fill-checkbox)
:label (tr "workspace.options.show-fill-on-export")
:checked (not hide-on-export) :checked (not hide-on-export)
:on-change on-change-show-on-export}]]])])])) :on-change on-change-show-on-export}])])]))

View File

@ -50,14 +50,5 @@
} }
.fill-checkbox { .fill-checkbox {
// TODO create a checkbox component in the DS
@extend .input-checkbox;
padding-inline-start: var(--sp-s); padding-inline-start: var(--sp-s);
span.checked {
background-color: var(--color-accent-primary);
svg {
@extend .button-icon-small;
stroke: var(--color-background-primary);
}
}
} }

View File

@ -148,10 +148,13 @@
[:div {:class (stl/css :grid-title)} [:div {:class (stl/css :grid-title)}
[:div {:class (stl/css-case :option-row true [:div {:class (stl/css-case :option-row true
:hidden is-hidden?)} :hidden is-hidden?)}
[:button {:class (stl/css-case :show-options true [:> icon-button* {:variant "secondary"
:selected open?) :icon i/menu
:on-click toggle-advanced-options} :class (stl/css :show-options)
deprecated-icon/menu] :aria-pressed open?
:aria-label (tr "labels.options")
:on-click toggle-advanced-options
:disabled is-hidden?}]
[:div {:class (stl/css :type-select-wrapper)} [:div {:class (stl/css :type-select-wrapper)}
[:& select [:& select
{:class (stl/css :grid-type-select) {:class (stl/css :grid-type-select)
@ -204,10 +207,11 @@
:origin :guides :origin :guides
:on-change handle-change-color :on-change handle-change-color
:on-detach handle-detach-color}] :on-detach handle-detach-color}]
[:button {:class (stl/css-case :show-more-options true [:> icon-button* {:variant "ghost"
:selected show-more-options?) :icon i/menu
:on-click toggle-more-options} :aria-pressed show-more-options?
deprecated-icon/menu]] :aria-label (tr "labels.options")
:on-click toggle-more-options}]]
(when show-more-options? (when show-more-options?
[:div {:class (stl/css :second-row)} [:div {:class (stl/css :second-row)}
[:button {:class (stl/css-case :btn-options true [:button {:class (stl/css-case :btn-options true
@ -284,11 +288,12 @@
:className (stl/css :numeric-input) :className (stl/css :numeric-input)
:value (or (:margin params) 0)}]] :value (or (:margin params) 0)}]]
[:button {:class (stl/css-case :show-more-options true [:> icon-button* {:variant "ghost"
:selected show-more-options?) :icon i/menu
:aria-pressed show-more-options?
:aria-label (tr "labels.options")
:on-click toggle-more-options :on-click toggle-more-options
:disabled is-default} :disabled is-default}]
deprecated-icon/menu]
(when show-more-options? (when show-more-options?
[:div {:class (stl/css :more-options)} [:div {:class (stl/css :more-options)}
[:button {:class (stl/css :option-btn) [:button {:class (stl/css :option-btn)

View File

@ -38,18 +38,7 @@
border-radius: deprecated.$br-8; border-radius: deprecated.$br-8;
background-color: var(--input-details-color); background-color: var(--input-details-color);
.show-options { .show-options {
@extend .button-secondary;
height: deprecated.$s-32;
width: deprecated.$s-28;
border-radius: deprecated.$br-8 0 0 deprecated.$br-8; border-radius: deprecated.$br-8 0 0 deprecated.$br-8;
box-sizing: border-box;
border: deprecated.$s-1 solid var(--input-border-color);
svg {
@extend .button-icon;
}
&.selected {
@extend .button-icon-selected;
}
} }
.type-select-wrapper { .type-select-wrapper {
flex-grow: 1; flex-grow: 1;
@ -108,7 +97,6 @@
&.hidden { &.hidden {
.show-options { .show-options {
@include deprecated.hiddenElement;
border: deprecated.$s-1 solid var(--input-border-color-disabled); border: deprecated.$s-1 solid var(--input-border-color-disabled);
} }
.type-select-wrapper, .type-select-wrapper,
@ -176,17 +164,7 @@
.color-wrapper { .color-wrapper {
width: deprecated.$s-156; width: deprecated.$s-156;
} }
.show-more-options {
@extend .button-tertiary;
height: deprecated.$s-32;
width: deprecated.$s-32;
svg {
@extend .button-icon;
}
&.selected {
@extend .button-icon-selected;
}
}
.height { .height {
@extend .input-element; @extend .input-element;
@include deprecated.bodySmallTypography; @include deprecated.bodySmallTypography;

View File

@ -16,8 +16,9 @@
[app.main.data.workspace.shape-layout :as dwsl] [app.main.data.workspace.shape-layout :as dwsl]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.numeric-input :refer [numeric-input*]] [app.main.ui.components.numeric-input :refer [numeric-input*]]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.hooks :as hooks] [app.main.ui.hooks :as hooks]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
@ -35,10 +36,10 @@
:justify-self :justify-self
:area-name]) :area-name])
(mf/defc set-self-alignment (mf/defc set-self-alignment*
[{:keys [is-col? alignment set-alignment] :as props}] [{:keys [is-col alignment set-alignment]}]
(let [alignment (or alignment :auto) (let [alignment (or alignment :auto)
type (if is-col? "col" "row") type (if is-col "col" "row")
handle-set-alignment handle-set-alignment
(mf/use-callback (mf/use-callback
@ -46,39 +47,35 @@
(fn [value] (fn [value]
(set-alignment (-> value keyword))))] (set-alignment (-> value keyword))))]
[:div {:class (stl/css :self-align-menu)} [:> radio-buttons* {:class (stl/css :self-align-menu)
[:& radio-buttons {:selected (d/name alignment) :selected (d/name alignment)
:on-change handle-set-alignment :name (dm/str "flex-align-items-" type)
:allow-empty true :allow-empty true
:name (dm/str "flex-align-items-" type)} :on-change handle-set-alignment
[:& radio-button {:value "start" :options [{:id (dm/str "align-self-start-" type)
:icon (if is-col? :icon (if is-col
i/align-self-row-left i/align-self-row-left
i/align-self-column-top) i/align-self-column-top)
:title "Align self start" :label "Align self start"
:id (dm/str "align-self-start-" type)}] :value "start"}
{:id (dm/str "align-self-center-" type)
[:& radio-button {:value "center" :icon (if is-col
:icon (if is-col?
i/align-self-row-center i/align-self-row-center
i/align-self-column-center) i/align-self-column-center)
:title "Align self center" :label "Align self center"
:id (dm/str "align-self-center-" type)}] :value "center"}
{:id (dm/str "align-self-end-" type)
[:& radio-button {:value "end" :icon (if is-col
:icon (if is-col?
i/align-self-row-right i/align-self-row-right
i/align-self-column-bottom) i/align-self-column-bottom)
:title "Align self end" :label "Align self end"
:id (dm/str "align-self-end-" type)}] :value "end"}
{:id (dm/str "align-self-stretch-" type)
[:& radio-button {:value "stretch" :icon (if is-col
:icon (if is-col?
i/align-self-row-stretch i/align-self-row-stretch
i/align-self-column-stretch) i/align-self-column-stretch)
:title "Align self stretch" :label "Align self stretch"
:id (dm/str "align-self-stretch-" type)}]]])) :value "stretch"}]}]))
(mf/defc options (mf/defc options
{::mf/wrap [mf/memo]} {::mf/wrap [mf/memo]}
@ -182,16 +179,19 @@
(when open? (when open?
[:div {:class (stl/css :grid-cell-menu-container)} [:div {:class (stl/css :grid-cell-menu-container)}
[:div {:class (stl/css :cell-mode :row)} [:> radio-buttons* {:selected (d/name cell-mode)
[:& radio-buttons {:selected (d/name cell-mode)
:on-change set-cell-mode
:name "cell-mode" :name "cell-mode"
:wide true} :on-change set-cell-mode
[:& radio-button {:value "auto" :id :auto}] :options [{:id "auto"
[:& radio-button {:value "manual" :id :manual}] :label "Auto"
[:& radio-button {:value "area" :value "auto"}
:id :area {:id "manual"
:disabled (not valid-area-cells?)}]]] :label "Manual"
:value "manual"}
{:id "area"
:label "Area"
:value "area"
:disabled (not valid-area-cells?)}]}]
(when (= :area cell-mode) (when (= :area cell-mode)
[:div {:class (stl/css :row)} [:div {:class (stl/css :row)}
@ -261,16 +261,15 @@
:value row-end}]]]]) :value row-end}]]]])
[:div {:class (stl/css :row)} [:div {:class (stl/css :row)}
[:& set-self-alignment {:is-col? false [:> set-self-alignment* {:is-col false
:alignment align-self :alignment align-self
:set-alignment set-alignment}] :set-alignment set-alignment}]
[:& set-self-alignment {:is-col? true [:> set-self-alignment* {:is-col true
:alignment justify-self :alignment justify-self
:set-alignment set-justify-self}]] :set-alignment set-justify-self}]]
[:div {:class (stl/css :row)} [:div {:class (stl/css :row)}
[:button [:> button* {:variant "secondary"
{:class (stl/css :edit-grid-btn) :class (stl/css :edit-grid-btn)
:alt (tr "workspace.layout_grid.editor.options.edit-grid")
:on-click toggle-edit-mode} :on-click toggle-edit-mode}
(tr "workspace.layout_grid.editor.options.edit-grid")]]])])) (tr "workspace.layout_grid.editor.options.edit-grid")]]])]))

View File

@ -30,17 +30,6 @@
@include deprecated.flexRow; @include deprecated.flexRow;
} }
.cell-mode :global(label) {
padding: 0 deprecated.$s-12;
}
.edit-grid-btn {
@extend .button-secondary;
@include deprecated.uppercaseTitleTipography;
width: 100%;
padding: deprecated.$s-8;
}
.area-input { .area-input {
@extend .input-element; @extend .input-element;
@include deprecated.bodySmallTypography; @include deprecated.bodySmallTypography;
@ -66,3 +55,7 @@
border-radius: 0 deprecated.$br-8 deprecated.$br-8 0; border-radius: 0 deprecated.$br-8 deprecated.$br-8 0;
border-left: deprecated.$s-1 solid var(--panel-background-color); border-left: deprecated.$s-1 solid var(--panel-background-color);
} }
.edit-grid-btn {
flex-grow: 1;
}

View File

@ -17,13 +17,13 @@
[app.main.data.workspace.interactions :as dwi] [app.main.data.workspace.interactions :as dwi]
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.components.select :refer [select]] [app.main.ui.components.select :refer [select]]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.checkbox :refer [checkbox*]] [app.main.ui.ds.controls.checkbox :refer [checkbox*]]
[app.main.ui.ds.controls.input :refer [input*]] [app.main.ui.ds.controls.input :refer [input*]]
[app.main.ui.ds.controls.numeric-input :refer [numeric-input*]] [app.main.ui.ds.controls.numeric-input :refer [numeric-input*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.ds.product.empty-state :refer [empty-state*]] [app.main.ui.ds.product.empty-state :refer [empty-state*]]
[app.util.dom :as dom] [app.util.dom :as dom]
@ -582,41 +582,43 @@
:options animation-opts :options animation-opts
:on-change change-animation-type}]]] :on-change change-animation-type}]]]
;; Direction ;; Way
(when (ctsi/has-way? interaction) (when (ctsi/has-way? interaction)
[:div {:class (stl/css :interaction-row)} [:div {:class (stl/css :interaction-row)}
[:div {:class (stl/css :interaction-row-radio)} [:div {:class (stl/css :interaction-row-radio)}
[:& radio-buttons {:selected (d/name way) [:> radio-buttons* {:selected (d/name way)
:on-change change-way :on-change change-way
:name "animation-way"} :name "animation-way"
[:& radio-button {:value "in" :options [{:id "animation-way-in"
:id "animation-way-in"}] :label (tr "workspace.options.interaction-animation-direction-in")
[:& radio-button {:id "animation-way-out" :value "in"}
:value "out"}]]]]) {:id "animation-way-out"
:label (tr "workspace.options.interaction-animation-direction-out")
:value "out"}]}]]])
;; Direction ;; Direction
(when (ctsi/has-direction? interaction) (when (ctsi/has-direction? interaction)
[:div {:class (stl/css :interaction-row)} [:div {:class (stl/css :interaction-row)}
[:div {:class (stl/css :interaction-row-radio)} [:div {:class (stl/css :interaction-row-radio)}
[:& radio-buttons {:selected (d/name direction) [:> radio-buttons* {:selected (d/name direction)
:on-change change-direction :on-change change-direction
:name "animation-direction"} :name "animation-direction"
[:& radio-button {:icon i/row :options [{:id "animation-right"
:icon-class (stl/css :right) :icon i/row
:value "right" :label (tr "workspace.options.interaction-animation-direction-right")
:id "animation-right"}] :value "right"}
[:& radio-button {:icon i/row-reverse {:id "animation-left"
:icon-class (stl/css :left) :icon i/row-reverse
:id "animation-left" :label (tr "workspace.options.interaction-animation-direction-left")
:value "left"}] :value "left"}
[:& radio-button {:icon i/column {:id "animation-down"
:icon-class (stl/css :down) :icon i/column
:id "animation-down" :label (tr "workspace.options.interaction-animation-direction-down")
:value "down"}] :value "down"}
[:& radio-button {:icon i/column-reverse {:id "animation-up"
:icon-class (stl/css :up) :icon i/column-reverse
:id "animation-up" :label (tr "workspace.options.interaction-animation-direction-up")
:value "up"}]]]]) :value "up"}]}]]])
;; Duration ;; Duration
(when (ctsi/has-duration? interaction) (when (ctsi/has-duration? interaction)

View File

@ -23,12 +23,13 @@
[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.components.numeric-input :as deprecated-input] [app.main.ui.components.numeric-input :as deprecated-input]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.components.select :refer [select]] [app.main.ui.components.select :refer [select]]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.context :as muc] [app.main.ui.context :as muc]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.numeric-input :refer [numeric-input*]] [app.main.ui.ds.controls.numeric-input :refer [numeric-input*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.formats :as fmt] [app.main.ui.formats :as fmt]
[app.main.ui.hooks :as h] [app.main.ui.hooks :as h]
@ -202,128 +203,118 @@
:space-between i/align-content-row-between :space-between i/align-content-row-between
:stretch i/align-content-row-stretch)))) :stretch i/align-content-row-stretch))))
(mf/defc direction-row-flex (mf/defc direction-row-flex*
{::mf/props :obj {::mf/private true}
::mf/private true}
[{:keys [value on-change]}] [{:keys [value on-change]}]
[:& radio-buttons {:class (stl/css :direction-row-flex) [:> radio-buttons* {:class (stl/css :direction-row-flex)
:selected (d/name value) :selected (d/name value)
:decode-fn keyword
:on-change on-change :on-change on-change
:name "flex-direction"} :name "flex-direction"
[:& radio-button {:value "row" :options [{:id "flex-direction-row"
:id "flex-direction-row" :icon (dir-icons-refactor :row)
:title "Row" :label "Row"
:icon (dir-icons-refactor :row)}] :value "row"}
[:& radio-button {:value "row-reverse" {:id "flex-direction-row-reverse"
:id "flex-direction-row-reverse" :icon (dir-icons-refactor :row-reverse)
:title "Row reverse" :label "Row reverse"
:icon (dir-icons-refactor :row-reverse)}] :value "row-reverse"}
[:& radio-button {:value "column" {:id "flex-direction-column"
:id "flex-direction-column" :icon (dir-icons-refactor :column)
:title "Column" :label "Column"
:icon (dir-icons-refactor :column)}] :value "column"}
[:& radio-button {:value "column-reverse" {:id "flex-direction-column-reverse"
:id "flex-direction-column-reverse" :icon (dir-icons-refactor :column-reverse)
:title "Column reverse" :label "Column reverse"
:icon (dir-icons-refactor :column-reverse)}]]) :value "column-reverse"}]}])
(mf/defc wrap-row (mf/defc wrap-row*
{::mf/props :obj}
[{:keys [wrap-type on-click]}] [{:keys [wrap-type on-click]}]
[:button {:class (stl/css-case :wrap-button true [:> icon-button* {:variant "ghost"
:selected (= wrap-type :wrap)) :aria-label (if (= :wrap wrap-type) "No wrap" "Wrap")
:title (if (= :wrap wrap-type) :aria-pressed (= wrap-type :wrap)
"No wrap" :on-click on-click
"Wrap") :icon i/wrap}])
:on-click on-click}
deprecated-icon/wrap])
(mf/defc align-row (mf/defc align-row*
{::mf/props :obj}
[{:keys [is-column value on-change]}] [{:keys [is-column value on-change]}]
[:& radio-buttons {:class (stl/css :align-row) [:> radio-buttons* {:class (stl/css :align-row)
:selected (d/name value) :selected (d/name value)
:decode-fn keyword
:on-change on-change :on-change on-change
:name "flex-align-items"} :name "flex-align-items"
[:& radio-button {:value "start" :options [{:id "align-items-start"
:icon (get-layout-flex-icon :align-items :start is-column) :icon (get-layout-flex-icon :align-items :start is-column)
:title "Align items start" :label "Align items start"
:id "align-items-start"}] :value "start"}
[:& radio-button {:value "center" {:id "align-items-center"
:icon (get-layout-flex-icon :align-items :center is-column) :icon (get-layout-flex-icon :align-items :center is-column)
:title "Align items center" :label "Align items center"
:id "align-items-center"}] :value "center"}
[:& radio-button {:value "end" {:id "align-items-end"
:icon (get-layout-flex-icon :align-items :end is-column) :icon (get-layout-flex-icon :align-items :end is-column)
:title "Align items end" :label "Align items end"
:id "align-items-end"}]]) :value "end"}]}])
(mf/defc align-content-row (mf/defc align-content-row*
{::mf/props :obj}
[{:keys [is-column value on-change]}] [{:keys [is-column value on-change]}]
[:& radio-buttons {:class (stl/css :align-content-row) [:> radio-buttons* {:class (stl/css :align-content-row)
:selected (d/name value) :selected (d/name value)
:decode-fn keyword
:on-change on-change :on-change on-change
:name "flex-align-content"} :name "flex-align-content"
[:& radio-button {:value "start" :options [{:id "align-content-start"
:icon (get-layout-flex-icon :align-content :start is-column) :icon (get-layout-flex-icon :align-content :start is-column)
:title "Align content start" :label "Align content start"
:id "align-content-start"}] :value "start"}
[:& radio-button {:value "center" {:id "align-content-center"
:icon (get-layout-flex-icon :align-content :center is-column) :icon (get-layout-flex-icon :align-content :center is-column)
:title "Align content center" :label "Align content center"
:id "align-content-center"}] :value "center"}
[:& radio-button {:value "end" {:id "align-content-end"
:icon (get-layout-flex-icon :align-content :end is-column) :icon (get-layout-flex-icon :align-content :end is-column)
:title "Align content end" :label "Align content end"
:id "align-content-end"}] :value "end"}
[:& radio-button {:value "space-between" {:id "align-content-space-between"
:icon (get-layout-flex-icon :align-content :space-between is-column) :icon (get-layout-flex-icon :align-content :space-between is-column)
:title "Align content space-between" :label "Align content space-between"
:id "align-content-space-between"}] :value "space-between"}
[:& radio-button {:value "space-around" {:id "align-content-space-around"
:icon (get-layout-flex-icon :align-content :space-around is-column) :icon (get-layout-flex-icon :align-content :space-around is-column)
:title "Align content space-around" :label "Align content space-around"
:id "align-content-space-around"}] :value "space-around"}
[:& radio-button {:value "space-evenly" {:id "align-content-space-evenly"
:icon (get-layout-flex-icon :align-content :space-evenly is-column) :icon (get-layout-flex-icon :align-content :space-evenly is-column)
:title "Align content space-evenly" :label "Align content space-evenly"
:id "align-content-space-evenly"}]]) :value "space-evenly"}]}])
(mf/defc justify-content-row (mf/defc justify-content-row*
{::mf/props :obj}
[{:keys [is-column justify-content on-change]}] [{:keys [is-column justify-content on-change]}]
[:& radio-buttons {:class (stl/css :justify-content-row) [:> radio-buttons* {:class (stl/css :justify-content-row)
:selected (d/name justify-content) :selected (d/name justify-content)
:on-change on-change :on-change on-change
:name "flex-justify"} :name "flex-justify"
[:& radio-button {:value "start" :options [{:id "justify-content-start"
:icon (get-layout-flex-icon :justify-content :start is-column) :icon (get-layout-flex-icon :justify-content :start is-column)
:title "Justify content start" :label "Justify content start"
:id "justify-content-start"}] :value "start"}
[:& radio-button {:value "center" {:id "justify-content-center"
:icon (get-layout-flex-icon :justify-content :center is-column) :icon (get-layout-flex-icon :justify-content :center is-column)
:title "Justify content center" :label "Justify content center"
:id "justify-content-center"}] :value "center"}
[:& radio-button {:value "end" {:id "justify-content-end"
:icon (get-layout-flex-icon :justify-content :end is-column) :icon (get-layout-flex-icon :justify-content :end is-column)
:title "Justify content end" :label "Justify content end"
:id "justify-content-end"}] :value "end"}
[:& radio-button {:value "space-between" {:id "justify-content-space-between"
:icon (get-layout-flex-icon :justify-content :space-between is-column) :icon (get-layout-flex-icon :justify-content :space-between is-column)
:title "Justify content space-between" :label "Justify content space-between"
:id "justify-content-space-between"}] :value "space-between"}
[:& radio-button {:value "space-around" {:id "justify-content-space-around"
:icon (get-layout-flex-icon :justify-content :space-around is-column) :icon (get-layout-flex-icon :justify-content :space-around is-column)
:title "Justify content space-around" :label "Justify content space-around"
:id "justify-content-space-around"}] :value "space-around"}
[:& radio-button {:value "space-evenly" {:id "justify-content-space-evenly"
:icon (get-layout-flex-icon :justify-content :space-evenly is-column) :icon (get-layout-flex-icon :justify-content :space-evenly is-column)
:title "Justify content space-evenly" :label "Justify content space-evenly"
:id "justify-content-space-evenly"}]]) :value "space-evenly"}]}])
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; PADDING ;; PADDING
@ -679,14 +670,12 @@
(= type :multiple) (= type :multiple)
[:> multiple-padding-selection* props])] [:> multiple-padding-selection* props])]
[:button {:class (stl/css-case [:> icon-button* {:variant "ghost"
:padding-toggle true
:selected (= type :multiple))
:title (tr "workspace.layout_grid.editor.padding.expand")
:aria-label (tr "workspace.layout_grid.editor.padding.expand") :aria-label (tr "workspace.layout_grid.editor.padding.expand")
:aria-pressed (= type :multiple)
:data-type (d/name type) :data-type (d/name type)
:on-click on-type-change'} :on-click on-type-change'
deprecated-icon/padding-extended]])) :icon i/padding-extended}]]))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; GAP ;; GAP
@ -831,25 +820,22 @@
;; GRID COMPONENTS ;; GRID COMPONENTS
(mf/defc direction-row-grid (mf/defc direction-row-grid*
{::mf/props :obj}
[{:keys [value on-change] :as props}] [{:keys [value on-change] :as props}]
[:& radio-buttons {:class (stl/css :direction-row-grid) [:> radio-buttons* {:class (stl/css :direction-row-grid)
:selected (d/name value) :selected (d/name value)
:decode-fn keyword
:on-change on-change :on-change on-change
:name "grid-direction"} :name "grid-direction"
[:& radio-button {:value "row" :options [{:id "grid-direction-row"
:id "grid-direction-row" :icon (dir-icons-refactor :row)
:title "Row" :label "Row"
:icon (dir-icons-refactor :row)}] :value "row"}
[:& radio-button {:value "column" {:id "grid-direction-column"
:id "grid-direction-column" :icon (dir-icons-refactor :column)
:title "Column" :label "Column"
:icon (dir-icons-refactor :column)}]]) :value "column"}]}])
(mf/defc grid-edit-mode (mf/defc grid-edit-mode*
{::mf/props :obj}
[{:keys [id]}] [{:keys [id]}]
(let [edition (mf/deref refs/selected-edition) (let [edition (mf/deref refs/selected-edition)
active? (= id edition) active? (= id edition)
@ -861,81 +847,65 @@
(if-not active? (if-not active?
(st/emit! (udw/start-edition-mode id)) (st/emit! (udw/start-edition-mode id))
(st/emit! :interrupt))))] (st/emit! :interrupt))))]
[:button
{:class (stl/css :edit-mode-btn) [:> button* {:variant "secondary"
:alt "Grid edit mode" :class (stl/css :edit-mode-btn)
:on-click toggle-edit-mode} :on-click toggle-edit-mode}
(tr "workspace.layout_grid.editor.options.edit-grid")])) (tr "workspace.layout_grid.editor.options.edit-grid")]))
(mf/defc align-grid-row (mf/defc align-grid-row*
{::mf/props :obj {::mf/private true}
::mf/private true}
[{:keys [is-column value on-change]}] [{:keys [is-column value on-change]}]
(let [type (if ^boolean is-column "column" "row")] (let [type (if ^boolean is-column "column" "row")]
[:& radio-buttons {:class (stl/css :align-grid-row) [:> radio-buttons* {:class (stl/css :align-grid-row)
:selected (d/name value) :selected (d/name value)
:decode-fn keyword
:on-change on-change :on-change on-change
:name (dm/str "flex-align-items-" type)} :name (dm/str "flex-align-items-" type)
[:& radio-button {:value "start" :options [{:id (dm/str "align-items-start-" type)
:icon (get-layout-grid-icon :align-items :start is-column) :icon (get-layout-flex-icon :align-items :start is-column)
:title "Align items start" :label "Align items start"
:id (dm/str "align-items-start-" type)}] :value "start"}
[:& radio-button {:value "center" {:id (dm/str "align-items-center-" type)
:icon (get-layout-grid-icon :align-items :center is-column) :icon (get-layout-flex-icon :align-items :center is-column)
:title "Align items center" :label "Align items center"
:id (dm/str "align-items-center-" type)}] :value "center"}
[:& radio-button {:value "end" {:id (dm/str "align-items-end-" type)
:icon (get-layout-grid-icon :align-items :end is-column) :icon (get-layout-flex-icon :align-items :end is-column)
:title "Align items end" :label "Align items end"
:id (dm/str "align-items-end-" type)}]])) :value "end"}]}]))
(mf/defc justify-grid-row (mf/defc justify-grid-row*
{::mf/props :obj {::mf/private true}
::mf/private :obj}
[{:keys [is-column value on-change]}] [{:keys [is-column value on-change]}]
(let [type (if ^boolean is-column "column" "row")] (let [type (if ^boolean is-column "column" "row")]
[:& radio-buttons {:class (stl/css :justify-grid-row) [:> radio-buttons* {:class (stl/css :justify-grid-row)
:selected (d/name value) :selected (d/name value)
:on-change on-change :on-change on-change
:decode-fn keyword :name (dm/str "grid-justify-items-" type)
:name (dm/str "grid-justify-items-" type)} :options [{:id (dm/str "justify-items-start-" type)
[:& radio-button {:key "justify-item-start"
:value "start"
:icon (get-layout-grid-icon :justify-items :start is-column) :icon (get-layout-grid-icon :justify-items :start is-column)
:title "Justify items start" :label "Justify items start"
:id (dm/str "justify-items-start-" type)}] :value "start"}
{:id (dm/str "justify-items-center-" type)
[:& radio-button {:key "justify-item-center"
:value "center"
:icon (get-layout-grid-icon :justify-items :center is-column) :icon (get-layout-grid-icon :justify-items :center is-column)
:title "Justify items center" :label "Justify items center"
:id (dm/str "justify-items-center-" type)}] :value "center"}
{:id (dm/str "justify-items-end-" type)
[:& radio-button {:key "justify-item-end"
:value "end"
:icon (get-layout-grid-icon :justify-items :end is-column) :icon (get-layout-grid-icon :justify-items :end is-column)
:title "Justify items end" :label "Justify items end"
:id (dm/str "justify-items-end-" type)}] :value "end"}
{:id (dm/str "justify-items-space-around-" type)
[:& radio-button {:key "justify-item-space-around"
:value "space-around"
:icon (get-layout-grid-icon :justify-items :space-around is-column) :icon (get-layout-grid-icon :justify-items :space-around is-column)
:title "Justify items space-around" :label "Justify items space-around"
:id (dm/str "justify-items-space-around-" type)}] :value "space-around"}
{:id (dm/str "justify-items-space-between-" type)
[:& radio-button {:key "justify-item-space-between"
:value "space-between"
:icon (get-layout-grid-icon :justify-items :space-between is-column) :icon (get-layout-grid-icon :justify-items :space-between is-column)
:title "Justify items space-between" :label "Justify items space-between"
:id (dm/str "justify-items-space-between-" type)}] :value "space-between"}
{:id (dm/str "justify-items-stretch-" type)
[:& radio-button {:key "justify-item-stretch"
:value "stretch"
:icon (get-layout-grid-icon :justify-items :stretch is-column) :icon (get-layout-grid-icon :justify-items :stretch is-column)
:title "Justify items stretch" :label "Justify items stretch"
:id (dm/str "justify-items-stretch-" type)}]])) :value "stretch"}]}]))
(defn- manage-values (defn- manage-values
[{:keys [type value]}] [{:keys [type value]}]
@ -946,8 +916,7 @@
:fixed (fmt/format-pixels value) :fixed (fmt/format-pixels value)
value)) value))
(mf/defc grid-track-info (mf/defc grid-track-info*
{::mf/props :obj}
[{:keys [is-column [{:keys [is-column
type type
index index
@ -1030,8 +999,7 @@
:data-index index :data-index index
:icon i/remove}]])) :icon i/remove}]]))
(mf/defc grid-columns-row (mf/defc grid-columns-row*
{::mf/props :obj}
[{:keys [is-column expanded? column-values toggle add-new-element set-column-value set-column-type [{:keys [is-column expanded? column-values toggle add-new-element set-column-value set-column-type
remove-element reorder-track hover-track on-select-track]}] remove-element reorder-track hover-track on-select-track]}]
(let [column-num (count column-values) (let [column-num (count column-values)
@ -1052,17 +1020,28 @@
[:div {:class (stl/css :grid-tracks) :data-testid testid} [:div {:class (stl/css :grid-tracks) :data-testid testid}
[:div {:class (stl/css :grid-track-header)} [:div {:class (stl/css :grid-track-header)}
[:button {:class (stl/css :expand-icon) :on-click toggle} deprecated-icon/menu] [:> icon-button* {:variant "secondary"
:class (stl/css :expand-icon)
:aria-pressed expanded?
:aria-label (tr "labels.options")
:on-click toggle
:icon i/menu}]
#_[:button {:class (stl/css :expand-icon) :on-click toggle} deprecated-icon/menu]
[:div {:class (stl/css :track-title) :on-click toggle} [:div {:class (stl/css :track-title) :on-click toggle}
[:div {:class (stl/css :track-name) :title track-name} track-name] [:div {:class (stl/css :track-name) :title track-name} track-name]
[:div {:class (stl/css :track-detail) :title track-detail} track-detail]] [:div {:class (stl/css :track-detail) :title track-detail} track-detail]]
[:button {:class (stl/css :add-column) :on-click add-track} deprecated-icon/add]] [:> icon-button* {:variant "secondary"
:class (stl/css :add-column)
:aria-label (tr "labels.add")
:on-click add-track
:icon i/add}]
#_[:button {:class (stl/css :add-column) :on-click add-track} deprecated-icon/add]]
(when expanded? (when expanded?
[:> h/sortable-container* {} [:> h/sortable-container* {}
[:div {:class (stl/css :grid-tracks-info-container)} [:div {:class (stl/css :grid-tracks-info-container)}
(for [[index column] (d/enumerate column-values)] (for [[index column] (d/enumerate column-values)]
[:& grid-track-info {:key (dm/str index "-" (d/name type)) [:> grid-track-info* {:key (dm/str index "-" (d/name type))
:type type :type type
:is-column is-column :is-column is-column
:index index :index index
@ -1208,8 +1187,8 @@
(mf/deps layout-type ids) (mf/deps layout-type ids)
(fn [dir] (fn [dir]
(if (= :flex layout-type) (if (= :flex layout-type)
(st/emit! (dwsl/update-layout ids {:layout-flex-dir dir})) (st/emit! (dwsl/update-layout ids {:layout-flex-dir (keyword dir)}))
(st/emit! (dwsl/update-layout ids {:layout-grid-dir dir}))))) (st/emit! (dwsl/update-layout ids {:layout-grid-dir (keyword dir)})))))
;; Align grid ;; Align grid
align-items-row (:layout-align-items values) align-items-row (:layout-align-items values)
@ -1219,13 +1198,13 @@
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout ids {:layout-justify-items value})))) (st/emit! (dwsl/update-layout ids {:layout-justify-items (keyword value)}))))
on-row-align-change on-row-align-change
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout ids {:layout-align-items value})))) (st/emit! (dwsl/update-layout ids {:layout-align-items (keyword value)}))))
;; Justify grid ;; Justify grid
grid-justify-content-row (:layout-justify-content values) grid-justify-content-row (:layout-justify-content values)
@ -1235,13 +1214,13 @@
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout ids {:layout-align-content value})))) (st/emit! (dwsl/update-layout ids {:layout-align-content (keyword value)}))))
on-row-justify-change on-row-justify-change
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout ids {:layout-justify-content value})))) (st/emit! (dwsl/update-layout ids {:layout-justify-content (keyword value)}))))
on-toggle-dropdown-visibility on-toggle-dropdown-visibility
(mf/use-fn #(swap! show-dropdown* not)) (mf/use-fn #(swap! show-dropdown* not))
@ -1314,31 +1293,31 @@
:flex :flex
[:div {:class (stl/css :flex-layout-menu)} [:div {:class (stl/css :flex-layout-menu)}
[:div {:class (stl/css :first-row)} [:div {:class (stl/css :first-row)}
[:& align-row {:is-column is-column [:> align-row* {:is-column is-column
:value align-items :value align-items
:on-change set-align-items}] :on-change set-align-items}]
[:& direction-row-flex {:on-change on-direction-change [:> direction-row-flex* {:on-change on-direction-change
:value saved-dir}] :value saved-dir}]
[:& wrap-row {:wrap-type wrap-type [:> wrap-row* {:wrap-type wrap-type
:on-click toggle-wrap}]] :on-click toggle-wrap}]]
[:div {:class (stl/css :second-row :help-button-wrapper)} [:div {:class (stl/css :middle-row)}
[:& justify-content-row {:is-column is-column [:div {:class (stl/css :help-button-wrapper)}
[:> justify-content-row* {:is-column is-column
:justify-content justify-content :justify-content justify-content
:on-change set-justify-content}] :on-change set-justify-content}]
[:> icon-button* {:variant "ghost" [:> icon-button* {:variant "ghost"
:aria-label (tr "labels.help-center") :aria-label (tr "labels.help-center")
:on-click open-flex-help :on-click open-flex-help
:icon i/help}]] :icon i/help}]]
(when (= :wrap wrap-type) (when (= :wrap wrap-type)
[:div {:class (stl/css :third-row)} [:> align-content-row* {:is-column is-column
[:& align-content-row {:is-column is-column
:value align-content :value align-content
:on-change on-align-content-change}]]) :on-change on-align-content-change}])]
[:div {:class (stl/css :forth-row)}
[:div {:class (stl/css :last-row)}
[:> gap-section* {:is-column is-column [:> gap-section* {:is-column is-column
:wrap-type wrap-type :wrap-type wrap-type
:on-change on-gap-change :on-change on-gap-change
@ -1356,7 +1335,7 @@
[:div {:class (stl/css :grid-layout-menu)} [:div {:class (stl/css :grid-layout-menu)}
(when (= 1 (count ids)) (when (= 1 (count ids))
[:div {:class (stl/css :edit-grid-wrapper)} [:div {:class (stl/css :edit-grid-wrapper)}
[:& grid-edit-mode {:id (first ids)}] [:> grid-edit-mode* {:id (first ids)}]
[:> icon-button* {:variant "ghost" [:> icon-button* {:variant "ghost"
:aria-label (tr "labels.help-center") :aria-label (tr "labels.help-center")
:on-click open-grid-help :on-click open-grid-help
@ -1365,21 +1344,21 @@
[:div {:class (stl/css :first-row)} [:div {:class (stl/css :first-row)}
[:div {:class (stl/css :direction-edit)} [:div {:class (stl/css :direction-edit)}
[:div {:class (stl/css :direction)} [:div {:class (stl/css :direction)}
[:& direction-row-grid {:value saved-grid-dir [:> direction-row-grid* {:value saved-grid-dir
:on-change on-direction-change}]]] :on-change on-direction-change}]]]
[:& align-grid-row {:is-column false [:> align-grid-row* {:is-column false
:value align-items-row :value align-items-row
:on-change on-row-align-change}] :on-change on-row-align-change}]
[:& align-grid-row {:is-column true [:> align-grid-row* {:is-column true
:value align-items-column :value align-items-column
:on-change on-column-align-change}]] :on-change on-column-align-change}]]
[:div {:class (stl/css :row :grid-layout-align)} [:div {:class (stl/css :row :grid-layout-align)}
[:& justify-grid-row {:is-column true [:> justify-grid-row* {:is-column true
:value grid-justify-content-column :value grid-justify-content-column
:on-change on-column-justify-change}] :on-change on-column-justify-change}]
[:& justify-grid-row {:is-column false [:> justify-grid-row* {:is-column false
:value grid-justify-content-row :value grid-justify-content-row
:on-change on-row-justify-change}]] :on-change on-row-justify-change}]]
@ -1407,7 +1386,7 @@
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [dir] (fn [dir]
(st/emit! (dwsl/update-layout ids {:layout-grid-dir dir})))) (st/emit! (dwsl/update-layout ids {:layout-grid-dir (keyword dir)}))))
on-gap-change on-gap-change
(mf/use-fn (mf/use-fn
@ -1446,13 +1425,13 @@
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout ids {:layout-justify-items value})))) (st/emit! (dwsl/update-layout ids {:layout-justify-items (keyword value)}))))
on-row-align-change on-row-align-change
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout ids {:layout-align-items value})))) (st/emit! (dwsl/update-layout ids {:layout-align-items (keyword value)}))))
;; Justify grid ;; Justify grid
grid-justify-content-row (:layout-justify-content values) grid-justify-content-row (:layout-justify-content values)
@ -1462,13 +1441,13 @@
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout ids {:layout-align-content value})))) (st/emit! (dwsl/update-layout ids {:layout-align-content (keyword value)}))))
on-row-justify-change on-row-justify-change
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout ids {:layout-justify-content value})))) (st/emit! (dwsl/update-layout ids {:layout-justify-content (keyword value)}))))
columns-open? (mf/use-state false) columns-open? (mf/use-state false)
rows-open? (mf/use-state false) rows-open? (mf/use-state false)
@ -1549,29 +1528,30 @@
:aria-label (tr "labels.help-center") :aria-label (tr "labels.help-center")
:on-click open-grid-help :on-click open-grid-help
:icon i/help}] :icon i/help}]
[:button {:class (stl/css :exit-btn) [:> button* {:variant "secondary"
:class (stl/css :exit-btn)
:on-click #(st/emit! (udw/clear-edition-mode))} :on-click #(st/emit! (udw/clear-edition-mode))}
(tr "workspace.layout_grid.editor.options.exit")]] (tr "workspace.layout_grid.editor.options.exit")]]
[:div {:class (stl/css :row :first-row)} [:div {:class (stl/css :row :first-row)}
[:div {:class (stl/css :direction-edit)} [:div {:class (stl/css :direction-edit)}
[:div {:class (stl/css :direction)} [:div {:class (stl/css :direction)}
[:& direction-row-grid {:value saved-grid-dir [:> direction-row-grid* {:value saved-grid-dir
:on-change on-direction-change}]]] :on-change on-direction-change}]]]
[:& align-grid-row {:is-column false [:> align-grid-row* {:is-column false
:value align-items-row :value align-items-row
:on-change on-row-align-change}] :on-change on-row-align-change}]
[:& align-grid-row {:is-column true [:> align-grid-row* {:is-column true
:value align-items-column :value align-items-column
:on-change on-column-align-change}]] :on-change on-column-align-change}]]
[:div {:class (stl/css :row :grid-layout-align)} [:div {:class (stl/css :row :grid-layout-align)}
[:& justify-grid-row {:is-column true [:> justify-grid-row* {:is-column true
:value grid-justify-content-column :value grid-justify-content-column
:on-change on-column-justify-change}] :on-change on-column-justify-change}]
[:& justify-grid-row {:is-column false [:> justify-grid-row* {:is-column false
:value grid-justify-content-row :value grid-justify-content-row
:on-change on-row-justify-change}] :on-change on-row-justify-change}]
@ -1587,14 +1567,14 @@
:applied-tokens applied-tokens :applied-tokens applied-tokens
:value (:layout-gap values)}]] :value (:layout-gap values)}]]
[:div {:class (stl/css :padding-row :padding-section)} [:div {:class (stl/css :padding-row)}
[:> padding-section* {:value (:layout-padding values) [:> padding-section* {:value (:layout-padding values)
:type (:layout-padding-type values) :type (:layout-padding-type values)
:on-type-change on-padding-type-change :on-type-change on-padding-type-change
:on-change on-padding-change}]] :on-change on-padding-change}]]
[:div {:class (stl/css :grid-tracks-row)} [:div {:class (stl/css :grid-tracks-row)}
[:& grid-columns-row {:is-column true [:> grid-columns-row* {:is-column true
:expanded? @columns-open? :expanded? @columns-open?
:toggle toggle-columns-open :toggle toggle-columns-open
:column-values column-values :column-values column-values
@ -1606,7 +1586,7 @@
:hover-track hover-track :hover-track hover-track
:on-select-track handle-select-track}] :on-select-track handle-select-track}]
[:& grid-columns-row {:is-column false [:> grid-columns-row* {:is-column false
:expanded? @rows-open? :expanded? @rows-open?
:toggle toggle-rows-open :toggle toggle-rows-open
:column-values rows-values :column-values rows-values

View File

@ -42,6 +42,7 @@
.flex-layout-menu { .flex-layout-menu {
@include sidebar.option-grid-structure; @include sidebar.option-grid-structure;
row-gap: var(--sp-s);
margin-block-end: var(--sp-s); margin-block-end: var(--sp-s);
} }
@ -49,8 +50,6 @@
grid-column: 1 / -1; grid-column: 1 / -1;
display: grid; display: grid;
grid-template-columns: subgrid; grid-template-columns: subgrid;
margin-block-end: var(--sp-m);
margin-block-start: var(--sp-xs);
} }
.align-row { .align-row {
@ -61,27 +60,11 @@
grid-column: span 4; grid-column: span 4;
} }
// TODO: Replace this buttons with DS buttons .middle-row {
.wrap-button { grid-column: span 8;
@extend .button-tertiary; display: flex;
border-radius: $br-8; flex-direction: column;
block-size: $sz-32; row-gap: var(--sp-xs);
inline-size: $sz-32;
svg {
@extend .button-icon;
stroke: var(--color-foreground-secondary);
}
&.selected {
@extend .button-icon-selected;
}
}
.second-row,
.third-row {
grid-column: 1 / -1;
display: grid;
grid-template-columns: subgrid;
margin-block-end: var(--sp-m);
} }
.align-content-row, .align-content-row,
@ -89,7 +72,7 @@
grid-column: span 6; grid-column: span 6;
} }
.forth-row { .last-row {
display: grid; display: grid;
grid-template-columns: grid-template-columns:
var(--grid-exception-input-width) /* first input block */ var(--grid-exception-input-width) /* first input block */
@ -100,9 +83,7 @@
} }
.help-button-wrapper { .help-button-wrapper {
grid-column: 1 / -1;
display: flex; display: flex;
flex-direction: row;
justify-content: space-between; justify-content: space-between;
} }
@ -149,23 +130,10 @@
gap: var(--sp-xs); gap: var(--sp-xs);
} }
// TODO: Replace this buttons with DS buttons
.padding-toggle {
@extend .button-tertiary;
block-size: $sz-32;
inline-size: $sz-32;
border-radius: $br-8;
svg {
@extend .button-icon;
stroke: var(--color-foreground-secondary);
}
&.selected {
@extend .button-icon-selected;
}
}
.grid-layout-menu { .grid-layout-menu {
@include sidebar.option-grid-structure; @include sidebar.option-grid-structure;
margin-top: var(--sp-xs);
row-gap: var(--sp-s);
} }
.edit-grid-wrapper, .edit-grid-wrapper,
@ -177,7 +145,6 @@
} }
.first-row { .first-row {
margin-block-end: var(--sp-s);
display: grid; display: grid;
grid-template-columns: subgrid; grid-template-columns: subgrid;
} }
@ -202,20 +169,12 @@
grid-column: span 5; grid-column: span 5;
} }
// TODO: Replace this buttons with DS buttons
.edit-mode-btn { .edit-mode-btn {
@extend .button-secondary; justify-content: center;
@include t.use-typography("headline-small");
inline-size: 100%;
padding: var(--sp-s);
grid-column: span 7; grid-column: span 7;
} }
// TODO: Replace this buttons with DS buttons
.exit-btn { .exit-btn {
@extend .button-secondary;
@include t.use-typography("headline-small");
padding: var(--sp-s) var(--sp-xl);
grid-column: span 2; grid-column: span 2;
} }
@ -227,14 +186,11 @@
margin-block-start: var(--sp-xs); margin-block-start: var(--sp-xs);
} }
.padding-section {
margin-block-start: var(--sp-s);
}
.grid-tracks-row { .grid-tracks-row {
display: grid; display: grid;
grid-template-columns: subgrid; grid-template-columns: subgrid;
grid-column: 1 / -1; grid-column: 1 / -1;
row-gap: var(--sp-s);
} }
.edit-grid-wrapper { .edit-grid-wrapper {
@ -293,7 +249,6 @@
display: grid; display: grid;
grid-template-columns: subgrid; grid-template-columns: subgrid;
grid-column: 1 / -1; grid-column: 1 / -1;
margin-block-start: var(--sp-s);
} }
.grid-track-header { .grid-track-header {
@ -304,7 +259,7 @@
border-radius: $br-8; border-radius: $br-8;
overflow: hidden; overflow: hidden;
background: var(--color-background-tertiary); background: var(--color-background-tertiary);
block-size: px2rem(52); block-size: $sz-48;
grid-column: 1 / -1; grid-column: 1 / -1;
} }
@ -328,44 +283,14 @@
color: var(--color-foreground-secondary); color: var(--color-foreground-secondary);
} }
// TODO: Replace this buttons with DS buttons
.expand-icon { .expand-icon {
@extend .button-secondary; block-size: $sz-48;
block-size: px2rem(52);
border-radius: $br-8 0 0 $br-8; border-radius: $br-8 0 0 $br-8;
border-inline-end: $b-1 solid var(--color-background-primary);
svg {
@extend .button-icon;
stroke: var(--color-foreground-secondary);
fill: var(--color-foreground-secondary);
}
&:hover,
&:active {
svg {
stroke: var(--color-accent-primary);
fill: var(--color-accent-primary);
}
}
} }
// TODO: Replace this buttons with DS buttons
.add-column { .add-column {
@extend .button-tertiary; block-size: $sz-48;
block-size: px2rem(52); border-radius: 0 $br-8 $br-8 0;
svg {
display: flex;
justify-content: center;
align-items: center;
color: transparent;
fill: none;
stroke-width: px2rem(1);
block-size: $sz-12;
inline-size: $sz-12;
stroke: var(--color-foreground-secondary);
fill: var(--color-foreground-secondary);
}
} }
.layout-options { .layout-options {

View File

@ -14,8 +14,9 @@
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.numeric-input :as deprecated-input] [app.main.ui.components.numeric-input :as deprecated-input]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.main.ui.workspace.sidebar.options.menus.layout-container :refer [get-layout-flex-icon]] [app.main.ui.workspace.sidebar.options.menus.layout-container :refer [get-layout-flex-icon]]
@ -211,105 +212,85 @@
(= type :multiple) (= type :multiple)
[:> margin-multiple* props])] [:> margin-multiple* props])]
[:button {:class (stl/css-case [:> icon-button* {:variant "ghost"
:margin-mode true :aria-pressed (= type :multiple)
:selected (= type :multiple)) :aria-label (tr "workspace.layout_grid.editor.margin.expand")
:title "Margin - multiple" :on-click on-type-change'
:on-click on-type-change'} :icon i/margin}]]))
deprecated-icon/margin]]))
(mf/defc element-behaviour-horizontal (mf/defc element-behaviour-horizontal*
{::mf/props :obj {::mf/private true}
::mf/private true}
[{:keys [^boolean is-auto ^boolean has-fill value on-change]}] [{:keys [^boolean is-auto ^boolean has-fill value on-change]}]
[:div {:class (stl/css-case [:div {:class (stl/css-case :horizontal-behaviour true
:horizontal-behaviour true
:one-element (and (not has-fill) (not is-auto)) :one-element (and (not has-fill) (not is-auto))
:two-element (or has-fill is-auto) :two-element (or has-fill is-auto)
:three-element (and has-fill is-auto))} :three-element (and has-fill is-auto))}
[:& radio-buttons [:> radio-buttons* {:selected (d/name value)
{:selected (d/name value)
:decode-fn keyword
:on-change on-change :on-change on-change
:name "flex-behaviour-h"} :name "flex-behaviour-h"
:options (remove nil?
[:& radio-button [{:id "behaviour-h-fix"
{:value "fix"
:icon i/fixed-width :icon i/fixed-width
:title "Fix width" :label (tr "workspace.layout_item.fix-width")
:id "behaviour-h-fix"}] :value "fix"}
(when has-fill (when has-fill
[:& radio-button {:id "behaviour-h-fill"
{:value "fill"
:icon i/fill-content :icon i/fill-content
:title "Width 100%" :label (tr "workspace.layout_item.width-100")
:id "behaviour-h-fill"}]) :value "fill"})
(when is-auto (when is-auto
[:& radio-button {:id "behaviour-h-auto"
{:value "auto"
:icon i/hug-content :icon i/hug-content
:title "Fit content (Horizontal)" :label (tr "workspace.layout_item.fit-content-horizontal")
:id "behaviour-h-auto"}])]]) :value "auto"})])}]])
(mf/defc element-behaviour-vertical (mf/defc element-behaviour-vertical*
{::mf/props :obj {::mf/private true}
::mf/private true}
[{:keys [^boolean is-auto ^boolean has-fill value on-change]}] [{:keys [^boolean is-auto ^boolean has-fill value on-change]}]
[:div {:class (stl/css-case [:div {:class (stl/css-case :vertical-behaviour true
:vertical-behaviour true
:one-element (and (not has-fill) (not is-auto)) :one-element (and (not has-fill) (not is-auto))
:two-element (or has-fill is-auto) :two-element (or has-fill is-auto)
:three-element (and has-fill is-auto))} :three-element (and has-fill is-auto))}
[:& radio-buttons [:> radio-buttons* {:selected (d/name value)
{:selected (d/name value)
:decode-fn keyword
:on-change on-change :on-change on-change
:name "flex-behaviour-v"} :name "flex-behaviour-v"
:options (remove nil?
[:& radio-button [{:id "behaviour-v-fix"
{:value "fix"
:icon i/fixed-width :icon i/fixed-width
:icon-class (stl/css :rotated) :label (tr "workspace.layout_item.fix-height")
:title "Fix height" :class (stl/css :rotated)
:id "behaviour-v-fix"}] :value "fix"}
(when has-fill (when has-fill
[:& radio-button {:id "behaviour-v-fill"
{:value "fill"
:icon i/fill-content :icon i/fill-content
:icon-class (stl/css :rotated) :label (tr "workspace.layout_item.height-100")
:title "Height 100%" :class (stl/css :rotated)
:id "behaviour-v-fill"}]) :value "fill"})
(when is-auto (when is-auto
[:& radio-button {:id "behaviour-v-auto"
{:value "auto"
:icon i/hug-content :icon i/hug-content
:icon-class (stl/css :rotated) :label (tr "workspace.layout_item.fit-content-vertical")
:title "Fit content (Vertical)" :class (stl/css :rotated)
:id "behaviour-v-auto"}])]]) :value "auto"})])}]])
(mf/defc align-self-row (mf/defc align-self-row*
{::mf/props :obj}
[{:keys [^boolean is-col value on-change]}] [{:keys [^boolean is-col value on-change]}]
[:& radio-buttons {:selected (d/name value) [:> radio-buttons* {:selected (d/name value)
:decode-fn keyword
:on-change on-change
:name "flex-align-self" :name "flex-align-self"
:allow-empty true} :on-change on-change
[:& radio-button {:value "start" :allow-empty true
:options [{:id "align-self-start"
:icon (get-layout-flex-icon :align-self :start is-col) :icon (get-layout-flex-icon :align-self :start is-col)
:title "Align self start" :label "Align self start"
:id "align-self-start"}] :value "start"}
[:& radio-button {:value "center" {:id "align-self-center"
:icon (get-layout-flex-icon :align-self :center is-col) :icon (get-layout-flex-icon :align-self :center is-col)
:title "Align self center" :label "Align self center"
:id "align-self-center"}] :value "center"}
[:& radio-button {:value "end" {:id "align-self-end"
:icon (get-layout-flex-icon :align-self :end is-col) :icon (get-layout-flex-icon :align-self :end is-col)
:title "Align self end" :label "Align self end"
:id "align-self-end"}]]) :value "end"}]}])
(mf/defc layout-item-menu (mf/defc layout-item-menu
{::mf/memo #{:ids :values :type :is-layout-child? :is-grid-parent :is-flex-parent? :is-grid-layout? :is-flex-layout?} {::mf/memo #{:ids :values :type :is-layout-child? :is-grid-parent :is-flex-parent? :is-grid-layout? :is-flex-layout?}
@ -377,9 +358,10 @@
(mf/use-fn (mf/use-fn
(mf/deps ids align-self) (mf/deps ids align-self)
(fn [value] (fn [value]
(let [value (keyword value)]
(if (= align-self value) (if (= align-self value)
(st/emit! (dwsl/update-layout-child ids {:layout-item-align-self nil})) (st/emit! (dwsl/update-layout-child ids {:layout-item-align-self nil}))
(st/emit! (dwsl/update-layout-child ids {:layout-item-align-self value}))))) (st/emit! (dwsl/update-layout-child ids {:layout-item-align-self value}))))))
;; Margin ;; Margin
on-margin-type-change on-margin-type-change
@ -407,13 +389,13 @@
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout-child ids {:layout-item-h-sizing value})))) (st/emit! (dwsl/update-layout-child ids {:layout-item-h-sizing (keyword value)}))))
on-behaviour-v-change on-behaviour-v-change
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(st/emit! (dwsl/update-layout-child ids {:layout-item-v-sizing value})))) (st/emit! (dwsl/update-layout-child ids {:layout-item-v-sizing (keyword value)}))))
;; Size and position ;; Size and position
on-size-change on-size-change
@ -429,9 +411,10 @@
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids)
(fn [value] (fn [value]
(let [value (keyword value)]
(when (= value :static) (when (= value :static)
(st/emit! (dwsl/update-layout-child ids {:layout-item-z-index nil}))) (st/emit! (dwsl/update-layout-child ids {:layout-item-z-index nil})))
(st/emit! (dwsl/update-layout-child ids {:layout-item-absolute (= value :absolute)})))) (st/emit! (dwsl/update-layout-child ids {:layout-item-absolute (= value :absolute)})))))
;; Z Index ;; Z Index
on-change-z-index on-change-z-index
@ -452,16 +435,17 @@
[:div {:class (stl/css :flex-element-menu)} [:div {:class (stl/css :flex-element-menu)}
(when (or is-layout-child? is-absolute?) (when (or is-layout-child? is-absolute?)
[:div {:class (stl/css :position-row)} [:div {:class (stl/css :position-row)}
[:div {:class (stl/css :position-options)} [:> radio-buttons* {:class (stl/css :position-options)
[:& radio-buttons {:selected (if is-absolute? "absolute" "static") :selected (if is-absolute? "absolute" "static")
:decode-fn keyword
:on-change on-change-position :on-change on-change-position
:name "layout-style" :name "layout-style"
:wide true} :extended true
[:& radio-button {:value "static" :options [{:id "static-position"
:id :static-position}] :label "Static"
[:& radio-button {:value "absolute" :value "static"}
:id :absolute-position}]]] {:id "absolute-position"
:label "Absolute"
:value "absolute"}]}]
[:div {:class (stl/css :z-index-wrapper) [:div {:class (stl/css :z-index-wrapper)
:title "z-index"} :title "z-index"}
@ -480,20 +464,18 @@
:behaviour-menu true :behaviour-menu true
:wrap (and ^boolean is-layout-child? :wrap (and ^boolean is-layout-child?
^boolean is-layout-container?))} ^boolean is-layout-container?))}
[:& element-behaviour-horizontal [:> element-behaviour-horizontal* {:is-auto is-layout-container?
{:is-auto is-layout-container?
:has-fill is-layout-child? :has-fill is-layout-child?
:value (:layout-item-h-sizing values) :value (:layout-item-h-sizing values)
:on-change on-behaviour-h-change}] :on-change on-behaviour-h-change}]
[:& element-behaviour-vertical [:> element-behaviour-vertical* {:is-auto is-layout-container?
{:is-auto is-layout-container?
:has-fill is-layout-child? :has-fill is-layout-child?
:value (:layout-item-v-sizing values) :value (:layout-item-v-sizing values)
:on-change on-behaviour-v-change}]]] :on-change on-behaviour-v-change}]]]
(when (and is-layout-child? is-flex-parent?) (when (and is-layout-child? is-flex-parent?)
[:div {:class (stl/css :align-row)} [:div {:class (stl/css :align-row)}
[:& align-self-row {:is-col is-col? [:> align-self-row* {:is-col is-col?
:value align-self :value align-self
:on-change on-align-self-change}]]) :on-change on-align-self-change}]])

View File

@ -30,10 +30,8 @@
grid-template-columns: auto auto; grid-template-columns: auto auto;
} }
.vertical-behaviour { .rotated {
.rotated {
transform: rotate(90deg); transform: rotate(90deg);
}
} }
.z-index-wrapper { .z-index-wrapper {
@ -70,18 +68,6 @@
gap: var(--sp-xs); gap: var(--sp-xs);
} }
.margin-mode {
@extend .button-tertiary;
grid-column: 3;
height: deprecated.$s-32;
svg {
@extend .button-icon;
}
&.selected {
@extend .button-icon-selected;
}
}
.margin-simple { .margin-simple {
display: grid; display: grid;
gap: var(--sp-xs); gap: var(--sp-xs);

View File

@ -26,11 +26,11 @@
[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.components.numeric-input :as deprecated-input] [app.main.ui.components.numeric-input :as deprecated-input]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.context :as muc] [app.main.ui.context :as muc]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.numeric-input :refer [numeric-input*]] [app.main.ui.ds.controls.numeric-input :refer [numeric-input*]]
[app.main.ui.ds.foundations.assets.icon :refer [icon*] :as i] [app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.main.ui.workspace.sidebar.options.menus.border-radius :refer [border-radius-menu*]] [app.main.ui.workspace.sidebar.options.menus.border-radius :refer [border-radius-menu*]]
[app.util.dom :as dom] [app.util.dom :as dom]
@ -237,12 +237,6 @@
proportion-lock proportion-lock
(get values :proportion-lock) (get values :proportion-lock)
clip-content-ref
(mf/use-ref nil)
show-in-viewer-ref
(mf/use-ref nil)
;; PRESETS ;; PRESETS
preset-state* preset-state*
(mf/use-state false) (mf/use-state false)
@ -390,19 +384,19 @@
;; CLIP CONTENT AND SHOW IN VIEWER ;; CLIP CONTENT AND SHOW IN VIEWER
on-change-clip-content on-change-clip-content
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids values)
(fn [event] (fn []
(let [value (-> event dom/get-target dom/checked?)] (let [value (not (:show-content values))]
(st/emit! (dwsh/update-shapes ids (fn [shape] (assoc shape :show-content (not value)))))))) (st/emit! (dwsh/update-shapes ids (fn [shape] (assoc shape :show-content value)))))))
on-change-show-in-viewer on-change-show-in-viewer
(mf/use-fn (mf/use-fn
(mf/deps ids) (mf/deps ids values)
(fn [event] (fn []
(let [value (-> event dom/get-target dom/checked?) (let [value (not (:hide-in-viewer values))
undo-id (js/Symbol)] undo-id (js/Symbol)]
(st/emit! (dwu/start-undo-transaction undo-id) (st/emit! (dwu/start-undo-transaction undo-id)
(dwsh/update-shapes ids (fn [shape] (cls/change-show-in-viewer shape (not value))))) (dwsh/update-shapes ids (fn [shape] (cls/change-show-in-viewer shape value))))
(when-not value (when-not value
;; when a frame is no longer shown in view mode, cannot ;; when a frame is no longer shown in view mode, cannot
@ -450,19 +444,20 @@
(when preset-match (when preset-match
[:span {:class (stl/css :check-icon)} deprecated-icon/tick])])))]]] [:span {:class (stl/css :check-icon)} deprecated-icon/tick])])))]]]
[:& radio-buttons {:selected (or (d/name orientation) "") [:> radio-buttons* {:class (stl/css :radio-buttons)
:selected (or (d/name orientation) "")
:on-change on-orientation-change :on-change on-orientation-change
:name "frame-orientation" :name "frame-orientation"
:wide true :options [{:id "size-vertical"
:class (stl/css :radio-buttons)} :icon i/size-vertical
[:& radio-button {:icon i/size-vertical :label (tr "workspace.options.orientation.vertical")
:value "vert" :value "vert"}
:id "size-vertical"}] {:id "size-horizontal"
[:& radio-button {:icon i/size-horizontal :icon i/size-horizontal
:value "horiz" :label (tr "workspace.options.orientation.horizontal")
:id "size-horizontal"}]] :value "horiz"}]}]
[:> icon-button*
{:variant "ghost" [:> icon-button* {:variant "ghost"
:aria-label (tr "workspace.options.fit-content") :aria-label (tr "workspace.options.fit-content")
:on-pointer-down handle-fit-content :on-pointer-down handle-fit-content
:icon i/fit-content}]]) :icon i/fit-content}]])
@ -522,8 +517,8 @@
[:> icon-button* {:variant "ghost" [:> icon-button* {:variant "ghost"
:tooltip-placement "top-left" :tooltip-placement "top-left"
:icon (if proportion-lock "lock" "unlock") :icon (if proportion-lock "lock" "unlock")
:class (stl/css-case :selected (true? proportion-lock))
:disabled (= proportion-lock :multiple) :disabled (= proportion-lock :multiple)
:aria-pressed (true? proportion-lock)
:aria-label (if proportion-lock (tr "workspace.options.size.unlock") (tr "workspace.options.size.lock")) :aria-label (if proportion-lock (tr "workspace.options.size.unlock") (tr "workspace.options.size.lock"))
:on-click on-proportion-lock-change}]]) :on-click on-proportion-lock-change}]])
@ -608,34 +603,20 @@
:applied-tokens applied-tokens :applied-tokens applied-tokens
:shapes shapes :shapes shapes
:shape shape}])]) :shape shape}])])
(when (or (options :clip-content) (options :show-in-viewer))
(when (or (options :clip-content)
(options :show-in-viewer))
[:div {:class (stl/css :clip-show)} [:div {:class (stl/css :clip-show)}
(when (options :clip-content) (when (options :clip-content)
[:div {:class (stl/css :clip-content)} [:> icon-button* {:variant "ghost"
[:input {:type "checkbox" :aria-pressed (not (:show-content values))
:id "clip-content" :aria-label (tr "workspace.options.clip-content")
:ref clip-content-ref :on-click on-change-clip-content
:class (stl/css :clip-content-input) :icon i/clip-content}])
:checked (not (:show-content values))
:on-change on-change-clip-content}]
[:label {:for "clip-content"
:title (tr "workspace.options.clip-content")
:class (stl/css-case :clip-content-label true
:selected (not (:show-content values)))}
[:> icon* {:icon-id i/clip-content}]]])
(when (options :show-in-viewer) (when (options :show-in-viewer)
[:div {:class (stl/css :show-in-viewer)} [:> icon-button* {:variant "ghost"
[:input {:type "checkbox" :aria-pressed (not (:hide-in-viewer values))
:id "show-in-viewer" :aria-label (tr "workspace.options.show-in-viewer")
:ref show-in-viewer-ref :on-click on-change-show-in-viewer
:class (stl/css :clip-content-input) :icon i/play}])])]))
:checked (not (:hide-in-viewer values))
:on-change on-change-show-in-viewer}]
[:label {:for "show-in-viewer"
:title (tr "workspace.options.show-in-viewer")
:class (stl/css-case :clip-content-label true
:selected (not (:hide-in-viewer values)))}
[:> icon* {:icon-id i/play}]]])])]))

View File

@ -144,16 +144,6 @@
grid-column: 2/-1; grid-column: 2/-1;
} }
.lock-size-btn {
@extend .button-tertiary;
border-radius: deprecated.$br-8;
height: deprecated.$s-32;
width: deprecated.$s-28;
&.selected {
@extend .button-icon-selected;
}
}
.lock-ratio-icon { .lock-ratio-icon {
@extend .button-icon; @extend .button-icon;
stroke: var(--icon-foreground); stroke: var(--icon-foreground);
@ -166,28 +156,6 @@
gap: deprecated.$s-4; gap: deprecated.$s-4;
} }
.clip-content,
.show-in-viewer {
.clip-content-input {
display: none;
}
}
.clip-content-label {
@extend .button-tertiary;
height: var(--sp-xxxl);
width: var(--sp-xxxl);
border-radius: deprecated.$br-8;
}
.selected {
@extend .button-icon-selected;
}
.checkbox-button {
@extend .button-icon;
}
// TODO: Add a proper variable to this sizing // TODO: Add a proper variable to this sizing
.numeric-input-measures { .numeric-input-measures {
--dropdown-width: var(--7-columns-dropdown-width); --dropdown-width: var(--7-columns-dropdown-width);

View File

@ -18,15 +18,15 @@
[app.main.features :as features] [app.main.features :as features]
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.components.title-bar :refer [title-bar*]] [app.main.ui.components.title-bar :refer [title-bar*]]
[app.main.ui.context :as ctx] [app.main.ui.context :as ctx]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.hooks :as hooks] [app.main.ui.hooks :as hooks]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.main.ui.workspace.sidebar.options.menus.typography :refer [text-options [app.main.ui.workspace.sidebar.options.menus.typography :refer [text-options*
typography-entry]] typography-entry*]]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[app.util.text.ui :as txu] [app.util.text.ui :as txu]
@ -35,96 +35,99 @@
[potok.v2.core :as ptk] [potok.v2.core :as ptk]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(mf/defc text-align-options (mf/defc text-align-options*
[{:keys [values on-change on-blur] :as props}] [{:keys [values on-change on-blur]}]
(let [{:keys [text-align]} values (let [{:keys [text-align]} values
handle-change handle-change
(mf/use-fn (mf/use-fn
(mf/deps on-change on-blur) (mf/deps on-change on-blur)
(fn [value] (fn [value]
(on-change {:text-align value}) (on-change {:text-align value})
(when (some? on-blur) (on-blur))))] (when (some? on-blur)
(on-blur))))]
;; --- Align [:> radio-buttons* {:class (stl/css :align-options)
[:div {:class (stl/css :align-options)} :selected text-align
[:& radio-buttons {:selected text-align
:on-change handle-change :on-change handle-change
:name "align-text-options"} :name "align-text-options"
[:& radio-button {:value "left" :options [{:id "text-align-left"
:id "text-align-left" :icon i/text-align-left
:title (tr "workspace.options.text-options.text-align-left") :label (tr "workspace.options.text-options.text-align-left")
:icon i/text-align-left}] :value "left"}
[:& radio-button {:value "center" {:id "text-align-center"
:id "text-align-center" :icon i/text-align-center
:title (tr "workspace.options.text-options.text-align-center") :label (tr "workspace.options.text-options.text-align-center")
:icon i/text-align-center}] :value "center"}
[:& radio-button {:value "right" {:id "text-align-right"
:id "text-align-right" :icon i/text-align-right
:title (tr "workspace.options.text-options.text-align-right") :label (tr "workspace.options.text-options.text-align-right")
:icon i/text-align-right}] :value "right"}
[:& radio-button {:value "justify" {:id "text-align-justify"
:id "text-align-justify" :icon i/text-justify
:title (tr "workspace.options.text-options.text-align-justify") :label (tr "workspace.options.text-options.text-align-justify")
:icon i/text-justify}]]])) :value "justify"}]}]))
(mf/defc text-direction-options (mf/defc text-direction-options*
[{:keys [values on-change on-blur] :as props}] [{:keys [values on-change on-blur]}]
(let [direction (:text-direction values) (let [direction (:text-direction values)
handle-change handle-change
(mf/use-fn (mf/use-fn
(mf/deps on-change on-blur direction) (mf/deps on-change on-blur direction)
(fn [value] (fn [value]
(let [dir (if (= value direction) (let [dir (if (= value direction) "none" value)]
"none"
value)]
(on-change {:text-direction dir}) (on-change {:text-direction dir})
(when (some? on-blur) (on-blur)))))] (when (some? on-blur)
(on-blur)))))]
[:div {:class (stl/css :text-direction-options)} [:> radio-buttons* {:class (stl/css :text-direction-options)
[:& radio-buttons {:selected direction :selected direction
:on-change handle-change :on-change handle-change
:name "text-direction-options"} :allow-empty true
[:& radio-button {:value "ltr" :name "text-direction-options"
:type "checkbox" :options [{:id "ltr-text-direction"
:id "ltr-text-direction" :icon i/text-ltr
:title (tr "workspace.options.text-options.direction-ltr") :label (tr "workspace.options.text-options.direction-ltr")
:icon i/text-ltr}] :value "ltr"}
[:& radio-button {:value "rtl" {:id "rtl-text-direction"
:type "checkbox" :icon i/text-rtl
:id "rtl-text-direction" :label (tr "workspace.options.text-options.direction-rtl")
:title (tr "workspace.options.text-options.direction-rtl") :value "rtl"}]}]))
:icon i/text-rtl}]]]))
(mf/defc vertical-align (mf/defc vertical-align*
[{:keys [values on-change on-blur] :as props}] [{:keys [values on-change on-blur]}]
(let [{:keys [vertical-align]} values (let [{:keys [vertical-align]} values
vertical-align (or vertical-align "top") vertical-align (or vertical-align "top")
handle-change handle-change
(mf/use-fn (mf/use-fn
(mf/deps on-change on-blur) (mf/deps on-change on-blur)
(fn [value] (fn [value]
(on-change {:vertical-align value}) (on-change {:vertical-align value})
(when (some? on-blur) (on-blur))))] (when (some? on-blur)
(on-blur))))]
[:div {:class (stl/css :vertical-align-options)} [:> radio-buttons* {:class (stl/css :vertical-align-options)
[:& radio-buttons {:selected vertical-align :selected vertical-align
:on-change handle-change :on-change handle-change
:name "vertical-align-text-options"} :name "vertical-align-text-options"
[:& radio-button {:value "top" :options [{:id "vertical-text-align-top"
:id "vertical-text-align-top" :icon i/text-top
:title (tr "workspace.options.text-options.align-top") :label (tr "workspace.options.text-options.align-top")
:icon i/text-top}] :value "top"}
[:& radio-button {:value "center" {:id "vertical-text-align-center"
:id "vertical-text-align-center" :icon i/text-middle
:title (tr "workspace.options.text-options.align-middle") :label (tr "workspace.options.text-options.align-middle")
:icon i/text-middle}] :value "center"}
[:& radio-button {:value "bottom" {:id "vertical-text-align-bottom"
:id "vertical-text-align-bottom" :icon i/text-bottom
:title (tr "workspace.options.text-options.align-bottom") :label (tr "workspace.options.text-options.align-bottom")
:icon i/text-bottom}]]])) :value "bottom"}]}]))
(mf/defc grow-options (mf/defc grow-options*
[{:keys [ids values on-blur] :as props}] [{:keys [ids values on-blur]}]
(let [grow-type (:grow-type values) (let [grow-type (:grow-type values)
handle-change-grow handle-change-grow
@ -141,55 +144,56 @@
(st/emit! (dwt/resize-wasm-text-all ids))) (st/emit! (dwt/resize-wasm-text-all ids)))
;; We asynchronously commit so every sychronous event is resolved first and inside the transaction ;; We asynchronously commit so every sychronous event is resolved first and inside the transaction
(ts/schedule #(st/emit! (dwu/commit-undo-transaction uid)))) (ts/schedule #(st/emit! (dwu/commit-undo-transaction uid))))
(when (some? on-blur) (on-blur))))] (when (some? on-blur)
(on-blur))))]
[:div {:class (stl/css :grow-options)} [:> radio-buttons* {:class (stl/css :grow-options)
[:& radio-buttons {:selected (d/name grow-type) :selected (d/name grow-type)
:on-change handle-change-grow :on-change handle-change-grow
:name "grow-text-options"} :name "grow-text-options"
[:& radio-button {:value "fixed" :options [{:id "text-fixed-grow"
:id "text-fixed-grow" :icon i/text-fixed
:title (tr "workspace.options.text-options.grow-fixed") :label (tr "workspace.options.text-options.grow-fixed")
:icon i/text-fixed}] :value "fixed"}
[:& radio-button {:value "auto-width" {:id "text-auto-width-grow"
:id "text-auto-width-grow" :icon i/text-auto-width
:title (tr "workspace.options.text-options.grow-auto-width") :label (tr "workspace.options.text-options.grow-auto-width")
:icon i/text-auto-width}] :value "auto-width"}
[:& radio-button {:value "auto-height" {:id "text-auto-height-grow"
:id "text-auto-height-grow" :icon i/text-auto-height
:title (tr "workspace.options.text-options.grow-auto-height") :label (tr "workspace.options.text-options.grow-auto-height")
:icon i/text-auto-height}]]])) :value "auto-height"}]}]))
(mf/defc text-decoration-options (mf/defc text-decoration-options*
[{:keys [values on-change on-blur] :as props}] [{:keys [values on-change on-blur]}]
(let [text-decoration (or (:text-decoration values) "none") (let [text-decoration (or (:text-decoration values) "none")
handle-change handle-change
(mf/use-fn (mf/use-fn
(mf/deps on-change on-blur text-decoration) (mf/deps on-change on-blur text-decoration)
(fn [value] (fn [value]
(let [decoration (if (= value text-decoration) (let [decoration (if (= value text-decoration) "none" value)]
"none"
value)]
(on-change {:text-decoration decoration}) (on-change {:text-decoration decoration})
(when (some? on-blur) (on-blur)))))] (when (some? on-blur)
[:div {:class (stl/css :text-decoration-options)} (on-blur)))))]
[:& radio-buttons {:selected text-decoration
:on-change handle-change
:name "text-decoration-options"}
[:& radio-button {:value "underline"
:type "checkbox"
:id "underline-text-decoration"
:title (tr "workspace.options.text-options.underline" (sc/get-tooltip :underline))
:icon i/text-underlined}]
[:& radio-button {:value "line-through"
:type "checkbox"
:id "line-through-text-decoration"
:title (tr "workspace.options.text-options.strikethrough" (sc/get-tooltip :line-through))
:icon i/text-stroked}]]]))
(mf/defc text-menu [:> radio-buttons* {:class (stl/css :text-decoration-options)
:selected text-decoration
:on-change handle-change
:name "grow-text-options"
:allow-empty true
:options [{:id "underline-text-decoration"
:icon i/text-underlined
:label (tr "workspace.options.text-options.underline" (sc/get-tooltip :underline))
:value "underline"}
{:id "line-through-text-decoration"
:icon i/text-stroked
:label (tr "workspace.options.text-options.strikethrough" (sc/get-tooltip :line-through))
:value "line-through"}]}]))
(mf/defc text-menu*
{::mf/wrap [mf/memo]} {::mf/wrap [mf/memo]}
[{:keys [ids type values] :as props}] [{:keys [ids type values]}]
(let [file-id (mf/use-ctx ctx/current-file-id) (let [file-id (mf/use-ctx ctx/current-file-id)
typographies (mf/deref refs/workspace-file-typography) typographies (mf/deref refs/workspace-file-typography)
@ -282,7 +286,8 @@
multiple? (->> values vals (d/seek #(= % :multiple))) multiple? (->> values vals (d/seek #(= % :multiple)))
opts #js {:ids ids props
(mf/props {:ids ids
:values values :values values
:on-change on-change :on-change on-change
:show-recent true :show-recent true
@ -293,7 +298,7 @@
(fn [] (fn []
(when (not= "INPUT" (-> (dom/get-active) (dom/get-tag-name))) (when (not= "INPUT" (-> (dom/get-active) (dom/get-tag-name)))
(let [node (txu/get-text-editor-content)] (let [node (txu/get-text-editor-content)]
(dom/focus! node))))))}] (dom/focus! node))))))})]
(hooks/use-stream (hooks/use-stream
expand-stream expand-stream
#(swap! state* assoc-in [:more-options] true)) #(swap! state* assoc-in [:more-options] true))
@ -315,7 +320,7 @@
[:div {:class (stl/css :element-content)} [:div {:class (stl/css :element-content)}
(cond (cond
typography typography
[:& typography-entry {:file-id typography-file-id [:> typography-entry* {:file-id typography-file-id
:typography typography :typography typography
:local? (= typography-file-id file-id) :local? (= typography-file-id file-id)
:on-detach handle-detach-typography :on-detach handle-detach-typography
@ -330,19 +335,20 @@
deprecated-icon/detach]] deprecated-icon/detach]]
:else :else
[:> text-options opts]) [:> text-options* props])
[:div {:class (stl/css :text-align-options)} [:div {:class (stl/css :text-align-options)}
[:> text-align-options opts] [:> text-align-options* props]
[:> grow-options opts] [:> grow-options* props]
[:> icon-button* {:variant "ghost" [:> icon-button* {:variant "ghost"
:aria-label (tr "labels.options") :aria-label (tr "labels.options")
:aria-pressed more-options-open?
:data-testid "text-align-options-button" :data-testid "text-align-options-button"
:on-click toggle-more-options :on-click toggle-more-options
:icon i/menu}]] :icon i/menu}]]
(when more-options-open? (when more-options-open?
[:div {:class (stl/css :text-decoration-options)} [:div {:class (stl/css :text-decoration-options)}
[:> vertical-align opts] [:> vertical-align* props]
[:> text-decoration-options opts] [:> text-decoration-options* props]
[:> text-direction-options opts]])])])) [:> text-direction-options* props]])])]))

View File

@ -22,10 +22,10 @@
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.editable-select :refer [editable-select]] [app.main.ui.components.editable-select :refer [editable-select]]
[app.main.ui.components.numeric-input :refer [numeric-input*]] [app.main.ui.components.numeric-input :refer [numeric-input*]]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.components.search-bar :refer [search-bar*]] [app.main.ui.components.search-bar :refer [search-bar*]]
[app.main.ui.components.select :refer [select]] [app.main.ui.components.select :refer [select]]
[app.main.ui.context :as ctx] [app.main.ui.context :as ctx]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.util.dom :as dom] [app.util.dom :as dom]
@ -422,27 +422,24 @@
(on-change {:text-transform type})) (on-change {:text-transform type}))
(when (some? on-blur) (on-blur)))] (when (some? on-blur) (on-blur)))]
[:div {:class (stl/css :text-transform)} [:> radio-buttons* {:selected text-transform
[:& radio-buttons {:selected text-transform
:on-change handle-change :on-change handle-change
:name "text-transform"} :name "text-transform"
[:& radio-button {:icon i/text-uppercase :allow-empty true
:type "checkbox" :options [{:id "text-transform-uppercase"
:title (tr "inspect.attributes.typography.text-transform.uppercase") :icon i/text-uppercase
:value "uppercase" :label (tr "inspect.attributes.typography.text-transform.uppercase")
:id "text-transform-uppercase"}] :value "uppercase"}
[:& radio-button {:icon i/text-mixed {:id "text-transform-capitalize"
:type "checkbox" :icon i/text-mixed
:value "capitalize" :label (tr "inspect.attributes.typography.text-transform.capitalize")
:title (tr "inspect.attributes.typography.text-transform.capitalize") :value "capitalize"}
:id "text-transform-capitalize"}] {:id "text-transform-lowercase"
[:& radio-button {:icon i/text-lowercase :icon i/text-lowercase
:type "checkbox" :label (tr "inspect.attributes.typography.text-transform.lowercase")
:title (tr "inspect.attributes.typography.text-transform.lowercase") :value "lowercase"}]}]))
:value "lowercase"
:id "text-transform-lowercase"}]]]))
(mf/defc text-options (mf/defc text-options*
{::mf/wrap-props false} {::mf/wrap-props false}
[{:keys [ids editor values on-change on-blur show-recent]}] [{:keys [ids editor values on-change on-blur show-recent]}]
(let [full-size-selector? (and show-recent (= (mf/use-ctx ctx/sidebar) :right)) (let [full-size-selector? (and show-recent (= (mf/use-ctx ctx/sidebar) :right))
@ -500,14 +497,13 @@
:on-click on-close} :on-click on-close}
deprecated-icon/tick]] deprecated-icon/tick]]
[:& text-options {:values typography [:> text-options* {:values typography
:on-change on-change :on-change on-change
:show-recent false}]] :show-recent false}]]
[:div {:class (stl/css :typography-info-wrapper)} [:div {:class (stl/css :typography-info-wrapper)}
[:div {:class (stl/css :typography-name-wrapper)} [:div {:class (stl/css :typography-name-wrapper)}
[:div {:class (stl/css :typography-sample) [:div {:class (stl/css :typography-sample)
:style {:font-family (:font-family typography) :style {:font-family (:font-family typography)
:font-weight (:font-weight typography) :font-weight (:font-weight typography)
:font-style (:font-style typography)}} :font-style (:font-style typography)}}
@ -547,7 +543,7 @@
:on-click navigate-to-library} :on-click navigate-to-library}
(tr "workspace.assets.typography.go-to-edit")])])]))) (tr "workspace.assets.typography.go-to-edit")])])])))
(mf/defc typography-entry (mf/defc typography-entry*
{::mf/wrap-props false} {::mf/wrap-props false}
[{:keys [file-id typography local? selected? on-click on-change on-detach on-context-menu editing? renaming? focus-name? external-open*]}] [{:keys [file-id typography local? selected? on-click on-change on-detach on-context-menu editing? renaming? focus-name? external-open*]}]
(let [name-input-ref (mf/use-ref) (let [name-input-ref (mf/use-ref)

View File

@ -324,15 +324,6 @@
} }
} }
} }
.text-transform {
@extend .asset-element;
width: fit-content;
padding: 0;
background-color: var(--radio-btns-background-color);
&:hover {
background-color: var(--radio-btns-background-color);
}
}
} }
} }

View File

@ -141,8 +141,9 @@
[:> icon-button* {:variant "secondary" [:> icon-button* {:variant "secondary"
:icon i/menu :icon i/menu
:class (stl/css-case :shadow-basic-button true :class (stl/css-case :shadow-basic-button true
:selected is-open) :hidden hidden?)
:aria-label "open more options" :aria-pressed is-open
:aria-label (tr "labels.options")
:disabled hidden? :disabled hidden?
:on-click on-toggle-open}] :on-click on-toggle-open}]
[:& select {:class (stl/css :shadow-basic-select) [:& select {:class (stl/css :shadow-basic-select)

View File

@ -43,14 +43,8 @@
.shadow-basic-button { .shadow-basic-button {
border-radius: $br-8 0 0 $br-8; border-radius: $br-8 0 0 $br-8;
&.hidden {
&.selected { border: deprecated.$s-1 solid var(--input-border-color-disabled);
--button-bg-color: var(--color-background-quaternary);
--button-fg-color: var(--color-accent-primary);
}
&:disabled {
border: $b-1 solid var(--color-background-quaternary);
} }
} }

View File

@ -169,7 +169,7 @@
[:& blur-menu {:type type :ids blur-ids :values blur-values}]) [:& blur-menu {:type type :ids blur-ids :values blur-values}])
(when-not (empty? text-ids) (when-not (empty? text-ids)
[:& ot/text-menu {:type type :ids text-ids :values text-values}]) [:> ot/text-menu* {:type type :ids text-ids :values text-values}])
(when-not (empty? svg-values) (when-not (empty? svg-values)
[:& svg-attrs-menu {:ids ids :values svg-values}]) [:& svg-attrs-menu {:ids ids :values svg-values}])

View File

@ -478,7 +478,7 @@
[:& constraints-menu {:ids constraint-ids :values constraint-values}]) [:& constraints-menu {:ids constraint-ids :values constraint-values}])
(when-not (empty? text-ids) (when-not (empty? text-ids)
[:& ot/text-menu {:type type :ids text-ids :values text-values}]) [:> ot/text-menu* {:type type :ids text-ids :values text-values}])
(when-not (empty? fill-ids) (when-not (empty? fill-ids)
[:> fill/fill-menu* {:type type [:> fill/fill-menu* {:type type

View File

@ -25,7 +25,7 @@
[app.main.ui.workspace.sidebar.options.menus.measures :refer [measure-attrs measures-menu*]] [app.main.ui.workspace.sidebar.options.menus.measures :refer [measure-attrs measures-menu*]]
[app.main.ui.workspace.sidebar.options.menus.shadow :refer [shadow-menu*]] [app.main.ui.workspace.sidebar.options.menus.shadow :refer [shadow-menu*]]
[app.main.ui.workspace.sidebar.options.menus.stroke :refer [stroke-attrs stroke-menu]] [app.main.ui.workspace.sidebar.options.menus.stroke :refer [stroke-attrs stroke-menu]]
[app.main.ui.workspace.sidebar.options.menus.text :refer [text-menu]] [app.main.ui.workspace.sidebar.options.menus.text :refer [text-menu*]]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(mf/defc options* (mf/defc options*
@ -160,8 +160,7 @@
{:ids ids {:ids ids
:values (select-keys shape constraint-attrs)}]) :values (select-keys shape constraint-attrs)}])
[:& text-menu [:> text-menu* {:ids ids
{:ids ids
:type type :type type
:values text-values}] :values text-values}]

View File

@ -12,14 +12,15 @@
[app.common.schema :as sm] [app.common.schema :as sm]
[app.common.types.token :as cto] [app.common.types.token :as cto]
[app.main.data.workspace.tokens.errors :as wte] [app.main.data.workspace.tokens.errors :as wte]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.forms :as forms] [app.main.ui.forms :as forms]
[app.main.ui.hooks :as hooks] [app.main.ui.hooks :as hooks]
[app.main.ui.workspace.tokens.management.forms.controls :as token.controls] [app.main.ui.workspace.tokens.management.forms.controls :as token.controls]
[app.main.ui.workspace.tokens.management.forms.generic-form :as generic] [app.main.ui.workspace.tokens.management.forms.generic-form :as generic]
[app.main.ui.workspace.tokens.management.forms.validators :refer [check-self-reference default-validate-token]] [app.main.ui.workspace.tokens.management.forms.validators :refer [check-self-reference
default-validate-token]]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :refer [tr]] [app.util.i18n :refer [tr]]
[beicon.v2.core :as rx] [beicon.v2.core :as rx]
@ -231,18 +232,17 @@
:aria-label (tr "workspace.tokens.shadow-add-shadow") :aria-label (tr "workspace.tokens.shadow-add-shadow")
:on-click on-add-shadow-block :on-click on-add-shadow-block
:icon i/add}] :icon i/add}]
[:& radio-buttons {:class (stl/css :listing-options) [:> radio-buttons* {:selected (d/name tab)
:selected (d/name tab)
:on-change handle-toggle :on-change handle-toggle
:name "reference-composite-tab"} :name "reference-composite-tab"
[:& radio-button {:icon i/layers :options [{:id "composite-opt"
:value "composite" :icon i/layers
:title (tr "workspace.tokens.individual-tokens") :label (tr "workspace.tokens.individual-tokens")
:id "composite-opt"}] :value "composite"}
[:& radio-button {:icon i/tokens {:id "reference-opt"
:value "reference" :icon i/tokens
:title (tr "workspace.tokens.use-reference") :label (tr "workspace.tokens.use-reference")
:id "reference-opt"}]]] :value "reference"}]}]]
(if (= tab :composite) (if (= tab :composite)
[:> composite-form* {:token token [:> composite-form* {:token token

View File

@ -12,11 +12,13 @@
[app.common.schema :as sm] [app.common.schema :as sm]
[app.common.types.token :as cto] [app.common.types.token :as cto]
[app.main.data.workspace.tokens.errors :as wte] [app.main.data.workspace.tokens.errors :as wte]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]] [app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.foundations.assets.icon :as i] [app.main.ui.ds.foundations.assets.icon :as i]
[app.main.ui.workspace.tokens.management.forms.controls :as token.controls] [app.main.ui.workspace.tokens.management.forms.controls :as token.controls]
[app.main.ui.workspace.tokens.management.forms.generic-form :as generic] [app.main.ui.workspace.tokens.management.forms.generic-form :as generic]
[app.main.ui.workspace.tokens.management.forms.validators :refer [check-coll-self-reference check-self-reference default-validate-token]] [app.main.ui.workspace.tokens.management.forms.validators :refer [check-coll-self-reference
check-self-reference
default-validate-token]]
[app.util.i18n :refer [tr]] [app.util.i18n :refer [tr]]
[beicon.v2.core :as rx] [beicon.v2.core :as rx]
[cuerdas.core :as str] [cuerdas.core :as str]
@ -185,18 +187,17 @@
[:* [:*
[:div {:class (stl/css :title-bar)} [:div {:class (stl/css :title-bar)}
[:div {:class (stl/css :title)} (tr "labels.typography")] [:div {:class (stl/css :title)} (tr "labels.typography")]
[:& radio-buttons {:class (stl/css :listing-options) [:> radio-buttons* {:selected (d/name tab)
:selected (d/name tab)
:on-change handle-toggle :on-change handle-toggle
:name "reference-composite-tab"} :name "reference-composite-tab"
[:& radio-button {:icon i/layers :options [{:id "composite-opt"
:value "composite" :icon i/layers
:title (tr "workspace.tokens.individual-tokens") :label (tr "workspace.tokens.individual-tokens")
:id "composite-opt"}] :value "composite"}
[:& radio-button {:icon i/tokens {:id "reference-opt"
:value "reference" :icon i/tokens
:title (tr "workspace.tokens.use-reference") :label (tr "workspace.tokens.use-reference")
:id "reference-opt"}]]] :value "reference"}]}]]
[:div {:class (stl/css :inputs-wrapper)} [:div {:class (stl/css :inputs-wrapper)}
(if (= tab :composite) (if (= tab :composite)
[:> composite-form* {:token token [:> composite-form* {:token token

View File

@ -16,11 +16,11 @@
[app.main.data.workspace.tokens.library-edit :as dwtl] [app.main.data.workspace.tokens.library-edit :as dwtl]
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.radio-buttons :refer [radio-button radio-buttons]]
[app.main.ui.ds.buttons.button :refer [button*]] [app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.ds.buttons.icon-button :refer [icon-button*]] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.controls.combobox :refer [combobox*]] [app.main.ui.ds.controls.combobox :refer [combobox*]]
[app.main.ui.ds.controls.input :refer [input*]] [app.main.ui.ds.controls.input :refer [input*]]
[app.main.ui.ds.controls.radio-buttons :refer [radio-buttons*]]
[app.main.ui.ds.controls.utilities.label :refer [label*]] [app.main.ui.ds.controls.utilities.label :refer [label*]]
[app.main.ui.ds.foundations.assets.icon :refer [icon*] :as i] [app.main.ui.ds.foundations.assets.icon :refer [icon*] :as i]
[app.main.ui.ds.foundations.typography.heading :refer [heading*]] [app.main.ui.ds.foundations.typography.heading :refer [heading*]]
@ -85,20 +85,20 @@
:on-click create-theme} :on-click create-theme}
(tr "workspace.tokens.add-new-theme")]]]])) (tr "workspace.tokens.add-new-theme")]]]]))
(mf/defc switch (mf/defc switch*
[{:keys [selected? name on-change]}] [{:keys [selected? name on-change]}]
(let [selected (if selected? :on :off)] (let [selected (if selected? :on :off)]
[:& radio-buttons {:selected selected [:> radio-buttons* {:selected selected
:on-change on-change :on-change on-change
:name name} :name name
[:& radio-button {:id :on :options [{:id "on"
:value :on
:icon i/tick :icon i/tick
:label ""}] :label (tr "workspace.tokens.theme.enable")
[:& radio-button {:id :off :value :on}
:value :off {:id "off"
:icon i/close :icon i/close
:label ""}]])) :label (tr "workspace.tokens.theme.disable")
:value :off}]}]))
(mf/defc themes-overview (mf/defc themes-overview
[{:keys [change-view]}] [{:keys [change-view]}]
@ -151,7 +151,7 @@
(dom/prevent-default e) (dom/prevent-default e)
(dom/stop-propagation e) (dom/stop-propagation e)
(st/emit! (dwtl/toggle-token-theme-active id)))} (st/emit! (dwtl/toggle-token-theme-active id)))}
[:& switch {:name (tr "workspace.tokens.theme-name" name) [:> switch* {:name (tr "workspace.tokens.theme-name" name)
:on-change (constantly nil) :on-change (constantly nil)
:selected? selected?}]]] :selected? selected?}]]]
[:div {:class (stl/css :theme-name-row)} [:div {:class (stl/css :theme-name-row)}

View File

@ -17,9 +17,10 @@
[app.main.features :as features] [app.main.features :as features]
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.components.file-uploader :refer [file-uploader]] [app.main.ui.components.file-uploader :refer [file-uploader*]]
[app.main.ui.context :as ctx] [app.main.ui.context :as ctx]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[app.util.timers :as ts] [app.util.timers :as ts]
@ -27,7 +28,7 @@
[potok.v2.core :as ptk] [potok.v2.core :as ptk]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(mf/defc image-upload (mf/defc image-upload*
{::mf/wrap [mf/memo]} {::mf/wrap [mf/memo]}
[] []
(let [ref (mf/use-ref nil) (let [ref (mf/use-ref nil)
@ -53,14 +54,13 @@
:position (gpt/point x y)}] :position (gpt/point x y)}]
(st/emit! (dwm/upload-media-workspace params)))))] (st/emit! (dwm/upload-media-workspace params)))))]
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.toolbar.image" (sc/get-tooltip :insert-image)) :class (stl/css :main-toolbar-options-button)
:icon i/img
:aria-label (tr "workspace.toolbar.image" (sc/get-tooltip :insert-image)) :aria-label (tr "workspace.toolbar.image" (sc/get-tooltip :insert-image))
:on-click on-click :tooltip-placement "bottom"
:class (stl/css :main-toolbar-options-button)} :on-click on-click}
deprecated-icon/img [:> file-uploader* {:input-id "image-upload"
[:& file-uploader
{:input-id "image-upload"
:accept dwm/accept-image-types :accept dwm/accept-image-types
:multi true :multi true
:ref ref :ref ref
@ -136,98 +136,104 @@
[:ul {:class (stl/css :main-toolbar-options) [:ul {:class (stl/css :main-toolbar-options)
:data-testid "toolbar-options"} :data-testid "toolbar-options"}
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.toolbar.move" (sc/get-tooltip :move)) :class (stl/css :main-toolbar-options-button)
:icon i/move
:aria-pressed (and (nil? drawtool) (not edition))
:aria-label (tr "workspace.toolbar.move" (sc/get-tooltip :move)) :aria-label (tr "workspace.toolbar.move" (sc/get-tooltip :move))
:class (stl/css-case :main-toolbar-options-button true :tooltip-placement "bottom"
:selected (and (nil? drawtool) :on-click interrupt}]]
(not edition)))
:on-click interrupt}
deprecated-icon/move]]
[:* [:*
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title test-tooltip-board-text :class (stl/css :main-toolbar-options-button)
:aria-label (tr "workspace.toolbar.frame" (sc/get-tooltip :draw-frame)) :icon i/board
:class (stl/css-case :main-toolbar-options-button true :selected (= drawtool :frame)) :aria-pressed (= drawtool :frame)
:aria-label test-tooltip-board-text
:tooltip-placement "bottom"
:on-click select-drawtool :on-click select-drawtool
:data-tool "frame" :data-tool "frame"
:data-testid "artboard-btn"} :data-testid "artboard-btn"}]]
deprecated-icon/board]]
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.toolbar.rect" (sc/get-tooltip :draw-rect)) :class (stl/css :main-toolbar-options-button)
:icon i/rectangle
:aria-pressed (= drawtool :rect)
:aria-label (tr "workspace.toolbar.rect" (sc/get-tooltip :draw-rect)) :aria-label (tr "workspace.toolbar.rect" (sc/get-tooltip :draw-rect))
:class (stl/css-case :main-toolbar-options-button true :selected (= drawtool :rect)) :tooltip-placement "bottom"
:on-click select-drawtool :on-click select-drawtool
:data-tool "rect" :data-tool "rect"
:data-testid "rect-btn"} :data-testid "rect-btn"}]]
deprecated-icon/rectangle]]
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.toolbar.ellipse" (sc/get-tooltip :draw-ellipse)) :class (stl/css :main-toolbar-options-button)
:icon i/elipse
:aria-pressed (= drawtool :circle)
:aria-label (tr "workspace.toolbar.ellipse" (sc/get-tooltip :draw-ellipse)) :aria-label (tr "workspace.toolbar.ellipse" (sc/get-tooltip :draw-ellipse))
:class (stl/css-case :main-toolbar-options-button true :selected (= drawtool :circle)) :tooltip-placement "bottom"
:on-click select-drawtool :on-click select-drawtool
:data-tool "circle" :data-tool "circle"
:data-testid "ellipse-btn"} :data-testid "ellipse-btn"}]]
deprecated-icon/elipse]]
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.toolbar.text" (sc/get-tooltip :draw-text)) :class (stl/css :main-toolbar-options-button)
:icon i/text
:aria-pressed (= drawtool :text)
:aria-label (tr "workspace.toolbar.text" (sc/get-tooltip :draw-text)) :aria-label (tr "workspace.toolbar.text" (sc/get-tooltip :draw-text))
:class (stl/css-case :main-toolbar-options-button true :selected (= drawtool :text)) :tooltip-placement "bottom"
:on-click select-drawtool :on-click select-drawtool
:data-tool "text"} :data-tool "text"
deprecated-icon/text]] :data-testid "text-btn"}]]
[:& image-upload] [:> image-upload*]
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.toolbar.curve" (sc/get-tooltip :draw-curve)) :class (stl/css :main-toolbar-options-button)
:icon i/curve
:aria-pressed (= drawtool :curve)
:aria-label (tr "workspace.toolbar.curve" (sc/get-tooltip :draw-curve)) :aria-label (tr "workspace.toolbar.curve" (sc/get-tooltip :draw-curve))
:class (stl/css-case :main-toolbar-options-button true :selected (= drawtool :curve)) :tooltip-placement "bottom"
:on-click select-drawtool :on-click select-drawtool
:data-tool "curve" :data-tool "curve"
:data-testid "curve-btn"} :data-testid "curve-btn"}]]
deprecated-icon/curve]]
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.toolbar.path" (sc/get-tooltip :draw-path)) :class (stl/css :main-toolbar-options-button)
:icon i/path
:aria-pressed (= drawtool :path)
:aria-label (tr "workspace.toolbar.path" (sc/get-tooltip :draw-path)) :aria-label (tr "workspace.toolbar.path" (sc/get-tooltip :draw-path))
:class (stl/css-case :main-toolbar-options-button true :selected (= drawtool :path)) :tooltip-placement "bottom"
:on-click select-drawtool :on-click select-drawtool
:data-tool "path" :data-tool "path"
:data-testid "path-btn"} :data-testid "path-btn"}]]
deprecated-icon/path]]
(when (features/active-feature? @st/state "plugins/runtime") (when (features/active-feature? @st/state "plugins/runtime")
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title (tr "workspace.toolbar.plugins" (sc/get-tooltip :plugins))
:aria-label (tr "workspace.toolbar.plugins" (sc/get-tooltip :plugins))
:class (stl/css :main-toolbar-options-button) :class (stl/css :main-toolbar-options-button)
:icon i/puzzle
:aria-label (tr "workspace.toolbar.plugins" (sc/get-tooltip :plugins))
:tooltip-placement "bottom"
:on-click #(st/emit! :on-click #(st/emit!
(ptk/data-event ::ev/event {::ev/name "open-plugins-manager" (ptk/data-event ::ev/event {::ev/name "open-plugins-manager"
::ev/origin "workspace:toolbar"}) ::ev/origin "workspace:toolbar"})
(modal/show :plugin-management {})) (modal/show :plugin-management {}))
:data-tool "plugins" :data-tool "plugins"
:data-testid "plugins-btn"} :data-testid "plugins-btn"}]])
deprecated-icon/puzzle]])
(when *assert* (when *assert*
[:li [:li
[:button [:> icon-button* {:variant "ghost"
{:title "Debugging tool" :class (stl/css :main-toolbar-options-button)
:class (stl/css-case :main-toolbar-options-button true :selected (contains? layout :debug-panel)) :icon i/bug
:on-click toggle-debug-panel} :aria-pressed (contains? layout :debug-panel)
deprecated-icon/bug]])]] :aria-label "Debugging tool"
:tooltip-placement "bottom"
:on-click toggle-debug-panel}]])]]
[:button {:title (tr "workspace.toolbar.toggle-toolbar") [:button {:title (tr "workspace.toolbar.toggle-toolbar")
:aria-label (tr "workspace.toolbar.toggle-toolbar") :aria-label (tr "workspace.toolbar.toggle-toolbar")
:class (stl/css :toolbar-handler) :class (stl/css :toolbar-handler)
:on-click toggle-toolbar} :on-click toggle-toolbar}
[:div {:class (stl/css :toolbar-handler-btn)}]]]))) [:div {:class (stl/css :toolbar-handler-btn)}]]])))

View File

@ -54,6 +54,7 @@
align-items: center; align-items: center;
margin: 0; margin: 0;
opacity: deprecated.$op-10; opacity: deprecated.$op-10;
gap: var(--sp-xs);
transition: opacity 0.3s ease; transition: opacity 0.3s ease;
li { li {
@ -62,21 +63,8 @@
} }
.main-toolbar-options-button { .main-toolbar-options-button {
@extend .button-tertiary;
height: deprecated.$s-36; height: deprecated.$s-36;
width: deprecated.$s-36; width: deprecated.$s-36;
flex-shrink: 0;
border-radius: deprecated.$s-8;
margin: 0 deprecated.$s-2;
svg {
@extend .button-icon;
stroke: var(--color-foreground-secondary);
}
&.selected {
@extend .button-icon-selected;
}
} }
.toolbar-handler { .toolbar-handler {
@ -97,7 +85,3 @@
background-color: var(--palette-handler-background-color); background-color: var(--palette-handler-background-color);
} }
} }
ul.main-toolbar-panels {
display: none;
}

View File

@ -28,6 +28,7 @@
[app.main.refs :as refs] [app.main.refs :as refs]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.css-cursors :as cur] [app.main.ui.css-cursors :as cur]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.formats :as fmt] [app.main.ui.formats :as fmt]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.icons :as deprecated-icon]
[app.main.ui.workspace.viewport.viewport-ref :as uwvv] [app.main.ui.workspace.viewport.viewport-ref :as uwvv]
@ -59,10 +60,12 @@
[:div {:class (stl/css :grid-actions-container)} [:div {:class (stl/css :grid-actions-container)}
[:div {:class (stl/css :grid-actions-title)} [:div {:class (stl/css :grid-actions-title)}
(tr "workspace.layout_grid.editor.title") " " [:span {:stl/css :board-name} (:name shape)]] (tr "workspace.layout_grid.editor.title") " " [:span {:stl/css :board-name} (:name shape)]]
[:button {:class (stl/css :locate-btn) [:> button* {:variant "secondary"
:class (stl/css :action-btn)
:on-click #(st/emit! (dwge/locate-board (:id shape)))} :on-click #(st/emit! (dwge/locate-board (:id shape)))}
(tr "workspace.layout_grid.editor.top-bar.locate")] (tr "workspace.layout_grid.editor.top-bar.locate")]
[:button {:class (stl/css :done-btn) [:> button* {:variant "primary"
:class (stl/css :action-btn)
:on-click #(st/emit! (dw/clear-edition-mode))} :on-click #(st/emit! (dw/clear-edition-mode))}
(tr "workspace.layout_grid.editor.top-bar.done")]]]) (tr "workspace.layout_grid.editor.top-bar.done")]]])

View File

@ -138,18 +138,8 @@
padding-left: deprecated.$s-8; padding-left: deprecated.$s-8;
} }
.locate-btn { .action-btn {
@extend .button-secondary; padding: 0 var(--sp-xl);
text-transform: uppercase;
padding: deprecated.$s-8 deprecated.$s-20;
font-size: deprecated.$fs-11;
}
.done-btn {
@extend .button-primary;
text-transform: uppercase;
padding: deprecated.$s-8 deprecated.$s-20;
font-size: deprecated.$fs-11;
} }
.close-btn { .close-btn {

View File

@ -11,40 +11,11 @@
[app.main.data.workspace.path :as drp] [app.main.data.workspace.path :as drp]
[app.main.data.workspace.path.shortcuts :as sc] [app.main.data.workspace.path.shortcuts :as sc]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.icons :as deprecated-icon] [app.main.ui.ds.buttons.icon-button :refer [icon-button*]]
[app.main.ui.ds.foundations.assets.icon :as i]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(def ^:private pentool-icon
(deprecated-icon/icon-xref :pentool (stl/css :pentool-icon :pathbar-icon)))
(def ^:private move-icon
(deprecated-icon/icon-xref :move (stl/css :move-icon :pathbar-icon)))
(def ^:private add-icon
(deprecated-icon/icon-xref :add (stl/css :add-icon :pathbar-icon)))
(def ^:private remove-icon
(deprecated-icon/icon-xref :remove (stl/css :remove :pathbar-icon)))
(def ^:private merge-nodes-icon
(deprecated-icon/icon-xref :merge-nodes (stl/css :merge-nodes-icon :pathbar-icon)))
(def ^:private join-nodes-icon
(deprecated-icon/icon-xref :join-nodes (stl/css :join-nodes-icon :pathbar-icon)))
(def ^:private separate-nodes-icon
(deprecated-icon/icon-xref :separate-nodes (stl/css :separate-nodes-icon :pathbar-icon)))
(def ^:private to-corner-icon
(deprecated-icon/icon-xref :to-corner (stl/css :to-corner-icon :pathbar-icon)))
(def ^:private to-curve-icon
(deprecated-icon/icon-xref :to-curve (stl/css :to-curve-icon :pathbar-icon)))
(def ^:private snap-nodes-icon
(deprecated-icon/icon-xref :snap-nodes (stl/css :snap-nodes-icon :pathbar-icon)))
(defn check-enabled [content selected-points] (defn check-enabled [content selected-points]
(when content (when content
(let [segments (path.segm/get-segments-with-points content selected-points) (let [segments (path.segm/get-segments-with-points content selected-points)
@ -144,76 +115,91 @@
[:div {:class (stl/css :sub-actions) [:div {:class (stl/css :sub-actions)
:data-dont-clear-path true} :data-dont-clear-path true}
[:div {:class (stl/css :sub-actions-group)} [:div {:class (stl/css :sub-actions-group)}
;; Draw Mode ;; Draw Mode
[:button {:class (stl/css-case :is-toggled (= edit-mode :draw) [:> icon-button* {:variant "ghost"
:topbar-btn true) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.draw-nodes" (sc/get-tooltip :draw-nodes)) :icon i/pentool
:on-click on-select-draw-mode} :aria-pressed (= edit-mode :draw)
pentool-icon] :aria-label (tr "workspace.path.actions.draw-nodes" (sc/get-tooltip :draw-nodes))
:tooltip-placement "bottom"
:on-click on-select-draw-mode}]
;; Edit mode ;; Edit mode
[:button {:class (stl/css-case :is-toggled (= edit-mode :move) [:> icon-button* {:variant "ghost"
:topbar-btn true) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.move-nodes" (sc/get-tooltip :move-nodes)) :icon i/move
:on-click on-select-edit-mode} :aria-pressed (= edit-mode :move)
move-icon]] :aria-label (tr "workspace.path.actions.move-nodes" (sc/get-tooltip :move-nodes))
:tooltip-placement "bottom"
:on-click on-select-edit-mode}]]
[:div {:class (stl/css :sub-actions-group)} [:div {:class (stl/css :sub-actions-group)}
;; Add Node ;; Add Node
[:button {:disabled (not (:add-node enabled-buttons)) [:> icon-button* {:variant "ghost"
:class (stl/css :topbar-btn) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.add-node" (sc/get-tooltip :add-node)) :icon i/add
:on-click on-add-node} :aria-label (tr "workspace.path.actions.add-node" (sc/get-tooltip :add-node))
add-icon] :tooltip-placement "bottom"
:on-click on-add-node
:disabled (not (:add-node enabled-buttons))}]
;; Remove node ;; Remove node
[:button {:disabled (not (:remove-node enabled-buttons)) [:> icon-button* {:variant "ghost"
:class (stl/css :topbar-btn) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.delete-node" (sc/get-tooltip :delete-node)) :icon i/remove
:on-click on-remove-node} :aria-label (tr "workspace.path.actions.delete-node" (sc/get-tooltip :delete-node))
remove-icon]] :tooltip-placement "bottom"
:on-click on-remove-node
:disabled (not (:remove-node enabled-buttons))}]]
[:div {:class (stl/css :sub-actions-group)} [:div {:class (stl/css :sub-actions-group)}
;; Merge Nodes ;; Merge Nodes
[:button {:disabled (not (:merge-nodes enabled-buttons)) [:> icon-button* {:variant "ghost"
:class (stl/css :topbar-btn) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.merge-nodes" (sc/get-tooltip :merge-nodes)) :icon i/merge-nodes
:on-click on-merge-nodes} :aria-label (tr "workspace.path.actions.merge-nodes" (sc/get-tooltip :merge-nodes))
merge-nodes-icon] :tooltip-placement "bottom"
:on-click on-merge-nodes
:disabled (not (:merge-nodes enabled-buttons))}]
;; Join Nodes ;; Join Nodes
[:button {:disabled (not (:join-nodes enabled-buttons)) [:> icon-button* {:variant "ghost"
:class (stl/css :topbar-btn) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.join-nodes" (sc/get-tooltip :join-nodes)) :icon i/join-nodes
:on-click on-join-nodes} :aria-label (tr "workspace.path.actions.join-nodes" (sc/get-tooltip :join-nodes))
join-nodes-icon] :tooltip-placement "bottom"
:on-click on-join-nodes
:disabled (not (:join-nodes enabled-buttons))}]
;; Separate Nodes ;; Separate Nodes
[:button {:disabled (not (:separate-nodes enabled-buttons)) [:> icon-button* {:variant "ghost"
:class (stl/css :topbar-btn) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.separate-nodes" (sc/get-tooltip :separate-nodes)) :icon i/separate-nodes
:on-click on-separate-nodes} :aria-label (tr "workspace.path.actions.separate-nodes" (sc/get-tooltip :separate-nodes))
separate-nodes-icon]] :tooltip-placement "bottom"
:on-click on-separate-nodes
:disabled (not (:separate-nodes enabled-buttons))}]]
[:div {:class (stl/css :sub-actions-group)} [:div {:class (stl/css :sub-actions-group)}
; Make Corner ; Make Corner
[:button {:disabled (not (:make-corner enabled-buttons)) [:> icon-button* {:variant "ghost"
:class (stl/css :topbar-btn) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.make-corner" (sc/get-tooltip :make-corner)) :icon i/to-corner
:on-click on-make-corner} :aria-label (tr "workspace.path.actions.make-corner" (sc/get-tooltip :make-corner))
to-corner-icon] :tooltip-placement "bottom"
:on-click on-make-corner
:disabled (not (:make-corner enabled-buttons))}]
;; Make Curve ;; Make Curve
[:button {:disabled (not (:make-curve enabled-buttons)) [:> icon-button* {:variant "ghost"
:class (stl/css :topbar-btn) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.make-curve" (sc/get-tooltip :make-curve)) :icon i/to-curve
:on-click on-make-curve} :aria-label (tr "workspace.path.actions.make-curve" (sc/get-tooltip :make-curve))
to-curve-icon]] :tooltip-placement "bottom"
:on-click on-make-curve
:disabled (not (:make-curve enabled-buttons))}]]
[:div {:class (stl/css :sub-actions-group)} [:div {:class (stl/css :sub-actions-group)}
;; Toggle snap ;; Toggle snap
[:button {:class (stl/css-case :is-toggled snap-toggled [:> icon-button* {:variant "ghost"
:topbar-btn true) :class (stl/css :topbar-btn)
:title (tr "workspace.path.actions.snap-nodes" (sc/get-tooltip :snap-nodes)) :icon i/snap-nodes
:on-click on-toggle-snap} :aria-pressed snap-toggled
snap-nodes-icon]]])) :aria-label (tr "workspace.path.actions.snap-nodes" (sc/get-tooltip :snap-nodes))
:tooltip-placement "bottom"
:on-click on-toggle-snap}]]]))

View File

@ -34,27 +34,11 @@
align-items: center; align-items: center;
margin: 0; margin: 0;
opacity: deprecated.$op-10; opacity: deprecated.$op-10;
gap: var(--sp-xs);
transition: opacity 0.3s ease; transition: opacity 0.3s ease;
} }
.topbar-btn { .topbar-btn {
--pathbar-icon-color: var(--color-foreground-secondary);
@extend .button-tertiary;
height: deprecated.$s-36; height: deprecated.$s-36;
width: deprecated.$s-36; width: deprecated.$s-36;
flex-shrink: 0;
background-color: transparent;
border-radius: deprecated.$s-8;
border: none;
margin: 0 deprecated.$s-2;
&.is-toggled {
--pathbar-icon-color: var(--button-radio-foreground-color-active);
background-color: var(--button-radio-background-color-active);
}
.pathbar-icon {
@extend .button-icon;
stroke: var(--pathbar-icon-color);
}
} }

View File

@ -10,6 +10,7 @@
[app.main.data.workspace :as dw] [app.main.data.workspace :as dw]
[app.main.data.workspace.common :as dwc] [app.main.data.workspace.common :as dwc]
[app.main.store :as st] [app.main.store :as st]
[app.main.ui.ds.buttons.button :refer [button*]]
[app.main.ui.workspace.viewport.grid-layout-editor :refer [grid-edition-actions]] [app.main.ui.workspace.viewport.grid-layout-editor :refer [grid-edition-actions]]
[app.main.ui.workspace.viewport.path-actions :refer [path-actions*]] [app.main.ui.workspace.viewport.path-actions :refer [path-actions*]]
[app.util.i18n :as i18n :refer [tr]] [app.util.i18n :as i18n :refer [tr]]
@ -34,7 +35,8 @@
[:> i18n/tr-html* [:> i18n/tr-html*
{:tag-name "span" {:tag-name "span"
:content (tr "workspace.top-bar.view-only")}]] :content (tr "workspace.top-bar.view-only")}]]
[:button {:class (stl/css :done-btn) [:> button* {:variant "primary"
:class (stl/css :done-btn)
:on-click handle-close-view-mode} :on-click handle-close-view-mode}
(tr "workspace.top-bar.read-only.done")]]])) (tr "workspace.top-bar.read-only.done")]]]))

View File

@ -45,10 +45,7 @@
} }
.done-btn { .done-btn {
@extend .button-primary; padding: 0 var(--sp-xl);
text-transform: uppercase;
padding: deprecated.$s-8 deprecated.$s-20;
font-size: deprecated.$fs-11;
} }
.viewport-actions-no-rulers { .viewport-actions-no-rulers {

View File

@ -5168,6 +5168,10 @@ msgstr "Show interactions on click"
msgid "viewer.header.sitemap" msgid "viewer.header.sitemap"
msgstr "Sitemap" msgstr "Sitemap"
#: src/app/main/ui/viewer/header.cljs:185
msgid "viewer.header.edit-in-workspace"
msgstr "Edit in workspace"
#: src/app/main/ui/dashboard/team.cljs:1203 #: src/app/main/ui/dashboard/team.cljs:1203
msgid "webhooks.last-delivery.success" msgid "webhooks.last-delivery.success"
msgstr "Last delivery was successful." msgstr "Last delivery was successful."
@ -5393,6 +5397,10 @@ msgstr "Ungroup"
msgid "workspace.colorpicker.color-tokens" msgid "workspace.colorpicker.color-tokens"
msgstr "Color tokens" msgstr "Color tokens"
#: src/app/main/ui/workspace/colorpicker.cljs:434
msgid "workspace.colorpicker.get-color"
msgstr "Get color"
#: src/app/main/ui/workspace/sidebar/options/menus/component.cljs:506 #: src/app/main/ui/workspace/sidebar/options/menus/component.cljs:506
msgid "workspace.component.swap.loop-error" msgid "workspace.component.swap.loop-error"
msgstr "Components can't be nested inside themselves." msgstr "Components can't be nested inside themselves."
@ -5679,7 +5687,11 @@ msgstr "Full screen"
msgid "workspace.header.zoom-selected" msgid "workspace.header.zoom-selected"
msgstr "Zoom to selected" msgstr "Zoom to selected"
#: src/app/main/ui/workspace/sidebar/options/menus/grid_cell.cljs:274, src/app/main/ui/workspace/sidebar/options/menus/grid_cell.cljs:276, src/app/main/ui/workspace/sidebar/options/menus/layout_container.cljs:868 #: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:217
msgid "workspace.layout_grid.editor.margin.expand"
msgstr "Show 4 sided margin options"
#: src/app/main/ui/workspace/sidebar/options/menus/grid_cell.cljs:273, src/app/main/ui/workspace/sidebar/options/menus/grid_cell.cljs:275, src/app/main/ui/workspace/sidebar/options/menus/layout_container.cljs:868
msgid "workspace.layout_grid.editor.options.edit-grid" msgid "workspace.layout_grid.editor.options.edit-grid"
msgstr "Edit grid" msgstr "Edit grid"
@ -5731,6 +5743,30 @@ msgstr "Locate"
msgid "workspace.layout_grid.editor.top-bar.locate.tooltip" msgid "workspace.layout_grid.editor.top-bar.locate.tooltip"
msgstr "Locate grid layout" msgstr "Locate grid layout"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:234
msgid "workspace.layout_item.fix-width"
msgstr "Fix width"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:238
msgid "workspace.layout_item.width-100"
msgstr "Width 100%"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:242
msgid "workspace.layout_item.fit-content-horizontal"
msgstr "Fit content (Horizontal)"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:260
msgid "workspace.layout_item.fix-height"
msgstr "Fix height"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:264
msgid "workspace.layout_item.height-100"
msgstr "Height 100%"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:268
msgid "workspace.layout_item.fit-content-vertical"
msgstr "Fit content (Vertical)"
#: src/app/main/ui/workspace/libraries.cljs #: src/app/main/ui/workspace/libraries.cljs
#, unused #, unused
msgid "workspace.libraries.add" msgid "workspace.libraries.add"
@ -6331,7 +6367,31 @@ msgstr "After delay"
msgid "workspace.options.interaction-animation" msgid "workspace.options.interaction-animation"
msgstr "Animation" msgstr "Animation"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:383 #: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:609
msgid "workspace.options.interaction-animation-direction-right"
msgstr "Right"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:613
msgid "workspace.options.interaction-animation-direction-left"
msgstr "Left"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:617
msgid "workspace.options.interaction-animation-direction-down"
msgstr "Down"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:621
msgid "workspace.options.interaction-animation-direction-up"
msgstr "Up"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:595
msgid "workspace.options.interaction-animation-direction-in"
msgstr "In"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:599
msgid "workspace.options.interaction-animation-direction-out"
msgstr "Out"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:413
msgid "workspace.options.interaction-animation-dissolve" msgid "workspace.options.interaction-animation-dissolve"
msgstr "Dissolve" msgstr "Dissolve"
@ -6776,6 +6836,14 @@ msgstr "More color tokens"
msgid "workspace.options.opacity" msgid "workspace.options.opacity"
msgstr "Opacity" msgstr "Opacity"
#: src/app/main/ui/workspace/sidebar/options/menus/measures.cljs:457, frontend/src/app/main/ui/workspace/sidebar/options/drawing/frame.cljs:108
msgid "workspace.options.orientation.horizontal"
msgstr "Horizontal"
#: src/app/main/ui/workspace/sidebar/options/menus/measures.cljs:453, frontend/src/app/main/ui/workspace/sidebar/options/drawing/frame.cljs:104
msgid "workspace.options.orientation.vertical"
msgstr "Vertical"
#: src/app/main/ui/workspace/sidebar/options/shapes/frame.cljs, src/app/main/ui/workspace/sidebar/options/menus/measures.cljs #: src/app/main/ui/workspace/sidebar/options/shapes/frame.cljs, src/app/main/ui/workspace/sidebar/options/menus/measures.cljs
#, unused #, unused
msgid "workspace.options.position" msgid "workspace.options.position"
@ -7610,6 +7678,10 @@ msgstr "Layers"
msgid "workspace.sidebar.layers.components" msgid "workspace.sidebar.layers.components"
msgstr "Components" msgstr "Components"
#: src/app/main/ui/workspace/sidebar/layers.cljs:295
msgid "workspace.sidebar.layers.filter"
msgstr "Filter"
#: src/app/main/ui/workspace/sidebar/layers.cljs:311, src/app/main/ui/workspace/sidebar/layers.cljs:339 #: src/app/main/ui/workspace/sidebar/layers.cljs:311, src/app/main/ui/workspace/sidebar/layers.cljs:339
msgid "workspace.sidebar.layers.frames" msgid "workspace.sidebar.layers.frames"
msgstr "Boards" msgstr "Boards"
@ -8209,7 +8281,15 @@ msgstr "none | uppercase | lowercase | capitalize or {alias}"
msgid "workspace.tokens.text-decoration-value-enter" msgid "workspace.tokens.text-decoration-value-enter"
msgstr "none | underline | strike-through or {alias}" msgstr "none | underline | strike-through or {alias}"
#: src/app/main/ui/workspace/tokens/themes/create_modal.cljs:154 #: src/app/main/ui/workspace/tokens/themes/create_modal.cljs:100
msgid "workspace.tokens.theme.disable"
msgstr "Disable"
#: src/app/main/ui/workspace/tokens/themes/create_modal.cljs:96
msgid "workspace.tokens.theme.enable"
msgstr "Enable"
#: src/app/main/ui/workspace/tokens/themes/create_modal.cljs:155
msgid "workspace.tokens.theme-name" msgid "workspace.tokens.theme-name"
msgstr "Theme %s" msgstr "Theme %s"

View File

@ -5147,6 +5147,10 @@ msgstr "Mostrar interacciones al hacer click"
msgid "viewer.header.sitemap" msgid "viewer.header.sitemap"
msgstr "Mapa del sitio" msgstr "Mapa del sitio"
#: src/app/main/ui/viewer/header.cljs:185
msgid "viewer.header.edit-in-workspace"
msgstr "Editar en el espacio de trabajo"
#: src/app/main/ui/dashboard/team.cljs:1203 #: src/app/main/ui/dashboard/team.cljs:1203
msgid "webhooks.last-delivery.success" msgid "webhooks.last-delivery.success"
msgstr "El último envío fue correcto." msgstr "El último envío fue correcto."
@ -5374,6 +5378,10 @@ msgstr "Desagrupar"
msgid "workspace.colorpicker.color-tokens" msgid "workspace.colorpicker.color-tokens"
msgstr "Tokens de color" msgstr "Tokens de color"
#: src/app/main/ui/workspace/colorpicker.cljs:434
msgid "workspace.colorpicker.get-color"
msgstr "Absorber color"
#: src/app/main/ui/workspace/sidebar/options/menus/component.cljs:506 #: src/app/main/ui/workspace/sidebar/options/menus/component.cljs:506
msgid "workspace.component.swap.loop-error" msgid "workspace.component.swap.loop-error"
msgstr "Los componentes no pueden anidarse dentro de sí mismos." msgstr "Los componentes no pueden anidarse dentro de sí mismos."
@ -5655,7 +5663,11 @@ msgstr "Pantalla completa"
msgid "workspace.header.zoom-selected" msgid "workspace.header.zoom-selected"
msgstr "Zoom a selección" msgstr "Zoom a selección"
#: src/app/main/ui/workspace/sidebar/options/menus/grid_cell.cljs:274, src/app/main/ui/workspace/sidebar/options/menus/grid_cell.cljs:276, src/app/main/ui/workspace/sidebar/options/menus/layout_container.cljs:868 #: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:217
msgid "workspace.layout_grid.editor.margin.expand"
msgstr "Mostrar el margen a 4 lados"
#: src/app/main/ui/workspace/sidebar/options/menus/grid_cell.cljs:273, src/app/main/ui/workspace/sidebar/options/menus/grid_cell.cljs:275, src/app/main/ui/workspace/sidebar/options/menus/layout_container.cljs:868
msgid "workspace.layout_grid.editor.options.edit-grid" msgid "workspace.layout_grid.editor.options.edit-grid"
msgstr "Editar rejilla" msgstr "Editar rejilla"
@ -5707,6 +5719,30 @@ msgstr "Mostrar"
msgid "workspace.layout_grid.editor.top-bar.locate.tooltip" msgid "workspace.layout_grid.editor.top-bar.locate.tooltip"
msgstr "Mostrar grid layout" msgstr "Mostrar grid layout"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:234
msgid "workspace.layout_item.fix-width"
msgstr "Fijar anchura"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:238
msgid "workspace.layout_item.width-100"
msgstr "Anchura 100%"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:242
msgid "workspace.layout_item.fit-content-horizontal"
msgstr "Ajustar contenido (horizontal)"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:260
msgid "workspace.layout_item.fix-height"
msgstr "Fijar altura"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:264
msgid "workspace.layout_item.height-100"
msgstr "Altura 100%"
#: src/app/main/ui/workspace/sidebar/options/menus/layout_item.cljs:268
msgid "workspace.layout_item.fit-content-vertical"
msgstr "Ajustar contenido (vertical)"
#: src/app/main/ui/workspace/libraries.cljs #: src/app/main/ui/workspace/libraries.cljs
#, unused #, unused
msgid "workspace.libraries.add" msgid "workspace.libraries.add"
@ -6271,7 +6307,31 @@ msgstr "Tiempo"
msgid "workspace.options.interaction-animation" msgid "workspace.options.interaction-animation"
msgstr "Animación" msgstr "Animación"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:383 #: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:609
msgid "workspace.options.interaction-animation-direction-right"
msgstr "Derecha"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:613
msgid "workspace.options.interaction-animation-direction-left"
msgstr "Izquierda"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:617
msgid "workspace.options.interaction-animation-direction-down"
msgstr "Abajo"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:621
msgid "workspace.options.interaction-animation-direction-up"
msgstr "Arriba"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:595
msgid "workspace.options.interaction-animation-direction-in"
msgstr "Dentro"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:599
msgid "workspace.options.interaction-animation-direction-out"
msgstr "Fuera"
#: src/app/main/ui/workspace/sidebar/options/menus/interactions.cljs:413
msgid "workspace.options.interaction-animation-dissolve" msgid "workspace.options.interaction-animation-dissolve"
msgstr "Disolver" msgstr "Disolver"
@ -6716,6 +6776,14 @@ msgstr "Más tokens de color"
msgid "workspace.options.opacity" msgid "workspace.options.opacity"
msgstr "Opacidad" msgstr "Opacidad"
#: src/app/main/ui/workspace/sidebar/options/menus/measures.cljs:457, frontend/src/app/main/ui/workspace/sidebar/options/drawing/frame.cljs:108
msgid "workspace.options.orientation.horizontal"
msgstr "Horizontal"
#: src/app/main/ui/workspace/sidebar/options/menus/measures.cljs:453, frontend/src/app/main/ui/workspace/sidebar/options/drawing/frame.cljs:104
msgid "workspace.options.orientation.vertical"
msgstr "Vertical"
#: src/app/main/ui/workspace/sidebar/options/shapes/frame.cljs, src/app/main/ui/workspace/sidebar/options/menus/measures.cljs #: src/app/main/ui/workspace/sidebar/options/shapes/frame.cljs, src/app/main/ui/workspace/sidebar/options/menus/measures.cljs
#, unused #, unused
msgid "workspace.options.position" msgid "workspace.options.position"
@ -7554,6 +7622,10 @@ msgstr "Capas"
msgid "workspace.sidebar.layers.components" msgid "workspace.sidebar.layers.components"
msgstr "Componentes" msgstr "Componentes"
#: src/app/main/ui/workspace/sidebar/layers.cljs:295
msgid "workspace.sidebar.layers.filter"
msgstr "Filtrar"
#: src/app/main/ui/workspace/sidebar/layers.cljs:311, src/app/main/ui/workspace/sidebar/layers.cljs:339 #: src/app/main/ui/workspace/sidebar/layers.cljs:311, src/app/main/ui/workspace/sidebar/layers.cljs:339
msgid "workspace.sidebar.layers.frames" msgid "workspace.sidebar.layers.frames"
msgstr "Paneles" msgstr "Paneles"
@ -8088,7 +8160,15 @@ msgstr "none | uppercase | lowercase | capitalize o {alias}"
msgid "workspace.tokens.text-decoration-value-enter" msgid "workspace.tokens.text-decoration-value-enter"
msgstr "none | underline | strike-through o {alias}" msgstr "none | underline | strike-through o {alias}"
#: src/app/main/ui/workspace/tokens/themes/create_modal.cljs:154 #: src/app/main/ui/workspace/tokens/themes/create_modal.cljs:100
msgid "workspace.tokens.theme.disable"
msgstr "Deshabilitar"
#: src/app/main/ui/workspace/tokens/themes/create_modal.cljs:96
msgid "workspace.tokens.theme.enable"
msgstr "Habilitar"
#: src/app/main/ui/workspace/tokens/themes/create_modal.cljs:155
msgid "workspace.tokens.theme-name" msgid "workspace.tokens.theme-name"
msgstr "Tema %s" msgstr "Tema %s"