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.

467 lines
16 KiB

3 months ago
  1. <template>
  2. <view :data-theme="theme">
  3. <form @submit="formSubmit" report-submit='true'>
  4. <view class='personal-data pad30'>
  5. <view class='list borRadius14'>
  6. <view class="item acea-row row-between-wrapper">
  7. <view>头像</view>
  8. <!-- #ifndef MP -->
  9. <view class="pictrue" @click.stop='uploadpic'>
  10. <image :src='newAvatar'></image>
  11. <image :src='editPng' class="alter"></image>
  12. </view>
  13. <!-- #endif -->
  14. <!-- #ifdef MP -->
  15. <view class="pictrue">
  16. <button class="avatar-wrapper" open-type="chooseAvatar" @chooseavatar="onChooseAvatar">
  17. <image class="avatar" :src="newAvatar"></image>
  18. </button>
  19. <image :src='editPng' class="alter"></image>
  20. </view>
  21. <!-- #endif -->
  22. </view>
  23. <view class='item acea-row row-between-wrapper'>
  24. <view>昵称</view>
  25. <view class='input'>
  26. <!-- #ifndef MP -->
  27. <input type='text' name='nickname' :value='userInfo.nickname' maxlength="20"></input>
  28. <!-- #endif -->
  29. <!-- #ifdef MP -->
  30. <input type="nickname" name='nickname' :value='nickname' class="weui-input"
  31. placeholder="请输入昵称" />
  32. <!-- #endif -->
  33. </view>
  34. </view>
  35. <view class='item acea-row row-between-wrapper'>
  36. <view>手机号码</view>
  37. <navigator url="/pages/users/app_login/index" hover-class="none" class="input"
  38. v-if="!userInfo.phone">
  39. 点击绑定手机号<text class="iconfont icon-xiangyou"></text>
  40. </navigator>
  41. <navigator url="/pages/infos/user_phone/index" hover-class="none" class="input" v-else>
  42. <view class='input acea-row row-between-wrapper'>
  43. <input disabled='true' name='phone' :value='userInfo.phone'
  44. class='id'></input>
  45. <text class='iconfont icon-xiangyou'></text>
  46. </view>
  47. </navigator>
  48. </view>
  49. <view class='item acea-row row-between-wrapper'>
  50. <view>ID号</view>
  51. <view class='input acea-row row-between-wrapper'>
  52. <input type='text' :value='uid' disabled='true' class='id'></input>
  53. <text class='iconfont icon-suozi'></text>
  54. </view>
  55. </view>
  56. <!-- #ifdef MP -->
  57. <view class='item acea-row row-between-wrapper'>
  58. <view>权限设置</view>
  59. <view class="input" @click="Setting">
  60. 点击管理<text class="iconfont icon-xiangyou"></text>
  61. </view>
  62. </view>
  63. <!-- #endif -->
  64. <!-- #ifdef H5 -->
  65. <view class="item acea-row row-between-wrapper" v-if="userInfo.phone && wechat">
  66. <view>密码</view>
  67. <navigator url="/pages/infos/user_pwd_edit/index" hover-class="none" class="input">
  68. 点击修改密码<text class="iconfont icon-xiangyou"></text>
  69. </navigator>
  70. </view>
  71. <!-- #endif -->
  72. <!-- #ifdef APP-PLUS -->
  73. <view class="item acea-row row-between-wrapper" v-if="userInfo.phone">
  74. <view>密码</view>
  75. <navigator url="/pages/infos/user_pwd_edit/index" hover-class="none" class="input">
  76. 点击修改密码<text class="iconfont icon-xiangyou"></text>
  77. </navigator>
  78. </view>
  79. <!-- #endif -->
  80. <view class='item acea-row row-between-wrapper'>
  81. <view>地址管理</view>
  82. <view class="input" @click="toAddress">
  83. 立即设置<text class="iconfont icon-xiangyou"></text>
  84. </view>
  85. </view>
  86. </view>
  87. <button class='modifyBnt bg_color' formType="submit">保存修改</button>
  88. <!-- #ifdef H5 -->
  89. <view class="logOut cart-color acea-row row-center-wrapper" @click="outLogin"
  90. v-if="!this.$wechat.isWeixin() || (this.$wechat.isWeixin() && publicLoginType ==2)">退出登录</view>
  91. <!-- #endif -->
  92. <!-- #ifdef APP-PLUS -->
  93. <view class="logOut cart-color acea-row row-center-wrapper" @click="outLogin">退出登录</view>
  94. <!-- #endif -->
  95. </view>
  96. </form>
  97. </view>
  98. </template>
  99. <script>
  100. import {
  101. userEdit,
  102. getLogout
  103. } from '@/api/user.js';
  104. import {
  105. switchH5Login
  106. } from '@/api/api.js';
  107. import {
  108. toLogin
  109. } from '@/libs/login.js';
  110. import {
  111. mapGetters
  112. } from "vuex";
  113. import {
  114. Debounce
  115. } from '@/utils/validate.js'
  116. import dayjs from "@/plugin/dayjs/dayjs.min.js";
  117. let app = getApp();
  118. export default {
  119. data() {
  120. return {
  121. urlDomain: this.$Cache.get("imgHost"),
  122. memberInfo: {},
  123. loginType: 'h5', //app.globalData.loginType
  124. userIndex: 0,
  125. newAvatar: '',
  126. nickname: '',
  127. wechat: false,
  128. theme: app.globalData.theme,
  129. editPng: `${this.$Cache.get("imgHost")}crmebimage/perset/staticImg/alert1.png`,
  130. publicLoginType: app.globalData.publicLoginType //公众号登录方式(单选),1微信授权,2手机号登录
  131. };
  132. },
  133. computed: mapGetters(['isLogin', 'uid', 'userInfo']),
  134. onLoad() {
  135. if (!this.isLogin) {
  136. toLogin();
  137. }
  138. this.newAvatar = this.userInfo.avatar ? this.userInfo.avatar : `${this.$Cache.get("imgHost")}crmebimage/perset/staticImg/f.png`;
  139. this.nickname = this.userInfo.nickname ? this.userInfo.nickname : '-';
  140. // #ifdef H5
  141. let ua = navigator.userAgent.toLowerCase();
  142. if (ua.match(/MicroMessenger/i) == "micromessenger") {
  143. this.$set(this, 'wechat', false);
  144. } else {
  145. this.$set(this, 'wechat', true);
  146. }
  147. // #endif
  148. switch (this.theme) {
  149. case 'theme2':
  150. this.editPng = `${this.$Cache.get("imgHost")}crmebimage/perset/staticImg/alert2.png`
  151. break;
  152. case 'theme3':
  153. this.editPng = `${this.$Cache.get("imgHost")}crmebimage/perset/staticImg/alert3.png`
  154. break;
  155. case 'theme4':
  156. this.editPng = `${this.$Cache.get("imgHost")}crmebimage/perset/staticImg/alert4.png`
  157. break;
  158. case 'theme5':
  159. this.editPng = `${this.$Cache.get("imgHost")}crmebimage/perset/staticImg/alert5.png`
  160. break;
  161. default:
  162. this.editPng = `${this.$Cache.get("imgHost")}crmebimage/perset/staticImg/alert1.png`
  163. break;
  164. }
  165. },
  166. methods: {
  167. //to地址
  168. toAddress(){
  169. uni.navigateTo({
  170. url:'/pages/users/user_address_list/index'
  171. })
  172. },
  173. /**
  174. * 小程序端上传头像
  175. *
  176. */
  177. onChooseAvatar(e) {
  178. const {
  179. avatarUrl
  180. } = e.detail
  181. uni.showLoading({
  182. title: '加载中...'
  183. });
  184. this.$util.uploadImgs(avatarUrl, {
  185. url: 'upload/image',
  186. name: 'multipart',
  187. model: "user",
  188. pid: 7
  189. }, (res) => {
  190. this.newAvatar = res.data.url;
  191. uni.hideLoading();
  192. }, (err) => {
  193. uni.hideLoading();
  194. })
  195. },
  196. /**
  197. * 小程序设置
  198. */
  199. Setting: function() {
  200. uni.openSetting({
  201. success: function(res) {
  202. console.log(res.authSetting)
  203. }
  204. });
  205. },
  206. /**
  207. * 退出登录
  208. *
  209. */
  210. outLogin: function() {
  211. let that = this;
  212. if (that.loginType == 'h5') {
  213. uni.showModal({
  214. title: '提示',
  215. content: '确认退出登录?',
  216. success: function(res) {
  217. if (res.confirm) {
  218. uni.showLoading({
  219. title: '加载中...'
  220. })
  221. getLogout()
  222. .then(res => {
  223. that.$store.commit("LOGOUT");
  224. uni.hideLoading();
  225. uni.reLaunch({
  226. url: '/pages/index/index'
  227. });
  228. })
  229. .catch(err => {
  230. uni.hideLoading();
  231. });
  232. } else if (res.cancel) {
  233. console.log('用户点击取消');
  234. }
  235. }
  236. });
  237. }
  238. },
  239. /**
  240. * 上传文件
  241. *
  242. */
  243. uploadpic: function() {
  244. let that = this;
  245. that.$util.uploadImageOne({
  246. url: 'upload/image',
  247. name: 'multipart',
  248. model: "user",
  249. pid: 7
  250. }, function(res) {
  251. that.newAvatar = res.data.url;
  252. });
  253. },
  254. /**
  255. * 提交修改
  256. */
  257. formSubmit: Debounce(function(e) {
  258. let that = this,
  259. value = e.detail.value
  260. if (!value.nickname) return that.$util.Tips({
  261. title: '用户姓名不能为空'
  262. });
  263. value.avatar = that.newAvatar ? that.newAvatar : that.userInfo.avatar;
  264. userEdit(value).then(res => {
  265. that.$store.commit("changInfo", {
  266. amount1: 'avatar',
  267. amount2: that.newAvatar
  268. });
  269. return that.$util.Tips({
  270. title: '保存成功',
  271. icon: 'success'
  272. }, {
  273. tab: 3,
  274. url: 1
  275. });
  276. }).catch(msg => {
  277. return that.$util.Tips({
  278. title: msg || '保存失败,您并没有修改'
  279. }, {
  280. tab: 3,
  281. url: 1
  282. });
  283. });
  284. })
  285. }
  286. }
  287. </script>
  288. <style scoped lang="scss">
  289. .personal-data .wrapper {
  290. margin: 10rpx 0;
  291. background-color: #fff;
  292. padding: 36rpx 30rpx 13rpx 30rpx;
  293. }
  294. .personal-data .wrapper .title {
  295. margin-bottom: 30rpx;
  296. font-size: 32rpx;
  297. color: #282828;
  298. }
  299. .personal-data .wrapper .wrapList .item {
  300. width: 690rpx;
  301. height: 160rpx;
  302. background-color: #f8f8f8;
  303. border-radius: 20rpx;
  304. margin-bottom: 22rpx;
  305. padding: 0 30rpx;
  306. position: relative;
  307. border: 2rpx solid #f8f8f8;
  308. box-sizing: border-box;
  309. }
  310. .personal-data .wrapper .wrapList .item.on {
  311. border-color: $theme-color;
  312. border-radius: 20rpx;
  313. background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAArIAAACgCAYAAADw+I85AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyhpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKE1hY2ludG9zaCkiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6M0QzNkY3NzlCNzJCMTFFOTgyNEU4QzhGQTRFRUY2REQiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6M0QzNkY3N0FCNzJCMTFFOTgyNEU4QzhGQTRFRUY2REQiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDozRDM2Rjc3N0I3MkIxMUU5ODI0RThDOEZBNEVFRjZERCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDozRDM2Rjc3OEI3MkIxMUU5ODI0RThDOEZBNEVFRjZERCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pn3rJMAAAArUSURBVHja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
  314. background-size: 100% 100%;
  315. background-color: #fff9f9;
  316. background-repeat: no-repeat;
  317. }
  318. .personal-data .wrapper .wrapList .item .picTxt {
  319. width: 445rpx;
  320. }
  321. .personal-data .wrapper .wrapList .item .picTxt .pictrue {
  322. width: 96rpx;
  323. height: 96rpx;
  324. position: relative;
  325. }
  326. .personal-data .wrapper .wrapList .item .picTxt .pictrue image,
  327. .pictrue button {
  328. width: 100%;
  329. height: 100%;
  330. border-radius: 50%;
  331. }
  332. .personal-data .wrapper .wrapList .item .picTxt .pictrue .alter {
  333. width: 30rpx;
  334. height: 30rpx;
  335. border-radius: 50%;
  336. position: absolute;
  337. bottom: 0;
  338. right: 0;
  339. }
  340. .personal-data .wrapper .wrapList .item .picTxt .text {
  341. width: 325rpx;
  342. }
  343. .personal-data .wrapper .wrapList .item .picTxt .text .name {
  344. width: 100%;
  345. font-size: 30rpx;
  346. color: #282828;
  347. }
  348. .personal-data .wrapper .wrapList .item .picTxt .text .phone {
  349. font-size: 24rpx;
  350. color: #999;
  351. margin-top: 10rpx;
  352. }
  353. .personal-data .wrapper .wrapList .item .bnt {
  354. font-size: 24rpx;
  355. background-color: #fff;
  356. border-radius: 27rpx;
  357. width: 140rpx;
  358. height: 54rpx;
  359. border: 2rpx solid $theme-color;
  360. }
  361. .personal-data .wrapper .wrapList .item .currentBnt {
  362. position: absolute;
  363. right: 0;
  364. top: 0;
  365. font-size: 26rpx;
  366. background-color: rgba(233, 51, 35, 0.1);
  367. width: 140rpx;
  368. height: 48rpx;
  369. border-radius: 0 20rpx 0 20rpx;
  370. }
  371. .personal-data .list {
  372. margin-top: 30rpx;
  373. background-color: #fff;
  374. }
  375. .personal-data .list .item {
  376. border-bottom: 1rpx solid #f2f2f2;
  377. padding: 24rpx;
  378. font-size: 32rpx;
  379. color: #282828;
  380. }
  381. .personal-data .list .item .phone {
  382. width: 160rpx;
  383. height: 56rpx;
  384. font-size: 24rpx;
  385. color: #fff;
  386. line-height: 56rpx;
  387. border-radius: 32rpx
  388. }
  389. .personal-data .list .item .pictrue {
  390. width: 88rpx;
  391. height: 88rpx;
  392. position: relative;
  393. }
  394. .personal-data .list .item .pictrue image {
  395. width: 100%;
  396. height: 100%;
  397. border-radius: 50%;
  398. }
  399. .personal-data .list .item .pictrue .alter {
  400. width: 30rpx;
  401. height: 30rpx;
  402. border-radius: 50%;
  403. position: absolute;
  404. bottom: 0;
  405. right: 0;
  406. }
  407. .personal-data .list .item .input {
  408. width: 415rpx;
  409. text-align: right;
  410. color: #868686;
  411. }
  412. .personal-data .list .item .input .id {
  413. width: 365rpx;
  414. }
  415. .personal-data .list .item .input .iconfont {
  416. font-size: 35rpx;
  417. }
  418. .personal-data .modifyBnt {
  419. font-size: 32rpx;
  420. color: #fff;
  421. width: 690rpx;
  422. height: 90rpx;
  423. border-radius: 50rpx;
  424. text-align: center;
  425. line-height: 90rpx;
  426. margin: 76rpx auto 0 auto;
  427. }
  428. .bg_color {
  429. @include main_bg_color(theme);
  430. }
  431. .personal-data .logOut {
  432. font-size: 32rpx;
  433. text-align: center;
  434. width: 690rpx;
  435. height: 90rpx;
  436. border-radius: 45rpx;
  437. margin: 30rpx auto 0 auto;
  438. }
  439. </style>