mirror of https://github.com/sylv/micro.git
27 lines
886 B
TypeScript
27 lines
886 B
TypeScript
import clsx from 'clsx';
|
|
import type { FC, HTMLAttributes } from 'react';
|
|
import React from 'react';
|
|
|
|
export interface SpinnerProps extends HTMLAttributes<SVGElement> {
|
|
size?: 'small' | 'medium' | 'large';
|
|
}
|
|
|
|
export const Spinner: FC<SpinnerProps> = ({ size, className, ...rest }) => {
|
|
const classes = clsx('animate-spin', className, {
|
|
'w-4': size === 'small',
|
|
'w-6': !size || size === 'medium',
|
|
'w-9': size === 'large',
|
|
});
|
|
|
|
return (
|
|
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" {...rest} className={classes}>
|
|
<circle className="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" strokeWidth="4" />
|
|
<path
|
|
className="opacity-75"
|
|
fill="currentColor"
|
|
d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
|
|
/>
|
|
</svg>
|
|
);
|
|
};
|