logo

pleroma-fe

My custom branche(s) on git.pleroma.social/pleroma/pleroma-fe git clone https://anongit.hacktivis.me/git/pleroma-fe.git/

routes.js (6713B)


  1. import PublicTimeline from 'components/public_timeline/public_timeline.vue'
  2. import PublicAndExternalTimeline from 'components/public_and_external_timeline/public_and_external_timeline.vue'
  3. import FriendsTimeline from 'components/friends_timeline/friends_timeline.vue'
  4. import TagTimeline from 'components/tag_timeline/tag_timeline.vue'
  5. import BookmarkTimeline from 'components/bookmark_timeline/bookmark_timeline.vue'
  6. import ConversationPage from 'components/conversation-page/conversation-page.vue'
  7. import Interactions from 'components/interactions/interactions.vue'
  8. import DMs from 'components/dm_timeline/dm_timeline.vue'
  9. import ChatList from 'components/chat_list/chat_list.vue'
  10. import Chat from 'components/chat/chat.vue'
  11. import UserProfile from 'components/user_profile/user_profile.vue'
  12. import Search from 'components/search/search.vue'
  13. import Registration from 'components/registration/registration.vue'
  14. import PasswordReset from 'components/password_reset/password_reset.vue'
  15. import FollowRequests from 'components/follow_requests/follow_requests.vue'
  16. import OAuthCallback from 'components/oauth_callback/oauth_callback.vue'
  17. import Notifications from 'components/notifications/notifications.vue'
  18. import AuthForm from 'components/auth_form/auth_form.js'
  19. import ShoutPanel from 'components/shout_panel/shout_panel.vue'
  20. import WhoToFollow from 'components/who_to_follow/who_to_follow.vue'
  21. import About from 'components/about/about.vue'
  22. import RemoteUserResolver from 'components/remote_user_resolver/remote_user_resolver.vue'
  23. import Lists from 'components/lists/lists.vue'
  24. import ListsTimeline from 'components/lists_timeline/lists_timeline.vue'
  25. import ListsEdit from 'components/lists_edit/lists_edit.vue'
  26. import NavPanel from 'src/components/nav_panel/nav_panel.vue'
  27. import AnnouncementsPage from 'components/announcements_page/announcements_page.vue'
  28. import QuotesTimeline from '../components/quotes_timeline/quotes_timeline.vue'
  29. import Drafts from 'components/drafts/drafts.vue'
  30. import BookmarkFolders from '../components/bookmark_folders/bookmark_folders.vue'
  31. import BookmarkFolderEdit from '../components/bookmark_folder_edit/bookmark_folder_edit.vue'
  32. export default (store) => {
  33. const validateAuthenticatedRoute = (to, from, next) => {
  34. if (store.state.users.currentUser) {
  35. next()
  36. } else {
  37. next(store.state.instance.redirectRootNoLogin || '/main/all')
  38. }
  39. }
  40. let routes = [
  41. {
  42. name: 'root',
  43. path: '/',
  44. redirect: _to => {
  45. return (store.state.users.currentUser
  46. ? store.state.instance.redirectRootLogin
  47. : store.state.instance.redirectRootNoLogin) || '/main/all'
  48. }
  49. },
  50. { name: 'public-external-timeline', path: '/main/all', component: PublicAndExternalTimeline },
  51. { name: 'public-timeline', path: '/main/public', component: PublicTimeline },
  52. { name: 'friends', path: '/main/friends', component: FriendsTimeline, beforeEnter: validateAuthenticatedRoute },
  53. { name: 'tag-timeline', path: '/tag/:tag', component: TagTimeline },
  54. { name: 'bookmarks', path: '/bookmarks', component: BookmarkTimeline },
  55. { name: 'conversation', path: '/notice/:id', component: ConversationPage, meta: { dontScroll: true } },
  56. { name: 'quotes', path: '/notice/:id/quotes', component: QuotesTimeline },
  57. {
  58. name: 'remote-user-profile-acct',
  59. path: '/remote-users/:_(@)?:username([^/@]+)@:hostname([^/@]+)',
  60. component: RemoteUserResolver,
  61. beforeEnter: validateAuthenticatedRoute
  62. },
  63. {
  64. name: 'remote-user-profile',
  65. path: '/remote-users/:hostname/:username',
  66. component: RemoteUserResolver,
  67. beforeEnter: validateAuthenticatedRoute
  68. },
  69. { name: 'external-user-profile', path: '/users/$:id', component: UserProfile },
  70. { name: 'interactions', path: '/users/:username/interactions', component: Interactions, beforeEnter: validateAuthenticatedRoute },
  71. { name: 'dms', path: '/users/:username/dms', component: DMs, beforeEnter: validateAuthenticatedRoute },
  72. { name: 'registration', path: '/registration', component: Registration },
  73. { name: 'password-reset', path: '/password-reset', component: PasswordReset, props: true },
  74. { name: 'registration-token', path: '/registration/:token', component: Registration },
  75. { name: 'friend-requests', path: '/friend-requests', component: FollowRequests, beforeEnter: validateAuthenticatedRoute },
  76. { name: 'notifications', path: '/:username/notifications', component: Notifications, props: () => ({ disableTeleport: true }), beforeEnter: validateAuthenticatedRoute },
  77. { name: 'login', path: '/login', component: AuthForm },
  78. { name: 'shout-panel', path: '/shout-panel', component: ShoutPanel, props: () => ({ floating: false }) },
  79. { name: 'oauth-callback', path: '/oauth-callback', component: OAuthCallback, props: (route) => ({ code: route.query.code }) },
  80. { name: 'search', path: '/search', component: Search, props: (route) => ({ query: route.query.query }) },
  81. { name: 'who-to-follow', path: '/who-to-follow', component: WhoToFollow, beforeEnter: validateAuthenticatedRoute },
  82. { name: 'about', path: '/about', component: About },
  83. { name: 'announcements', path: '/announcements', component: AnnouncementsPage },
  84. { name: 'drafts', path: '/drafts', component: Drafts },
  85. { name: 'user-profile', path: '/users/:name', component: UserProfile },
  86. { name: 'legacy-user-profile', path: '/:name', component: UserProfile },
  87. { name: 'lists', path: '/lists', component: Lists },
  88. { name: 'lists-timeline', path: '/lists/:id', component: ListsTimeline },
  89. { name: 'lists-edit', path: '/lists/:id/edit', component: ListsEdit },
  90. { name: 'lists-new', path: '/lists/new', component: ListsEdit },
  91. { name: 'edit-navigation', path: '/nav-edit', component: NavPanel, props: () => ({ forceExpand: true, forceEditMode: true }), beforeEnter: validateAuthenticatedRoute },
  92. { name: 'bookmark-folders', path: '/bookmark_folders', component: BookmarkFolders },
  93. { name: 'bookmark-folder-new', path: '/bookmarks/new-folder', component: BookmarkFolderEdit },
  94. { name: 'bookmark-folder', path: '/bookmarks/:id', component: BookmarkTimeline },
  95. { name: 'bookmark-folder-edit', path: '/bookmarks/:id/edit', component: BookmarkFolderEdit }
  96. ]
  97. if (store.state.instance.pleromaChatMessagesAvailable) {
  98. routes = routes.concat([
  99. { name: 'chat', path: '/users/:username/chats/:recipient_id', component: Chat, meta: { dontScroll: false }, beforeEnter: validateAuthenticatedRoute },
  100. { name: 'chats', path: '/users/:username/chats', component: ChatList, meta: { dontScroll: false }, beforeEnter: validateAuthenticatedRoute }
  101. ])
  102. }
  103. return routes
  104. }