aboutsummaryrefslogtreecommitdiff
path: root/src/boot
diff options
context:
space:
mode:
Diffstat (limited to 'src/boot')
-rw-r--r--src/boot/after_store.js44
-rw-r--r--src/boot/routes.js66
2 files changed, 69 insertions, 41 deletions
diff --git a/src/boot/after_store.js b/src/boot/after_store.js
index 24a8d3ac..8cd13df7 100644
--- a/src/boot/after_store.js
+++ b/src/boot/after_store.js
@@ -1,21 +1,8 @@
import Vue from 'vue'
import VueRouter from 'vue-router'
+import routes from './routes'
import App from '../App.vue'
-import PublicTimeline from '../components/public_timeline/public_timeline.vue'
-import PublicAndExternalTimeline from '../components/public_and_external_timeline/public_and_external_timeline.vue'
-import FriendsTimeline from '../components/friends_timeline/friends_timeline.vue'
-import TagTimeline from '../components/tag_timeline/tag_timeline.vue'
-import ConversationPage from '../components/conversation-page/conversation-page.vue'
-import Mentions from '../components/mentions/mentions.vue'
-import DMs from '../components/dm_timeline/dm_timeline.vue'
-import UserProfile from '../components/user_profile/user_profile.vue'
-import Settings from '../components/settings/settings.vue'
-import Registration from '../components/registration/registration.vue'
-import UserSettings from '../components/user_settings/user_settings.vue'
-import FollowRequests from '../components/follow_requests/follow_requests.vue'
-import OAuthCallback from '../components/oauth_callback/oauth_callback.vue'
-import UserSearch from '../components/user_search/user_search.vue'
const afterStoreSetup = ({ store, i18n }) => {
window.fetch('/api/statusnet/config.json')
@@ -102,35 +89,10 @@ const afterStoreSetup = ({ store, i18n }) => {
store.dispatch('disableChat')
}
- const routes = [
- { name: 'root',
- path: '/',
- redirect: to => {
- return (store.state.users.currentUser
- ? store.state.instance.redirectRootLogin
- : store.state.instance.redirectRootNoLogin) || '/main/all'
- }},
- { path: '/main/all', component: PublicAndExternalTimeline },
- { path: '/main/public', component: PublicTimeline },
- { path: '/main/friends', component: FriendsTimeline },
- { path: '/tag/:tag', component: TagTimeline },
- { name: 'conversation', path: '/notice/:id', component: ConversationPage, meta: { dontScroll: true } },
- { name: 'user-profile', path: '/users/:id', component: UserProfile },
- { name: 'mentions', path: '/:username/mentions', component: Mentions },
- { name: 'dms', path: '/:username/dms', component: DMs },
- { name: 'settings', path: '/settings', component: Settings },
- { name: 'registration', path: '/registration', component: Registration },
- { name: 'registration', path: '/registration/:token', component: Registration },
- { name: 'friend-requests', path: '/friend-requests', component: FollowRequests },
- { name: 'user-settings', path: '/user-settings', component: UserSettings },
- { name: 'oauth-callback', path: '/oauth-callback', component: OAuthCallback, props: (route) => ({ code: route.query.code }) },
- { name: 'user-search', path: '/user-search', component: UserSearch, props: (route) => ({ query: route.query.query }) }
- ]
-
const router = new VueRouter({
mode: 'history',
- routes,
- scrollBehavior: (to, from, savedPosition) => {
+ routes: routes(store),
+ scrollBehavior: (to, _from, savedPosition) => {
if (to.matched.some(m => m.meta.dontScroll)) {
return false
}
diff --git a/src/boot/routes.js b/src/boot/routes.js
new file mode 100644
index 00000000..839dda73
--- /dev/null
+++ b/src/boot/routes.js
@@ -0,0 +1,66 @@
+import PublicTimeline from 'components/public_timeline/public_timeline.vue'
+import PublicAndExternalTimeline from 'components/public_and_external_timeline/public_and_external_timeline.vue'
+import FriendsTimeline from 'components/friends_timeline/friends_timeline.vue'
+import TagTimeline from 'components/tag_timeline/tag_timeline.vue'
+import ConversationPage from 'components/conversation-page/conversation-page.vue'
+import Mentions from 'components/mentions/mentions.vue'
+import DMs from 'components/dm_timeline/dm_timeline.vue'
+import UserProfile from 'components/user_profile/user_profile.vue'
+import Settings from 'components/settings/settings.vue'
+import Registration from 'components/registration/registration.vue'
+import UserSettings from 'components/user_settings/user_settings.vue'
+import FollowRequests from 'components/follow_requests/follow_requests.vue'
+import OAuthCallback from 'components/oauth_callback/oauth_callback.vue'
+import UserSearch from 'components/user_search/user_search.vue'
+
+export default (store) => {
+ return [
+ { name: 'root',
+ path: '/',
+ redirect: _to => {
+ return (store.state.users.currentUser
+ ? store.state.instance.redirectRootLogin
+ : store.state.instance.redirectRootNoLogin) || '/~/main/all'
+ }
+ },
+ { name: 'public-external-timeline', path: '/~/main/all', component: PublicAndExternalTimeline },
+ { name: 'public-timeline', path: '/~/main/public', component: PublicTimeline },
+ { name: 'friends', path: '/~/main/friends', component: FriendsTimeline },
+ // Beginning of temporary redirects
+ { path: '/main/:route',
+ redirect: to => {
+ const { params } = to
+
+ return { path: `/~/main/${params.route}` }
+ }
+ },
+ { path: '/tag/:tag',
+ redirect: to => {
+ const { params } = to
+
+ return { path: `/~/tag/${params.tag}` }
+ }
+ },
+ { path: '/notice/:id',
+ redirect: to => {
+ const { params } = to
+
+ return { path: `/~/notice/${params.id}` }
+ }
+ },
+ // End of temporary redirects
+ { name: 'tag-timeline', path: '/~/tag/:tag', component: TagTimeline },
+ { name: 'conversation', path: '/~/notice/:id', component: ConversationPage, meta: { dontScroll: true } },
+ { name: 'user-profile', path: '/:name', component: UserProfile },
+ { name: 'external-user-profile', path: '/~/users/:id', component: UserProfile },
+ { name: 'mentions', path: '/:username/mentions', component: Mentions },
+ { name: 'dms', path: '/:username/dms', component: DMs },
+ { name: 'settings', path: '/~/settings', component: Settings },
+ { name: 'registration', path: '/~/registration', component: Registration },
+ { name: 'registration', path: '/~/registration/:token', component: Registration },
+ { name: 'friend-requests', path: '/~/friend-requests', component: FollowRequests },
+ { name: 'user-settings', path: '/~/user-settings', component: UserSettings },
+ { name: 'oauth-callback', path: '/~/oauth-callback', component: OAuthCallback, props: (route) => ({ code: route.query.code }) },
+ { name: 'user-search', path: '/~/user-search', component: UserSearch, props: (route) => ({ query: route.query.query }) }
+ ]
+}