]> Untitled Git - lemmy.git/blob - ui/src/index.tsx
Add new comments views to main and community pages. Fixes #480
[lemmy.git] / ui / src / index.tsx
1 import { render, Component } from 'inferno';
2 import { BrowserRouter, Route, Switch } from 'inferno-router';
3 import { Provider } from 'inferno-i18next';
4 import { Main } from './components/main';
5 import { Navbar } from './components/navbar';
6 import { Footer } from './components/footer';
7 import { Login } from './components/login';
8 import { CreatePost } from './components/create-post';
9 import { CreateCommunity } from './components/create-community';
10 import { CreatePrivateMessage } from './components/create-private-message';
11 import { PasswordChange } from './components/password_change';
12 import { Post } from './components/post';
13 import { Community } from './components/community';
14 import { Communities } from './components/communities';
15 import { User } from './components/user';
16 import { Modlog } from './components/modlog';
17 import { Setup } from './components/setup';
18 import { Inbox } from './components/inbox';
19 import { Search } from './components/search';
20 import { Sponsors } from './components/sponsors';
21 import { Symbols } from './components/symbols';
22 import { i18n } from './i18next';
23
24 import { WebSocketService, UserService } from './services';
25
26 const container = document.getElementById('app');
27
28 class Index extends Component<any, any> {
29   constructor(props: any, context: any) {
30     super(props, context);
31     WebSocketService.Instance;
32     UserService.Instance;
33   }
34
35   render() {
36     return (
37       <Provider i18next={i18n}>
38         <BrowserRouter>
39           <Navbar />
40           <div class="mt-4 p-0 fl-1">
41             <Switch>
42               <Route exact path={`/`} component={Main} />
43               <Route
44                 path={`/home/data_type/:data_type/listing_type/:listing_type/sort/:sort/page/:page`}
45                 component={Main}
46               />
47               <Route path={`/login`} component={Login} />
48               <Route path={`/create_post`} component={CreatePost} />
49               <Route path={`/create_community`} component={CreateCommunity} />
50               <Route
51                 path={`/create_private_message`}
52                 component={CreatePrivateMessage}
53               />
54               <Route path={`/communities/page/:page`} component={Communities} />
55               <Route path={`/communities`} component={Communities} />
56               <Route path={`/post/:id/comment/:comment_id`} component={Post} />
57               <Route path={`/post/:id`} component={Post} />
58               <Route
59                 path={`/c/:name/data_type/:data_type/sort/:sort/page/:page`}
60                 component={Community}
61               />
62               <Route path={`/community/:id`} component={Community} />
63               <Route path={`/c/:name`} component={Community} />
64               <Route
65                 path={`/u/:username/view/:view/sort/:sort/page/:page`}
66                 component={User}
67               />
68               <Route path={`/user/:id`} component={User} />
69               <Route path={`/u/:username`} component={User} />
70               <Route path={`/inbox`} component={Inbox} />
71               <Route
72                 path={`/modlog/community/:community_id`}
73                 component={Modlog}
74               />
75               <Route path={`/modlog`} component={Modlog} />
76               <Route path={`/setup`} component={Setup} />
77               <Route
78                 path={`/search/q/:q/type/:type/sort/:sort/page/:page`}
79                 component={Search}
80               />
81               <Route path={`/search`} component={Search} />
82               <Route path={`/sponsors`} component={Sponsors} />
83               <Route
84                 path={`/password_change/:token`}
85                 component={PasswordChange}
86               />
87             </Switch>
88             <Symbols />
89           </div>
90           <Footer />
91         </BrowserRouter>
92       </Provider>
93     );
94   }
95 }
96
97 render(<Index />, container);