123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- "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: {
- init() {
- this.allowMp = true;
- },
- // 判断传入的name属性,是否图片路径,只要带有"/"均认为是图片形式
- isImg() {
- return this.src.indexOf("/") !== -1;
- },
- // 图片加载时失败时触发
- errorHandler() {
- this.avatarUrl = this.defaultUrl || base64Avatar;
- },
- clickHandler() {
- this.$emit("click", this.name);
- }
- }
- };
- if (!Array) {
- const _easycom_u_icon2 = common_vendor.resolveComponent("u-icon");
- const _easycom_u__text2 = common_vendor.resolveComponent("u--text");
- (_easycom_u_icon2 + _easycom_u__text2)();
- }
- const _easycom_u_icon = () => "../u-icon/u-icon.js";
- const _easycom_u__text = () => "../u-text/u-text.js";
- if (!Math) {
- (_easycom_u_icon + _easycom_u__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: _ctx.$u.addUnit(_ctx.size),
- height: _ctx.$u.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: _ctx.$u.addUnit(_ctx.size),
- height: _ctx.$u.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 : _ctx.$u.random(0, 19)] : _ctx.bgColor : "transparent",
- width: _ctx.$u.addUnit(_ctx.size),
- height: _ctx.$u.addUnit(_ctx.size)
- }),
- o: common_vendor.s(_ctx.$u.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"], ["__file", "D:/project/赋强公证/notarization_applet/node_modules/uview-plus/components/u-avatar/u-avatar.vue"]]);
- wx.createComponent(Component);
|