mirror of
https://github.com/ArthurDanjou/ui.git
synced 2026-01-16 13:08:06 +01:00
115 lines
2.3 KiB
Vue
115 lines
2.3 KiB
Vue
<template>
|
|
<component
|
|
:is="$attrs.onSubmit ? 'form': 'div'"
|
|
:class="cardClass"
|
|
v-bind="$attrs"
|
|
>
|
|
<div
|
|
v-if="$slots.header"
|
|
:class="[headerClass, headerBackgroundClass, borderColorClass, !!$slots.default && 'border-b']"
|
|
>
|
|
<slot name="header" />
|
|
</div>
|
|
<div :class="[bodyClass, bodyBackgroundClass]">
|
|
<slot />
|
|
</div>
|
|
<div
|
|
v-if="$slots.footer"
|
|
:class="[footerClass, footerBackgroundClass, borderColorClass, (!!$slots.default || (!$slots.default && !!$slots.header)) && 'border-t']"
|
|
>
|
|
<slot name="footer" />
|
|
</div>
|
|
</component>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { computed } from 'vue'
|
|
import { classNames } from '../../utils'
|
|
import $ui from '#build/ui'
|
|
|
|
const props = defineProps({
|
|
padded: {
|
|
type: Boolean,
|
|
default: false
|
|
},
|
|
rounded: {
|
|
type: Boolean,
|
|
default: true
|
|
},
|
|
baseClass: {
|
|
type: String,
|
|
default: () => $ui.card.base
|
|
},
|
|
backgroundClass: {
|
|
type: String,
|
|
default: () => $ui.card.background
|
|
},
|
|
borderColorClass: {
|
|
type: String,
|
|
default: () => $ui.card.border
|
|
},
|
|
shadowClass: {
|
|
type: String,
|
|
default: () => $ui.card.shadow
|
|
},
|
|
ringClass: {
|
|
type: String,
|
|
default: () => $ui.card.ring
|
|
},
|
|
roundedClass: {
|
|
type: String,
|
|
default: () => $ui.card.rounded,
|
|
validator (value: string) {
|
|
return !value || ['sm', 'md', 'lg', 'xl', '2xl', '3xl'].map(size => `rounded-${size}`).includes(value)
|
|
}
|
|
},
|
|
bodyClass: {
|
|
type: String,
|
|
default: () => $ui.card.body
|
|
},
|
|
bodyBackgroundClass: {
|
|
type: String,
|
|
default: null
|
|
},
|
|
headerClass: {
|
|
type: String,
|
|
default: () => $ui.card.header
|
|
},
|
|
headerBackgroundClass: {
|
|
type: String,
|
|
default: null
|
|
},
|
|
footerClass: {
|
|
type: String,
|
|
default: () => $ui.card.footer
|
|
},
|
|
footerBackgroundClass: {
|
|
type: String,
|
|
default: null
|
|
},
|
|
customClass: {
|
|
type: String,
|
|
default: null
|
|
}
|
|
})
|
|
|
|
const cardClass = computed(() => {
|
|
return classNames(
|
|
props.baseClass,
|
|
props.padded && props.rounded && props.roundedClass,
|
|
!props.padded && props.rounded && props.roundedClass && `sm:${props.roundedClass}`,
|
|
props.ringClass,
|
|
props.shadowClass,
|
|
props.backgroundClass,
|
|
props.customClass
|
|
)
|
|
})
|
|
</script>
|
|
|
|
<script lang="ts">
|
|
export default {
|
|
name: 'UCard',
|
|
inheritAttrs: false
|
|
}
|
|
</script>
|