|
|
|
@ -1,39 +1,44 @@
|
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
|
import configureStore from '../store/configureStore';
|
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
|
import configureStore from '../store/configureStore';
|
|
|
|
|
import {
|
|
|
|
|
refreshTimelineSuccess,
|
|
|
|
|
updateTimeline,
|
|
|
|
|
deleteFromTimelines,
|
|
|
|
|
refreshTimeline
|
|
|
|
|
} from '../actions/timelines';
|
|
|
|
|
} from '../actions/timelines';
|
|
|
|
|
import { setAccessToken } from '../actions/meta';
|
|
|
|
|
import { setAccountSelf } from '../actions/accounts';
|
|
|
|
|
import PureRenderMixin from 'react-addons-pure-render-mixin';
|
|
|
|
|
import PureRenderMixin from 'react-addons-pure-render-mixin';
|
|
|
|
|
import createBrowserHistory from 'history/lib/createBrowserHistory';
|
|
|
|
|
import {
|
|
|
|
|
applyRouterMiddleware,
|
|
|
|
|
useRouterHistory,
|
|
|
|
|
Router,
|
|
|
|
|
Route,
|
|
|
|
|
hashHistory,
|
|
|
|
|
IndexRoute
|
|
|
|
|
} from 'react-router';
|
|
|
|
|
import { useScroll } from 'react-router-scroll';
|
|
|
|
|
import UI from '../features/ui';
|
|
|
|
|
import Account from '../features/account';
|
|
|
|
|
import Status from '../features/status';
|
|
|
|
|
import GettingStarted from '../features/getting_started';
|
|
|
|
|
import PublicTimeline from '../features/public_timeline';
|
|
|
|
|
import AccountTimeline from '../features/account_timeline';
|
|
|
|
|
import HomeTimeline from '../features/home_timeline';
|
|
|
|
|
import MentionsTimeline from '../features/mentions_timeline';
|
|
|
|
|
import Compose from '../features/compose';
|
|
|
|
|
import Followers from '../features/followers';
|
|
|
|
|
import Following from '../features/following';
|
|
|
|
|
import Reblogs from '../features/reblogs';
|
|
|
|
|
import Favourites from '../features/favourites';
|
|
|
|
|
import HashtagTimeline from '../features/hashtag_timeline';
|
|
|
|
|
} from 'react-router';
|
|
|
|
|
import { useScroll } from 'react-router-scroll';
|
|
|
|
|
import UI from '../features/ui';
|
|
|
|
|
import Account from '../features/account';
|
|
|
|
|
import Status from '../features/status';
|
|
|
|
|
import GettingStarted from '../features/getting_started';
|
|
|
|
|
import PublicTimeline from '../features/public_timeline';
|
|
|
|
|
import AccountTimeline from '../features/account_timeline';
|
|
|
|
|
import HomeTimeline from '../features/home_timeline';
|
|
|
|
|
import MentionsTimeline from '../features/mentions_timeline';
|
|
|
|
|
import Compose from '../features/compose';
|
|
|
|
|
import Followers from '../features/followers';
|
|
|
|
|
import Following from '../features/following';
|
|
|
|
|
import Reblogs from '../features/reblogs';
|
|
|
|
|
import Favourites from '../features/favourites';
|
|
|
|
|
import HashtagTimeline from '../features/hashtag_timeline';
|
|
|
|
|
|
|
|
|
|
const store = configureStore();
|
|
|
|
|
|
|
|
|
|
const browserHistory = useRouterHistory(createBrowserHistory)({
|
|
|
|
|
basename: '/web'
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const Mastodon = React.createClass({
|
|
|
|
|
|
|
|
|
|
propTypes: {
|
|
|
|
@ -78,24 +83,24 @@ const Mastodon = React.createClass({
|
|
|
|
|
render () {
|
|
|
|
|
return (
|
|
|
|
|
<Provider store={store}>
|
|
|
|
|
<Router history={hashHistory} render={applyRouterMiddleware(useScroll())}>
|
|
|
|
|
<Router history={browserHistory} render={applyRouterMiddleware(useScroll())}>
|
|
|
|
|
<Route path='/' component={UI}>
|
|
|
|
|
<IndexRoute component={GettingStarted} />
|
|
|
|
|
<Route path='/statuses/new' component={Compose} />
|
|
|
|
|
|
|
|
|
|
<Route path='/statuses/home' component={HomeTimeline} />
|
|
|
|
|
<Route path='/statuses/mentions' component={MentionsTimeline} />
|
|
|
|
|
<Route path='/statuses/all' component={PublicTimeline} />
|
|
|
|
|
<Route path='/statuses/tag/:id' component={HashtagTimeline} />
|
|
|
|
|
<Route path='timelines/home' component={HomeTimeline} />
|
|
|
|
|
<Route path='timelines/mentions' component={MentionsTimeline} />
|
|
|
|
|
<Route path='timelines/public' component={PublicTimeline} />
|
|
|
|
|
<Route path='timelines/tag/:id' component={HashtagTimeline} />
|
|
|
|
|
|
|
|
|
|
<Route path='/statuses/:statusId' component={Status} />
|
|
|
|
|
<Route path='/statuses/:statusId/reblogs' component={Reblogs} />
|
|
|
|
|
<Route path='/statuses/:statusId/favourites' component={Favourites} />
|
|
|
|
|
<Route path='statuses/new' component={Compose} />
|
|
|
|
|
<Route path='statuses/:statusId' component={Status} />
|
|
|
|
|
<Route path='statuses/:statusId/reblogs' component={Reblogs} />
|
|
|
|
|
<Route path='statuses/:statusId/favourites' component={Favourites} />
|
|
|
|
|
|
|
|
|
|
<Route path='/accounts/:accountId' component={Account}>
|
|
|
|
|
<Route path='accounts/:accountId' component={Account}>
|
|
|
|
|
<IndexRoute component={AccountTimeline} />
|
|
|
|
|
<Route path='/accounts/:accountId/followers' component={Followers} />
|
|
|
|
|
<Route path='/accounts/:accountId/following' component={Following} />
|
|
|
|
|
<Route path='followers' component={Followers} />
|
|
|
|
|
<Route path='following' component={Following} />
|
|
|
|
|
</Route>
|
|
|
|
|
</Route>
|
|
|
|
|
</Router>
|
|
|
|
|