Sha256: 901c09acb6917fd8354152e3a3a9d3b966813db71463e87176ab8fe6da9f1ef7
Contents?: true
Size: 1.75 KB
Versions: 260
Compression:
Stored size: 1.75 KB
Contents
import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps, noop } from '../utilities/props' import { globalProps } from '../utilities/globalProps' import Button from '../pb_button/_button' import Icon from '../pb_icon/_icon' type CircleIconButtonProps = { aria?: { [key: string]: string }, className?: string, dark?: boolean, data?: { [key: string]: string }, disabled?: boolean, icon: string, htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, id?: string, link?: string, onClick?: React.MouseEventHandler<HTMLElement>, newWindow?: boolean, type?: 'button' | 'submit' | 'reset' | undefined, variant?: 'primary' | 'secondary' | 'link', } const CircleIconButton = (props: CircleIconButtonProps): React.ReactElement => { const { aria = {}, className, dark, data = {}, disabled, htmlOptions = {}, icon, id, onClick = noop, type, link, newWindow, variant, } = props const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const classes = classnames( buildCss('pb_circle_icon_button_kit'), globalProps(props), className ) return ( <div {...ariaProps} {...dataProps} {...htmlProps} className={classes} id={id} > <Button dark={dark} disabled={disabled} htmlType={type} link={link} newWindow={newWindow} onClick={onClick} text={null} variant={variant} > <Icon fixedWidth icon={icon} /> </Button> </div> ) } export default CircleIconButton
Version data entries
260 entries across 260 versions & 1 rubygems