index.ts 5.8 KB

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