index.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. <template>
  2. <view>
  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. <view class="pictrue" @click.stop='uploadpic'>
  9. <image :src='newAvatar ? newAvatar : userInfo.avatar'></image>
  10. <image src='../../../static/images/alter.png' class="alter"></image>
  11. </view>
  12. </view>
  13. <view class='item acea-row row-between-wrapper'>
  14. <view>昵称</view>
  15. <view class='input'>
  16. <input type='text' name='nickname' :value='userInfo.nickname' />
  17. </view>
  18. </view>
  19. <view class='item acea-row row-between-wrapper'>
  20. <view>手机号码</view>
  21. <navigator url="/pages/users/app_login/index" hover-class="none" class="input"
  22. v-if="!userInfo.mobile">
  23. 点击绑定手机号 <text class="iconfont icon-xiangyou" />
  24. </navigator>
  25. <navigator url="/pages/users/user_phone/index" hover-class="none" class="input" v-else>
  26. <view class='input acea-row row-between-wrapper'>
  27. <input type='text' disabled='true' name='phone' :value='userInfo.mobile' class='id' />
  28. <text class='iconfont icon-xiangyou'></text>
  29. </view>
  30. </navigator>
  31. </view>
  32. <!-- #ifdef MP -->
  33. <view class='item acea-row row-between-wrapper'>
  34. <view>权限设置</view>
  35. <view class="input" @click="Setting">
  36. 点击管理<text class="iconfont icon-xiangyou"></text>
  37. </view>
  38. </view>
  39. <!-- #endif -->
  40. <view class="item acea-row row-between-wrapper" v-if="userInfo.mobile">
  41. <view>密码</view>
  42. <navigator url="/pages/users/user_pwd_edit/index" hover-class="none" class="input">
  43. 点击修改密码<text class="iconfont icon-xiangyou"></text>
  44. </navigator>
  45. </view>
  46. </view>
  47. <button class='modifyBnt bg-color' formType="submit">保存修改</button>
  48. <!-- #ifdef H5 -->
  49. <view class="logOut cart-color acea-row row-center-wrapper" @click="outLogin"
  50. v-if="!this.$wechat.isWeixin()">退出登录</view>
  51. <!-- #endif -->
  52. </view>
  53. </form>
  54. </view>
  55. </template>
  56. <script>
  57. import { toLogin } from '@/libs/login.js';
  58. import { mapGetters } from "vuex";
  59. import * as UserApi from '@/api/member/user.js';
  60. import * as AuthApi from '@/api/member/auth.js';
  61. export default {
  62. components: {},
  63. data() {
  64. return {
  65. memberInfo: {},
  66. loginType: 'h5', //app.globalData.loginType
  67. newAvatar: '',
  68. };
  69. },
  70. computed: mapGetters(['isLogin', 'userInfo']),
  71. onLoad() {
  72. if (!this.isLogin) {
  73. toLogin();
  74. }
  75. },
  76. methods: {
  77. /**
  78. * 小程序设置
  79. */
  80. Setting: function() {
  81. uni.openSetting({
  82. success: function(res) {
  83. console.log(res.authSetting)
  84. }
  85. });
  86. },
  87. /**
  88. * 退出登录
  89. */
  90. outLogin: function() {
  91. if (this.loginType === 'h5') {
  92. uni.showModal({
  93. title: '提示',
  94. content: '确认退出登录?',
  95. success: res => {
  96. if (!res.confirm) {
  97. console.log('用户点击取消');
  98. return
  99. }
  100. AuthApi.logout().then(res => {
  101. this.$store.commit("LOGOUT");
  102. uni.reLaunch({
  103. url: '/pages/index/index'
  104. });
  105. }).catch(err => {
  106. console.log(err);
  107. });
  108. }
  109. });
  110. }
  111. },
  112. /**
  113. * 上传文件
  114. */
  115. uploadpic: function() {
  116. console.log('我走到这')
  117. this.$util.uploadImageOne({}, res => {
  118. console.log('我进来了')
  119. this.newAvatar = res.data;
  120. });
  121. },
  122. /**
  123. * 提交修改
  124. */
  125. formSubmit: function(e) {
  126. const formData = e.detail.value
  127. if (!formData.nickname) {
  128. return this.$util.Tips({
  129. title: '用户姓名不能为空'
  130. });
  131. }
  132. UserApi.updateUser({
  133. nickname: formData.nickname,
  134. avatar: this.newAvatar ? this.newAvatar : this.userInfo.avatar
  135. }).then(res => {
  136. // 刷新用户信息
  137. this.$store.dispatch('USERINFO');
  138. // 提示
  139. return this.$util.Tips({
  140. title: '保存成功',
  141. icon: 'success'
  142. }, {
  143. tab: 3,
  144. url: 1
  145. });
  146. }).catch(msg => {
  147. return this.$util.Tips({
  148. title: msg || '保存失败,您并没有修改'
  149. });
  150. });
  151. }
  152. }
  153. }
  154. </script>
  155. <style scoped lang="scss">
  156. .personal-data .wrapper {
  157. margin: 10rpx 0;
  158. background-color: #fff;
  159. padding: 36rpx 30rpx 13rpx 30rpx;
  160. }
  161. .personal-data .wrapper .title {
  162. margin-bottom: 30rpx;
  163. font-size: 32rpx;
  164. color: #282828;
  165. }
  166. .personal-data .wrapper .wrapList .item {
  167. width: 690rpx;
  168. height: 160rpx;
  169. background-color: #f8f8f8;
  170. border-radius: 20rpx;
  171. margin-bottom: 22rpx;
  172. padding: 0 30rpx;
  173. position: relative;
  174. border: 2rpx solid #f8f8f8;
  175. box-sizing: border-box;
  176. }
  177. .personal-data .wrapper .wrapList .item.on {
  178. border-color: $theme-color;
  179. border-radius: 20rpx;
  180. background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAArIAAACgCAYAAADw+I85AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyhpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNi1jMTQ1IDc5LjE2MzQ5OSwgMjAxOC8wOC8xMy0xNjo0MDoyMiAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTkgKE1hY2ludG9zaCkiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6M0QzNkY3NzlCNzJCMTFFOTgyNEU4QzhGQTRFRUY2REQiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6M0QzNkY3N0FCNzJCMTFFOTgyNEU4QzhGQTRFRUY2REQiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDozRDM2Rjc3N0I3MkIxMUU5ODI0RThDOEZBNEVFRjZERCIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDozRDM2Rjc3OEI3MkIxMUU5ODI0RThDOEZBNEVFRjZERCIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pn3rJMAAAArUSURBVHja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");
  181. background-size: 100% 100%;
  182. background-color: #fff9f9;
  183. background-repeat: no-repeat;
  184. }
  185. .personal-data .wrapper .wrapList .item .picTxt {
  186. width: 445rpx;
  187. }
  188. .personal-data .wrapper .wrapList .item .picTxt .pictrue {
  189. width: 96rpx;
  190. height: 96rpx;
  191. position: relative;
  192. }
  193. .personal-data .wrapper .wrapList .item .picTxt .pictrue image {
  194. width: 100%;
  195. height: 100%;
  196. border-radius: 50%;
  197. }
  198. .personal-data .wrapper .wrapList .item .picTxt .pictrue .alter {
  199. width: 30rpx;
  200. height: 30rpx;
  201. border-radius: 50%;
  202. position: absolute;
  203. bottom: 0;
  204. right: 0;
  205. }
  206. .personal-data .wrapper .wrapList .item .picTxt .text {
  207. width: 325rpx;
  208. }
  209. .personal-data .wrapper .wrapList .item .picTxt .text .name {
  210. width: 100%;
  211. font-size: 30rpx;
  212. color: #282828;
  213. }
  214. .personal-data .wrapper .wrapList .item .picTxt .text .phone {
  215. font-size: 24rpx;
  216. color: #999;
  217. margin-top: 10rpx;
  218. }
  219. .personal-data .wrapper .wrapList .item .bnt {
  220. font-size: 24rpx;
  221. background-color: #fff;
  222. border-radius: 27rpx;
  223. width: 140rpx;
  224. height: 54rpx;
  225. border: 2rpx solid $theme-color;
  226. }
  227. .personal-data .wrapper .wrapList .item .currentBnt {
  228. position: absolute;
  229. right: 0;
  230. top: 0;
  231. font-size: 26rpx;
  232. background-color: rgba(233, 51, 35, 0.1);
  233. width: 140rpx;
  234. height: 48rpx;
  235. border-radius: 0 20rpx 0 20rpx;
  236. }
  237. .personal-data .list {
  238. margin-top: 30rpx;
  239. background-color: #fff;
  240. }
  241. .personal-data .list .item {
  242. border-bottom: 1rpx solid #f2f2f2;
  243. padding: 24rpx;
  244. font-size: 32rpx;
  245. color: #282828;
  246. }
  247. .personal-data .list .item .phone {
  248. width: 160rpx;
  249. height: 56rpx;
  250. font-size: 24rpx;
  251. color: #fff;
  252. line-height: 56rpx;
  253. border-radius: 32rpx
  254. }
  255. .personal-data .list .item .pictrue {
  256. width: 88rpx;
  257. height: 88rpx;
  258. position: relative;
  259. }
  260. .personal-data .list .item .pictrue image {
  261. width: 100%;
  262. height: 100%;
  263. border-radius: 50%;
  264. }
  265. .personal-data .list .item .pictrue .alter {
  266. width: 30rpx;
  267. height: 30rpx;
  268. border-radius: 50%;
  269. position: absolute;
  270. bottom: 0;
  271. right: 0;
  272. }
  273. .personal-data .list .item .input {
  274. width: 415rpx;
  275. text-align: right;
  276. color: #868686;
  277. }
  278. .personal-data .list .item .input .id {
  279. width: 365rpx;
  280. }
  281. .personal-data .list .item .input .iconfont {
  282. font-size: 35rpx;
  283. }
  284. .personal-data .modifyBnt {
  285. font-size: 32rpx;
  286. color: #fff;
  287. width: 690rpx;
  288. height: 90rpx;
  289. border-radius: 50rpx;
  290. text-align: center;
  291. line-height: 90rpx;
  292. margin: 76rpx auto 0 auto;
  293. }
  294. .personal-data .logOut {
  295. font-size: 32rpx;
  296. text-align: center;
  297. width: 690rpx;
  298. height: 90rpx;
  299. border-radius: 45rpx;
  300. margin: 30rpx auto 0 auto;
  301. }
  302. </style>