137 lines
7.4 KiB
JavaScript
137 lines
7.4 KiB
JavaScript
"use strict";
|
||
const common_vendor = require("../../../../common/vendor.js");
|
||
const base64Avatar = "";
|
||
const _sfc_main = {
|
||
name: "u-avatar",
|
||
mixins: [common_vendor.mpMixin, common_vendor.mixin, common_vendor.props$2],
|
||
data() {
|
||
return {
|
||
// 如果配置randomBgColor参数为true,在图标或者文字的模式下,会随机从中取出一个颜色值当做背景色
|
||
colors: [
|
||
"#ffb34b",
|
||
"#f2bba9",
|
||
"#f7a196",
|
||
"#f18080",
|
||
"#88a867",
|
||
"#bfbf39",
|
||
"#89c152",
|
||
"#94d554",
|
||
"#f19ec2",
|
||
"#afaae4",
|
||
"#e1b0df",
|
||
"#c38cc1",
|
||
"#72dcdc",
|
||
"#9acdcb",
|
||
"#77b1cc",
|
||
"#448aca",
|
||
"#86cefa",
|
||
"#98d1ee",
|
||
"#73d1f1",
|
||
"#80a7dc"
|
||
],
|
||
avatarUrl: this.src,
|
||
allowMp: false
|
||
};
|
||
},
|
||
watch: {
|
||
// 监听头像src的变化,赋值给内部的avatarUrl变量,因为图片加载失败时,需要修改图片的src为默认值
|
||
// 而组件内部不能直接修改props的值,所以需要一个中间变量
|
||
src: {
|
||
immediate: true,
|
||
handler(newVal) {
|
||
this.avatarUrl = newVal;
|
||
if (!newVal) {
|
||
this.errorHandler();
|
||
}
|
||
}
|
||
}
|
||
},
|
||
computed: {
|
||
imageStyle() {
|
||
const style = {};
|
||
return style;
|
||
}
|
||
},
|
||
created() {
|
||
this.init();
|
||
},
|
||
emits: ["click"],
|
||
methods: {
|
||
addStyle: common_vendor.addStyle,
|
||
addUnit: common_vendor.addUnit,
|
||
random: common_vendor.random,
|
||
init() {
|
||
this.allowMp = true;
|
||
},
|
||
// 判断传入的name属性,是否图片路径,只要带有"/"均认为是图片形式
|
||
isImg() {
|
||
return this.src.indexOf("/") !== -1;
|
||
},
|
||
// 图片加载时失败时触发
|
||
errorHandler() {
|
||
this.avatarUrl = this.defaultUrl || base64Avatar;
|
||
},
|
||
clickHandler(e) {
|
||
this.$emit("click", this.name, e);
|
||
}
|
||
}
|
||
};
|
||
if (!Array) {
|
||
const _easycom_u_icon2 = common_vendor.resolveComponent("u-icon");
|
||
const _easycom_up_text2 = common_vendor.resolveComponent("up-text");
|
||
(_easycom_u_icon2 + _easycom_up_text2)();
|
||
}
|
||
const _easycom_u_icon = () => "../u-icon/u-icon.js";
|
||
const _easycom_up_text = () => "../u-text/u-text.js";
|
||
if (!Math) {
|
||
(_easycom_u_icon + _easycom_up_text)();
|
||
}
|
||
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
||
return common_vendor.e({
|
||
a: _ctx.mpAvatar && $data.allowMp
|
||
}, _ctx.mpAvatar && $data.allowMp ? {
|
||
b: common_vendor.s({
|
||
width: $options.addUnit(_ctx.size),
|
||
height: $options.addUnit(_ctx.size)
|
||
})
|
||
} : {}, {
|
||
c: _ctx.mpAvatar && $data.allowMp
|
||
}, _ctx.mpAvatar && $data.allowMp ? {} : _ctx.icon ? {
|
||
e: common_vendor.p({
|
||
name: _ctx.icon,
|
||
size: _ctx.fontSize,
|
||
color: _ctx.color
|
||
})
|
||
} : _ctx.text ? {
|
||
g: common_vendor.p({
|
||
text: _ctx.text,
|
||
size: _ctx.fontSize,
|
||
color: _ctx.color,
|
||
align: "center",
|
||
customStyle: "justify-content: center"
|
||
})
|
||
} : {
|
||
h: common_vendor.n(`u-avatar__image--${_ctx.shape}`),
|
||
i: $data.avatarUrl || _ctx.defaultUrl,
|
||
j: _ctx.mode,
|
||
k: common_vendor.o((...args) => $options.errorHandler && $options.errorHandler(...args)),
|
||
l: common_vendor.s({
|
||
width: $options.addUnit(_ctx.size),
|
||
height: $options.addUnit(_ctx.size)
|
||
})
|
||
}, {
|
||
d: _ctx.icon,
|
||
f: _ctx.text,
|
||
m: common_vendor.n(`u-avatar--${_ctx.shape}`),
|
||
n: common_vendor.s({
|
||
backgroundColor: _ctx.text || _ctx.icon ? _ctx.randomBgColor ? $data.colors[_ctx.colorIndex !== "" ? _ctx.colorIndex : $options.random(0, 19)] : _ctx.bgColor : "transparent",
|
||
width: $options.addUnit(_ctx.size),
|
||
height: $options.addUnit(_ctx.size)
|
||
}),
|
||
o: common_vendor.s($options.addStyle(_ctx.customStyle)),
|
||
p: common_vendor.o((...args) => $options.clickHandler && $options.clickHandler(...args))
|
||
});
|
||
}
|
||
const Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-14a988f2"]]);
|
||
wx.createComponent(Component);
|