userinfo.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548
  1. <template>
  2. <view>
  3. <view style="color: #fff;">
  4. <tn-nav-bar backgroundColor="#26B3A0" :bottomShadow="false">修改用户信息</tn-nav-bar>
  5. <view :style="{ height: tobheight + 'px' }"></view>
  6. </view>
  7. <form @submit="formSubmit">
  8. <view class='personal-data'>
  9. <view class='list'>
  10. <view class='item acea-row row-between-wrapper'>
  11. <view>头像</view>
  12. <view class="avatar-box" @click.stop='uploadpic'>
  13. <image mode="aspectFill" :src="userinfo.avatar?userinfo.avatar:'/static/images/head.jpg'">
  14. </image>
  15. </view>
  16. <!-- #ifdef MP-WEIXIN -->
  17. <button style="padding: 0;" class="getbutton" open-type="chooseAvatar"
  18. @chooseavatar="onChooseAvatar"></button>
  19. <!-- #endif -->
  20. </view>
  21. <view class='item acea-row row-between-wrapper'>
  22. <view>昵称</view>
  23. <view class='input'><input type='nickname' name='nickname' placeholder="请输入昵称"
  24. :value='userinfo.nickname'></input>
  25. </view>
  26. </view>
  27. <view v-if="userinfo.id_number" class='item acea-row row-between-wrapper'>
  28. <view>ID号</view>
  29. <view class='input acea-row row-between-wrapper'>
  30. <input type='text' :value='userinfo.id_number' disabled='true' class='id'></input>
  31. <u-icon name="lock" size="22" color="#868686"></u-icon>
  32. </view>
  33. </view>
  34. <!-- #ifdef MP -->
  35. <view class='item acea-row row-between-wrapper'>
  36. <view>权限设置</view>
  37. <view class="input" @click="Setting">
  38. 点击管理<u-icon name="arrow-right" size="17" color="#868686" top="1"></u-icon>
  39. </view>
  40. </view>
  41. <!-- #endif -->
  42. </view>
  43. <button class='modifyBnt' style="background: linear-gradient(to right, #00ca88, #00BCD4);"
  44. hover-class="hoversubmit" formType="submit">保存修改</button>
  45. <!-- #ifdef H5 || APP-PLUS -->
  46. <view class="modifyBnt bg-color"
  47. style="margin-top: 40rpx;background: #ededed;color: #00ca88;border: 1px solid #00ca88;"
  48. @click="outLogin">退出登录</view>
  49. <!-- #endif -->
  50. </view>
  51. </form>
  52. </view>
  53. </template>
  54. <script>
  55. import {
  56. mapMutations,
  57. mapActions,
  58. mapState,
  59. mapGetters
  60. } from 'vuex';
  61. import {
  62. apiurl
  63. } from '@/common/request/request';
  64. // import Header from '@/components/header.vue';
  65. export default {
  66. // components: {
  67. // Header
  68. // },
  69. data() {
  70. return {
  71. loginType: 'h5', //app.globalData.loginType
  72. userIndex: 0,
  73. switchUserInfo: [],
  74. isAuto: false, //没有授权的不会自动授权
  75. isShowAuth: false, //是否隐藏授权
  76. canvasWidth: "",
  77. canvasHeight: "",
  78. canvasStatus: false,
  79. fileSizeString: '',
  80. version: '',
  81. ifimg: false,
  82. userinfo: {},
  83. tobheight: 45,
  84. platform: this.$platform.get(),
  85. };
  86. },
  87. computed: {
  88. ...mapGetters(['appInfo', 'isLogin', 'userInfo'])
  89. },
  90. onLoad() {
  91. let that = this;
  92. that.userinfo = that.userInfo
  93. if (this.platform == 'wxMiniProgram') {
  94. var menumtop = uni.getMenuButtonBoundingClientRect().top - uni.getSystemInfoSync().statusBarHeight;
  95. var paddingtop = uni.getSystemInfoSync().statusBarHeight + menumtop;
  96. this.tobheight = menumtop + paddingtop + uni.getMenuButtonBoundingClientRect().height;
  97. }
  98. },
  99. methods: {
  100. ...mapActions(['logout']),
  101. isNew() {
  102. this.$util.Tips({
  103. title: '当前为最新版本'
  104. });
  105. },
  106. onChooseAvatar(e) {
  107. var that = this;
  108. // console.log(e.detail.avatarUrl);
  109. // this.userinfo.avatar = e.detail.avatarUrl
  110. // this.ifimg = true
  111. uni.uploadFile({
  112. url: apiurl('common/upload'),
  113. filePath: e.detail.avatarUrl,
  114. name: 'file',
  115. formData: {
  116. accept: 'image'
  117. },
  118. success: res2 => {
  119. let a = JSON.parse(res2.data);
  120. if (a.code == 0) {
  121. that.userinfo.avatar = a.data.path
  122. that.ifimg = true
  123. } else {
  124. uni.showToast({
  125. title: '上传图片失败',
  126. icon: 'none'
  127. })
  128. that.ifimg = false
  129. }
  130. }
  131. });
  132. },
  133. updateApp() {
  134. this.$refs.appUpdate.update(); //调用子组件 检查更新
  135. },
  136. formatSize() {
  137. let that = this;
  138. plus.cache.calculate(function(size) {
  139. let sizeCache = parseInt(size);
  140. if (sizeCache == 0) {
  141. that.fileSizeString = "0B";
  142. } else if (sizeCache < 1024) {
  143. that.fileSizeString = sizeCache + "B";
  144. } else if (sizeCache < 1048576) {
  145. that.fileSizeString = (sizeCache / 1024).toFixed(2) + "KB";
  146. } else if (sizeCache < 1073741824) {
  147. that.fileSizeString = (sizeCache / 1048576).toFixed(2) + "MB";
  148. } else {
  149. that.fileSizeString = (sizeCache / 1073741824).toFixed(2) + "GB";
  150. }
  151. });
  152. },
  153. initData() {
  154. uni.showModal({
  155. title: '清楚缓存',
  156. content: '确定清楚本地缓存数据吗?',
  157. success: (res) => {
  158. if (res.confirm) {
  159. this.clearCache()
  160. this.formatSize()
  161. } else if (res.cancel) {
  162. return that.$util.Tips({
  163. title: '已取消'
  164. });
  165. }
  166. }
  167. });
  168. },
  169. clearCache() {
  170. let that = this;
  171. let os = plus.os.name;
  172. if (os == 'Android') {
  173. let main = plus.android.runtimeMainActivity();
  174. let sdRoot = main.getCacheDir();
  175. let files = plus.android.invoke(sdRoot, "listFiles");
  176. let len = files.length;
  177. for (let i = 0; i < len; i++) {
  178. let filePath = '' + files[i]; // 没有找到合适的方法获取路径,这样写可以转成文件路径
  179. plus.io.resolveLocalFileSystemURL(filePath, function(entry) {
  180. if (entry.isDirectory) {
  181. entry.removeRecursively(function(entry) { //递归删除其下的所有文件及子目录
  182. uni.showToast({
  183. title: '缓存清理完成',
  184. duration: 2000
  185. });
  186. that.formatSize(); // 重新计算缓存
  187. }, function(e) {
  188. console.log(e.message)
  189. });
  190. } else {
  191. entry.remove();
  192. }
  193. }, function(e) {
  194. console.log('文件路径读取失败')
  195. });
  196. }
  197. } else { // ios暂时未找到清理缓存的方法,以下是官方提供的方法,但是无效,会报错
  198. plus.cache.clear(function() {
  199. uni.showToast({
  200. title: '缓存清理完成',
  201. duration: 2000
  202. });
  203. that.formatSize();
  204. });
  205. }
  206. },
  207. /**
  208. * 小程序设置
  209. */
  210. Setting: function() {
  211. uni.openSetting({
  212. success: function(res) {}
  213. });
  214. },
  215. /**
  216. * 退出登录
  217. *
  218. */
  219. outLogin: function() {
  220. let that = this;
  221. if (that.loginType == 'h5') {
  222. uni.showModal({
  223. confirmColor: '#26B3A0',
  224. title: '提示',
  225. content: '确认退出登录?',
  226. success: function(res) {
  227. if (res.confirm) {
  228. // getLogout()
  229. // .then(res => {
  230. // console.log(res.code);
  231. // uni.clearStorage()
  232. that.logout();
  233. // that.$store.commit("LOGOUT");
  234. // uni.navigateBack({})
  235. uni.redirectTo({
  236. url: '/pages/user/signin'
  237. })
  238. // uni.reLaunch({
  239. // url: '/pages/index/index'
  240. // })
  241. // })
  242. // .catch(err => {});
  243. } else if (res.cancel) {
  244. console.log('用户点击取消');
  245. }
  246. }
  247. });
  248. }
  249. },
  250. /**
  251. * 上传文件
  252. *
  253. */
  254. uploadpic: function() {
  255. let that = this;
  256. uni.chooseImage({
  257. count: 1, //默认9
  258. sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
  259. sourceType: ['album', 'camera'], //从相册选择
  260. success: function(res) {
  261. const tempFilePaths = res.tempFilePaths;
  262. //上传服务器将服务器;
  263. uni.uploadFile({
  264. url: apiurl('common/upload'),
  265. filePath: tempFilePaths[0],
  266. name: 'file',
  267. formData: {
  268. accept: 'image'
  269. },
  270. success: res2 => {
  271. let a = JSON.parse(res2.data);
  272. if (a.code == 0) {
  273. that.userinfo.avatar = a.data.path
  274. that.ifimg = true
  275. } else {
  276. uni.showToast({
  277. title: '上传图片失败',
  278. icon: 'none'
  279. })
  280. that.ifimg = false
  281. }
  282. }
  283. });
  284. }
  285. });
  286. },
  287. /**
  288. * 提交修改
  289. */
  290. formSubmit: function(e) {
  291. let that = this,
  292. value = e.detail.value;
  293. if (!that.ifimg && !that.userInfo.avatar) return that.$u.toast('保存失败,请上传头像');
  294. if (value.nickname == that.userinfo.nickname && !that.userInfo.nickname) return that.$u.toast(
  295. '保存失败,请填写昵称');
  296. if (value.nickname == that.userinfo.nickname && !that.ifimg) return that.$u.toast('保存失败,您并没有修改');
  297. that.$http('user.profile', {
  298. nickname: value.nickname,
  299. avatar: that.userinfo.avatar
  300. }).then(res => {
  301. if (res.code == 0) {
  302. uni.showToast({
  303. title: '保存中...',
  304. duration: 1000,
  305. icon: 'loading',
  306. })
  307. that.$store.dispatch('getUserInfo')
  308. setTimeout(function() {
  309. uni.showToast({
  310. title: '保存成功',
  311. duration: 1000,
  312. })
  313. setTimeout(function() {
  314. uni.navigateBack()
  315. }, 1000);
  316. }, 1000);
  317. } else {
  318. that.$u.toast('保存失败,请重试');
  319. }
  320. })
  321. }
  322. }
  323. }
  324. </script>
  325. <style lang="scss">
  326. page {
  327. background: #ededed;
  328. }
  329. .cartcolor {
  330. color: var(--view-theme);
  331. border: 1px solid var(--view-theme);
  332. }
  333. .personal-data .wrapper {
  334. margin: 10rpx 0;
  335. background-color: #fff;
  336. padding: 36rpx 30rpx 13rpx 30rpx;
  337. }
  338. .personal-data .wrapper .title {
  339. margin-bottom: 30rpx;
  340. font-size: 32rpx;
  341. color: #282828;
  342. }
  343. .personal-data .wrapper .wrapList .item {
  344. width: 690rpx;
  345. height: 160rpx;
  346. background-color: #f8f8f8;
  347. border-radius: 20rpx;
  348. margin-bottom: 22rpx;
  349. padding: 0 30rpx;
  350. position: relative;
  351. border: 2rpx solid #f8f8f8;
  352. box-sizing: border-box;
  353. }
  354. .personal-data .wrapper .wrapList .item.on {
  355. border-color: #e93323;
  356. border-radius: 20rpx;
  357. background-image: url("");
  358. background-size: 100% 100%;
  359. background-color: #fff9f9;
  360. background-repeat: no-repeat;
  361. }
  362. .personal-data .wrapper .wrapList .item .picTxt {
  363. width: 445rpx;
  364. }
  365. .personal-data .wrapper .wrapList .item .picTxt .pictrue {
  366. width: 96rpx;
  367. height: 96rpx;
  368. position: relative;
  369. }
  370. .personal-data .wrapper .wrapList .item .picTxt .pictrue image {
  371. width: 100%;
  372. height: 100%;
  373. border-radius: 50%;
  374. }
  375. .personal-data .wrapper .wrapList .item .picTxt .pictrue .alter {
  376. width: 30rpx;
  377. height: 30rpx;
  378. border-radius: 50%;
  379. position: absolute;
  380. bottom: 0;
  381. right: 0;
  382. }
  383. .personal-data .wrapper .wrapList .item .picTxt .text {
  384. width: 325rpx;
  385. }
  386. .personal-data .wrapper .wrapList .item .picTxt .text .name {
  387. width: 100%;
  388. font-size: 30rpx;
  389. color: #282828;
  390. }
  391. .personal-data .wrapper .wrapList .item .picTxt .text .phone {
  392. font-size: 24rpx;
  393. color: #999;
  394. margin-top: 10rpx;
  395. }
  396. .personal-data .wrapper .wrapList .item .bnt {
  397. font-size: 24rpx;
  398. background-color: #fff;
  399. border-radius: 27rpx;
  400. width: 140rpx;
  401. height: 54rpx;
  402. border: 2rpx solid #e93323;
  403. }
  404. .personal-data .wrapper .wrapList .item .currentBnt {
  405. position: absolute;
  406. right: 0;
  407. top: 0;
  408. font-size: 26rpx;
  409. background-color: rgba(233, 51, 35, 0.1);
  410. width: 140rpx;
  411. height: 48rpx;
  412. border-radius: 0 20rpx 0 20rpx;
  413. }
  414. .personal-data .list {
  415. margin-top: 15rpx;
  416. background-color: #fff;
  417. }
  418. .personal-data .list .item {
  419. padding: 30rpx 30rpx 30rpx 0;
  420. border-bottom: 1rpx solid #f2f2f2;
  421. margin-left: 30rpx;
  422. font-size: 32rpx;
  423. color: #282828;
  424. }
  425. .personal-data .list .item .phone {
  426. width: 160rpx;
  427. height: 56rpx;
  428. font-size: 24rpx;
  429. color: #fff;
  430. line-height: 56rpx;
  431. border-radius: 32rpx
  432. }
  433. .personal-data .list .item .pictrue {
  434. width: 88rpx;
  435. height: 88rpx;
  436. }
  437. .personal-data .list .item .pictrue image {
  438. width: 100%;
  439. height: 100%;
  440. border-radius: 50%;
  441. }
  442. .personal-data .list .item .input {
  443. width: 415rpx;
  444. text-align: right;
  445. color: #868686;
  446. display: flex;
  447. align-items: center;
  448. justify-content: flex-end;
  449. }
  450. .personal-data .list .item .input .id {
  451. width: 305rpx;
  452. }
  453. .personal-data .list .item .input .iconfont {
  454. font-size: 35rpx;
  455. }
  456. .personal-data .modifyBnt {
  457. font-size: 32rpx;
  458. color: #fff;
  459. width: 690rpx;
  460. height: 90rpx;
  461. border-radius: 50rpx;
  462. text-align: center;
  463. line-height: 90rpx;
  464. margin: 76rpx auto 0 auto;
  465. }
  466. .personal-data .hoversubmit {
  467. background: #f7f7f7;
  468. color: #acacb3;
  469. }
  470. .personal-data .logOut {
  471. font-size: 32rpx;
  472. text-align: center;
  473. width: 690rpx;
  474. height: 90rpx;
  475. border-radius: 45rpx;
  476. margin: 30rpx auto 0 auto;
  477. }
  478. .avatar-box {
  479. width: 96rpx;
  480. height: 96rpx;
  481. image {
  482. width: 100%;
  483. height: 100%;
  484. border-radius: 50%;
  485. }
  486. }
  487. .acea-row {
  488. display: flex;
  489. flex-wrap: wrap;
  490. }
  491. .acea-row.row-between-wrapper {
  492. align-items: center;
  493. justify-content: space-between;
  494. }
  495. .bg-color {
  496. background-color: #333;
  497. }
  498. .getbutton {
  499. position: absolute;
  500. width: 96rpx;
  501. height: 96rpx;
  502. opacity: 0;
  503. right: 30rpx;
  504. // margin-top: 180rpx;
  505. }
  506. </style>