react-styled-base
v3.0.0
Published
> Base component that prevents rendering unknown props in DOM
Downloads
19
Readme
react-styled-base
Base component that prevents rendering unknown props in DOM
- [x] Filter unknown props from DOM
- [x] Based on
react-html-attributes
(50% smaller - 3kb when minified / 1kb gziped, without many deprecated attributes & elements) - [x] Override inner element with
as
prop - [x] Great for CSS-in-JS component libraries (NOTE: some provide this feature out of box!)
📦 Install
$ yarn add react-styled-base
📖 API
Base
component
import Base from 'react-styled-base'
Props
as: Component
— React component or DOM element (likediv
,input
,span
, ...), defaultdiv
See createBase
for more options.
Example
import { render } from 'react-dom'
import styled from 'react-emotion'
import Base from 'react-styled-base'
const LinkComp = styled(Base)`
color: ${props => props.foo === 'bar' ? 'royalblue' : 'hotpink'};
`
render((
<LinkComp as='a' href='http://example.com' foo='bar' abc='xyz'>
Click Me
</LinkComp>
), document.body)
// →
// <a class="css-0" href="http://example.com">Click Me</a>
createBase
factory
import { createBase } from 'react-styled-base'
Params
defaultComp: Component
— React component or DOM element (likediv
,input
,span
, ...), defaultdiv
options: Object
— (Optional, default to{ componentProp: 'as' }
)options.whitelist: Array
— List of props that always will be rendered (optional)options.blacklist: Array
— List of props that always be be omitted (optional)options.isPropValid: function (tagName, propName) => boolean
— Custom function to filter propsoptions.tagName: string
— DOM element. Used whendefaultComp
is not DOM element (optional)
Return: Component
— wrapped in React.forwardRef
.
Example
import { render } from 'react-dom'
import styled from 'react-emotion'
import { Link as RouterLink } from 'react-router-dom'
import { createBase } from 'react-styled-base'
const LinkComp = styled(createBase('span'))`
color: ${props => props.foo === 'bar' ? 'royalblue' : 'hotpink'};
`
const RouterLinkBase = createBase(RouterLink, {
tagName: 'a',
whitelist: [ 'to' ]
})
const CustomComp = createBase((props) => <span {...props} />, {
isPropValid: (tag, prop) => prop !== 'foo'
})
render((
<span>
<LinkComp as={RouterLinkBase} to='/page-2' foo='bar'>
Page 2
</LinkComp>
<LinkComp as='a' href='https://google.com' target='_blank' foo='baz'>
Search
</LinkComp>
<CustomComp title='notice' foo='bar'>
Notice
</CustomComp
</span>
), document.body)
// →
// <span>
// <a class="css-0" href="/app/page-2">Page 2</a>
// <a class="css-1" href="https://google.com" target="_blank">Search</a>
// <span title="notice">Notice</span>
// </span>
isPropValid
function
import { isPropValid } from 'react-styled-base'
Params
propName: string
— prop name (likehref
,value
,onChange
)tagName: string
— DOM element (likea
,input
,div
)
Return: boolean
Example
import { isPropValid } from 'react-styled-base'
isPropValid('foo', 'a') // → false
isPropValid('bar', 'a') // → false
isPropValid('href', 'a') // → true
💁♂️ Alternative
clean-element
— Use component prop-types as blacklist
🔗 Links
- ⚠️ Unknown Prop Warning
- 💬 Separate HTML attributes from styling props
- 💄
pss
— Prop Styles System - 📐
pss-components
— Components - 💄
glamorous
— Inspired by - 👩🎤
@emotion/is-prop-valid
— Approach used insideemotion
andstyled-components
MIT © John Grishin