ctyled is a HOC for styling components. its fundamental tool for styling is the style prop. a style prop takes in some arbitrary value and maps it to some css rules for a given component. for example, a style prop named 'size' may be used to determine the font-size, padding, and width of a button component. style props are contextual. 'size' for a component is not defined as an absolute value, but rather as a ratio comparing that component's size relative to its parent. this is true not just for size, but color, padding, spacing, or any style prop you want to define.
by default, components with ctyled have a set of core style props pre-defined, some provide extra functionality:
color
: base color for component. see relative colorsborderColor
: color of borders, variation of base color by defaultbgColor
: color of background, base color bg by defaultsize
: base size for componentbg
: bool if bg should existborder
: bool if border should existpadd
: bool if padding should exist. if numeric treated as a multiple of the base sizegutter
: bool if gutter spacing between child elements should exist. if numeric treated as multiple of the base sizelined
: bool if internal borders should be put between each child componentdisabled
: bool if component should be non interactive and greyed out
and some are just shorthands for existing css rules:
column
: bool changes flex-directionalign
: shorthand for align-itemsjustify
: shorthand for justify-contentalignSelf
: shorthand for align-selfreverse
: changes flex direction to *-reverseflex
: sets the flex propertyrounded
: shorthand for border-radius. defined as multiple of base sizeflatLeft, flatRight...
removes border radius on verts adjacent to the flat sidenoselect
makes the component not selectable
base dom elements with ctyled can be created with the shorthand ctyled.element_name
, or an existing component can be passed to ctyled(Component)
:
import ctyled from 'ctyled'
const CtyledLink = ctyled.link
const CtyledThing = ctyled(MyOwnComponent)
default style prop values for a component can be defined with component.styles({...props})
. Usually each prop value is a function that takes in the value from the components parent, and returns the new value.
import ctyled from 'ctyled'
const CtyledLink = ctyled.link.styles({
size: parentSize => parentSize * 0.9, //small link
color: parentColor => parentColor.invert(), //flip fg and bg
padd: true, //add padding (relative to size as per prop definition)
})
style prop values can also be extends on the component at render by passing the styles
prop. In this case the CtyledLink will have all of its defaultProps and a border:
<CtyledLink styles={{ border: true }} />
ctyled components can call component.extendSheet
with a template literal to add arbitrary css. functions in the template will be passed the style props of the component, and the properties on the component itself (styleProps, reactProps) => css
import ctyled from 'ctyled'
const CtyledButton = ctyled(MyButton).styles({
size: parentSize => parentSize * 2, // massive button
}).extendSheet`
opacity:0.5;
margin-left:${styleProps => style.props.size * 3}px;
`
if only features of inline styles component.extend
can be used instead and no stylesheet will be generated.
often it is useful to make the styles of a component be dependent on other properties. you can use component.attrs({defaultProps})
to set the default values for those props and to tell the typesystem what to expect.
import ctyled from 'ctyled'
const CtyledButton = ctyled.div.attrs({ big: false }).styles({
size: parentSize => parentSize * (big ? 2 : 1), // massive button if 'big'
})
const big = <CtyledButton big />
its maybe changing look at /classes/core for an example
to make colors in ctyled useful we need a way of defining a color scheme, then a way of defining specific colors relative to each other within that scheme. A color scheme is defined as a gradient with a series of stops from the foreground to the background of that color.
import Color from 'ctyled/color'
const grayScale = new Color(['white', 'black']),
red = new Color(['red', 'white'])
once the color is created you can retrieve fg and bg colors using color.fg
and color.bg
. you can also change where on the gradient the fg and bg are sampled from using the functions:
color.nudge(amount: number)
get a new color, different from the current one. the larger the |amount| the greater the difference from the starting colorcolor.contrast(amount: number)
change the contrast of the color, moving the fg and bg further or closer to eachother with a + or - amountcolor.invert()
swap the fg and bgcolor.as(otherColor: gradient)
get a new color with the same brightness, contrast, invertedness, but from a different color palette