-
-
Notifications
You must be signed in to change notification settings - Fork 6.9k
/
VSheet.tsx
62 lines (55 loc) 路 1.82 KB
/
VSheet.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// Styles
import './VSheet.sass'
// Composables
import { makeBorderProps, useBorder } from '@/composables/border'
import { makeDimensionProps, useDimension } from '@/composables/dimensions'
import { makeElevationProps, useElevation } from '@/composables/elevation'
import { makePositionProps, usePosition } from '@/composables/position'
import { makeRoundedProps, useRounded } from '@/composables/rounded'
import { makeTagProps } from '@/composables/tag'
import { useBackgroundColor } from '@/composables/color'
import { makeThemeProps, provideTheme } from '@/composables/theme'
// Utilities
import { toRef } from 'vue'
import { defineComponent } from '@/util'
export const VSheet = defineComponent({
name: 'VSheet',
props: {
color: String,
...makeBorderProps(),
...makeDimensionProps(),
...makeElevationProps(),
...makePositionProps(),
...makeRoundedProps(),
...makeTagProps(),
...makeThemeProps(),
},
setup (props, { slots }) {
const { themeClasses } = provideTheme(props)
const { backgroundColorClasses, backgroundColorStyles } = useBackgroundColor(toRef(props, 'color'))
const { borderClasses } = useBorder(props)
const { dimensionStyles } = useDimension(props)
const { elevationClasses } = useElevation(props)
const { positionClasses, positionStyles } = usePosition(props)
const { roundedClasses } = useRounded(props)
return () => (
<props.tag
class={[
'v-sheet',
themeClasses.value,
backgroundColorClasses.value,
borderClasses.value,
elevationClasses.value,
positionClasses.value,
roundedClasses.value,
]}
style={[
backgroundColorStyles.value,
dimensionStyles.value,
positionStyles.value,
]}
v-slots={ slots }
/>
)
},
})