element-plus
Version:
A Component Library for Vue3.0
56 lines (52 loc) • 1.09 kB
text/typescript
import { defineComponent, computed, h, provide } from 'vue'
export default defineComponent({
name: 'ElRow',
props: {
tag: {
type: String,
default: 'div',
},
gutter: {
type: Number,
default: 0,
},
justify: {
type: String,
default: 'start',
},
align: {
type: String,
default: 'top',
},
},
setup(props, { slots }) {
const gutter = computed(() => props.gutter)
provide('ElRow', {
gutter,
})
const style = computed(() => {
const ret = {
marginLeft: '',
marginRight: '',
}
if (props.gutter) {
ret.marginLeft = `-${props.gutter / 2}px`
ret.marginRight = ret.marginLeft
}
return ret
})
return () =>
h(
props.tag,
{
class: [
'el-row',
props.justify !== 'start' ? `is-justify-${props.justify}` : '',
props.align !== 'top' ? `is-align-${props.align}` : '',
],
style: style.value,
},
slots.default?.(),
)
},
})