44 lines
755 B
Vue
44 lines
755 B
Vue
<script>
|
|
export default {
|
|
props: {
|
|
label: {
|
|
type: String,
|
|
required: false,
|
|
default: 'Loading',
|
|
},
|
|
|
|
size: {
|
|
type: String,
|
|
required: false,
|
|
default: '1',
|
|
},
|
|
|
|
inline: {
|
|
type: Boolean,
|
|
required: false,
|
|
default: false,
|
|
},
|
|
},
|
|
|
|
computed: {
|
|
rootElementType() {
|
|
return this.inline ? 'span' : 'div';
|
|
},
|
|
cssClass() {
|
|
return `fa-${this.size}x`;
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
<template>
|
|
<component
|
|
:is="this.rootElementType"
|
|
class="text-center">
|
|
<i
|
|
class="fa fa-spin fa-spinner"
|
|
:class="cssClass"
|
|
aria-hidden="true"
|
|
:aria-label="label">
|
|
</i>
|
|
</component>
|
|
</template>
|