wxRequest.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. import { getToken } from '@/utils/auth'
  2. import { getVersion } from '@/api/version'
  3. import config from '@/config'
  4. let base_url = null;
  5. const baseConfig = config
  6. //上传文件还是选择相册图片
  7. const getWxFile = (type,fileNum) => {
  8. return new Promise((resolve, reject) => {
  9. //文件上传
  10. if (type === 'file') {
  11. wx.chooseMessageFile({
  12. count: fileNum || 1,
  13. type: 'file',
  14. success: (res) => {
  15. resolve(res)
  16. },
  17. fail(error) {
  18. console.log(' 上传失败', error);
  19. uni.showToast({
  20. title: '上传失败',
  21. icon: 'none'
  22. })
  23. reject(error)
  24. }
  25. });
  26. }
  27. //相册或者摄像头
  28. if (type === 'img') {
  29. wx.chooseImage({
  30. count: 1, // 选择图片数量
  31. sizeType: ['original', 'compressed'], // 图片类型
  32. sourceType: ['album', 'camera'], // 来源(相册或摄像头)
  33. success: function (res) {
  34. resolve(res)
  35. },
  36. fail(error) {
  37. console.log(' 上传失败', error);
  38. uni.showToast({
  39. title: '上传失败',
  40. icon: 'none'
  41. })
  42. reject(error)
  43. }
  44. });
  45. }
  46. })
  47. }
  48. const getUploadPromise = (file) => {
  49. return new Promise(async(resolve, reject) => {
  50. const path = file.path
  51. if (!base_url) {
  52. const ver_res = await getVersion(baseConfig.appInfo.version)
  53. base_url = ver_res.data.serviceUrl;
  54. console.log("TCL: ver_res", ver_res)
  55. }
  56. wx.uploadFile({
  57. url: base_url + '/common/upload', // 服务器接口地址
  58. filePath: path, // 本地文件路径(通过 wx.chooseImage 获取)
  59. name: 'file', // 文件对应的 key(服务器接收字段名)
  60. formData: { // 额外表单数据
  61. file: file,
  62. },
  63. header: {
  64. 'Authorization': 'Bearer ' + getToken(), // 自定义请求头
  65. },
  66. success(res) {
  67. const data = JSON.parse(res.data);
  68. resolve(data);
  69. },
  70. fail(error) {
  71. console.log(' 上传失败', error);
  72. uni.showToast({
  73. title: '上传失败',
  74. icon: 'none'
  75. })
  76. reject(error)
  77. }
  78. });
  79. })
  80. }
  81. const uploadFile = async (files) => {
  82. const filesPromise = files.map((item) => {
  83. return getUploadPromise(item)
  84. })
  85. try {
  86. const results = await Promise.all(filesPromise)
  87. console.log('results',results);
  88. return results;
  89. } catch (error) {
  90. console.log('上传失败-uploadFile', error);
  91. throw error;
  92. }
  93. }
  94. /**
  95. *
  96. * type: 文件上传方式
  97. * file:选择文件
  98. * img: 相册或者摄像头
  99. */
  100. export const wxUploadFile = async (type,fileNum) => {
  101. try {
  102. console.log('11');
  103. //选择文件
  104. const files = await getWxFile(type,fileNum);
  105. console.log('选择文件', files,files.tempFiles);
  106. uni.showLoading({
  107. title: '文件上传中...',
  108. })
  109. //上传服务器
  110. const u_files = await uploadFile(files.tempFiles);
  111. console.log('上传服务器', u_files);
  112. return u_files;
  113. } catch (error) {
  114. console.log('上传失败-wxUploadFile', error);
  115. throw error;
  116. } finally {
  117. uni.hideLoading()
  118. }
  119. }
  120. /**
  121. * 拨打电话
  122. */
  123. export const wxMakePhoneCall = (phoneNumber) => {
  124. uni.makePhoneCall({
  125. phoneNumber: phoneNumber
  126. });
  127. }