import { CSSProperties, ReactNode } from 'react' import classNames from 'classnames' import { CommonComponentProps } from '../../utils/types' import './Loading.scss' export interface LoadingProps extends CommonComponentProps { className?: string style?: CSSProperties children?: ReactNode type?: 'border' | 'clock' color?: string size?: string text?: string vertical?: boolean } export function Loading(props: LoadingProps) { const { className, style, children, type = 'border', color = '', size = '', text = '', vertical = false, ...restProps } = props const loadingClass = classNames( 's-loading', { 's-loading-vertical': vertical, }, className ) const loadingStyle = { color, ...style, } const spinnerClass = classNames( 's-loading-spinner', 's-loading-spinner-' + type ) const spinnerStyle = { fontSize: size, } return (