React Styled Components Star Rating Percent

node v6.12.2
version: 112.0.0
endpointsharetweet
let html const React = require('react'); const { renderToString } = require('react-dom/server'); const _styled = require('styled-components') const styled = _styled.default const { css, keyframes } = _styled const render = component => { const sheet = new _styled.ServerStyleSheet() html = renderToString(sheet.collectStyles(component)) return sheet.getStyleTags() + html }
Here are some other ways of doing it. - https://codepen.io/Bluetidepro/pen/GkpEa - http://jsfiddle.net/james_alley/kR4jn/
const Rating = styled(props => <div {...props}> <Stars count={props.stars} /> <div>{props.ratings}</div> </div> )` display: flex; flex-direction: row; ` const Stars = ({ count }) => <EmptyStars><FilledStars percent={count/5} /></EmptyStars> const EmptyStars = styled.div` height: 16px; width: 90px; background-position: 0 0; /* clear stars */ background: url() repeat-x; ` const FilledStars = styled.span` height: inherit; display: block; background: inherit; background-position: 0 -16px; /* filled stars */ width: ${props => Math.round(props.percent * 100)}%; ` render( <Rating stars={4.2} ratings='(50)' /> )
Loading…

no comments

    sign in to comment