quasar
Version:
Build high-performance VueJS user interfaces (SPA, PWA, SSR, Mobile and Desktop) in record time
41 lines (33 loc) • 792 B
JavaScript
import { h } from 'vue'
import useSpinner, { useSpinnerProps } from './use-spinner.js'
import { createComponent } from '../../utils/private/create.js'
export default createComponent({
name: 'QSpinner',
props: {
...useSpinnerProps,
thickness: {
type: Number,
default: 5
}
},
setup (props) {
const { cSize, classes } = useSpinner(props)
return () => h('svg', {
class: classes.value + ' q-spinner-mat',
width: cSize.value,
height: cSize.value,
viewBox: '25 25 50 50'
}, [
h('circle', {
class: 'path',
cx: '50',
cy: '50',
r: '20',
fill: 'none',
stroke: 'currentColor',
'stroke-width': props.thickness,
'stroke-miterlimit': '10'
})
])
}
})