feat: CellGroup component

This commit is contained in:
chenjiahan 2020-07-05 16:40:10 +08:00
parent 2f1f540d6a
commit bd5651402a
2 changed files with 50 additions and 0 deletions

View File

@ -0,0 +1,38 @@
// Utils
import { createNamespace } from '../utils';
import { BORDER_TOP_BOTTOM } from '../utils/constant';
const [createComponent, bem] = createNamespace('cell-group');
export default createComponent({
props: {
title: String,
border: {
type: Boolean,
default: true,
},
},
setup(props, { slots }) {
return function () {
const Group = (
<div class={[bem(), { [BORDER_TOP_BOTTOM]: props.border }]}>
{slots.default?.()}
</div>
);
if (props.title || slots.title) {
return (
<>
<div class={bem('title')} {...this.$attrs}>
{slots.title ? slots.title() : props.title}
</div>
{Group}
</>
);
}
return Group;
};
},
});

View File

@ -0,0 +1,12 @@
@import '../style/var';
.van-cell-group {
background-color: @cell-group-background-color;
&__title {
padding: @cell-group-title-padding;
color: @cell-group-title-color;
font-size: @cell-group-title-font-size;
line-height: @cell-group-title-line-height;
}
}