1
0
mirror of https://gitlab.com/bramw/baserow.git synced 2024-11-21 23:37:55 +00:00
bramw_baserow/web-frontend/modules/core/components/ButtonText.vue
2024-07-18 12:51:03 +00:00

131 lines
2.8 KiB
Vue

<template>
<component
:is="tag === 'a' || href ? 'a' : 'button'"
class="button-text"
:class="classes"
:disabled="disabled || loading"
v-bind.prop="customBind"
v-on="$listeners"
>
<i v-if="icon !== '' && !loading" class="button-text__icon" :class="icon" />
<i v-if="loading" class="button-text__spinner"></i>
<span v-if="$slots.default" class="button-text__label"><slot /></span>
</component>
</template>
<script>
export default {
props: {
/**
* The tag to use for the root element.
*/
tag: {
required: false,
type: String,
default: 'button',
validator(value) {
return ['a', 'button'].includes(value)
},
},
/**
* The size of the button. Available sizes are `regular` and `small`.
*/
size: {
required: false,
type: String,
default: 'regular',
validator(value) {
return ['regular', 'small'].includes(value)
},
},
/**
* The type of the button. Available types are `primary` and `secondary`.
*/
type: {
required: false,
type: String,
default: 'primary',
validator(value) {
return ['primary', 'secondary'].includes(value)
},
},
/**
* The icon of the button. Must be a valid iconoir or baserow icon class name.
*/
icon: {
required: false,
type: String,
default: '',
},
/**
* If true a loading icon will be shown.
*/
loading: {
required: false,
type: Boolean,
default: false,
},
/**
* If true the button will be disabled.
*/
disabled: {
required: false,
type: Boolean,
default: false,
},
/**
* The href attribute of the button.
*/
href: {
required: false,
type: String,
default: '',
},
/**
* The rel attribute of the button.
*/
rel: {
required: false,
type: String,
default: '',
},
/**
* The target attribute of the button.
*/
target: {
required: false,
type: String,
validator(value) {
return ['_blank', '_self'].includes(value)
},
default: '_self',
},
},
computed: {
classes() {
const classObj = {
[`button-text--${this.size}`]: this.size !== 'regular',
[`button-text--${this.type}`]: this.type !== 'primary',
'button-text--loading': this.loading,
}
return classObj
},
customBind() {
const attr = {}
if (this.tag === 'a') {
attr.href = this.href
attr.target = this.target
attr.rel = this.target
}
return Object.keys(attr).forEach((key) => {
if (attr[key] === null) {
delete attr[key]
}
})
},
},
}
</script>