bigbluebutton-Github/bigbluebutton-html5/imports/startup/client/routes.js

32 lines
1.2 KiB
JavaScript
Raw Normal View History

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';
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)({
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>
);