UNPKG

@alifd/meet-react

Version:

Fusion Mobile React UI System Component

79 lines (78 loc) 4 kB
"use strict"; exports.__esModule = true; exports.default = void 0; var _tslib = require("tslib"); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _meetReactComponentOne = require("@alifd/meet-react-component-one"); var _view = _interopRequireDefault(require("../view")); var _icon = _interopRequireDefault(require("../icon")); var _utils = require("../utils"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 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 && Object.prototype.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 _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } var Avatar = function (props, ref) { var _props$prefix = props.prefix, prefix = _props$prefix === void 0 ? 'mt-' : _props$prefix, _props$size = props.size, size = _props$size === void 0 ? 'medium' : _props$size, _props$shape = props.shape, shape = _props$shape === void 0 ? 'circle' : _props$shape, src = props.src, alt = props.alt, srcSet = props.srcSet, className = props.className, _props$icon = props.icon, icon = _props$icon === void 0 ? null : _props$icon, _props$onError = props.onError, onError = _props$onError === void 0 ? function () {} : _props$onError, _props$onClick = props.onClick, onClick = _props$onClick === void 0 ? function () {} : _props$onClick, others = (0, _tslib.__rest)(props, ["prefix", "size", "shape", "src", "alt", "srcSet", "className", "icon", "onError", "onClick"]); var children = props.children; var _useState = (0, _react.useState)(true), isImgExist = _useState[0], setImgExist = _useState[1]; var iconCls = prefix + "avatar-icon--" + size; var handleError = function (err) { if (!_utils.isStrictMiniApp) { onError(err); setImgExist(false); } }; if (src) { if (isImgExist) { children = /*#__PURE__*/(0, _react.createElement)(_meetReactComponentOne.Image, { src: src, source: { uri: src }, srcSet: srcSet, alt: alt, onError: handleError }); } else if (alt) { children = (0, _utils.isString)(alt) ? alt.substr(0, 2) : children; } } else if ((0, _utils.isString)(icon)) { children = /*#__PURE__*/(0, _react.createElement)(_icon.default, { className: iconCls, name: icon }); } else if (icon) { children = (0, _react.cloneElement)(icon, { className: iconCls }); } else { children = (0, _utils.isString)(children) ? children.substr(0, 2) : children; } return /*#__PURE__*/(0, _react.createElement)(_view.default, _extends({ ref: ref }, others, { className: (0, _classnames.default)(className, prefix + "avatar", prefix + "avatar--" + size, prefix + "avatar--" + shape), onClick: onClick }), children); }; Avatar.displayName = 'Avatar'; var _default = exports.default = /*#__PURE__*/(0, _react.forwardRef)(Avatar);