UNPKG

@atlaskit/avatar

Version:

An avatar is a visual representation of a user or entity.

166 lines (160 loc) 8.02 kB
/* avatar.tsx generated by @compiled/babel-plugin v0.36.1 */ "use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; require("./avatar.compiled.css"); var _react = _interopRequireWildcard(require("react")); var React = _react; var _runtime = require("@compiled/react/runtime"); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _analyticsNext = require("@atlaskit/analytics-next"); var _useId = require("@atlaskit/ds-lib/use-id"); var _avatarContent = require("./avatar-content"); var _context = require("./context"); var _avatarImage = _interopRequireDefault(require("./internal/avatar-image")); var _presence = require("./presence"); var _status = require("./status"); var _utilities = require("./utilities"); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } var packageName = "@atlaskit/avatar"; var packageVersion = "25.0.2"; var containerStyles = null; // eslint-disable-next-line @repo/internal/react/consistent-types-definitions /** * __Avatar__ * * An avatar is a visual representation of a user or entity. * * - [Examples](https://atlassian.design/components/avatar/examples) * - [Code](https://atlassian.design/components/avatar/code) * - [Usage](https://atlassian.design/components/avatar/usage) */ var Avatar = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) { var analyticsContext = _ref.analyticsContext, _ref$appearance = _ref.appearance, appearance = _ref$appearance === void 0 ? 'circle' : _ref$appearance, label = _ref.label, borderColor = _ref.borderColor, children = _ref.children, href = _ref.href, isDisabled = _ref.isDisabled, name = _ref.name, onClick = _ref.onClick, presence = _ref.presence, sizeProp = _ref.size, src = _ref.src, stackIndex = _ref.stackIndex, status = _ref.status, target = _ref.target, testId = _ref.testId, _ref$as = _ref.as, AvatarContainer = _ref$as === void 0 ? 'div' : _ref$as; var _useAnalyticsEvents = (0, _analyticsNext.useAnalyticsEvents)(), createAnalyticsEvent = _useAnalyticsEvents.createAnalyticsEvent; var context = (0, _context.useAvatarContext)(); var size = sizeProp || (context === null || context === void 0 ? void 0 : context.size) || 'medium'; var customPresenceNode = /*#__PURE__*/(0, _react.isValidElement)(presence) ? presence : null; var customStatusNode = /*#__PURE__*/(0, _react.isValidElement)(status) ? status : null; var isValidIconSize = size !== 'xxlarge' && size !== 'xsmall'; var lastAnalytics = (0, _react.useRef)(analyticsContext); var labelId = (0, _useId.useId)(); (0, _react.useEffect)(function () { lastAnalytics.current = analyticsContext; }, [analyticsContext]); var onClickHandler = (0, _react.useCallback)(function (event) { if (isDisabled || typeof onClick !== 'function') { return; } var analyticsEvent = createAnalyticsEvent({ action: 'clicked', actionSubject: 'avatar', attributes: { componentName: 'avatar', packageName: packageName, packageVersion: packageVersion } }); /** * To avoid wrapping this component in AnalyticsContext we manually * push the parent context's meta data into the context. */ var context = _objectSpread({ componentName: 'avatar', packageName: packageName, packageVersion: packageVersion }, lastAnalytics.current); analyticsEvent.context.push(context); /** * Replicating the logic in the `withAnalyticsEvents` HOC. */ var clone = analyticsEvent.clone(); if (clone) { clone.fire('atlaskit'); } onClick(event, analyticsEvent); }, [createAnalyticsEvent, isDisabled, onClick]); var isPresence = isValidIconSize && presence && !status; var isStatus = isValidIconSize && status; // add presence or status to the label by default if presence and status are passed as a string // if status or presence are nodes this is not added to the label by default var defaultLabel = [name, isStatus && !customStatusNode && "(".concat(status, ")"), isPresence && !customPresenceNode && "(".concat(presence, ")")].filter(Boolean).join(' '); var isInteractive = onClick || href || isDisabled; var containerShouldBeImage = Boolean(!isInteractive && defaultLabel); return /*#__PURE__*/React.createElement(_context.EnsureIsInsideAvatarContext.Provider, { value: true }, /*#__PURE__*/React.createElement(AvatarContainer, { "data-testid": testId, role: containerShouldBeImage ? 'img' : undefined, "aria-labelledby": containerShouldBeImage ? labelId : undefined, style: { zIndex: stackIndex }, className: (0, _runtime.ax)(["_12ji1r31 _1qu2glyw _12y3idpf _1e0c1o8l _kqswh2mm"]) }, /*#__PURE__*/React.createElement(_context.AvatarContentContext.Provider, { value: { as: (0, _utilities.getCustomElement)(isDisabled, href, onClick), appearance: appearance, borderColor: borderColor, href: href, isDisabled: isDisabled, label: label || defaultLabel, onClick: isInteractive ? onClickHandler : undefined, ref: ref, size: size, stackIndex: stackIndex, target: target, testId: testId ? "".concat(testId, "--inner") : undefined, avatarImage: /*#__PURE__*/React.createElement(_avatarImage.default, { alt: !containerShouldBeImage && src ? name : undefined, src: src, appearance: appearance, size: size, testId: testId }) } }, children || /*#__PURE__*/React.createElement(_avatarContent.AvatarContent, null)), isPresence && /*#__PURE__*/React.createElement(_presence.PresenceWrapper, { appearance: appearance, size: size, presence: typeof presence === 'string' ? presence : undefined, testId: testId }, customPresenceNode), isStatus && /*#__PURE__*/React.createElement(_status.StatusWrapper, { appearance: appearance, size: size, borderColor: borderColor, status: typeof status === 'string' ? status : undefined, testId: testId }, customStatusNode), containerShouldBeImage ? /*#__PURE__*/React.createElement("span", { "data-testid": testId && "".concat(testId, "--label"), id: labelId, hidden: true }, defaultLabel) : undefined)); }); Avatar.displayName = 'Avatar'; var _default = exports.default = Avatar;