2016-04-29 03:02:51 +08:00
|
|
|
import React from 'react';
|
2016-07-08 20:22:49 +08:00
|
|
|
import { Router, Route, Redirect, IndexRoute, useRouterHistory } from 'react-router';
|
2016-05-10 03:19:52 +08:00
|
|
|
import { createHistory } from 'history';
|
2016-04-29 03:02:51 +08:00
|
|
|
|
2017-03-11 02:33:46 +08:00
|
|
|
import { joinRouteHandler, authenticatedRouteHandler } from './auth';
|
2017-03-10 03:50:21 +08:00
|
|
|
import Base from './base';
|
2016-06-02 00:45:01 +08:00
|
|
|
|
2017-03-11 02:33:46 +08:00
|
|
|
import LoadingScreen from '/imports/ui/components/loading-screen/component';
|
2016-07-07 22:01:40 +08:00
|
|
|
import ChatContainer from '/imports/ui/components/chat/container';
|
|
|
|
import UserListContainer from '/imports/ui/components/user-list/container';
|
2016-04-29 03:02:51 +08:00
|
|
|
|
2016-05-10 03:19:52 +08:00
|
|
|
const browserHistory = useRouterHistory(createHistory)({
|
2016-08-17 23:48:03 +08:00
|
|
|
basename: Meteor.settings.public.app.basename,
|
2016-05-10 03:19:52 +08:00
|
|
|
});
|
2016-05-07 03:12:28 +08:00
|
|
|
|
2016-04-29 03:02:51 +08:00
|
|
|
export const renderRoutes = () => (
|
|
|
|
<Router history={browserHistory}>
|
2017-03-11 02:33:46 +08:00
|
|
|
<Route path="/join/:meetingID/:userID/:authToken"
|
|
|
|
component={LoadingScreen} onEnter={joinRouteHandler} />
|
|
|
|
<Route path="/" component={Base} onEnter={authenticatedRouteHandler} >
|
2016-07-06 02:59:18 +08:00
|
|
|
<IndexRoute components={{}} />
|
2017-03-10 03:50:21 +08:00
|
|
|
<Route name="users" path="users" components={{ userList: UserListContainer }} />
|
|
|
|
<Route name="chat" path="users/chat/:chatID" components={{
|
|
|
|
userList: UserListContainer,
|
|
|
|
chat: ChatContainer,
|
2016-07-06 02:59:18 +08:00
|
|
|
}} />
|
|
|
|
<Redirect from="users/chat" to="/users/chat/public" />
|
2016-04-29 03:02:51 +08:00
|
|
|
</Route>
|
2016-07-06 02:59:18 +08:00
|
|
|
<Redirect from="*" to="/" />
|
2016-04-29 03:02:51 +08:00
|
|
|
</Router>
|
|
|
|
);
|