aboutsummaryrefslogblamecommitdiffstats
path: root/packages/website/ts/index.tsx
blob: 49bcdeaacdbe65751d52e2024b03bc67a7fdaa2d (plain) (tree)
1
2
3
4
5
6
7
8
9
            
                                                      
                               


                                                                                    
                                                               
                                                         
                                                      

                                            
                                                

                                                   


                                                                             
                                                  
                                                            
                                               
                                              
                                       
                      

                       

                                                                                                       
                                      
 


                                 



                                                                                                        







                                                                                                       

                                                                                                      
  

                                                                                                                  
  

                                                                                                    
  
                                                                                     
                                                                                                             
  

                                                                                                             
  
                                                                                     
                                                                                                             
  
                                                                                
                                                                                                   
  
                                                                                      
                                                                                                             
  


                                                                                                           
 
                 
                                                
                                                 








                                                                                      
                                                                                  
 
                                                                                            



                                                                                        
                                                                                                                       
                                                                                                                     



                                                                              
                                                                                                                   
                                  



                                                                              



                                                                               



                                                                             



                                                                              


                                                                                 









                                                                                    



                                                                                 
 





                                                                 
              

                                   
// Polyfills
import { MuiThemeProvider } from 'material-ui/styles';
import * as React from 'react';
import { render } from 'react-dom';
import { Provider } from 'react-redux';
import { BrowserRouter as Router, Redirect, Route, Switch } from 'react-router-dom';
import * as injectTapEventPlugin from 'react-tap-event-plugin';
import { createStore, Store as ReduxStore } from 'redux';
import { Redirecter } from 'ts/components/redirecter';
import { About } from 'ts/containers/about';
import { FAQ } from 'ts/containers/faq';
import { Landing } from 'ts/containers/landing';
import { NotFound } from 'ts/containers/not_found';
import { Wiki } from 'ts/containers/wiki';
import { createLazyComponent } from 'ts/lazy_component';
import { trackedTokenStorage } from 'ts/local_storage/tracked_token_storage';
import { tradeHistoryStorage } from 'ts/local_storage/trade_history_storage';
import { reducer, State } from 'ts/redux/reducer';
import { WebsiteLegacyPaths, WebsitePaths } from 'ts/types';
import { analytics } from 'ts/utils/analytics';
import { muiTheme } from 'ts/utils/mui_theme';
import { utils } from 'ts/utils/utils';
import 'whatwg-fetch';
injectTapEventPlugin();

// Check if we've introduced an update that requires us to clear the tradeHistory local storage entries
tradeHistoryStorage.clearIfRequired();
trackedTokenStorage.clearIfRequired();

import 'basscss/css/basscss.css';
import 'less/all.less';

// We pass modulePromise returning lambda instead of module promise,
// cause we only want to import the module when the user navigates to the page.
// At the same time webpack statically parses for System.import() to determine bundle chunk split points
// so each lazy import needs it's own `System.import()` declaration.
const LazyPortal =
    utils.isDevelopment() || utils.isStaging()
        ? createLazyComponent('Portal', async () =>
              System.import<any>(/* webpackChunkName: "portal" */ 'ts/containers/portal'),
          )
        : createLazyComponent('LegacyPortal', async () =>
              System.import<any>(/* webpackChunkName: "legacyPortal" */ 'ts/containers/legacy_portal'),
          );
const LazyZeroExJSDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "zeroExDocs" */ 'ts/containers/zero_ex_js_documentation'),
);
const LazySmartContractsDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "smartContractDocs" */ 'ts/containers/smart_contracts_documentation'),
);
const LazyConnectDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "connectDocs" */ 'ts/containers/connect_documentation'),
);
const LazyWeb3WrapperDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "web3WrapperDocs" */ 'ts/containers/web3_wrapper_documentation'),
);
const LazySolCompilerDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "solCompilerDocs" */ 'ts/containers/sol_compiler_documentation'),
);
const LazyJSONSchemasDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "jsonSchemasDocs" */ 'ts/containers/json_schemas_documentation'),
);
const LazySolCovDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "solCovDocs" */ 'ts/containers/sol_cov_documentation'),
);
const LazySubprovidersDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "subproviderDocs" */ 'ts/containers/subproviders_documentation'),
);
const LazyOrderUtilsDocumentation = createLazyComponent('Documentation', async () =>
    System.import<any>(/* webpackChunkName: "orderUtilsDocs" */ 'ts/containers/order_utils_documentation'),
);

analytics.init();
// tslint:disable-next-line:no-floating-promises
analytics.logProviderAsync((window as any).web3);
const store: ReduxStore<State> = createStore(reducer);
render(
    <Router>
        <div>
            <MuiThemeProvider muiTheme={muiTheme}>
                <Provider store={store}>
                    <div>
                        <Switch>
                            <Route exact={true} path="/" component={Landing as any} />
                            <Redirect from="/otc" to={`${WebsitePaths.Portal}`} />

                            <Route path={WebsitePaths.Jobs} component={Redirecter as any} />
                            <Route path={WebsitePaths.Portal} component={LazyPortal} />
                            <Route path={WebsitePaths.FAQ} component={FAQ as any} />
                            <Route path={WebsitePaths.About} component={About as any} />
                            <Route path={WebsitePaths.Wiki} component={Wiki as any} />
                            <Route path={`${WebsitePaths.ZeroExJs}/:version?`} component={LazyZeroExJSDocumentation} />
                            <Route path={`${WebsitePaths.Connect}/:version?`} component={LazyConnectDocumentation} />
                            <Route
                                path={`${WebsitePaths.SolCompiler}/:version?`}
                                component={LazySolCompilerDocumentation}
                            />
                            <Route path={`${WebsitePaths.SolCov}/:version?`} component={LazySolCovDocumentation} />
                            <Route
                                path={`${WebsitePaths.JSONSchemas}/:version?`}
                                component={LazyJSONSchemasDocumentation}
                            />
                            <Route
                                path={`${WebsitePaths.Subproviders}/:version?`}
                                component={LazySubprovidersDocumentation}
                            />
                            <Route
                                path={`${WebsitePaths.OrderUtils}/:version?`}
                                component={LazyOrderUtilsDocumentation}
                            />
                            <Route
                                path={`${WebsitePaths.Web3Wrapper}/:version?`}
                                component={LazyWeb3WrapperDocumentation}
                            />
                            <Route
                                path={`${WebsitePaths.SmartContracts}/:version?`}
                                component={LazySmartContractsDocumentation}
                            />

                            {/* Legacy endpoints */}
                            <Route
                                path={`${WebsiteLegacyPaths.ZeroExJs}/:version?`}
                                component={LazyZeroExJSDocumentation}
                            />
                            <Route
                                path={`${WebsiteLegacyPaths.Web3Wrapper}/:version?`}
                                component={LazyWeb3WrapperDocumentation}
                            />
                            <Route
                                path={`${WebsiteLegacyPaths.Deployer}/:version?`}
                                component={LazySolCompilerDocumentation}
                            />

                            <Route component={NotFound as any} />
                        </Switch>
                    </div>
                </Provider>
            </MuiThemeProvider>
        </div>
    </Router>,
    document.getElementById('app'),
);