Sha256: c4b98faec6fb7ae84ad4c3fdd4a9bff8789ecb6359086de75de42a1add02ef3c
Contents?: true
Size: 1.68 KB
Versions: 269
Compression:
Stored size: 1.68 KB
Contents
/* eslint-disable react/jsx-no-target-blank */ /* eslint-disable react/no-multi-comp, flowtype/space-before-type-colon */ import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props' import { globalProps, GlobalProps } from '../utilities/globalProps' import Badge from '../pb_badge/_badge' type HashtagProps = { aria?: {[key: string]: string}, className?: string, dark?: boolean, data?: string, htmlOptions?: {[key: string]: string | number | boolean | (() => void)}, id?: string, newWindow?: boolean, rel?: string, text?: string, type: "default" | "home" | "project" | "appointment", url?: string, } & GlobalProps const typeMap = { home: 'H#', project: 'P#', appointment: 'A#', default: '#', } const Hashtag = (props: HashtagProps) => { const { aria = {}, className, dark = false, data = {}, htmlOptions = {}, id, newWindow, rel, text, type = 'default', url, } = props const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const htmlProps = buildHtmlProps(htmlOptions) const classes = classnames(buildCss('pb_hashtag_kit'), globalProps(props), className) return ( <span {...ariaProps} {...dataProps} {...htmlProps} className={classes} id={id} > <a href={url} rel={(newWindow ? "noreferrer" : rel)} target={(newWindow ? '_blank' : '_self')} > <Badge dark={dark} text={typeMap[type] + text} variant="primary" /> </a> </span> ) } export default Hashtag
Version data entries
269 entries across 269 versions & 1 rubygems