2020-08-17 15:07:16 -05:00
|
|
|
import React from 'react'
|
2020-08-17 15:59:29 -05:00
|
|
|
import PropTypes from 'prop-types'
|
2020-02-13 19:40:04 -05:00
|
|
|
import { length } from 'stringz'
|
2019-08-09 12:06:27 -04:00
|
|
|
|
2020-04-23 02:13:29 -04:00
|
|
|
/**
|
|
|
|
* Renders a character counter
|
|
|
|
* @param {string} props.text - text to use to measure
|
|
|
|
* @param {number} props.max - max text allowed
|
|
|
|
*/
|
2020-08-17 19:57:35 -05:00
|
|
|
class CharacterCounter extends React.PureComponent {
|
2019-07-02 03:10:25 -04:00
|
|
|
|
2020-04-23 23:17:27 -04:00
|
|
|
render() {
|
2020-04-16 02:00:43 -04:00
|
|
|
const { text, max } = this.props
|
2020-04-23 02:13:29 -04:00
|
|
|
|
2021-02-15 21:47:56 -05:00
|
|
|
const actualRadius = 10
|
|
|
|
const radius = 8
|
2020-02-13 19:40:04 -05:00
|
|
|
const circumference = 2 * Math.PI * radius
|
2020-04-16 02:00:43 -04:00
|
|
|
const diff = Math.min(length(text), max) / max
|
2020-02-13 19:40:04 -05:00
|
|
|
const dashoffset = circumference * (1 - diff)
|
2021-02-15 21:47:56 -05:00
|
|
|
const circleClass = length(text) > max ? _s.strokeError : _s.strokeBrand
|
2019-08-09 12:06:27 -04:00
|
|
|
|
2020-01-27 14:46:42 -05:00
|
|
|
return (
|
2020-08-18 15:49:11 -05:00
|
|
|
<div className={[_s.d, _s.mr10, _s.jcCenter, _s.aiCenter].join(' ')}>
|
2020-04-23 23:17:27 -04:00
|
|
|
<svg
|
|
|
|
width={actualRadius * 2}
|
|
|
|
height={actualRadius * 2}
|
|
|
|
viewBox={`0 0 ${actualRadius * 2} ${actualRadius * 2}`}
|
|
|
|
>
|
|
|
|
<circle
|
|
|
|
fill='none'
|
|
|
|
cx={actualRadius}
|
|
|
|
cy={actualRadius}
|
|
|
|
r={radius}
|
|
|
|
fill='none'
|
|
|
|
strokeWidth='2'
|
2021-02-15 21:47:56 -05:00
|
|
|
className={_s.strokeSecondary}
|
2020-04-23 23:17:27 -04:00
|
|
|
/>
|
|
|
|
<circle
|
|
|
|
style={{
|
2020-02-13 19:40:04 -05:00
|
|
|
strokeDashoffset: dashoffset,
|
|
|
|
strokeDasharray: circumference,
|
|
|
|
}}
|
|
|
|
fill='none'
|
2020-02-28 10:20:47 -05:00
|
|
|
cx={actualRadius}
|
|
|
|
cy={actualRadius}
|
|
|
|
r={radius}
|
2021-02-15 21:47:56 -05:00
|
|
|
strokeWidth='2.25'
|
2020-02-13 19:40:04 -05:00
|
|
|
strokeLinecap='round'
|
2021-02-15 21:47:56 -05:00
|
|
|
className={circleClass}
|
2020-02-13 19:40:04 -05:00
|
|
|
/>
|
|
|
|
</svg>
|
2020-01-27 14:46:42 -05:00
|
|
|
</div>
|
|
|
|
)
|
2019-07-02 03:10:25 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-08-17 19:57:35 -05:00
|
|
|
|
|
|
|
CharacterCounter.propTypes = {
|
|
|
|
text: PropTypes.string.isRequired,
|
|
|
|
max: PropTypes.number.isRequired,
|
|
|
|
}
|
|
|
|
|
|
|
|
export default CharacterCounter
|