Sha256: 8e130c7b85f5961503e82c4d549f5facb456922ad93efdccc9e28e1a56db6a4c

Contents?: true

Size: 1.04 KB

Versions: 5

Compression:

Stored size: 1.04 KB

Contents

import React from 'react';
import PropTypes from "prop-types";
import classnames from 'classnames';
import { map } from 'lodash'
import Image from "../pb_image/_image.jsx";

const propTypes = {
  className: PropTypes.string,
  name: PropTypes.string,
  size: PropTypes.string,
  url: PropTypes.string
};

const defaultProps = {
  name: null,
  size: "base"
};

const initials = function(name) {
  if (name) {
    return map(name.split(/\s/), name => name[0]).join('').substring(0,2)
  }
};

const image = function(url, name) {
  if (url) {
    return (
      <Image alt={name}
          url={url}
      />
    )
  }
};

class Avatar extends React.Component {
  render() {
    const {
      className,
      name,
      size,
      url
    } = this.props;

    const css = classnames([
      `avatar_${size}`,
      className,
    ])

    return (
      <div className={css}
          data-initials={initials(name)}
      >
        {image(url, name)}
      </div>
    )
  }
}

Avatar.propTypes = propTypes;
Avatar.defaultProps = defaultProps;

export default Avatar;

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
playbook_ui-2.7.2 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-2.7.1 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-2.7.0 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-2.6.0 app/pb_kits/playbook/pb_avatar/_avatar.jsx
playbook_ui-2.5.0 app/pb_kits/playbook/pb_avatar/_avatar.jsx