index.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867
  1. let Parse = getApp().Parse;
  2. let company = getApp().globalData.company
  3. const request = require("../../utils/request");
  4. const qiniuUploader = require("../../utils/qiniuUploader");
  5. //获取应用实例
  6. const app = getApp()
  7. const real = require('../../utils/real')
  8. var timer
  9. /**
  10. * @class NovaAppAuth
  11. * @memberof module:components
  12. * @tutorial userauth
  13. * @desc 通用登录组件
  14. * # 登录组件相关数据表
  15. * - _User
  16. */
  17. Page({
  18. data: {
  19. phoneModal: false, //短信验证码登录弹窗
  20. logo: "https://file-cloud.fmode.cn/MldI5PBNt7/20210928/g0k1jb034826.png",
  21. name: "未来商城",
  22. desc: "江西脑控科技有限公司是国内领先的IT技术企业。专注于互联网+服务,面向政府提供区块链、大数据、物联网、人工智能解决方案",
  23. wxModel: false,
  24. avatarUrl: '',
  25. avatar: '',
  26. nickname: '',
  27. check: false,
  28. mobile: '', //手机号
  29. verilyCode: '', //验证码
  30. s: 0, //获取验证码倒计时 秒/s
  31. countDown: false,
  32. avatarKey: Date.now() // 用于强制刷新头像显示
  33. },
  34. onLoad: async function (options) {
  35. let Company = new Parse.Query('Company')
  36. Company.equalTo("objectId", company)
  37. let currentCompany = await Company.first()
  38. if (currentCompany && currentCompany.id) {
  39. this.setData({
  40. logo: currentCompany.get('logo'),
  41. name: currentCompany.get('name'),
  42. desc: currentCompany.get('desc')
  43. })
  44. }
  45. this.getUptoken()
  46. this.getAgreement() //用户协议
  47. },
  48. async getUptoken() {
  49. let res = await Parse.Cloud.run('qiniu_uptoken', {
  50. company: company
  51. })
  52. this.setData({
  53. uptokenURL: res.uptoken,
  54. domain: res.domain,
  55. uploadURL: res.zoneUrl
  56. })
  57. },
  58. async getAgreement() {
  59. let query = new Parse.Query('ContractAgreement')
  60. query.equalTo('type', 'wxapp')
  61. query.equalTo('company', company)
  62. query.select('title', 'content')
  63. let res = await query.first()
  64. if (res?.id) {
  65. this.setData({
  66. agreement: res.toJSON()
  67. })
  68. }
  69. },
  70. /* 是否同意授权协议 */
  71. getAgreementAuth() {
  72. if (!this.data.check && this.data.agreement) {
  73. wx.showModal({
  74. title: '提示',
  75. content: `请您仔细阅读并充分理解相关条款,点击同意即代表已阅读并同意《${this.data.agreement.title || '用户隐私协议'}》`,
  76. showCancel: true,
  77. cancelText: '取消',
  78. cancelColor: '#000000',
  79. confirmText: '同意',
  80. confirmColor: '#3CC51F',
  81. success: (result) => {
  82. if (result.confirm) {
  83. this.setData({
  84. check: true,
  85. })
  86. // this.getUserProfile()
  87. }
  88. },
  89. fail: () => { },
  90. complete: () => { }
  91. });
  92. return
  93. }
  94. // this.getUserProfile()
  95. return true
  96. },
  97. /* 判断是否绑定手机号 */
  98. async getUserProfile() {
  99. // 检查用户是否已登录
  100. let currentUser = Parse.User.current();
  101. if (!currentUser?.id) {
  102. console.log('⚠️ 用户未登录,需要先登录');
  103. // 不要在这里调用 checkAuth(true),因为它会触发微信官方的强制授权弹窗
  104. // 应该在外层(index.js)处理登录逻辑
  105. return false;
  106. }
  107. /* 如果手机号存在,已注册过判断是否上传过头像昵称信息 */
  108. if (currentUser?.get('mobile')) {
  109. wx.setStorageSync("userLogin", currentUser.id);
  110. // 检查是否需要完善信息(可选)
  111. // 如果用户没有昵称或昵称是默认的,提示完善信息
  112. const needProfile = !currentUser.get('nickname') ||
  113. currentUser.get('nickname') === '微信用户' ||
  114. currentUser.get('nickname') === '';
  115. if (needProfile) {
  116. // 显示自定义的完善信息弹窗(允许跳过)
  117. console.log('ℹ️ 显示自定义头像昵称弹窗');
  118. this.setData({
  119. wxModel: true
  120. });
  121. return false;
  122. }
  123. // 用户信息完整,返回上一页
  124. this.backLoad();
  125. return false;
  126. }
  127. // 用户已登录但没有手机号,允许继续
  128. return true;
  129. },
  130. /* 短信验证码登录弹窗 */
  131. async showDialogBtn() {
  132. let auth = this.getAgreementAuth()
  133. if (!auth) return
  134. let userProfile = await this.getUserProfile()
  135. if (!userProfile) return
  136. this.setData({
  137. phoneModal: true
  138. })
  139. },
  140. async getPhoneNumber(e) {
  141. let auth = this.getAgreementAuth()
  142. if (!auth) return
  143. let userProfile = await this.getUserProfile()
  144. if (!userProfile) return
  145. let {
  146. code
  147. } = e.detail
  148. console.log(code);
  149. let phoneNumber = await request.getPhone(code)
  150. if(phoneNumber) this.authMobileUser(phoneNumber)
  151. },
  152. //合并User与绑定手机号逻辑
  153. async authMobileUser(mobile) {
  154. let currentUser = Parse.User.current()
  155. let queryMobUser = new Parse.Query('_User')
  156. queryMobUser.equalTo('mobile', mobile)
  157. queryMobUser.equalTo('company', company)
  158. queryMobUser.notEqualTo('type', 'admin')
  159. queryMobUser.notEqualTo('isDeleted', true)
  160. // queryMobUser.exists(`wxapp.${getApp().globalData.appid}`)
  161. let resMobUser = await queryMobUser.first()
  162. if (resMobUser?.id) {
  163. //请求User合并API,获取token重新登录,再更新昵称头像信息等
  164. let token = await this.getUpdateUserToken(currentUser.id, resMobUser.id)
  165. console.log(token);
  166. if (token) {
  167. Parse.User.become(token).then(async user => {
  168. // let user = Parse.User.current();
  169. wx.setStorageSync("userLogin", user.id);
  170. if (!user.get('avatar') || user.get('nickname') == '微信用户' || !user.get('nickname')) {
  171. this.setData({
  172. phoneModal: false,
  173. wxModel: true
  174. })
  175. return
  176. }
  177. this.backLoad()
  178. return
  179. })
  180. .catch(async err => {
  181. console.log('❌ Parse.User.become 失败:', err);
  182. // 不要直接退出,而是尝试重新登录
  183. wx.showModal({
  184. title: '提示',
  185. content: '登录状态异常,是否重新登录?',
  186. showCancel: true,
  187. cancelText: '取消',
  188. confirmText: '重新登录',
  189. success: async (result) => {
  190. if (result.confirm) {
  191. // 清除登录状态
  192. wx.removeStorageSync("sessionToken");
  193. wx.removeStorageSync("userLogin");
  194. try {
  195. // 尝试重新登录
  196. await Parse.User.logOut();
  197. await getApp().checkAuth(true);
  198. // 重新获取用户信息
  199. const currentUser = Parse.User.current();
  200. if (currentUser && currentUser.get('mobile')) {
  201. wx.setStorageSync("userLogin", currentUser.id);
  202. this.backLoad();
  203. }
  204. } catch (reloginErr) {
  205. console.error('❌ 重新登录失败:', reloginErr);
  206. wx.showToast({
  207. title: '登录失败,请稍后重试',
  208. icon: 'none'
  209. });
  210. }
  211. } else {
  212. // 用户取消,返回上一页
  213. wx.navigateBack();
  214. }
  215. },
  216. });
  217. return
  218. })
  219. return
  220. }
  221. return
  222. }
  223. currentUser.set('mobile', mobile)
  224. await currentUser.save()
  225. if (!currentUser.get('avatar') || currentUser.get('nickname') == '微信用户' || !currentUser.get('nickname')) {
  226. this.setData({
  227. phoneModal: false,
  228. wxModel: true
  229. })
  230. return
  231. }
  232. this.backLoad()
  233. return
  234. },
  235. async getUpdateUserToken(oldUser, newUserId) {
  236. return new Promise((resolve, reject) => {
  237. wx.login({
  238. success: function (res) {
  239. let parms = {
  240. oldUserId: oldUser,
  241. newUserId: newUserId,
  242. appId: getApp().globalData.appid,
  243. code: res.code,
  244. companyId: company,
  245. appType: getApp().globalData.appType || ''
  246. }
  247. if (res.code) {
  248. let url = 'https://server.fmode.cn/api/wxapp/combine/user'
  249. wx.request({
  250. url: url,
  251. data: parms,
  252. header: { 'content-type': 'application/json' },
  253. method: 'POST',
  254. async success(res) {
  255. console.log(res);
  256. let data = res.data
  257. if (data.code == 200) {
  258. wx.setStorageSync("sessionToken", data.data.token);
  259. resolve(data.data.token)
  260. } else {
  261. console.log(data?.mess);
  262. wx.showModal({
  263. title: '提示',
  264. content: data?.mess,
  265. showCancel: false,
  266. cancelText: '取消',
  267. cancelColor: '#000000',
  268. confirmText: '确定',
  269. confirmColor: '#3CC51F',
  270. success: (result) => {
  271. if (result.confirm) {
  272. }
  273. },
  274. fail: () => { },
  275. complete: () => { }
  276. });
  277. resolve()
  278. }
  279. },
  280. });
  281. }
  282. },
  283. fail: function (err) {
  284. wx.showModal({
  285. title: '提示',
  286. content: '登录超时,请稍后重试',
  287. showCancel: false,
  288. cancelText: '取消',
  289. cancelColor: '#000000',
  290. confirmText: '确定',
  291. confirmColor: '#3CC51F',
  292. success: (result) => {
  293. if (result.confirm) {
  294. }
  295. },
  296. fail: () => { },
  297. complete: () => { }
  298. });
  299. console.warn('小程序wx.login失败');
  300. resolve()
  301. }
  302. });
  303. })
  304. },
  305. //获取验证码
  306. async getPhoneCode() {
  307. let { mobile, s, countDown } = this.data
  308. if (!real.isPoneAvailable(mobile)) {
  309. wx.showToast({
  310. title: '手机号格式有误',
  311. icon: 'error',
  312. duration: 1500,
  313. mask: false,
  314. });
  315. return
  316. }
  317. if(countDown || s > 0) return
  318. this.setData({
  319. countDown:true
  320. })
  321. let parsm = {
  322. company: company,
  323. mobile: mobile
  324. }
  325. let code = await this.getRequest(parsm, 'message')
  326. if(code?.code == 1){
  327. this.setData({
  328. s:60
  329. })
  330. this.decrementTime()
  331. }else{
  332. wx.showToast({
  333. title: '验证码获取失败',
  334. icon: 'error',
  335. image: '',
  336. duration: 1500,
  337. mask: false,
  338. });
  339. this.setData({
  340. countDown:false
  341. })
  342. }
  343. },
  344. //接口请求
  345. getRequest(parsm, apig) {
  346. return new Promise((resolve, rej) => {
  347. let url = 'https://server.fmode.cn/api/apig/'
  348. wx.request({
  349. url: url + apig,
  350. data: parsm,
  351. header: { 'content-type': 'application/json' },
  352. method: 'POST',
  353. dataType: 'json',
  354. responseType: 'text',
  355. success: (result) => {
  356. console.log(result);
  357. resolve(result.data)
  358. },
  359. fail: () => {
  360. resolve(false)
  361. },
  362. complete: () => { }
  363. });
  364. })
  365. },
  366. // 倒计时
  367. decrementTime(){
  368. timer = setTimeout(() => {
  369. let { s } = this.data
  370. if(s == 0){
  371. this.setData({ countDown:false })
  372. timer && clearTimeout(timer)
  373. return
  374. }
  375. s--
  376. this.setData({
  377. s:s
  378. })
  379. this.decrementTime()
  380. }, 1000);
  381. },
  382. //验证码绑定手机号登录
  383. async completePhone() {
  384. let { mobile, verilyCode } = this.data
  385. if(!real.isPoneAvailable(mobile) || !verilyCode.toString().trim()){
  386. wx.showToast({
  387. title: '手机号或验证码不正确',
  388. icon: 'none',
  389. image: '',
  390. duration: 1500,
  391. mask: false,
  392. });
  393. return
  394. }
  395. let parsm = {
  396. mobile: mobile,
  397. code:verilyCode
  398. }
  399. let isVerify = await this.getRequest(parsm, 'verifyCode')
  400. console.log(isVerify);
  401. if(isVerify.code == 200){
  402. this.authMobileUser(mobile.toString())
  403. }else{
  404. wx.showToast({
  405. title:isVerify?.msg || '验证码错误',
  406. icon: 'none',
  407. image: '',
  408. duration: 1500,
  409. mask: false,
  410. });
  411. return
  412. }
  413. },
  414. //关闭手机号授权弹窗
  415. hideModal: function () {
  416. this.setData({
  417. phoneModal: false
  418. })
  419. },
  420. backLoad() {
  421. console.log('===========================================');
  422. console.log('======= backLoad 方法调用 =======');
  423. let pages = getCurrentPages();
  424. console.log('当前页面栈层数:', pages.length);
  425. console.log('当前页面路由:', pages[pages.length - 1]?.route);
  426. // 如果页面栈只有1层或没有上一页,直接跳转到首页
  427. if (pages.length <= 1) {
  428. console.log('⚠️ 没有上一个页面,直接跳转到首页');
  429. this.goToHome();
  430. return;
  431. }
  432. // 有上一个页面
  433. let beforePage = pages[pages.length - 2];
  434. console.log('上一个页面路由:', beforePage.route);
  435. // 尝试调用上一个页面的 onLoad 方法(如果存在)
  436. if (beforePage && typeof beforePage.onLoad === 'function') {
  437. try {
  438. let options = beforePage.options || { isInit: true };
  439. beforePage.onLoad(options);
  440. console.log('✅ 已调用上一个页面的 onLoad');
  441. } catch (err) {
  442. console.warn('⚠️ 调用上一个页面 onLoad 失败:', err);
  443. }
  444. }
  445. // 返回上一页
  446. console.log('🔙 执行 navigateBack...');
  447. wx.navigateBack({
  448. delta: 1,
  449. success: () => {
  450. console.log('✅ navigateBack 成功');
  451. console.log('===========================================');
  452. },
  453. fail: (err) => {
  454. console.error('❌ navigateBack 失败:', err);
  455. console.log('⚠️ 尝试使用 reLaunch 跳转到首页');
  456. this.goToHome();
  457. }
  458. });
  459. },
  460. // 跳转到首页
  461. goToHome() {
  462. console.log('===========================================');
  463. console.log('======= goToHome 方法调用 =======');
  464. const app = getApp();
  465. console.log('globalData.rootPage:', app.globalData.rootPage);
  466. console.log('globalData.defaultTabBar:', app.globalData.defaultTabBar);
  467. // 尝试多个可能的首页路径
  468. let rootPage = app.globalData.rootPage
  469. || app.globalData.defaultTabBar?.list?.[0]?.pagePath
  470. || '/pages/index/index'
  471. || '/index/index';
  472. // 确保路径以 / 开头
  473. if (!rootPage.startsWith('/')) {
  474. rootPage = '/' + rootPage;
  475. }
  476. console.log('准备跳转到:', rootPage);
  477. wx.reLaunch({
  478. url: rootPage,
  479. success: () => {
  480. console.log('✅ reLaunch 成功');
  481. console.log('===========================================');
  482. },
  483. fail: (err) => {
  484. console.error('❌ reLaunch 失败:', err);
  485. console.log('⚠️ 尝试使用 switchTab');
  486. // 如果是 tabBar 页面,尝试使用 switchTab
  487. wx.switchTab({
  488. url: rootPage,
  489. success: () => {
  490. console.log('✅ switchTab 成功');
  491. console.log('===========================================');
  492. },
  493. fail: (err2) => {
  494. console.error('❌ switchTab 也失败:', err2);
  495. console.log('⚠️ 最后尝试:直接 navigateBack');
  496. // 最后的兜底:直接返回
  497. wx.navigateBack({
  498. delta: 1,
  499. fail: (err3) => {
  500. console.error('❌ 所有跳转方式都失败了:', err3);
  501. console.log('===========================================');
  502. // 显示错误提示
  503. wx.showModal({
  504. title: '提示',
  505. content: '页面跳转失败,请手动返回',
  506. showCancel: false
  507. });
  508. }
  509. });
  510. }
  511. });
  512. }
  513. });
  514. },
  515. goBack: function () {
  516. wx.navigateBack({
  517. delta: 1,
  518. })
  519. },
  520. //手动获取微信头像
  521. onChooseAvatar(e) {
  522. console.log('=== onChooseAvatar 触发 ===');
  523. console.log('事件对象:', e);
  524. const { avatarUrl } = e.detail;
  525. console.log('获取到的头像URL:', avatarUrl);
  526. console.log('头像URL类型:', typeof avatarUrl);
  527. console.log('头像URL长度:', avatarUrl ? avatarUrl.length : 0);
  528. if (avatarUrl) {
  529. // 微信头像URL可能是临时路径,需要先下载
  530. // 临时路径格式:http://tmp/xxx.jpg
  531. // 相机拍照路径格式:wxfile://tmp_xxx.jpg
  532. this.setData({
  533. avatarUrl: avatarUrl,
  534. avatarKey: Date.now() // 更新key强制刷新
  535. }, () => {
  536. console.log('✅ 头像URL已更新到data:', this.data.avatarUrl);
  537. console.log('✅ avatarKey已更新:', this.data.avatarKey);
  538. });
  539. } else {
  540. console.error('❌ 未获取到头像URL');
  541. // 在开发环境下,如果获取失败,提示用户可以跳过
  542. wx.showToast({
  543. title: '开发工具不支持,请真机测试或跳过',
  544. icon: 'none',
  545. duration: 2000
  546. });
  547. }
  548. },
  549. //获取昵称
  550. onChangeName(e) {
  551. console.log('=== 昵称输入事件 ===');
  552. console.log('事件对象:', e);
  553. // 注意:type="nickname" 的 input 会在用户输入时自动更新 model:value
  554. // 这里只是记录日志,实际的值更新由 model:value 自动处理
  555. if (e.detail && e.detail.value !== undefined) {
  556. console.log('昵称值:', e.detail.value);
  557. }
  558. },
  559. //确定头像昵称
  560. async onComplete() {
  561. console.log('=== onComplete 方法被调用 ===');
  562. let {
  563. nickname,
  564. avatarUrl
  565. } = this.data
  566. console.log('昵称:', nickname);
  567. console.log('头像URL:', avatarUrl);
  568. let user = Parse.User.current();
  569. if (!user) {
  570. console.error('❌ 用户未登录,无法保存信息');
  571. wx.showToast({
  572. title: '用户未登录',
  573. icon: 'none'
  574. });
  575. return;
  576. }
  577. console.log('当前用户ID:', user.id);
  578. // 显示加载提示
  579. wx.showLoading({
  580. title: '保存中...',
  581. mask: true
  582. });
  583. try {
  584. // 如果用户填写了信息,则更新
  585. if (nickname || avatarUrl) {
  586. console.log('ℹ️ 用户填写了信息,开始更新');
  587. // 如果有头像,上传头像
  588. if (avatarUrl) {
  589. console.log('📤 开始上传头像...');
  590. let avatar = await this.updataAvatar(avatarUrl);
  591. if (avatar) {
  592. user.set("avatar", avatar);
  593. console.log('✅ 头像上传成功:', avatar);
  594. } else {
  595. console.warn('⚠️ 头像上传失败');
  596. }
  597. }
  598. // 如果有昵称,更新昵称
  599. if (nickname) {
  600. user.set("nickname", nickname);
  601. console.log('✅ 昵称已设置:', nickname);
  602. }
  603. await user.save();
  604. console.log('✅ 用户信息保存成功');
  605. } else {
  606. // 用户没有填写任何信息,使用默认值
  607. console.log('ℹ️ 用户跳过头像昵称设置,使用默认值');
  608. // 如果用户没有昵称,设置默认昵称
  609. if (!user.get('nickname') || user.get('nickname') === '微信用户') {
  610. const defaultNickname = '用户' + user.id.substring(0, 6);
  611. user.set('nickname', defaultNickname);
  612. await user.save();
  613. console.log('✅ 已设置默认昵称:', defaultNickname);
  614. }
  615. }
  616. wx.hideLoading();
  617. // 关闭弹窗
  618. this.onClose();
  619. // 延迟一下再跳转,确保弹窗关闭动画完成
  620. setTimeout(() => {
  621. console.log('🚀 准备跳转...');
  622. this.backLoad();
  623. }, 300);
  624. } catch (err) {
  625. wx.hideLoading();
  626. console.error('❌ 保存用户信息失败:', err);
  627. wx.showModal({
  628. title: '提示',
  629. content: '保存失败,是否继续?',
  630. showCancel: true,
  631. cancelText: '重试',
  632. confirmText: '继续',
  633. success: (result) => {
  634. if (result.confirm) {
  635. // 用户选择继续,直接跳转
  636. this.onClose();
  637. setTimeout(() => {
  638. this.backLoad();
  639. }, 300);
  640. }
  641. // 用户选择重试,留在当前页面
  642. }
  643. });
  644. }
  645. },
  646. //跳过头像昵称设置
  647. async onSkip() {
  648. console.log('=== onSkip 方法被调用 ===');
  649. let user = Parse.User.current();
  650. if (!user) {
  651. console.error('❌ 用户未登录');
  652. wx.showToast({
  653. title: '用户未登录',
  654. icon: 'none'
  655. });
  656. return;
  657. }
  658. console.log('当前用户ID:', user.id);
  659. wx.showLoading({
  660. title: '处理中...',
  661. mask: true
  662. });
  663. try {
  664. // 设置默认昵称(如果没有)
  665. if (!user.get('nickname') || user.get('nickname') === '微信用户') {
  666. const defaultNickname = '用户' + user.id.substring(0, 6);
  667. user.set('nickname', defaultNickname);
  668. await user.save();
  669. console.log('✅ 已设置默认昵称:', defaultNickname);
  670. } else {
  671. console.log('ℹ️ 用户已有昵称:', user.get('nickname'));
  672. }
  673. wx.hideLoading();
  674. // 关闭弹窗
  675. this.onClose();
  676. // 延迟一下再跳转
  677. setTimeout(() => {
  678. console.log('🚀 准备跳转...');
  679. this.backLoad();
  680. }, 300);
  681. } catch (err) {
  682. wx.hideLoading();
  683. console.error('❌ 设置默认昵称失败:', err);
  684. // 即使失败也允许继续
  685. this.onClose();
  686. setTimeout(() => {
  687. this.backLoad();
  688. }, 300);
  689. }
  690. },
  691. //关闭头像昵称填写弹窗
  692. onClose() {
  693. this.setData({
  694. wxModel: false
  695. })
  696. },
  697. //上传头像
  698. updataAvatar(url) {
  699. let that = this;
  700. return new Promise((resolve, rejcet) => {
  701. qiniuUploader.upload(
  702. url,
  703. async (res) => {
  704. let img = res.imageURL;
  705. resolve(img)
  706. },
  707. (error) => {
  708. console.log("error: " + error);
  709. resolve(false)
  710. }, {
  711. region: "SCN",
  712. uploadURL: that.data.uploadURL,
  713. domain: that.data.domain,
  714. uptoken: that.data.uptokenURL,
  715. }
  716. );
  717. })
  718. },
  719. //选择勾选用户协议
  720. onCheckAgreement() {
  721. this.setData({
  722. check: !this.data.check
  723. })
  724. },
  725. //附件下载
  726. openFile() {
  727. let {
  728. agreement
  729. } = this.data
  730. let url = agreement.content,
  731. name = agreement.title
  732. const _this = this;
  733. let rep = this.getFileType(url)
  734. console.log(url, name);
  735. wx.showLoading({
  736. title: '加载中',
  737. })
  738. wx.downloadFile({
  739. url: url, //要预览的PDF的地址
  740. filePath: wx.env.USER_DATA_PATH + `/${name}.${rep}`,
  741. success: function (res) {
  742. console.log(res);
  743. if (res.statusCode === 200) { //成功
  744. var Path = res.filePath //返回的文件临时地址,用于后面打开本地预览所用
  745. console.log(Path)
  746. wx.openDocument({
  747. filePath: Path, //要打开的文件路径
  748. showMenu: true,
  749. success: function (res) {
  750. wx.hideLoading()
  751. console.log(res, '打开PDF成功');
  752. },
  753. fail: function (res) {
  754. console.log(res)
  755. wx.hideLoading()
  756. }
  757. })
  758. }
  759. },
  760. fail: function (res) {
  761. wx.hideLoading()
  762. console.log(res); //失败
  763. },
  764. })
  765. },
  766. //解析文件类型
  767. getFileType(url) {
  768. let pdfReg = /^.+(\.pdf)$/
  769. let txtReg = /^.+(\.txt)$/
  770. let wordReg = /^.+(\.doc|\.docx)$/
  771. let excelReg = /^.+(\.xls|\.xlsx)$/
  772. let jpgPng = /^.+(\.png)$/
  773. let jpgJpg = /^.+(\.jpg)$/
  774. let jpgJpeg = /^.+(\.jpeg)$/
  775. if (pdfReg.test(url)) {
  776. return 'pdf'
  777. }
  778. if (txtReg.test(url)) {
  779. return 'txt'
  780. }
  781. if (wordReg.test(url)) {
  782. return 'docx'
  783. }
  784. if (excelReg.test(url)) {
  785. return 'xls'
  786. }
  787. if (jpgPng.test(url)) {
  788. return 'png'
  789. }
  790. if (jpgJpg.test(url)) {
  791. return 'jpg'
  792. }
  793. if (jpgJpeg.test(url)) {
  794. return 'jpeg'
  795. }
  796. },
  797. onShow: function () {
  798. let userLogin = wx.getStorageSync('userLogin');
  799. if (userLogin != '') {
  800. wx.navigateBack();
  801. };
  802. },
  803. onReady: function () {
  804. },
  805. })