<template>
<view class="u-divider" :style="{
height: height == 'auto' ? 'auto' : height + 'rpx',
backgroundColor: bgColor,
marginBottom: marginBottom + 'rpx',
marginTop: marginTop + 'rpx'
}" @tap="click">
<view class="u-divider-line" :class="[type ? 'u-divider-line--bordercolor--' + type : '']" :style="[lineStyle]"></view>
<view v-if="useSlot" class="u-divider-text" :style="{
color: color,
fontSize: fontSize + 'rpx'
}"><slot /></view>
<view class="u-divider-line" :class="[type ? 'u-divider-line--bordercolor--' + type : '']" :style="[lineStyle]"></view>
</view>
</template>
<script>
export default {
name: 'u-divider',
props: {
halfWidth: {
type: [Number, String],
default: 150
},
borderColor: {
type: String,
default: '#dcdfe6'
},
type: {
type: String,
default: 'primary'
},
color: {
type: String,
default: '#909399'
},
fontSize: {
type: [Number, String],
default: 26
},
bgColor: {
type: String,
default: '#ffffff'
},
height: {
type: [Number, String],
default: 'auto'
},
marginTop: {
type: [String, Number],
default: 0
},
marginBottom: {
type: [String, Number],
default: 0
},
useSlot: {
type: Boolean,
default: true
}
},
computed: {
lineStyle() {
let style = {};
if(String(this.halfWidth).indexOf('%') != -1) style.width = this.halfWidth;
else style.width = this.halfWidth + 'rpx';
if(this.borderColor) style.borderColor = this.borderColor;
return style;
}
},
methods: {
click() {
this.$emit('click');
}
}
};
</script>
<style lang="scss" scoped>
@import "../../libs/css/style.components.scss";
.u-divider {
width: 100%;
position: relative;
text-align: center;
display: flex;
justify-content: center;
align-items: center;
overflow: hidden;
flex-direction: row;
}
.u-divider-line {
border-bottom: 1px solid #e4e7ed;
transform: scale(1, 0.5);
transform-origin: center;
&--bordercolor--primary {
border-color: #2979ff;
}
&--bordercolor--success {
border-color: #19be6b;
}
&--bordercolor--error {
border-color: #2979ff;
}
&--bordercolor--info {
border-color: #909399;
}
&--bordercolor--warning {
border-color: #ff9900;
}
}
.u-divider-text {
white-space: nowrap;
padding: 0 16rpx;
display: inline-flex;
}
</style>