import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props' import { globalProps } from '../utilities/globalProps' import Body from '../pb_body/_body' import Title from '../pb_title/_title' type ProgressPillsProps = { active?: number, aria?: {[key: string]: string}, className?: string, data?: { [key: string]: string }, dark?: boolean, htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, id?: string, steps?: number, title?: string, value?: string, } const ProgressPill = ({ active, dark, steps: step }: ProgressPillsProps) => (
) const showSteps = (steps: number, active: number, dark: boolean) => { const items = [] for (let step = 1; step <= steps; step++) { items.push(ProgressPill({ steps: step, active, dark })) } return items } const ProgressPills = (props: ProgressPillsProps) => { const { active = 0, aria = { hidden: 'true' }, className, data = {}, htmlOptions = {}, id, steps = 3, title, value, dark = false, } = props const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const classes = classnames(buildCss('pb_progress_pills_kit'), globalProps(props), className) return (
{title &&
<Body color="light" dark={dark} text={value} /> </div>} <div className="progress_pills">{showSteps(steps, active, dark)}</div> </div> ) } export default ProgressPills