tt-mp
Version:
一套组件化、可复用、易扩展的头条小程序 UI 组件库
123 lines (118 loc) • 2.53 kB
JavaScript
import baseComponent from '../helpers/baseComponent'
import classNames from '../helpers/classNames'
const defaultIcon = {
type: 'success',
size: 93,
color: '#33cd5f',
}
const getIcon = (icon) => {
if (icon !== null && typeof icon === 'object') {
return Object.assign({}, defaultIcon, icon)
} else if (typeof icon === 'string') {
return Object.assign({}, defaultIcon, {
type: icon,
})
}
return defaultIcon
}
baseComponent({
properties: {
prefixCls: {
type: String,
value: 'wux-result',
},
icon: {
type: null,
value: defaultIcon,
observer(newVal) {
this.setData({
resultIcon: getIcon(newVal),
})
},
},
title: {
type: String,
value: '',
},
label: {
type: String,
value: '',
},
buttons: {
type: Array,
value: [],
},
extra: {
type: String,
value: '',
},
fixed: {
type: Boolean,
value: false,
},
},
data: {
resultIcon: null,
},
computed: {
classes: [
'prefixCls, fixed',
function (prefixCls, fixed) {
const wrap = classNames(prefixCls, {
[`${prefixCls}--fixed`]: fixed,
})
const hd = `${prefixCls}__hd`
const icon = `${prefixCls}__icon`
const bd = `${prefixCls}__bd`
const title = `${prefixCls}__title`
const desc = `${prefixCls}__desc`
const buttons = `${prefixCls}__buttons`
const ft = `${prefixCls}__ft`
return {
wrap,
hd,
icon,
bd,
title,
desc,
buttons,
ft,
}
},
],
},
methods: {
onClick(e) {
this.triggerEvent('click', e.currentTarget.dataset)
},
bindgetuserinfo(e) {
this.triggerEvent('getuserinfo', {
...e.detail,
...e.currentTarget.dataset,
})
},
bindcontact(e) {
this.triggerEvent('contact', { ...e.detail, ...e.currentTarget.dataset })
},
bindgetphonenumber(e) {
this.triggerEvent('getphonenumber', {
...e.detail,
...e.currentTarget.dataset,
})
},
bindopensetting(e) {
this.triggerEvent('opensetting', {
...e.detail,
...e.currentTarget.dataset,
})
},
onError(e) {
this.triggerEvent('error', { ...e.detail, ...e.currentTarget.dataset })
},
},
attached() {
this.setData({
resultIcon: getIcon(this.data.icon),
})
},
})