Sha256: 878e5d0388bbd68cfd35552974d11c854d8c6b75dd5718d171639f42756f4d49

Contents?: true

Size: 2 KB

Versions: 91

Compression:

Stored size: 2 KB

Contents

import React, { useState } from 'react'
import classnames from 'classnames'

import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props'
import { globalProps, GlobalProps } from '../utilities/globalProps'

import Image from '../pb_image/_image'
import OnlineStatus from '../pb_online_status/_online_status'

type AvatarProps = {
  aria?: {[key: string]: string},
  className?: string,
  data?: {[key: string]: string},
  dark?: boolean,
  id?: string,
  imageAlt?: string,
  imageUrl: string,
  name: string,
  size?: "md" | "lg" | "sm" | "xl" | "xs" | "xxs",
  status?: "away" | "offline" | "online",
} & GlobalProps

const firstTwoInitials = (name: string) =>
  name.split(/\s/).map((name) => name[0])
    .join('')
    .substring(0, 2)

const Avatar = (props: AvatarProps): React.ReactElement => {
  const {
    aria = {},
    className,
    data = {},
    name = null,
    id = '',
    imageAlt = '',
    imageUrl,
    size = 'md',
    status = null,
    dark = false,
  } = props
  const dataProps: {[key: string]: any} = buildDataProps(data)
  const ariaProps: {[key: string]: any} = buildAriaProps(aria)
  const classes = classnames(
    buildCss('pb_avatar_kit', `size_${size}`),
    globalProps(props),
    className
  )

  const initials = name && firstTwoInitials(name)
  dataProps['data-initials'] = initials

  const [error, setError] = useState(false)
  const handleError = () => setError(true)

  const canShowImage = imageUrl && !error

  return (
    <div
        {...ariaProps}
        {...dataProps}
        className={classes}
        id={id}
    >
      <div
          className="avatar_wrapper"
          data-initials={initials}
      >
        { canShowImage && (
          <Image
              alt={imageAlt}
              onError={handleError}
              url={imageUrl}
          />
        )}
      </div>
      {status && (
        <OnlineStatus
            className={`size_${size}`}
            dark={dark}
            status={status}
        />
      )}
    </div>
  )
}

export default Avatar

Version data entries

91 entries across 91 versions & 1 rubygems

Version Path
playbook_ui-12.7.1.pre.alpha.rubyandnpmalpharelease293 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.7.1.pre.alpha.rubyandnpmalpharelease292 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.7.1.pre.alpha.rubyandnpmalpharelease291 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.7.1.pre.alpha.alpharubyrelease281 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.7.1.pre.alpha.menu2 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.7.1.pre.alpha.menu1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.7.1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.7.0 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.6.0.pre.alpha.sectionseparator1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.6.0.pre.alpha.menuyml1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.6.0.pre.alpha.collapsible1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.6.0.pre.alpha.cssphone1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.6.0 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.5.0.pre.alpha.datepickerinput1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.5.0.pre.alpha.phonerails1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.5.0.pre.alpha.datepicker1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.5.0.pre.alpha.filter1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.5.0 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.4.0.pre.alpha.map1 app/pb_kits/playbook/pb_avatar/_avatar.tsx
playbook_ui-12.4.0.pre.alpha.devdocstest1 app/pb_kits/playbook/pb_avatar/_avatar.tsx