UNPKG

quasar

Version:

Build high-performance VueJS user interfaces (SPA, PWA, SSR, Mobile and Desktop) in record time

87 lines (79 loc) 1.75 kB
import { h } from 'vue' import useSpinner, { useSpinnerProps } from './use-spinner.js' import { createComponent } from '../../utils/private/create.js' const svg = [ h('rect', { x: '0', y: '0', width: ' 100', height: '100', fill: 'none' }), h('path', { d: 'M78,19H22c-6.6,0-12,5.4-12,12v31c0,6.6,5.4,12,12,12h37.2c0.4,3,1.8,5.6,3.7,7.6c2.4,2.5,5.1,4.1,9.1,4 c-1.4-2.1-2-7.2-2-10.3c0-0.4,0-0.8,0-1.3h8c6.6,0,12-5.4,12-12V31C90,24.4,84.6,19,78,19z', fill: 'currentColor' }), h('circle', { cx: '30', cy: '47', r: '5', fill: '#fff' }, [ h('animate', { attributeName: 'opacity', from: '0', to: '1', values: '0;1;1', keyTimes: '0;0.2;1', dur: '1s', repeatCount: 'indefinite' }) ]), h('circle', { cx: '50', cy: '47', r: '5', fill: '#fff' }, [ h('animate', { attributeName: 'opacity', from: '0', to: '1', values: '0;0;1;1', keyTimes: '0;0.2;0.4;1', dur: '1s', repeatCount: 'indefinite' }) ]), h('circle', { cx: '70', cy: '47', r: '5', fill: '#fff' }, [ h('animate', { attributeName: 'opacity', from: '0', to: '1', values: '0;0;1;1', keyTimes: '0;0.4;0.6;1', dur: '1s', repeatCount: 'indefinite' }) ]) ] export default createComponent({ name: 'QSpinnerComment', props: useSpinnerProps, setup (props) { const { cSize, classes } = useSpinner(props) return () => h('svg', { class: classes.value, width: cSize.value, height: cSize.value, xmlns: 'http://www.w3.org/2000/svg', viewBox: '0 0 100 100', preserveAspectRatio: 'xMidYMid' }, svg) } })