u-avatar.js 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. "use strict";
  2. const common_vendor = require("../../../../common/vendor.js");
  3. const base64Avatar = "";
  4. const _sfc_main = {
  5. name: "u-avatar",
  6. mixins: [common_vendor.mpMixin, common_vendor.mixin, common_vendor.props$3],
  7. data() {
  8. return {
  9. // 如果配置randomBgColor参数为true,在图标或者文字的模式下,会随机从中取出一个颜色值当做背景色
  10. colors: [
  11. "#ffb34b",
  12. "#f2bba9",
  13. "#f7a196",
  14. "#f18080",
  15. "#88a867",
  16. "#bfbf39",
  17. "#89c152",
  18. "#94d554",
  19. "#f19ec2",
  20. "#afaae4",
  21. "#e1b0df",
  22. "#c38cc1",
  23. "#72dcdc",
  24. "#9acdcb",
  25. "#77b1cc",
  26. "#448aca",
  27. "#86cefa",
  28. "#98d1ee",
  29. "#73d1f1",
  30. "#80a7dc"
  31. ],
  32. avatarUrl: this.src,
  33. allowMp: false
  34. };
  35. },
  36. watch: {
  37. // 监听头像src的变化,赋值给内部的avatarUrl变量,因为图片加载失败时,需要修改图片的src为默认值
  38. // 而组件内部不能直接修改props的值,所以需要一个中间变量
  39. src: {
  40. immediate: true,
  41. handler(newVal) {
  42. this.avatarUrl = newVal;
  43. if (!newVal) {
  44. this.errorHandler();
  45. }
  46. }
  47. }
  48. },
  49. computed: {
  50. imageStyle() {
  51. const style = {};
  52. return style;
  53. }
  54. },
  55. created() {
  56. this.init();
  57. },
  58. emits: ["click"],
  59. methods: {
  60. addStyle: common_vendor.addStyle,
  61. addUnit: common_vendor.addUnit,
  62. random: common_vendor.random,
  63. init() {
  64. this.allowMp = true;
  65. },
  66. // 判断传入的name属性,是否图片路径,只要带有"/"均认为是图片形式
  67. isImg() {
  68. return this.src.indexOf("/") !== -1;
  69. },
  70. // 图片加载时失败时触发
  71. errorHandler() {
  72. this.avatarUrl = this.defaultUrl || base64Avatar;
  73. },
  74. clickHandler() {
  75. this.$emit("click", this.name);
  76. }
  77. }
  78. };
  79. if (!Array) {
  80. const _easycom_u_icon2 = common_vendor.resolveComponent("u-icon");
  81. const _easycom_up_text2 = common_vendor.resolveComponent("up-text");
  82. (_easycom_u_icon2 + _easycom_up_text2)();
  83. }
  84. const _easycom_u_icon = () => "../u-icon/u-icon.js";
  85. const _easycom_up_text = () => "../u-text/u-text.js";
  86. if (!Math) {
  87. (_easycom_u_icon + _easycom_up_text)();
  88. }
  89. function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
  90. return common_vendor.e({
  91. a: _ctx.mpAvatar && $data.allowMp
  92. }, _ctx.mpAvatar && $data.allowMp ? {
  93. b: common_vendor.s({
  94. width: $options.addUnit(_ctx.size),
  95. height: $options.addUnit(_ctx.size)
  96. })
  97. } : {}, {
  98. c: _ctx.mpAvatar && $data.allowMp
  99. }, _ctx.mpAvatar && $data.allowMp ? {} : _ctx.icon ? {
  100. e: common_vendor.p({
  101. name: _ctx.icon,
  102. size: _ctx.fontSize,
  103. color: _ctx.color
  104. })
  105. } : _ctx.text ? {
  106. g: common_vendor.p({
  107. text: _ctx.text,
  108. size: _ctx.fontSize,
  109. color: _ctx.color,
  110. align: "center",
  111. customStyle: "justify-content: center"
  112. })
  113. } : {
  114. h: common_vendor.n(`u-avatar__image--${_ctx.shape}`),
  115. i: $data.avatarUrl || _ctx.defaultUrl,
  116. j: _ctx.mode,
  117. k: common_vendor.o((...args) => $options.errorHandler && $options.errorHandler(...args)),
  118. l: common_vendor.s({
  119. width: $options.addUnit(_ctx.size),
  120. height: $options.addUnit(_ctx.size)
  121. })
  122. }, {
  123. d: _ctx.icon,
  124. f: _ctx.text,
  125. m: common_vendor.n(`u-avatar--${_ctx.shape}`),
  126. n: common_vendor.s({
  127. backgroundColor: _ctx.text || _ctx.icon ? _ctx.randomBgColor ? $data.colors[_ctx.colorIndex !== "" ? _ctx.colorIndex : $options.random(0, 19)] : _ctx.bgColor : "transparent",
  128. width: $options.addUnit(_ctx.size),
  129. height: $options.addUnit(_ctx.size)
  130. }),
  131. o: common_vendor.s($options.addStyle(_ctx.customStyle)),
  132. p: common_vendor.o((...args) => $options.clickHandler && $options.clickHandler(...args))
  133. });
  134. }
  135. const Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-14a988f2"], ["__file", "D:/project/学吧/learn_applet/node_modules/uview-plus/components/u-avatar/u-avatar.vue"]]);
  136. wx.createComponent(Component);