Files
Yi.Admin/Yi.Vue2.x/src/components/MaterialCard.vue
2022-04-26 01:34:47 +08:00

114 lines
2.3 KiB
Vue

<template>
<app-card
v-bind="$attrs"
class="v-card--material mt-4"
>
<v-card-title class="align-start">
<v-sheet
:color="color"
:width="fullHeader ? '100%' : undefined"
class="overflow-hidden mt-n9 transition-swing v-card--material__sheet"
elevation="6"
max-width="100%"
rounded
>
<v-theme-provider
v-if="hasHeading"
dark
>
<div
v-if="icon"
:class="iconSmall ? 'pa-7' : 'pa-8'"
>
<v-icon
:large="!iconSmall"
v-text="icon"
/>
</div>
<slot name="heading" />
<div
v-if="heading"
class="text-h4 white--text pa-7 v-card--material__title"
>
{{ heading }}
</div>
</v-theme-provider>
</v-sheet>
<div
v-if="hasTitle"
:class="fullHeader ? 'pt-4' : 'pl-3'"
class="text-h4 v-card--material__title"
>
<slot name="title" />
<template v-if="title">
{{ title }}
</template>
<div class="text-subtitle-1 mb-n4">
<slot name="subtitle" />
<template v-if="subtitle">
{{ subtitle }}
</template>
</div>
</div>
</v-card-title>
<slot />
<template v-if="$slots.actions">
<v-divider class="mt-2 mx-4" />
<v-card-actions class="px-4 text-caption grey--text">
<slot name="actions" />
</v-card-actions>
</template>
</app-card>
</template>
<script>
export default {
name: 'MaterialCard',
props: {
color: String,
fullHeader: Boolean,
heading: String,
icon: String,
iconSmall: Boolean,
subtitle: String,
title: String,
},
computed: {
hasHeading () {
return !!(
this.icon ||
this.heading ||
this.$slots.heading
)
},
hasTitle () {
return !!(
this.title ||
this.subtitle ||
this.$slots.title ||
this.$slots.subtitle
)
},
},
}
</script>
<style lang="sass">
.v-card.v-card--material
> .v-card__title
> .v-card--material__title
flex: 1 1 auto
word-break: break-word
</style>