|
|
|
|
@ -1,7 +1,6 @@
|
|
|
|
|
<script setup>
|
|
|
|
|
import { computed, ref } from 'vue'
|
|
|
|
|
import SpinnerIcon from '@/scripts/components/icons/SpinnerIcon.vue'
|
|
|
|
|
|
|
|
|
|
const props = defineProps({
|
|
|
|
|
contentLoading: {
|
|
|
|
|
type: Boolean,
|
|
|
|
|
@ -10,7 +9,7 @@ const props = defineProps({
|
|
|
|
|
defaultClass: {
|
|
|
|
|
type: String,
|
|
|
|
|
default:
|
|
|
|
|
'inline-flex whitespace-nowrap items-center border font-medium focus:outline-none focus:ring-2 focus:ring-offset-2 dark:focus:ring-offset-gray-800',
|
|
|
|
|
'inline-flex whitespace-nowrap items-center border font-medium focus:outline-none focus:ring-2 focus:ring-offset-2',
|
|
|
|
|
},
|
|
|
|
|
tag: {
|
|
|
|
|
type: String,
|
|
|
|
|
@ -28,10 +27,6 @@ const props = defineProps({
|
|
|
|
|
type: Boolean,
|
|
|
|
|
default: false,
|
|
|
|
|
},
|
|
|
|
|
loadingRight: {
|
|
|
|
|
type: Boolean,
|
|
|
|
|
default: false,
|
|
|
|
|
},
|
|
|
|
|
size: {
|
|
|
|
|
type: String,
|
|
|
|
|
default: 'md',
|
|
|
|
|
@ -86,17 +81,17 @@ const placeHolderSize = computed(() => {
|
|
|
|
|
|
|
|
|
|
const variantClass = computed(() => {
|
|
|
|
|
return {
|
|
|
|
|
'border-transparent shadow-sm text-white bg-primary-600 hover:bg-primary-700 focus:ring-primary-500 dark:bg-primary-500 dark:hover:bg-primary-600':
|
|
|
|
|
'border-transparent shadow-sm text-white bg-primary-600 hover:bg-primary-700 focus:ring-primary-500':
|
|
|
|
|
props.variant === 'primary',
|
|
|
|
|
'border-transparent text-primary-700 bg-primary-100 hover:bg-primary-200 focus:ring-primary-500':
|
|
|
|
|
props.variant === 'secondary',
|
|
|
|
|
'border-transparent border-solid border-primary-500 font-normal transition ease-in-out duration-150 text-primary-500 hover:bg-primary-100 shadow-inner focus:ring-primary-500 dark:text-primary-400 dark:border-primary-400 dark:hover:bg-transparent dark:hover:text-primary-500 dark:hover:border-primary-500':
|
|
|
|
|
'border-transparent border-solid border-primary-500 font-normal transition ease-in-out duration-150 text-primary-500 hover:bg-primary-200 shadow-inner focus:ring-primary-500':
|
|
|
|
|
props.variant == 'primary-outline',
|
|
|
|
|
'border-gray-200 text-gray-700 bg-white hover:bg-gray-50 focus:ring-primary-500 focus:ring-offset-0 dark:bg-gray-800 dark:border-gray-600 dark:text-gray-300 dark:hover:bg-gray-900':
|
|
|
|
|
'border-gray-200 text-gray-700 bg-white hover:bg-gray-50 focus:ring-primary-500 focus:ring-offset-0':
|
|
|
|
|
props.variant == 'white',
|
|
|
|
|
'border-transparent shadow-sm text-white bg-red-600 hover:bg-red-700 focus:ring-red-500':
|
|
|
|
|
props.variant === 'danger',
|
|
|
|
|
'border-transparent bg-gray-200 border hover:bg-opacity-60 focus:ring-gray-500 focus:ring-offset-0 dark:bg-gray-600 dark:text-white dark:hover:bg-opacity-60':
|
|
|
|
|
'border-transparent bg-gray-200 border hover:bg-opacity-60 focus:ring-gray-500 focus:ring-offset-0':
|
|
|
|
|
props.variant === 'gray',
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
@ -129,13 +124,6 @@ const iconRightClass = computed(() => {
|
|
|
|
|
'ml-3 -mr-1 h-5 w-5': props.size === 'lg' || props.size === 'xl',
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
const buttonDisabledClass = computed(() => {
|
|
|
|
|
if (props.disabled || props.loading)
|
|
|
|
|
return 'cursor-not-allowed bg-opacity-70 dark:!bg-opacity-40 hover:!bg-opacity-70 pointer-event-none'
|
|
|
|
|
|
|
|
|
|
return ''
|
|
|
|
|
})
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<template>
|
|
|
|
|
@ -153,17 +141,15 @@ const buttonDisabledClass = computed(() => {
|
|
|
|
|
<BaseCustomTag
|
|
|
|
|
v-else
|
|
|
|
|
:tag="tag"
|
|
|
|
|
:disabled="disabled || loading"
|
|
|
|
|
:class="[defaultClass, sizeClass, variantClass, roundedClass, buttonDisabledClass]"
|
|
|
|
|
:disabled="disabled"
|
|
|
|
|
:class="[defaultClass, sizeClass, variantClass, roundedClass]"
|
|
|
|
|
>
|
|
|
|
|
<SpinnerIcon v-if="loading && !loadingRight" :class="[iconLeftClass, iconVariantClass]" />
|
|
|
|
|
<SpinnerIcon v-if="loading" :class="[iconLeftClass, iconVariantClass]" />
|
|
|
|
|
|
|
|
|
|
<slot v-else name="left" :class="iconLeftClass" />
|
|
|
|
|
<slot v-else name="left" :class="iconLeftClass"></slot>
|
|
|
|
|
|
|
|
|
|
<slot />
|
|
|
|
|
|
|
|
|
|
<SpinnerIcon v-if="loading && loadingRight" :class="[iconRightClass, iconVariantClass]" />
|
|
|
|
|
|
|
|
|
|
<slot v-else name="right" :class="[iconRightClass, iconVariantClass]" />
|
|
|
|
|
<slot name="right" :class="[iconRightClass, iconVariantClass]"></slot>
|
|
|
|
|
</BaseCustomTag>
|
|
|
|
|
</template>
|
|
|
|
|
|