You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

281 lines
5.3 KiB

3 years ago
<template>
<text class="uni-tag" v-if="text" :class="classes" :style="customStyle" @click="onClick">
<slot />{{text}}
<slot name="right" />
</text>
</template>
<script>
/**
* Tag 标签
* @description 用于展示1个或多个文字标签可点击切换选中不选中的状态
* @tutorial https://ext.dcloud.net.cn/plugin?id=35
* @property {String} text 标签内容
* @property {String} size = [normal|small] 大小尺寸
* @value normal 正常
* @value small 小尺寸
* @property {String} type = [default|primary|successwarningerrorroyal] 颜色类型
* @value default 灰色
* @value primary 蓝色
* @value success 绿色
* @value warning 黄色
* @value error 红色
* @value royal 紫色
* @property {Boolean} disabled = [true|false] 是否为禁用状态
* @property {Boolean} inverted = [true|false] 是否无需背景颜色空心标签
* @property {Boolean} circle = [true|false] 是否为圆角
* @event {Function} click 点击 Tag 触发事件
*/
export default {
name: "UniTag",
props: {
type: {
// 标签类型default、primary、success、warning、error、royal
type: String,
default: "default"
},
size: {
// 标签大小 normal, small
type: String,
default: "normal"
},
// 标签内容
text: {
type: String,
default: ""
},
disabled: {
// 是否为禁用状态
type: [Boolean, String],
default: false
},
inverted: {
// 是否为空心
type: [Boolean, String],
default: false
},
circle: {
// 是否为圆角样式
type: [Boolean, String],
default: false
},
mark: {
// 是否为标记样式
type: [Boolean, String],
default: false
},
customStyle: {
type: String,
default: ''
}
},
computed: {
classes() {
const {
type,
disabled,
inverted,
circle,
mark,
size,
isTrue
} = this
return [
'uni-tag--' + type,
isTrue(disabled) ? 'uni-tag--disabled' : '',
isTrue(inverted) ? type + '-uni-tag--inverted' : '',
isTrue(circle) ? 'uni-tag--circle' : '',
isTrue(mark) ? 'uni-tag--mark' : '',
'uni-tag--' + size,
type === 'default' ? 'uni-tag--default' : 'uni-tag-text',
isTrue(inverted) ? 'uni-tag-text--' + type : '',
size === 'small' ? 'uni-tag-text--small' : ''
]
}
},
methods: {
isTrue(value) {
return value === true || value === 'true'
},
onClick() {
if (this.isTrue(this.disabled)) return
this.$emit("click");
}
}
};
</script>
<style scoped>
.uni-tag {
/* #ifndef APP-NVUE */
display: inline-block;
/* #endif */
/* #ifdef APP-NVUE */
align-self: flex-start;
/* #endif */
padding: 0px 16px;
line-height: 30px;
color: #333;
border-radius: 3px;
background-color: #f8f8f8;
border-width: 1rpx;
border-style: solid;
border-color: #f8f8f8;
/* #ifdef H5 */
cursor: pointer;
/* #endif */
}
.uni-tag--circle {
border-radius: 15px;
}
.uni-tag--mark {
border-top-left-radius: 0;
border-bottom-left-radius: 0;
border-top-right-radius: 15px;
border-bottom-right-radius: 15px;
}
.uni-tag--disabled {
opacity: 0.5;
/* #ifdef H5 */
cursor: not-allowed;
/* #endif */
}
.uni-tag--small {
height: 20px;
padding: 0px 8px;
line-height: 20px;
font-size: 12px;
}
.uni-tag--default {
color: #333;
font-size: 14px;
}
.uni-tag--royal {
color: #333;
font-size: 14px;
}
.uni-tag-text--small {
font-size: 12px;
}
.uni-tag-text {
color: #fff;
font-size: 14px;
}
.uni-tag-text--primary {
color: #007aff;
}
.uni-tag-text--success {
color: #4cd964;
}
.uni-tag-text--warning {
color: #f0ad4e;
}
.uni-tag-text--error {
color: #dd524d;
}
.uni-tag-text--royal {
color: #4335d6;
}
.uni-tag--primary {
color: #fff;
background-color: #007aff;
border-width: 1rpx;
border-style: solid;
border-color: #007aff;
}
.primary-uni-tag--inverted {
color: #007aff;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #007aff;
}
.uni-tag--success {
color: #fff;
background-color: #4cd964;
border-width: 1rpx;
border-style: solid;
border-color: #4cd964;
}
.success-uni-tag--inverted {
color: #4cd964;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #4cd964;
}
.uni-tag--warning {
color: #fff;
background-color: #f0ad4e;
border-width: 1rpx;
border-style: solid;
border-color: #f0ad4e;
}
.warning-uni-tag--inverted {
color: #f0ad4e;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #f0ad4e;
}
.uni-tag--error {
color: #fff;
background-color: #dd524d;
border-width: 1rpx;
border-style: solid;
border-color: #dd524d;
}
.error-uni-tag--inverted {
color: #dd524d;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #dd524d;
}
.uni-tag--royal {
color: #fff;
background-color: #4335d6;
border-width: 1rpx;
border-style: solid;
border-color: #4335d6;
}
.royal-uni-tag--inverted {
color: #4335d6;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #4335d6;
}
.uni-tag--inverted {
color: #333;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #f8f8f8;
}
</style>