import React from 'react' import classnames from 'classnames' import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props' import { globalProps, GlobalProps } from '../utilities/globalProps' import Icon from '../pb_icon/_icon' import Image from '../pb_image/_image' import Collapsible from '../pb_collapsible/_collapsible' type NavItemProps = { active?: boolean, aria?: { [key: string]: string }, bold?: boolean, emphasized?: boolean, children?: React.ReactNode[] | React.ReactNode, className?: string, collapsible?: boolean, data?: object, dark?: boolean, iconLeft?: string, iconRight?: string | string[], onIconRightClick?: () => void, onIconLeftClick?: () => void, id?: string, imageUrl?: string, link?: string, onClick?: () => void, target?: '_blank' | '_self' | '_parent' | '_top', text: string, collapsibleTrail?: boolean, collapsed?: boolean } & GlobalProps const NavItem = (props: NavItemProps) => { const { active = false, aria = {}, bold, emphasized, children, className, collapsible, data = {}, dark = false, iconLeft, iconRight, onIconRightClick, onIconLeftClick, id, imageUrl, link, onClick = () => { }, target = '_self', text = '', collapsibleTrail, collapsed } = props const Tag = link ? 'a' : 'div' const activeClass = active === true ? 'active' : '' const collapsibleTrailClass = collapsible && collapsibleTrail ? 'collapsible_trail' : '' const boldClass = collapsible && bold ? 'bold' : '' const emphasizedClass = collapsible && emphasized ? 'emphasized' : '' const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const classes = classnames(buildCss('pb_nav_list_kit_item', activeClass), collapsible ? buildCss('pb_collapsible_nav_item', activeClass, collapsibleTrailClass, boldClass, emphasizedClass) : '', globalProps(props), className) const handleIconClick = (e:any) => { if (onIconLeftClick) { e.stopPropagation(); onIconLeftClick() } } return (
  • { collapsible ? ( {imageUrl &&
    handleIconClick(e)} >
    } {iconLeft &&
    handleIconClick(e)} >
    } {text}
    {children}
    ) : ( {imageUrl &&
    } {iconLeft &&
    } {text || children} {iconRight &&
    }
    ) }
  • ) } export default NavItem