]> Untitled Git - lemmy.git/blob - ui/src/index.tsx
Merge branch 'paging' into dev. Adding Community, User, and Main
[lemmy.git] / ui / src / index.tsx
1 import { render, Component } from 'inferno';
2 import { HashRouter, BrowserRouter, Route, Switch } from 'inferno-router';
3 import { Main } from './components/main';
4 import { Navbar } from './components/navbar';
5 import { Footer } from './components/footer';
6 import { Login } from './components/login';
7 import { CreatePost } from './components/create-post';
8 import { CreateCommunity } from './components/create-community';
9 import { Post } from './components/post';
10 import { Community } from './components/community';
11 import { Communities } from './components/communities';
12 import { User } from './components/user';
13 import { Modlog } from './components/modlog';
14 import { Setup } from './components/setup';
15 import { Inbox } from './components/inbox';
16 import { Search } from './components/search';
17 import { Sponsors } from './components/sponsors';
18 import { Symbols } from './components/symbols';
19
20 import './css/bootstrap.min.css';
21 import './css/main.css';
22
23 import { WebSocketService, UserService } from './services';
24
25 const container = document.getElementById('app');
26
27 class Index extends Component<any, any> {
28
29   constructor(props: any, context: any) {
30     super(props, context);
31     WebSocketService.Instance;
32     UserService.Instance;
33   }
34
35   render() {
36     return (
37       <BrowserRouter>
38         <Navbar />
39         <div class="mt-3 p-0">
40           <Switch>
41             <Route path={`/home/type/:type/sort/:sort/page/:page`} component={Main} />
42             <Route exact path={`/`} component={Main} />
43             <Route path={`/login`} component={Login} />
44             <Route path={`/create_post`} component={CreatePost} />
45             <Route path={`/create_community`} component={CreateCommunity} />
46             <Route path={`/communities`} component={Communities} />
47             <Route path={`/post/:id/comment/:comment_id`} component={Post} />
48             <Route path={`/post/:id`} component={Post} />
49             <Route path={`/f/:name/sort/:sort/page/:page`} component={Community} />
50             <Route path={`/community/:id`} component={Community} />
51             <Route path={`/f/:name`} component={Community} />
52             <Route path={`/u/:username/view/:view/sort/:sort/page/:page`} component={User} />
53             <Route path={`/user/:id`} component={User} />
54             <Route path={`/u/:username`} component={User} />
55             <Route path={`/inbox`} component={Inbox} />
56             <Route path={`/modlog/community/:community_id`} component={Modlog} />
57             <Route path={`/modlog`} component={Modlog} />
58             <Route path={`/setup`} component={Setup} />
59             <Route path={`/search`} component={Search} />
60             <Route path={`/sponsors`} component={Sponsors} />
61           </Switch>
62           <Symbols />
63         </div>
64         <Footer />
65       </HashRouter>
66     );
67   }
68
69 }
70
71 render(<Index />, container);