UNPKG

@atlaskit/avatar

Version:

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

177 lines (171 loc) 8.65 kB
/* avatar.tsx generated by @compiled/babel-plugin v0.39.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 _contentContext = require("./internal/content-context"); var _ensureIsInsideAvatarContext = require("./internal/ensure-is-inside-avatar-context"); var _getCustomElement = _interopRequireDefault(require("./internal/get-custom-element")); var _presenceWrapper = _interopRequireDefault(require("./internal/presence-wrapper")); var _statusWrapper = _interopRequireDefault(require("./internal/status-wrapper")); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); } 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.11.1"; 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, _ref$isDecorative = _ref.isDecorative, isDecorative = _ref$isDecorative === void 0 ? false : _ref$isDecorative, imgLoading = _ref.imgLoading, ariaControls = _ref['aria-controls'], ariaExpanded = _ref['aria-expanded'], ariaHasPopup = _ref['aria-haspopup']; 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 || ariaHasPopup; var containerShouldBeImage = Boolean(!isInteractive && defaultLabel); return /*#__PURE__*/React.createElement(_ensureIsInsideAvatarContext.EnsureIsInsideAvatarContext.Provider, { value: true }, /*#__PURE__*/React.createElement(AvatarContainer, { "data-testid": testId, role: containerShouldBeImage ? 'img' : undefined, "aria-labelledby": containerShouldBeImage && !isDecorative ? labelId : undefined, style: { zIndex: stackIndex }, className: (0, _runtime.ax)(["_12ji1r31 _1qu2glyw _12y3idpf _1e0c1o8l _kqswh2mm"]) }, /*#__PURE__*/React.createElement(_contentContext.AvatarContentContext.Provider, { value: { as: (0, _getCustomElement.default)(isDisabled, href, onClick, ariaHasPopup), 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, 'aria-controls': ariaControls, 'aria-expanded': ariaExpanded, 'aria-haspopup': ariaHasPopup, avatarImage: /*#__PURE__*/React.createElement(_avatarImage.default, { alt: !containerShouldBeImage && src ? name : undefined, src: src, appearance: appearance, size: size, testId: testId, imgLoading: imgLoading }) } }, children || /*#__PURE__*/React.createElement(_avatarContent.AvatarContent, null)), isPresence && /*#__PURE__*/React.createElement(_presenceWrapper.default, { appearance: appearance, size: size, presence: typeof presence === 'string' ? presence : undefined, testId: testId }, customPresenceNode), isStatus && /*#__PURE__*/React.createElement(_statusWrapper.default, { 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;