Sha256: 66d858575eab0c9bdb0ac17a2a129fb0adc5ce750b71684596ca294f650d7406

Contents?: true

Size: 1.75 KB

Versions: 19

Compression:

Stored size: 1.75 KB

Contents

/* @flow */

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

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

import { Image, OnlineStatus } from '../'

type AvatarProps = {
  aria?: object,
  className?: string,
  data?: object,
  dark?: boolean,
  id?: string,
  imageUrl: string,
  name: string,
  size?: "md" | "lg" | "sm" | "xl" | "xs",
  status: "away" | "offline" | "online",
}

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

const Avatar = (props: AvatarProps) => {
  const { aria = {}, className, data = {}, name = null, id = '', imageUrl, size = 'md', status = null, dark = false } = props
  const dataProps = buildDataProps(data)
  const ariaProps = buildAriaProps(aria)
  const classes = classnames(
    buildCss('pb_avatar_kit', size),
    globalProps(props),
    className
  )

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

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

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

export default Avatar

Version data entries

19 entries across 19 versions & 1 rubygems

Version Path
playbook_ui-8.1.3 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.1.2 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.0.3 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.2.0.pre.alpha2 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.1.1 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.0.2 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.2.0.pre.alpha1 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.1.0 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.0.1 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.0.0 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.0.0.pre.alpha5 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.0.0.pre.alpha4 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-8.0.0.pre.alpha1 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-7.16.0.pre.alpha5 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-7.16.0.pre.alpha4 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-7.16.0.pre.alpha3 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-7.16.0.pre.alpha2 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-7.16.0.pre.alpha1 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-7.16.0 app/pb_kits/playbook/pb_avatar/_avatar.jsx