Sha256: 16dbd0b5ba779e975346ec8ffb826b36ae4f1baf42d5c5dcf8676a3c84e7bc31
Contents?: true
Size: 1.45 KB
Versions: 3
Compression:
Stored size: 1.45 KB
Contents
/* @flow */ import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props' import { deprecatedProps, globalProps } from '../utilities/globalProps.js' type CaptionProps = { aria?: object, children: array<React.ReactNode> | React.ReactNode, className?: string, color?: "default" | "light" | "lighter" | "success" | "error" | "link", data?: object, id?: string, size?: "xs" | "sm" | "md" | "lg" | "xl", tag?: "h1" | "h2" | "h3" | "h4" | "h5" | "h6" | "p" | "span" | "div" | "caption", text?: string, variant?: null | "link", }; const Caption = (props: CaptionProps) => { if (props.variant) deprecatedProps('Title', ['variant']) //variant prop is deprecated, use color instead const { aria = {}, children, className, color, data = {}, id, size = 'md', tag = 'div', text, } = props const tagOptions = [ 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'p', 'span', 'div', 'caption', ] const Tag = tagOptions.includes(tag) ? tag : 'div' const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const css = classnames( buildCss('pb_caption_kit', size, color), globalProps(props), className, ) return ( <Tag {...ariaProps} {...dataProps} className={css} id={id} > {text || children} </Tag> ) } export default Caption
Version data entries
3 entries across 3 versions & 1 rubygems