UNPKG

@primer/react

Version:

An implementation of GitHub's Primer Design System using React

68 lines (65 loc) 2.33 kB
import React from 'react'; import styled from 'styled-components'; import sx from '../sx.js'; import { VisuallyHidden } from '../internal/components/VisuallyHidden.js'; import Box from '../Box/Box.js'; import '@primer/behaviors/utils'; import '@primer/behaviors'; import { useId } from '../hooks/useId.js'; function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } const sizeMap = { small: '16px', medium: '32px', large: '64px' }; function Spinner({ size: sizeKey = 'medium', srText = 'Loading', 'aria-label': ariaLabel, ...props }) { const size = sizeMap[sizeKey]; const hasHiddenLabel = srText !== null && ariaLabel === undefined; const labelId = useId(); return ( /*#__PURE__*/ /* inline-flex removes the extra line height */ React.createElement(Box, { as: "span", sx: { display: 'inline-flex' } }, /*#__PURE__*/React.createElement("svg", _extends({ height: size, width: size, viewBox: "0 0 16 16", fill: "none", "aria-hidden": true, "aria-label": ariaLabel !== null && ariaLabel !== void 0 ? ariaLabel : undefined, "aria-labelledby": hasHiddenLabel ? labelId : undefined }, props), /*#__PURE__*/React.createElement("circle", { cx: "8", cy: "8", r: "7", stroke: "currentColor", strokeOpacity: "0.25", strokeWidth: "2", vectorEffect: "non-scaling-stroke" }), /*#__PURE__*/React.createElement("path", { d: "M15 8a7.002 7.002 0 00-7-7", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", vectorEffect: "non-scaling-stroke" })), hasHiddenLabel ? /*#__PURE__*/React.createElement(VisuallyHidden, { id: labelId }, srText) : null) ); } Spinner.displayName = "Spinner"; const StyledSpinner = styled(Spinner).withConfig({ displayName: "Spinner__StyledSpinner", componentId: "sc-1knt686-0" })(["@keyframes rotate-keyframes{100%{transform:rotate(360deg);}}animation:rotate-keyframes 1s linear infinite;", ""], sx); StyledSpinner.displayName = 'Spinner'; export { StyledSpinner as default };