index.ts 6.1 KB

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