Sha256: 51d3a423c9cf18f4b447a2692420b1fdf4684bc8c326717632cb1ab407fe3b2a
Contents?: true
Size: 1.98 KB
Versions: 6
Compression:
Stored size: 1.98 KB
Contents
import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props' import { deprecatedProps, globalProps, GlobalProps } from '../utilities/globalProps' import Highlight from '../pb_highlight/_highlight' type BodyProps = { aria?: {[key: string]: string}, className?: string, children?: React.ReactChild[] | React.ReactChild, color?: 'default' | 'light' | 'lighter' | 'link' | 'error' | 'success', dark?: boolean, data?: {[key: string]: string}, highlightedText?: string[], highlighting?: boolean, id?: string, status?: 'neutral' | 'negative' | 'positive', tag?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6' | 'p' | 'span' | 'div', text?: string, truncate?: null | '1' | '2' | '3' | '4' | '5', variant?: null | 'link', } & GlobalProps const Body = (props: BodyProps): React.ReactElement => { if (props.variant) deprecatedProps("Body", ["status"]) //status prop is deprecated, use color instead please const { aria = {}, children, className, color = '', data = {}, highlightedText = [], highlighting = false, id = '', status = null, tag = 'div', text = '', truncate = null, variant = null, } = props const ariaProps: {[key: string]: any} = buildAriaProps(aria) const dataProps: {[key: string]: any} = buildDataProps(data) const isTruncated = truncate ? `truncate_${truncate}` : '' const classes = classnames( buildCss('pb_body_kit', color, variant, status, isTruncated), globalProps(props), className ) const Tag: React.ReactElement | any = `${tag}` return ( <Tag {...ariaProps} {...dataProps} className={classes} id={id} > { highlighting && ( <Highlight highlightedText={highlightedText} text={text} > {children} </Highlight> ) } { !highlighting && ( text || children ) } </Tag> ) } export default Body
Version data entries
6 entries across 6 versions & 1 rubygems