index.ts 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. import { pages, subPackages } from '@/pages.json'
  2. import { isMpWeixin } from './platform'
  3. export function getLastPage() {
  4. // getCurrentPages() 至少有1个元素,所以不再额外判断
  5. // const lastPage = getCurrentPages().at(-1)
  6. // 上面那个在低版本安卓中打包会报错,所以改用下面这个【虽然我加了 src/interceptions/prototype.ts,但依然报错】
  7. const pages = getCurrentPages()
  8. return pages[pages.length - 1]
  9. }
  10. /**
  11. * 获取当前页面路由的 path 路径和 redirectPath 路径
  12. * path 如 '/pages/login/login'
  13. * redirectPath 如 '/pages/demo/base/route-interceptor'
  14. */
  15. export function currRoute() {
  16. const lastPage = getLastPage()
  17. if (!lastPage) {
  18. return {
  19. path: '',
  20. query: {},
  21. }
  22. }
  23. const currRoute = (lastPage as any).$page
  24. // console.log('lastPage.$page:', currRoute)
  25. // console.log('lastPage.$page.fullpath:', currRoute.fullPath)
  26. // console.log('lastPage.$page.options:', currRoute.options)
  27. // console.log('lastPage.options:', (lastPage as any).options)
  28. // 经过多端测试,只有 fullPath 靠谱,其他都不靠谱
  29. const { fullPath } = currRoute as { fullPath: string }
  30. // console.log(fullPath)
  31. // eg: /pages/login/login?redirect=%2Fpages%2Fdemo%2Fbase%2Froute-interceptor (小程序)
  32. // eg: /pages/login/login?redirect=%2Fpages%2Froute-interceptor%2Findex%3Fname%3Dfeige%26age%3D30(h5)
  33. return parseUrlToObj(fullPath)
  34. }
  35. export function ensureDecodeURIComponent(url: string) {
  36. if (url.startsWith('%')) {
  37. return ensureDecodeURIComponent(decodeURIComponent(url))
  38. }
  39. return url
  40. }
  41. /**
  42. * 解析 url 得到 path 和 query
  43. * 比如输入url: /pages/login/login?redirect=%2Fpages%2Fdemo%2Fbase%2Froute-interceptor
  44. * 输出: {path: /pages/login/login, query: {redirect: /pages/demo/base/route-interceptor}}
  45. */
  46. export function parseUrlToObj(url: string) {
  47. const [path, queryStr] = url.split('?')
  48. // console.log(path, queryStr)
  49. if (!queryStr) {
  50. return {
  51. path,
  52. query: {},
  53. }
  54. }
  55. const query: Record<string, string> = {}
  56. queryStr.split('&').forEach((item) => {
  57. const [key, value] = item.split('=')
  58. // console.log(key, value)
  59. query[key] = ensureDecodeURIComponent(value) // 这里需要统一 decodeURIComponent 一下,可以兼容h5和微信y
  60. })
  61. return { path, query }
  62. }
  63. /**
  64. * 得到所有的需要登录的 pages,包括主包和分包的
  65. * 这里设计得通用一点,可以传递 key 作为判断依据,默认是 excludeLoginPath, 与 route-block 配对使用
  66. * 如果没有传 key,则表示所有的 pages,如果传递了 key, 则表示通过 key 过滤
  67. */
  68. export function getAllPages(key = 'excludeLoginPath') {
  69. // 这里处理主包
  70. const mainPages = pages
  71. .filter(page => !key || page[key])
  72. .map(page => ({
  73. ...page,
  74. path: `/${page.path}`,
  75. }))
  76. // 这里处理分包
  77. const subPages: any[] = []
  78. subPackages.forEach((subPageObj) => {
  79. // console.log(subPageObj)
  80. const { root } = subPageObj
  81. subPageObj.pages
  82. .filter(page => !key || page[key])
  83. .forEach((page: { path: string } & Record<string, any>) => {
  84. subPages.push({
  85. ...page,
  86. path: `/${root}/${page.path}`,
  87. })
  88. })
  89. })
  90. const result = [...mainPages, ...subPages]
  91. // console.log(`getAllPages by ${key} result: `, result)
  92. return result
  93. }
  94. export function getCurrentPageI18nKey() {
  95. const routeObj = currRoute()
  96. const currPage = pages.find(page => `/${page.path}` === routeObj.path)
  97. if (!currPage) {
  98. console.warn('路由不正确')
  99. return ''
  100. }
  101. console.log(currPage)
  102. console.log(currPage.style.navigationBarTitleText)
  103. return currPage.style.navigationBarTitleText
  104. }
  105. /**
  106. * 根据微信小程序当前环境,判断应该获取的 baseUrl
  107. */
  108. export function getEnvBaseUrl() {
  109. // 请求基准地址
  110. let baseUrl = import.meta.env.VITE_SERVER_BASEURL
  111. // # 有些同学可能需要在微信小程序里面根据 develop、trial、release 分别设置上传地址,参考代码如下。
  112. const VITE_SERVER_BASEURL__WEIXIN_DEVELOP = 'https://ukw0y1.laf.run'
  113. const VITE_SERVER_BASEURL__WEIXIN_TRIAL = 'https://ukw0y1.laf.run'
  114. const VITE_SERVER_BASEURL__WEIXIN_RELEASE = 'https://ukw0y1.laf.run'
  115. // 微信小程序端环境区分
  116. if (isMpWeixin) {
  117. const {
  118. miniProgram: { envVersion },
  119. } = uni.getAccountInfoSync()
  120. switch (envVersion) {
  121. case 'develop':
  122. baseUrl = VITE_SERVER_BASEURL__WEIXIN_DEVELOP || baseUrl
  123. break
  124. case 'trial':
  125. baseUrl = VITE_SERVER_BASEURL__WEIXIN_TRIAL || baseUrl
  126. break
  127. case 'release':
  128. baseUrl = VITE_SERVER_BASEURL__WEIXIN_RELEASE || baseUrl
  129. break
  130. }
  131. }
  132. return baseUrl
  133. }
  134. /**
  135. * 根据微信小程序当前环境,判断应该获取的 UPLOAD_BASEURL
  136. */
  137. export function getEnvBaseUploadUrl() {
  138. // 请求基准地址
  139. let baseUploadUrl = import.meta.env.VITE_UPLOAD_BASEURL
  140. const VITE_UPLOAD_BASEURL__WEIXIN_DEVELOP = 'https://ukw0y1.laf.run/upload'
  141. const VITE_UPLOAD_BASEURL__WEIXIN_TRIAL = 'https://ukw0y1.laf.run/upload'
  142. const VITE_UPLOAD_BASEURL__WEIXIN_RELEASE = 'https://ukw0y1.laf.run/upload'
  143. // 微信小程序端环境区分
  144. if (isMpWeixin) {
  145. const {
  146. miniProgram: { envVersion },
  147. } = uni.getAccountInfoSync()
  148. switch (envVersion) {
  149. case 'develop':
  150. baseUploadUrl = VITE_UPLOAD_BASEURL__WEIXIN_DEVELOP || baseUploadUrl
  151. break
  152. case 'trial':
  153. baseUploadUrl = VITE_UPLOAD_BASEURL__WEIXIN_TRIAL || baseUploadUrl
  154. break
  155. case 'release':
  156. baseUploadUrl = VITE_UPLOAD_BASEURL__WEIXIN_RELEASE || baseUploadUrl
  157. break
  158. }
  159. }
  160. return baseUploadUrl
  161. }
  162. /**
  163. * 是否是双token模式
  164. */
  165. export const isDoubleTokenMode = import.meta.env.VITE_AUTH_MODE === 'double'
  166. /**
  167. * 首页路径,通过 page.json 里面的 type 为 home 的页面获取,如果没有,则默认是第一个页面
  168. * 通常为 /pages/index/index
  169. */
  170. export const HOME_PAGE = `/${pages.find(page => page.type === 'home')?.path || pages[0].path}`