From 4e7367c6eab1ba93037fed2b7ee6de1b3b7c51c3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dan=20B=C3=BCschlen?= Date: Thu, 5 Sep 2024 16:26:12 +0200 Subject: [PATCH] feat(layout): add reusable grid definitions as custom properties (#233) --- src/styles/custom-properties.css | 26 +++++++++++++ src/styles/style.stories.js | 66 ++++++++++++++++++++++++++++++++ 2 files changed, 92 insertions(+) create mode 100644 src/styles/style.stories.js diff --git a/src/styles/custom-properties.css b/src/styles/custom-properties.css index b900702..ab283f4 100644 --- a/src/styles/custom-properties.css +++ b/src/styles/custom-properties.css @@ -59,4 +59,30 @@ --leu-z-index-popup: 100; @leu-font-styles './font-definitions.json'; + + /* + * Grid system + * + * The design system uses a 6 columns system on smaller screens. + * For simplicity we use a 12 column grid for all breakpoints (zh web implementation does the same). + * + * The goal is to keep the css footprint small + * by not generating all classes for every cell width for every breakpoint. + * Most components don't need a grid and those who do probably have a very simple configuration. + * If we have enough use cases for a more complex grid system we can add it later. + */ + --leu-grid-gap: 1rem; + --leu-grid-template-columns: repeat(12, minmax(0, 4.25rem)); + --leu-grid-max-width: 73rem; + + --leu-grid-columns-full: 1 / -1; + --leu-grid-columns-offset: 1 / -1; + + @media (--viewport-regular) { + --leu-grid-columns-offset: 3 / -1; + } + + @media (--viewport-medium) { + --leu-grid-gap: 2rem; + } } diff --git a/src/styles/style.stories.js b/src/styles/style.stories.js new file mode 100644 index 0000000..e076fef --- /dev/null +++ b/src/styles/style.stories.js @@ -0,0 +1,66 @@ +import { html } from "lit" + +export default { + title: "Layout", + argTypes: { + name: { + control: "select", + }, + color: { + control: { + type: "color", + presetColors: ["#009ee0", "#d93c1a", "#1a7f1f"], + }, + }, + }, +} + +function Template() { + return html` +
+
+
--leu-grid-columns-full
+

A preset to use the full width of the grid

+
+
+
--leu-grid-columns-offset
+

+ A preset that indents the content by two columns starting at the + regular breakpoint. On smaller breakpoints it will use the full width. +

+
+ + ${[ + [2, 2, 2, 2, 2, 2], + [3, 3, 3, 3], + [4, 4, 4], + [6, 6], + ] + .flat() + .map( + (columns) => + html`
${columns}
` + )} +
` +} + +export const Regular = Template.bind({}) +Regular.args = {}