-
-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
7 changed files
with
192 additions
and
168 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,38 +1,30 @@ | ||
// 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 = <P extends Style & { theme: Theme }>({ | ||
// 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<Style>; | ||
|
||
// return <Component {...props} />; | ||
// }; | ||
// } | ||
|
||
// export default customStyled; | ||
|
||
export const TEST = {}; | ||
import React from 'react'; | ||
import { theme, parsers, Component, Style, Theme } from '@morfeo/web'; | ||
import styled, { StyledComponent } from 'styled-components'; | ||
|
||
export function customStyled(component: Component) { | ||
const { components } = theme.get(); | ||
const config = components[component]; | ||
const tag = (config.style.componentTag || component) as | ||
| keyof JSX.IntrinsicElements | ||
| React.ComponentType<any>; | ||
|
||
const result = function (props: any) { | ||
const variant = props.variant as any; | ||
const variantTag = (props.variant && config.variants | ||
? config.variants[variant].componentTag | ||
: tag) as keyof JSX.IntrinsicElements | React.ComponentType<any>; | ||
|
||
const Component = styled<any>(variantTag || (tag as any))( | ||
({ theme: styledTheme, children, ...style }) => { | ||
return parsers.resolve({ | ||
style: { componentName: component, ...(style as Style) }, | ||
}); | ||
}, | ||
) as StyledComponent<keyof JSX.IntrinsicElements, Theme, Style>; | ||
|
||
return <Component {...props} />; | ||
}; | ||
|
||
return result as StyledComponent<keyof JSX.IntrinsicElements, Theme, Style>; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
export const lightTheme = { | ||
colors: { | ||
primary: 'white', | ||
secondary: 'black', | ||
danger: 'red', | ||
}, | ||
radii: { | ||
m: '10px', | ||
round: '50%', | ||
}, | ||
space: { | ||
s: '40px', | ||
m: '100px', | ||
}, | ||
sizes: { | ||
s: '10px', | ||
m: '100px', | ||
xl: '200px', | ||
}, | ||
borderWidths: { | ||
s: '2px', | ||
}, | ||
breakpoints: { | ||
md: '900px', | ||
lg: '1300px', | ||
}, | ||
transitions: { | ||
light: 'all 0.5s', | ||
}, | ||
components: { | ||
Button: { | ||
style: { | ||
componentTag: 'button', | ||
transition: 'light', | ||
height: 'm', | ||
width: 'm', | ||
bg: { | ||
md: 'danger', | ||
lg: 'primary', | ||
}, | ||
color: 'secondary', | ||
borderRadius: 'm', | ||
borderWidth: 's', | ||
borderStyle: 'solid', | ||
borderColor: 'primary', | ||
'&:hover': { | ||
bg: 'secondary', | ||
color: 'primary', | ||
}, | ||
}, | ||
variants: { | ||
primary: { | ||
bg: 'secondary', | ||
borderColor: 'primary', | ||
color: 'primary', | ||
'&:hover': { | ||
bg: 'primary', | ||
color: 'secondary', | ||
}, | ||
}, | ||
round: { | ||
borderRadius: 'round', | ||
}, | ||
}, | ||
}, | ||
}, | ||
} as any; | ||
|
||
export const darkTheme = { | ||
colors: { | ||
primary: 'black', | ||
secondary: 'white', | ||
}, | ||
} as any; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,2 @@ | ||
export * from './useTheme'; | ||
export * from './useStyles'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
import { Style, parsers } from '@morfeo/core'; | ||
|
||
export function useStyles<K extends string>(styles: Record<K, Style>) { | ||
const styleKeys = Object.keys(styles); | ||
|
||
return styleKeys.reduce( | ||
(acc, curr) => ({ | ||
...acc, | ||
[curr]: parsers.resolve({ style: styles[curr] }), | ||
}), | ||
{}, | ||
) as Record<K, any>; | ||
} | ||
|
||
export function useStyle(style: Style) { | ||
return parsers.resolve({ style }); | ||
} |
Oops, something went wrong.