mirror of
https://gitlab.com/bramw/baserow.git
synced 2024-11-21 23:37:55 +00:00
131 lines
2.8 KiB
Vue
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>
|