Sha256: 813b96b23f47d55c2fbbd5bce9ac108e06de4ce9672de8df52e149b86909d23c
Contents?: true
Size: 1.7 KB
Versions: 10
Compression:
Stored size: 1.7 KB
Contents
import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props' import { deprecatedProps, globalProps, GlobalProps } from '../utilities/globalProps' type CaptionProps = { aria?: {[key: string]: string}, children?: React.ReactChild[] | React.ReactChild, className?: string, color?: "default" | "light" | "lighter" | "success" | "error" | "link", data?: {[key: string]: string}, htmlOptions?: {[key: string]: string | number | boolean | Function}, id?: string, size?: "xs" | "sm" | "md" | "lg" | "xl", tag?: "h1" | "h2" | "h3" | "h4" | "h5" | "h6" | "p" | "span" | "div" | "caption", text?: string, variant?: null | "link", } & GlobalProps; const Caption = (props: CaptionProps): React.ReactElement => { if (props.variant) deprecatedProps() //variant prop is deprecated, use color instead const { aria = {}, children, className, color, data = {}, htmlOptions = {}, id, size = 'md', tag = 'div', text, variant = null, } = 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 htmlProps = buildHtmlProps(htmlOptions) const css = classnames( buildCss('pb_caption_kit', size, variant, color), globalProps(props), className, ) return ( <Tag {...ariaProps} {...dataProps} {...htmlProps} className={css} id={id} > {text || children} </Tag> ) } export default Caption
Version data entries
10 entries across 10 versions & 1 rubygems