usePage.ts 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. import type { RouteLocationRaw, Router } from 'vue-router';
  2. import { PageEnum } from '/@/enums/pageEnum';
  3. import { isString } from '/@/utils/is';
  4. import { unref } from 'vue';
  5. import { useRouter } from 'vue-router';
  6. import { REDIRECT_NAME } from '/@/router/constant';
  7. import { useGlobSetting } from '/@/hooks/setting';
  8. export type RouteLocationRawEx = Omit<RouteLocationRaw, 'path'> & { path: PageEnum };
  9. function handleError(e: Error) {
  10. console.error(e);
  11. }
  12. // page switch
  13. export function useGo(_router?: Router) {
  14. const glob = useGlobSetting();
  15. let router;
  16. if (!_router) {
  17. router = useRouter();
  18. }
  19. const { push, replace } = _router || router;
  20. function go(opt: PageEnum | RouteLocationRawEx | string = glob.homePath || PageEnum.BASE_HOME, isReplace = false) {
  21. if (!opt) {
  22. return;
  23. }
  24. if (isString(opt)) {
  25. isReplace ? replace(opt).catch(handleError) : push(opt).catch(handleError);
  26. } else {
  27. const o = opt as RouteLocationRaw;
  28. isReplace ? replace(o).catch(handleError) : push(o).catch(handleError);
  29. }
  30. }
  31. return go;
  32. }
  33. /**
  34. * @description: redo current page
  35. */
  36. export const useRedo = (_router?: Router) => {
  37. const { push, currentRoute } = _router || useRouter();
  38. const { query, params = {}, name, fullPath } = unref(currentRoute.value);
  39. function redo(): Promise<boolean> {
  40. return new Promise((resolve) => {
  41. if (name === REDIRECT_NAME) {
  42. resolve(false);
  43. return;
  44. }
  45. if (name && Object.keys(params).length > 0) {
  46. //update-begin-author:taoyan date:2022-10-19 for: VUEN-2356 【vue3】online表单、表单设计器 功能测试 右键刷新时 404
  47. if(isDynamicRoute(params, name)){
  48. params['_redirect_type'] = 'path';
  49. params['path'] = fullPath;
  50. }else{
  51. params['_redirect_type'] = 'name';
  52. params['path'] = String(name);
  53. }
  54. //update-end-author:taoyan date:2022-10-19 for: VUEN-2356 【vue3】online表单、表单设计器 功能测试 右键刷新时 404
  55. } else {
  56. params['_redirect_type'] = 'path';
  57. params['path'] = fullPath;
  58. }
  59. push({ name: REDIRECT_NAME, params, query }).then(() => resolve(true));
  60. });
  61. }
  62. return redo;
  63. };
  64. /**
  65. * 判断是不是动态路由的跳转
  66. * @param params
  67. * @param name
  68. */
  69. function isDynamicRoute(params, name){
  70. let arr = Object.keys(params);
  71. let flag = false;
  72. for(let i=0;i<arr.length;i++){
  73. let key = '@'+arr[i];
  74. if((name as string).indexOf(key)>0){
  75. flag = true;
  76. break;
  77. }
  78. }
  79. return flag;
  80. }