Sha256: f2feb9a110ccda05c2c50dfb9e70d3e5a45b228562a62e90a4f9a8d46c9407b3
Contents?: true
Size: 1.5 KB
Versions: 6
Compression:
Stored size: 1.5 KB
Contents
/* @flow */ import React from 'react' import classnames from 'classnames' import { Body, Icon, } from '../' type StatChangeProps = { change?: 'increase' | 'decrease' | 'neutral', className?: String, id?: String, value?: String | Number } const statChangeCSS = ({}: StatChangeProps, status) => { const statusStyle = status !== '' ? `_${status}` : '' return 'pb_stat_change_kit' + statusStyle } const StatChange = (props: StatChangeProps) => { const { change='neutral', className, id, value, } = props const status = (function(change) { switch(change) { case 'increase': return 'positive'; case 'decrease': return 'negative'; default: return 'neutral'; } })(change) const icon = (function(change) { switch(change) { case 'increase': return 'arrow-up'; case 'decrease': return 'arrow-down'; default: return null; } })(change) const displayIcon = function(icon) { if (icon) { return ( <span> <Icon icon={icon} fixed_width={true} /> </span> ) } } const displayValue = function(status, value) { if (value) { return ( <Body status={status}> {displayIcon(icon)} {value}% </Body> ) } } return ( <div id={id} className={classnames(statChangeCSS(props, status), className)}> {displayValue(status, value)} </div> ) } export default StatChange
Version data entries
6 entries across 6 versions & 1 rubygems