diff options
author | Stas Vilchik <stas.vilchik@sonarsource.com> | 2018-10-05 09:57:16 +0200 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2018-10-10 09:23:00 +0200 |
commit | 62a465c3e954105b359a0046dc0bf893ccaa324a (patch) | |
tree | 366aeba7ecbd9fd30afb63ac539cf0de548d5142 /server/sonar-web/src | |
parent | 84ee6ecb75d2a68abb5990fe6907d2006f11ed72 (diff) | |
download | sonarqube-62a465c3e954105b359a0046dc0bf893ccaa324a.tar.gz sonarqube-62a465c3e954105b359a0046dc0bf893ccaa324a.zip |
rewrite app utils in ts (#773)
Diffstat (limited to 'server/sonar-web/src')
-rw-r--r-- | server/sonar-web/src/main/js/app/utils/getHistory.ts (renamed from server/sonar-web/src/main/js/app/utils/getHistory.js) | 16 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/app/utils/handleRequiredAuthentication.ts (renamed from server/sonar-web/src/main/js/app/utils/handleRequiredAuthentication.js) | 7 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/app/utils/handleRequiredAuthorization.ts (renamed from server/sonar-web/src/main/js/app/utils/handleRequiredAuthorization.js) | 7 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/app/utils/startReactApp.tsx (renamed from server/sonar-web/src/main/js/app/utils/startReactApp.js) | 131 |
4 files changed, 100 insertions, 61 deletions
diff --git a/server/sonar-web/src/main/js/app/utils/getHistory.js b/server/sonar-web/src/main/js/app/utils/getHistory.ts index de272923840..e23f7c5f756 100644 --- a/server/sonar-web/src/main/js/app/utils/getHistory.js +++ b/server/sonar-web/src/main/js/app/utils/getHistory.ts @@ -17,17 +17,19 @@ * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ -// @flow import { useRouterHistory } from 'react-router'; -import { createHistory } from 'history'; +import { createHistory, History } from 'history'; -let history; +let history: History; -const ensureHistory = () => { +function ensureHistory() { history = useRouterHistory(createHistory)({ - basename: window.baseUrl + '/' + // do not use `getBaseUrl` from `helpers/urls` to no import this file with all its dependecies + basename: (window as any).baseUrl + '/' }); return history; -}; +} -export default () => (history ? history : ensureHistory()); +export default function getHistory() { + return history ? history : ensureHistory(); +} diff --git a/server/sonar-web/src/main/js/app/utils/handleRequiredAuthentication.js b/server/sonar-web/src/main/js/app/utils/handleRequiredAuthentication.ts index bc3a3b95160..aaf5732e0ba 100644 --- a/server/sonar-web/src/main/js/app/utils/handleRequiredAuthentication.js +++ b/server/sonar-web/src/main/js/app/utils/handleRequiredAuthentication.ts @@ -17,14 +17,13 @@ * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ -// @flow import getHistory from './getHistory'; -export default () => { +export default function handleRequiredAuthentication() { const history = getHistory(); const returnTo = window.location.pathname + window.location.search + window.location.hash; history.replace({ pathname: '/sessions/new', - query: { return_to: returnTo } + query: { return_to: returnTo } // eslint-disable-line camelcase }); -}; +} diff --git a/server/sonar-web/src/main/js/app/utils/handleRequiredAuthorization.js b/server/sonar-web/src/main/js/app/utils/handleRequiredAuthorization.ts index eaa2cf81b75..a3a32b38ba6 100644 --- a/server/sonar-web/src/main/js/app/utils/handleRequiredAuthorization.js +++ b/server/sonar-web/src/main/js/app/utils/handleRequiredAuthorization.ts @@ -17,12 +17,11 @@ * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ -// @flow import getStore from './getStore'; import getHistory from './getHistory'; import { requireAuthorization } from '../../store/appState'; -export default () => { +export default function handleRequiredAuthorization() { const store = getStore(); const history = getHistory(); @@ -31,6 +30,6 @@ export default () => { store.dispatch(requireAuthorization()); history.replace({ pathname: '/sessions/new', - query: { return_to: returnTo } + query: { return_to: returnTo } // eslint-disable-line camelcase }); -}; +} diff --git a/server/sonar-web/src/main/js/app/utils/startReactApp.js b/server/sonar-web/src/main/js/app/utils/startReactApp.tsx index 474e9f56083..78bd52c4c53 100644 --- a/server/sonar-web/src/main/js/app/utils/startReactApp.js +++ b/server/sonar-web/src/main/js/app/utils/startReactApp.tsx @@ -18,11 +18,12 @@ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ /* eslint-disable react/jsx-sort-props */ -import React from 'react'; +import * as React from 'react'; import { render } from 'react-dom'; -import { Router, Route, IndexRoute, Redirect } from 'react-router'; +import { Router, Route, IndexRoute, Redirect, RouteProps, RouteConfig } from 'react-router'; import { Provider } from 'react-redux'; import { IntlProvider } from 'react-intl'; +import { Location } from 'history'; import getStore from './getStore'; import getHistory from './getHistory'; import MigrationContainer from '../components/MigrationContainer'; @@ -68,8 +69,9 @@ import { maintenanceRoutes, setupRoutes } from '../../apps/maintenance/routes'; import { globalPermissionsRoutes, projectPermissionsRoutes } from '../../apps/permissions/routes'; import { lazyLoad } from '../../components/lazyLoad'; import { isSonarCloud } from '../../helpers/system'; +import { CurrentUser, AppState } from '../types'; -function handleUpdate() { +function handleUpdate(this: { state: { location: Location } }) { const { action } = this.state.location; if (action === 'PUSH') { @@ -77,7 +79,16 @@ function handleUpdate() { } } -const startReactApp = (lang, currentUser, appState) => { +// this is not an official api +const RouteWithChildRoutes = Route as React.ComponentClass< + RouteProps & { childRoutes: RouteConfig } +>; + +export default function startReactApp( + lang: string, + currentUser?: CurrentUser, + appState?: AppState +) { const el = document.getElementById('content'); const history = getHistory(); @@ -96,7 +107,7 @@ const startReactApp = (lang, currentUser, appState) => { <Route path="/codingrules" - onEnter={(nextState, replace) => { + onEnter={(_, replace) => { replace('/coding_rules' + window.location.hash); }} /> @@ -110,7 +121,7 @@ const startReactApp = (lang, currentUser, appState) => { <Route path="/issues/search" - onEnter={(nextState, replace) => { + onEnter={(_, replace) => { replace('/issues' + window.location.hash); }} /> @@ -150,18 +161,18 @@ const startReactApp = (lang, currentUser, appState) => { <Route component={MigrationContainer}> <Route component={lazyLoad(() => import('../components/SimpleSessionsContainer'))}> - <Route path="/sessions" childRoutes={sessionsRoutes} /> + <RouteWithChildRoutes path="/sessions" childRoutes={sessionsRoutes} /> </Route> <Route path="/" component={App}> <IndexRoute component={lazyLoad(() => import('../components/Landing'))} /> - <Route path="about" childRoutes={aboutRoutes} /> + <RouteWithChildRoutes path="about" childRoutes={aboutRoutes} /> <Route component={GlobalContainer}> - <Route path="account" childRoutes={accountRoutes} /> - <Route path="coding_rules" childRoutes={codingRulesRoutes} /> - <Route path="component" childRoutes={componentRoutes} /> - <Route path="documentation" childRoutes={documentationRoutes} /> + <RouteWithChildRoutes path="account" childRoutes={accountRoutes} /> + <RouteWithChildRoutes path="coding_rules" childRoutes={codingRulesRoutes} /> + <RouteWithChildRoutes path="component" childRoutes={componentRoutes} /> + <RouteWithChildRoutes path="documentation" childRoutes={documentationRoutes} /> <Route path="explore" component={Explore}> <Route path="issues" component={ExploreIssues} /> <Route path="projects" component={ExploreProjects} /> @@ -171,7 +182,7 @@ const startReactApp = (lang, currentUser, appState) => { component={lazyLoad(() => import('../components/extensions/GlobalPageExtension'))} /> <Route path="issues" component={IssuesPageSelector} /> - <Route path="onboarding" childRoutes={onboardingRoutes} /> + <RouteWithChildRoutes path="onboarding" childRoutes={onboardingRoutes} /> {isSonarCloud() && ( <Route path="create-organization" @@ -180,22 +191,28 @@ const startReactApp = (lang, currentUser, appState) => { )} /> )} - <Route path="organizations" childRoutes={organizationsRoutes} /> - <Route path="projects" childRoutes={projectsRoutes} /> - <Route path="quality_gates" childRoutes={qualityGatesRoutes} /> + <RouteWithChildRoutes path="organizations" childRoutes={organizationsRoutes} /> + <RouteWithChildRoutes path="projects" childRoutes={projectsRoutes} /> + <RouteWithChildRoutes path="quality_gates" childRoutes={qualityGatesRoutes} /> <Route path="portfolios" component={lazyLoad(() => import('../components/extensions/PortfoliosPage'))} /> - <Route path="profiles" childRoutes={qualityProfilesRoutes} /> - <Route path="web_api" childRoutes={webAPIRoutes} /> + <RouteWithChildRoutes path="profiles" childRoutes={qualityProfilesRoutes} /> + <RouteWithChildRoutes path="web_api" childRoutes={webAPIRoutes} /> <Route component={lazyLoad(() => import('../components/ComponentContainer'))}> - <Route path="code" childRoutes={codeRoutes} /> - <Route path="component_measures" childRoutes={componentMeasuresRoutes} /> - <Route path="dashboard" childRoutes={overviewRoutes} /> - <Route path="portfolio" childRoutes={portfolioRoutes} /> - <Route path="project/activity" childRoutes={projectActivityRoutes} /> + <RouteWithChildRoutes path="code" childRoutes={codeRoutes} /> + <RouteWithChildRoutes + path="component_measures" + childRoutes={componentMeasuresRoutes} + /> + <RouteWithChildRoutes path="dashboard" childRoutes={overviewRoutes} /> + <RouteWithChildRoutes path="portfolio" childRoutes={portfolioRoutes} /> + <RouteWithChildRoutes + path="project/activity" + childRoutes={projectActivityRoutes} + /> <Route path="project/extension/:pluginKey/:extensionKey" component={lazyLoad(() => @@ -207,24 +224,39 @@ const startReactApp = (lang, currentUser, appState) => { path="project/security_reports/:type" component={lazyLoad(() => import('../../apps/securityReports/components/App'))} /> - <Route path="project/quality_gate" childRoutes={projectQualityGateRoutes} /> - <Route + <RouteWithChildRoutes + path="project/quality_gate" + childRoutes={projectQualityGateRoutes} + /> + <RouteWithChildRoutes path="project/quality_profiles" childRoutes={projectQualityProfilesRoutes} /> <Route component={lazyLoad(() => import('../components/ProjectAdminContainer'))}> - <Route path="custom_measures" childRoutes={customMeasuresRoutes} /> + <RouteWithChildRoutes + path="custom_measures" + childRoutes={customMeasuresRoutes} + /> <Route path="project/admin/extension/:pluginKey/:extensionKey" component={lazyLoad(() => import('../components/extensions/ProjectAdminPageExtension') )} /> - <Route path="project/background_tasks" childRoutes={backgroundTasksRoutes} /> - <Route path="project/branches" childRoutes={projectBranchesRoutes} /> - <Route path="project/settings" childRoutes={settingsRoutes} /> - <Route path="project_roles" childRoutes={projectPermissionsRoutes} /> - <Route path="project/webhooks" childRoutes={webhooksRoutes} /> + <RouteWithChildRoutes + path="project/background_tasks" + childRoutes={backgroundTasksRoutes} + /> + <RouteWithChildRoutes + path="project/branches" + childRoutes={projectBranchesRoutes} + /> + <RouteWithChildRoutes path="project/settings" childRoutes={settingsRoutes} /> + <RouteWithChildRoutes + path="project_roles" + childRoutes={projectPermissionsRoutes} + /> + <RouteWithChildRoutes path="project/webhooks" childRoutes={webhooksRoutes} /> <Route path="project/deletion" component={lazyLoad(() => import('../../apps/projectDeletion/App'))} @@ -249,18 +281,27 @@ const startReactApp = (lang, currentUser, appState) => { import('../components/extensions/GlobalAdminPageExtension') )} /> - <Route path="background_tasks" childRoutes={backgroundTasksRoutes} /> - <Route path="custom_metrics" childRoutes={customMetricsRoutes} /> - <Route path="groups" childRoutes={groupsRoutes} /> - <Route path="permission_templates" childRoutes={permissionTemplatesRoutes} /> - <Route path="roles/global" childRoutes={globalPermissionsRoutes} /> - <Route path="permissions" childRoutes={globalPermissionsRoutes} /> - <Route path="projects_management" childRoutes={projectsManagementRoutes} /> - <Route path="settings" childRoutes={settingsRoutes} /> - <Route path="system" childRoutes={systemRoutes} /> - <Route path="marketplace" childRoutes={marketplaceRoutes} /> - <Route path="users" childRoutes={usersRoutes} /> - <Route path="webhooks" childRoutes={webhooksRoutes} /> + <RouteWithChildRoutes + path="background_tasks" + childRoutes={backgroundTasksRoutes} + /> + <RouteWithChildRoutes path="custom_metrics" childRoutes={customMetricsRoutes} /> + <RouteWithChildRoutes path="groups" childRoutes={groupsRoutes} /> + <RouteWithChildRoutes + path="permission_templates" + childRoutes={permissionTemplatesRoutes} + /> + <RouteWithChildRoutes path="roles/global" childRoutes={globalPermissionsRoutes} /> + <RouteWithChildRoutes path="permissions" childRoutes={globalPermissionsRoutes} /> + <RouteWithChildRoutes + path="projects_management" + childRoutes={projectsManagementRoutes} + /> + <RouteWithChildRoutes path="settings" childRoutes={settingsRoutes} /> + <RouteWithChildRoutes path="system" childRoutes={systemRoutes} /> + <RouteWithChildRoutes path="marketplace" childRoutes={marketplaceRoutes} /> + <RouteWithChildRoutes path="users" childRoutes={usersRoutes} /> + <RouteWithChildRoutes path="webhooks" childRoutes={webhooksRoutes} /> </Route> </Route> <Route @@ -275,6 +316,4 @@ const startReactApp = (lang, currentUser, appState) => { </Provider>, el ); -}; - -export default startReactApp; +} |