skeleton-elements
Version:
Skeleton elements (aka UI Skeletons, Skeleton Screens, Ghost Elements) - UI for improved perceived performance
48 lines (43 loc) • 1.97 kB
JavaScript
function _extends() { _extends = Object.assign || 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); }
import React from 'react';
import multiplySvgPoints from '../utils/multiply-svg-points.js';
const SkeletonAvatar = ({
tag: Tag = 'span',
size = 48,
color,
showIcon = true,
iconColor,
borderRadius = '50%',
effect,
className,
children,
...other
} = {}) => {
const skeletonClassName = ['skeleton-avatar', effect && `skeleton-effect-${effect}`, className].filter(c => !!c).join(' ');
function multiplyPoints(pointsString) {
return multiplySvgPoints(pointsString, 56, size, size);
}
return /*#__PURE__*/React.createElement(Tag, _extends({
className: skeletonClassName
}, other), /*#__PURE__*/React.createElement("svg", {
xmlns: "http://www.w3.org/2000/svg",
width: size,
height: size,
viewBox: `0 0 ${size} ${size}`,
preserveAspectRatio: "none"
}, /*#__PURE__*/React.createElement("rect", {
width: size,
height: size,
fillRule: "evenodd",
style: {
fill: color
},
rx: borderRadius
}), showIcon && /*#__PURE__*/React.createElement("path", {
style: {
fill: iconColor
},
d: multiplyPoints('M28.22461,27.1590817 C34.9209931,27.1590817 40.6829044,21.1791004 40.6829044,13.3926332 C40.6829044,5.69958662 34.8898972,0 28.22461,0 C21.5594557,0 15.7663156,5.82423601 15.7663156,13.4549579 C15.7663156,21.1791004 21.5594557,27.1590817 28.22461,27.1590817 Z M8.66515427,56 L47.7841986,56 C52.6739629,56 54.4181241,54.5984253 54.4181241,51.8576005 C54.4181241,43.8219674 44.358068,32.7341519 28.22461,32.7341519 C12.0600561,32.7341519 2,43.8219674 2,51.8576005 C2,54.5984253 3.74402832,56 8.66515427,56 Z')
})), children);
};
export default SkeletonAvatar;