From d25758c76b2769d55c8852c9f124ce1c4fe3c7b8 Mon Sep 17 00:00:00 2001 From: mauroerta Date: Wed, 5 May 2021 21:54:10 +0200 Subject: [PATCH] feat: web sandbox improvement --- apps/web-sandbox/package.json | 4 +-- apps/web-sandbox/src/App.tsx | 43 ++++++++++++++++++++++++++++++--- apps/web-sandbox/src/styled.tsx | 38 +++++++++++++++++++++++++++++ package.json | 5 ++-- 4 files changed, 82 insertions(+), 8 deletions(-) create mode 100644 apps/web-sandbox/src/styled.tsx diff --git a/apps/web-sandbox/package.json b/apps/web-sandbox/package.json index fb8f818b..1feb4b2d 100644 --- a/apps/web-sandbox/package.json +++ b/apps/web-sandbox/package.json @@ -13,13 +13,13 @@ "@types/react": "^17.0.3", "@types/react-dom": "^17.0.3", "react-scripts": "4.0.3", - "styled-components": "^5.2.3", "web-vitals": "^1.1.1", "typescript": "^4.2.4" }, "peerDependencies": { "react": "^17.0.2", - "react-dom": "^17.0.2" + "react-dom": "^17.0.2", + "styled-components": "^5.2.3" }, "scripts": { "start": "react-scripts start", diff --git a/apps/web-sandbox/src/App.tsx b/apps/web-sandbox/src/App.tsx index 2aa38ced..30c45227 100644 --- a/apps/web-sandbox/src/App.tsx +++ b/apps/web-sandbox/src/App.tsx @@ -7,6 +7,7 @@ const lightTheme = { colors: { primary: 'white', secondary: 'black', + danger: 'red', }, radii: { m: '10px', @@ -39,7 +40,7 @@ const lightTheme = { height: 'm', width: 'm', bg: { - md: 'red', + md: 'danger', lg: 'primary', }, color: 'secondary', @@ -111,6 +112,16 @@ const StyledProvider: React.FC = ({ children }) => { return {children}; }; +function getStyle(component: Component, variant?: string) { + const { style, variants } = theme.getValue('components', component); + + if (variant && variants && variants[variant]) { + return JSON.stringify(variants[variant], undefined, 2); + } + + return JSON.stringify(style, undefined, 2); +} + function App() { const [light, setLight] = React.useState(true); @@ -119,6 +130,21 @@ function App() { setLight(prev => !prev); }, [light]); + const containerStyle = parsers.resolve({ + style: { + flex: 1, + display: 'flex', + flexDirection: 'column', + alignItems: 'center', + justifyContent: 'space-evenly', + height: '100%' as any, + }, + }); + + const codeStyle = parsers.resolve({ + style: { color: 'primary', display: 'block', py: 's' }, + }); + return (
- - - +
+ +
{getStyle('Button')}
+
+
+ +
{getStyle('Button', 'primary')}
+
+
+ +
{getStyle('Button', 'round')}
+
); diff --git a/apps/web-sandbox/src/styled.tsx b/apps/web-sandbox/src/styled.tsx new file mode 100644 index 00000000..ed2701d7 --- /dev/null +++ b/apps/web-sandbox/src/styled.tsx @@ -0,0 +1,38 @@ +// import React from 'react'; +// import scStyled, { StyledInterface } from 'styled-components'; +// import { Component, theme, parsers, Style, Theme } from '@morfeo/web'; + +// const customStyled = (tag: keyof StyledInterface) => { +// const callback =

({ +// theme: styledTheme, +// ...style +// }: P) => scStyled[tag](parsers.resolve({ style })); + +// const styledKeys = Object.keys(scStyled) as (keyof StyledInterface)[]; + +// for (let tag of styledKeys) { +// callback[tag] = callback(tag); +// } + +// return callback; +// }; + +// export function themeComponent(component: Component) { +// const { components } = theme.get(); +// const config = components[component]; +// const tag = config.style.componentTag || component; + +// return (props: Style = {}) => { +// const variant = props.variant; +// const variantTag = +// variant && config.variants ? config.variants[variant].componentTag : tag; + +// const Component = customStyled(variantTag || tag) as React.FC