Sha256: 8a68ed7db9cae871d9b30683ae6b4ce7bd6144d952ae161746e1c13c2cc46008

Contents?: true

Size: 1.77 KB

Versions: 35

Compression:

Stored size: 1.77 KB

Contents

/* @flow */

import React from 'react'
import classnames from 'classnames'

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

import Avatar from '../pb_avatar/_avatar'
import Icon from '../pb_icon/_icon'

type AvatarActionButtonProps = {
  action?: string,
  aria: Object,
  linkAriaLabel?: string,
  className?: string,
  dark?: boolean,
  data?: Object,
  id?: string,
  imageAlt?: string,
  imageUrl?: string,
  linkUrl?: string,
  name?: string,
  onClick?: string,
  placement?: string,
  size?: string,
}

const AvatarActionButton = (props: AvatarActionButtonProps) => {
  const {
    action = 'add',
    aria = {},
    linkAriaLabel,
    className,
    dark = false,
    data = {},
    id,
    imageAlt = '',
    imageUrl,
    linkUrl,
    name,
    onClick,
    placement = 'bottom left',
    size = 'md',
  } = props

  const ariaProps = buildAriaProps(aria)
  const dataProps = buildDataProps(data)

  const classes = classnames(buildCss(
    'pb_avatar_action_button_kit',
    [action],
    [placement],
    [size]),
  globalProps(props),
  className)

  const icons = {
    add: 'plus-circle',
    remove: 'times-circle',
  }

  return (
    <div
        {...ariaProps}
        {...dataProps}
        className={classes}
        id={id}
    >
      <a
          aria-label={linkAriaLabel}
          href={linkUrl}
          onClick={onClick}
      >
        <Avatar
            imageAlt={imageAlt}
            imageUrl={imageUrl}
            name={name}
            size={size}
        />
        <div className={`icon ${dark ? 'dark' : ''}`}>
          <Icon
              dark={dark}
              icon={icons[action]}
          />
        </div>
      </a>
    </div>
  )
}

export default AvatarActionButton

Version data entries

35 entries across 35 versions & 1 rubygems

Version Path
playbook_ui-11.2.2 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.2.1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.2.0 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.1.2 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.1.2.pre.alpha1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.1.1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.1.1.pre.alpha1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.1.0 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.0.1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.0.0 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.0.0.pre.alpha.2 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-11.0.0.pre.alpha.1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-10.26.1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-10.27.0.pre.lazysizes1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-10.27.0.pre.datepicker1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-10.26.0 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-10.26.0.pre.alpha5 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-10.26.0.pre.rc1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-10.26.0.pre.alpha.sticky1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx
playbook_ui-10.26.0.pre.alpha.display1 app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx