diff --git a/apps/zui/src/components/forms.module.css b/apps/zui/src/components/forms.module.css index 03edf44a8a..9e4e5b344c 100644 --- a/apps/zui/src/components/forms.module.css +++ b/apps/zui/src/components/forms.module.css @@ -1,188 +1,190 @@ .form label { - display: block; - font-weight: bold; - padding-left: var(--form-border-radius); + display: block; + font-weight: bold; + padding-left: var(--form-border-radius); } .form input, .form textarea, .form select { - display: block; - width: 100%; - height: var(--form-height); - border-radius: var(--form-border-radius); - background: var(--form-bg-color); - border: var(--form-border); - line-height: var(--form-line-height); - padding: var(--form-padding); + display: block; + width: 100%; + max-width: 100%; + overflow: hidden; + height: var(--form-height); + border-radius: var(--form-border-radius); + background: var(--form-bg-color); + border: var(--form-border); + line-height: var(--form-line-height); + padding: var(--form-padding); } .form input:focus-visible { - outline: none; - border-color: var(--primary-color); + outline: none; + border-color: var(--primary-color); } .form input:disabled { - background: var(--border-color); - background: transparent; - border-color: transparent; - color: currentColor; + background: var(--border-color); + background: transparent; + border-color: transparent; + color: currentColor; } .form fieldset { - border: none; - margin-left: 6px; - border-left: 1px solid var(--border-color); - padding: 18px; - display: grid; - gap: var(--form-field-gap); + border: none; + margin-left: 6px; + border-left: 1px solid var(--border-color); + padding: 18px; + display: grid; + gap: var(--form-field-gap); } .form .fields { - display: flex; - flex-direction: column; - gap: var(--form-field-gap); + display: flex; + flex-direction: column; + gap: var(--form-field-gap); } .form .horizontalFields { - flex-direction: column; - gap: var(--form-field-gap); - display: flex; + flex-direction: column; + gap: var(--form-field-gap); + display: flex; } -.form .horizontalFields>* { - display: flex; - justify-content: space-between; - width: 100%; +.form .horizontalFields > * { + display: flex; + justify-content: space-between; + width: 100%; } -.form .horizontalFields>*>*:not(label) { - max-width: 50%; +.form .horizontalFields > * > *:not(label) { + max-width: 50%; } .form select { - appearance: none; - background-image: url(/select-input-arrow.svg); - background-repeat: no-repeat; - background-size: 1.2em 1.2em; - background-position: calc(100% - 10px) center; + appearance: none; + background-image: url(/select-input-arrow.svg); + background-repeat: no-repeat; + background-size: 1.2em 1.2em; + background-position: calc(100% - 10px) center; } .form .cancel { - text-decoration: underline; - cursor: pointer; + text-decoration: underline; + cursor: pointer; } .form .submit { - height: var(--form-height); - border-radius: var(--form-border-radius); - background: var(--form-bg-color); - line-height: var(--form-line-height); - padding: var(--form-padding); - background: var(--primary-color); - border: 1px solid var(--primary-color-dark); - color: white; - font-weight: 500; - min-width: 80px; - user-select: none; + height: var(--form-height); + border-radius: var(--form-border-radius); + background: var(--form-bg-color); + line-height: var(--form-line-height); + padding: var(--form-padding); + background: var(--primary-color); + border: 1px solid var(--primary-color-dark); + color: white; + font-weight: 500; + min-width: 80px; + user-select: none; } .form .submit:hover:not(:disabled) { - background: var(--primary-color-dark); + background: var(--primary-color-dark); } .form .submit:active:not(:disabled) { - box-shadow: none; - transform: translateY(1px); + box-shadow: none; + transform: translateY(1px); } .form .button:active:not(:disabled) { - background: var(--primary-color-darker); + background: var(--primary-color-darker); } .form .button { - height: var(--form-height); - border-radius: var(--form-border-radius); - background: var(--form-bg-color); - line-height: var(--form-line-height); - padding: var(--form-padding); - border: 1px solid var(--border-color); - box-shadow: 0 3px 4px -4px var(--bg-color-less); - font-weight: 500; - min-width: 80px; - user-select: none; + height: var(--form-height); + border-radius: var(--form-border-radius); + background: var(--form-bg-color); + line-height: var(--form-line-height); + padding: var(--form-padding); + border: 1px solid var(--border-color); + box-shadow: 0 3px 4px -4px var(--bg-color-less); + font-weight: 500; + min-width: 80px; + user-select: none; } .form .button:hover:not(:disabled) { - background: var(--form-bg-color-dark); + background: var(--form-bg-color-dark); } .form .button:active:not(:disabled) { - background: var(--form-bg-color-darker); + background: var(--form-bg-color-darker); } .form .button:active:not(:disabled) { - box-shadow: none; - transform: translateY(1px); + box-shadow: none; + transform: translateY(1px); } .form .button:disabled, .form .submit:disabled { - opacity: 0.4; - cursor: no-drop + opacity: 0.4; + cursor: no-drop; } -.form input[type=checkbox] { - appearance: none; - margin: 0; - width: 1.15em; - height: 1.15em; - border-radius: 0.15em; +.form input[type="checkbox"] { + appearance: none; + margin: 0; + width: 1.15em; + height: 1.15em; + border-radius: 0.15em; } .form .actionLabel { - display: flex; - align-items: center; - justify-content: space-between; - padding-right: var(--form-border-radius); + display: flex; + align-items: center; + justify-content: space-between; + padding-right: var(--form-border-radius); } .form .actionLabel a { - text-decoration: underline; - cursor: pointer; - color: var(--fg-color-less); + text-decoration: underline; + cursor: pointer; + color: var(--fg-color-less); } .form .radioInput { - display: grid; - grid-template-columns: 1.1em auto; - align-items: center; - padding-top: 0; - padding: var(--form-padding); - height: 1.6em; + display: grid; + grid-template-columns: 1.1em auto; + align-items: center; + padding-top: 0; + padding: var(--form-padding); + height: 1.6em; } .form .radioInput label { - font-weight: 400; + font-weight: 400; } .form .submission { - display: flex; - justify-content: space-between; - margin-top: calc(var(--form-field-gap) * 3) + display: flex; + justify-content: space-between; + margin-top: calc(var(--form-field-gap) * 3); } .form .error { - background: #fde2d8; - color: #a81f07; - border-radius: 6px; - padding: 20px; - display: flex; - flex-direction: column; - gap: 10px; + background: #fde2d8; + color: #a81f07; + border-radius: 6px; + padding: 20px; + display: flex; + flex-direction: column; + gap: 10px; } .form input[readonly] { - border: none; - padding: 0 var(--form-border-radius); + border: none; + padding: 0 var(--form-border-radius); } diff --git a/apps/zui/src/components/tooltip.module.css b/apps/zui/src/components/tooltip.module.css index 458ab5dce3..2b6d4dcc84 100644 --- a/apps/zui/src/components/tooltip.module.css +++ b/apps/zui/src/components/tooltip.module.css @@ -1,17 +1,17 @@ .tooltip { - position: fixed; - top: 0; - right: 0; - padding-inline: 0.5rem; - padding-block: 0.1rem; - background: var(--bg-color); - border-radius: 3px; - width: fit-content; - z-index: 999; - pointer-events: none; - max-inline-size: var(--measure); - border: 1px solid var(--border-color-more); - box-shadow: - hsl(212 20% 10% / 0.25) 0 1px 3px -1px, - hsl(0 0% 0% / 0.21) 0 2px 10px -1px; + position: fixed; + top: 0; + right: 0; + padding-inline: 0.5rem; + padding-block: 0.1rem; + background: var(--bg-color); + border-radius: 3px; + width: fit-content; + z-index: 999; + pointer-events: none; + max-inline-size: var(--measure); + overflow-wrap: anywhere; + border: 1px solid var(--border-color-more); + box-shadow: hsl(212 20% 10% / 0.25) 0 1px 3px -1px, + hsl(0 0% 0% / 0.21) 0 2px 10px -1px; } diff --git a/apps/zui/src/css/_blocks.scss b/apps/zui/src/css/_blocks.scss new file mode 100644 index 0000000000..f71a1e52fa --- /dev/null +++ b/apps/zui/src/css/_blocks.scss @@ -0,0 +1,11 @@ +.field { + &>*+* { + margin-block-start: var(--s-3); + } +} + +.field-stack { + &>*+* { + margin-block-start: var(--s1); + } +} diff --git a/apps/zui/src/css/_global.scss b/apps/zui/src/css/_global.scss index 1d17a9345e..e87eeefb53 100644 --- a/apps/zui/src/css/_global.scss +++ b/apps/zui/src/css/_global.scss @@ -2,6 +2,7 @@ *::before, *::after { box-sizing: border-box; + overflow-wrap: break-word; } * { @@ -80,6 +81,7 @@ button { height: 0.75rem; } + *::-webkit-scrollbar-track { background-color: var(--emphasis-bg-less); } @@ -93,3 +95,11 @@ button { *::-webkit-scrollbar-corner { background-color: var(--emphasis-bg-less); } + +dt { + font-weight: bold; +} + +dd { + font-family: var(--mono-font); +} diff --git a/apps/zui/src/css/_layouts.scss b/apps/zui/src/css/_layouts.scss new file mode 100644 index 0000000000..7d83ba628d --- /dev/null +++ b/apps/zui/src/css/_layouts.scss @@ -0,0 +1,128 @@ +[class^="cluster"] { + display: flex; + flex-wrap: wrap; + gap: var(--s1); + justify-content: flex-start; + align-items: center; +} + +.cluster--4 { + gap: var(--s-4); +} + +.cluster--3 { + gap: var(--s-3); +} + +.cluster--2 { + gap: var(--s-2); +} + +.cluster--1 { + gap: var(--s-1); +} + +.cluster-0 { + gap: var(--s0); +} + +.cluster-1 { + gap: var(--s1); +} + +.cluster-2 { + gap: var(--s2); +} + +.cluster-3 { + gap: var(--s3); +} + +.cluster-4 { + gap: var(--s4); +} + +.cluster-5 { + gap: var(--s5); +} + + + + +[class^="stack"] { + display: flex; + flex-direction: column; + justify-content: flex-start; +} + +[class^="stack"]>* { + margin-block: 0; +} + +.stack--5>*+* { + margin-block-start: var(--s-5); +} + +.stack--4>*+* { + margin-block-start: var(--s-4); +} + +.stack--3>*+* { + margin-block-start: var(--s-3); +} + +.stack--2>*+* { + margin-block-start: var(--s-2); +} + +.stack--1>*+* { + margin-block-start: var(--s-1); +} + +.stack-0>*+* { + margin-block-start: var(--s0); +} + +.stack-1>*+* { + margin-block-start: var(--s1); +} + +.stack-2>*+* { + margin-block-start: var(--s2); +} + +.stack-3>*+* { + margin-block-start: var(--s3); +} + +.stack-4>*+* { + margin-block-start: var(--s4); +} + +.stack-5>*+* { + margin-block-start: var(--s5); +} + +.stack-6>*+* { + margin-block-start: var(--s6); +} + +.stack-7>*+* { + margin-block-start: var(--s7); +} + +.stack-8>*+* { + margin-block-start: var(--s8); +} + +.box-1 { + padding: var(--s1); +} + +.center { + margin-inline: auto; +} + +.flex { + display: flex; +} diff --git a/apps/zui/src/css/_utilities.scss b/apps/zui/src/css/_utilities.scss new file mode 100644 index 0000000000..dfd80adc07 --- /dev/null +++ b/apps/zui/src/css/_utilities.scss @@ -0,0 +1,75 @@ +.width\:measure { + inline-size: var(--measure); +} + +.max-width\:measure { + max-inline-size: var(--measure); +} + +.justify\:between { + justify-content: space-between; +} + +.align\:center { + align-items: center; +} + +.width\:viewport { + width: 100vw; +} + +.height\:viewport { + height: 100vh; +} + +.z\:1 { + z-index: 1; +} + +.z\:2 { + z-index: 2; +} + +.bg\:bg { + background-color: var(--bg-color); +} + +.bg\:backdrop { + background: rgba(0, 0, 0, var(--backdrop-transparency, 0.3)); +} + +.bg\:transparent { + background: transparent; +} + +.width\:fit { + inline-size: fit-content; +} + +.max-height\:viewport { + max-block-size: 100vh; +} + +.scroll\:y { + overflow-y: auto; +} + +.break\:all { + word-wrap: break-all; +} + +.overflow\:hidden { + overflow: hidden; +} + +.overflow-wrap\:anywhere { + overflow-wrap: anywhere; +} + +.border\:bottom { + border-bottom: 1px solid var(--border-color); +} + +.min-height\:full { + min-height: 100%; +} diff --git a/apps/zui/src/css/main.scss b/apps/zui/src/css/main.scss index f792fa04b6..49a0fb8b08 100644 --- a/apps/zui/src/css/main.scss +++ b/apps/zui/src/css/main.scss @@ -71,4 +71,9 @@ @import "results-pane"; @import "zed-view"; @import "modal-animation"; -@import "editor" +@import "editor"; + +// The CUBE Model +@import "layouts"; +@import "blocks"; +@import "utilities"; diff --git a/apps/zui/src/css/settings/_spacing.scss b/apps/zui/src/css/settings/_spacing.scss index 4e0030d59d..bd1345a9ed 100644 --- a/apps/zui/src/css/settings/_spacing.scss +++ b/apps/zui/src/css/settings/_spacing.scss @@ -7,3 +7,24 @@ $space-xs: 7.417px; $space-xxs: 4.584px; $bro-log-row-height: 25px; + + + +/* Sizing */ +:root { + --ratio: 1.35; + --s-5: calc(var(--s-4) / var(--ratio)); + --s-4: calc(var(--s-3) / var(--ratio)); + --s-3: calc(var(--s-2) / var(--ratio)); + --s-2: calc(var(--s-1) / var(--ratio)); + --s-1: calc(var(--s0) / var(--ratio)); + --s0: 1rem; + --s1: calc(var(--s0) * var(--ratio)); + --s2: calc(var(--s1) * var(--ratio)); + --s3: calc(var(--s2) * var(--ratio)); + --s4: calc(var(--s3) * var(--ratio)); + --s5: calc(var(--s4) * var(--ratio)); + --s6: calc(var(--s5) * var(--ratio)); + --s7: calc(var(--s6) * var(--ratio)); + --s8: calc(var(--s7) * var(--ratio)); +} diff --git a/apps/zui/src/views/pool-page/details.tsx b/apps/zui/src/views/pool-page/details.tsx index 98beca48c1..14ffab9715 100644 --- a/apps/zui/src/views/pool-page/details.tsx +++ b/apps/zui/src/views/pool-page/details.tsx @@ -1,13 +1,14 @@ import React from "react" import {Pool} from "src/app/core/pools/pool" import styles from "./details.module.css" +import classNames from "classnames" export function Details({pool}: {pool: Pool}) { const keys = pool.keys.map((k) => (k ? k.join(".") : "null")) return (

Pool Details

-
+
ID
{pool.id}
diff --git a/apps/zui/src/views/pool-page/index.module.css b/apps/zui/src/views/pool-page/index.module.css deleted file mode 100644 index efcc25b982..0000000000 --- a/apps/zui/src/views/pool-page/index.module.css +++ /dev/null @@ -1,27 +0,0 @@ -.page { - --page-padding: 32px; - --page-max-width: 990px; - width: 100%; - height: 100%; - overflow-y: auto; -} - -.wrap { - margin-left: auto; - margin-right: auto; - max-width: var(--page-max-width); -} - -.header { - position: sticky; - top: 0; - border-bottom: 1px solid var(--border-color); - background-color: var(--bg-color); -} - -.headerContent { - display: flex; - justify-content: space-between; - align-items: center; - padding: var(--page-padding); -} diff --git a/apps/zui/src/views/pool-page/index.tsx b/apps/zui/src/views/pool-page/index.tsx index 9ac795870c..6eca43e8ad 100644 --- a/apps/zui/src/views/pool-page/index.tsx +++ b/apps/zui/src/views/pool-page/index.tsx @@ -12,8 +12,6 @@ import {NotFound} from "./404" import {ButtonMenu} from "src/components/button-menu" import {RecentLoads} from "./recent-loads" import {Details} from "./details" -import styles from "./index.module.css" -import classNames from "classnames" const Toolbar = styled.div` display: flex; @@ -30,21 +28,6 @@ const Subtitle = styled.p` margin: 0; ` -const Body = styled.section` - height: 100%; - h4 { - margin-bottom: 6px; - opacity: 0.6; - } - dt { - font-weight: bold; - } - dd { - margin-bottom: 6px; - font-family: var(--mono-font); - } -` - export function InitPool({children}) { const dispatch = useDispatch() const poolId = usePoolId() @@ -68,11 +51,11 @@ export const Show = () => { const menu = poolToolbarMenu(pool) const isEmpty = pool.empty() return ( -
-
-
+
+
+
-

{pool.name}

+

{pool.name}

{isEmpty ? "This pool is empty." : bytes(pool.stats.size)} @@ -82,10 +65,10 @@ export const Show = () => {
- +
- +
) } diff --git a/apps/zui/src/views/session-page/footer.module.css b/apps/zui/src/views/session-page/footer.module.css index d9756c5d87..bf2824f593 100644 --- a/apps/zui/src/views/session-page/footer.module.css +++ b/apps/zui/src/views/session-page/footer.module.css @@ -1,28 +1,29 @@ .footer { - height: 2.625rem; - display: flex; - align-items: center; - justify-content: space-between; - padding: 0 10px; - box-shadow: 0 -1px 1px rgba(0, 0, 0, 0.1); - gap: 1rem; - z-index: 1; + height: 2.625rem; + display: flex; + align-items: center; + justify-content: space-between; + padding: 0 10px; + box-shadow: 0 -1px 1px rgba(0, 0, 0, 0.1); + gap: 1rem; + z-index: 1; + background-color: var(--bg-color); } .label { - text-transform: none; - letter-spacing: normal; - font-weight: normal; - font-size: 0.8rem; + text-transform: none; + letter-spacing: normal; + font-weight: normal; + font-size: 0.8rem; } -.footer [aria-pressed=true] .label { - font-weight: bold; +.footer [aria-pressed="true"] .label { + font-weight: bold; } .counts { - font-family: var(--mono-font); - display: flex; - white-space: nowrap; - gap: 1.5rem; + font-family: var(--mono-font); + display: flex; + white-space: nowrap; + gap: 1.5rem; } diff --git a/apps/zui/src/views/session-page/pins.module.css b/apps/zui/src/views/session-page/pins.module.css index 74c5fe8d80..667aa20265 100644 --- a/apps/zui/src/views/session-page/pins.module.css +++ b/apps/zui/src/views/session-page/pins.module.css @@ -1,50 +1,64 @@ .container { - display: flex; - flex-wrap: wrap; - margin-top: 0.25rem; + display: flex; + flex-wrap: wrap; + margin-top: 0.25rem; } .pin { - margin-bottom: 0.25rem; - white-space: nowrap; - display: relative; - font-family: var(--mono-font); - font-weight: 500; - font-size: 0.75rem; - height: 1.375rem; - background: var(--chrome-color); - border: none; - padding: 0 1.25rem; + text-align: left; + overflow: hidden; + overflow-wrap: anywhere; + margin-bottom: 0.25rem; + display: relative; + font-family: var(--mono-font); + font-weight: 500; + font-size: 0.75rem; + background: var(--chrome-color); + border: none; + padding: var(--s-5) var(--s-1); - --indent: 0.5rem; - --end: calc(100% - var(--indent)); - --start: var(--indent); - --right-point: polygon(0% 0%, var(--end) 0%, 100% 50%, var(--end) 100%, 0% 100%); - --right-chevron: polygon(var(--end) 0%, 100% 50%, var(--end) 100%, 0% 100%, var(--start) 50%, 0% 0%); - clip-path: var(--right-chevron); - margin-left: calc(calc(var(--indent) * -1) + 4px); + --indent: 0.5rem; + --end: calc(100% - var(--indent)); + --start: var(--indent); + --right-point: polygon( + 0% 0%, + var(--end) 0%, + 100% 50%, + var(--end) 100%, + 0% 100% + ); + --right-chevron: polygon( + var(--end) 0%, + 100% 50%, + var(--end) 100%, + 0% 100%, + var(--start) 50%, + 0% 0% + ); + clip-path: var(--right-chevron); + margin-left: calc(calc(var(--indent) * -1) + 4px); } .pin:hover { - transition: all var(--quick); - background: var(--chrome-color-more); - cursor: pointer; + transition: all var(--quick); + background: var(--chrome-color-more); + cursor: pointer; } .pin span { - color: var(--orange); + color: var(--orange); } .pin:first-child { - margin-left: 0; - padding-left: 1.225rem; - clip-path: var(--right-point); + margin-left: 0; + padding-left: 1.225rem; + clip-path: var(--right-point); } .disabled { - text-decoration: line-through; + text-decoration: line-through; } .hovering { - background: var(--primary-color-lighter); + background: var(--primary-color-lighter); } diff --git a/apps/zui/src/views/session-page/toolbar.module.css b/apps/zui/src/views/session-page/toolbar.module.css index 0bd9523a5f..c0fea13d8d 100644 --- a/apps/zui/src/views/session-page/toolbar.module.css +++ b/apps/zui/src/views/session-page/toolbar.module.css @@ -1,94 +1,94 @@ .toolbar { - height: 38px; - display: flex; - align-items: center; - justify-content: flex-start; - padding: 0 10px; - gap: 6px; - min-inline-size: 0; - overflow: hidden; + height: 38px; + display: flex; + align-items: center; + justify-content: flex-start; + padding: 0 10px; + gap: 6px; + min-inline-size: 0; + overflow: hidden; } -.toolbar> :nth-child(1) { - flex: 0 0 auto +.toolbar > :nth-child(1) { + flex: 0 0 auto; } -.toolbar>:nth-child(2) { - flex: 1 0 0; +.toolbar > :nth-child(2) { + flex: 0 999 auto; + min-width: 10ch; } -.toolbar>:nth-child(3) { - flex: 0 1 auto; - width: auto; - min-width: 32px; +.toolbar > :nth-child(3) { + flex: 1 1 fit-content; + min-width: 32px; } .nav { - display: inline-flex; + display: inline-flex; } .toolbar h1 { - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; } .toolbar h1 { - font-size: 1rem; + font-size: 1rem; } .form { - flex: 1; - width: 100%; - display: flex; - gap: 6px; + flex: 1; + width: 100%; + display: flex; + gap: 6px; } .input { - background: transparent; - font-size: 1rem; - font-weight: bold; - width: 100%; - border-radius: 0; - border: none; - border-bottom: 1px dashed var(--border-color); - background: var(--emphasis-bg); - outline: none; - padding: 0 6px; + background: transparent; + font-size: 1rem; + font-weight: bold; + width: 100%; + border-radius: 0; + border: none; + border-bottom: 1px dashed var(--border-color); + background: var(--emphasis-bg); + outline: none; + padding: 0 6px; } .input:focus-visible { - outline: none; + outline: none; } .untitled { - opacity: 0.3; + opacity: 0.3; } .modified { - font-style: italic; + font-style: italic; } .outdated { - display: flex; - background: var(--emphasis-bg-more); - border-radius: 6px; - font-weight: 800; - text-transform: uppercase; - letter-spacing: 1px; - font-size: 0.66rem; - padding: 0 0.5rem; - color: var(--fg-color-less); + display: flex; + background: var(--emphasis-bg-more); + border-radius: 6px; + font-weight: 800; + text-transform: uppercase; + letter-spacing: 1px; + font-size: 0.66rem; + padding: 0 0.5rem; + color: var(--fg-color-less); } .button { - padding: 0; - margin: 0; - background: none; - border: none; - cursor: text; - text-align: left; - flex: 1; - overflow: hidden; - min-inline-size: 5ch; + padding: 0; + margin: 0; + background: none; + border: none; + cursor: text; + text-align: left; + flex: 1; + overflow: hidden; + min-inline-size: 5ch; }