aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps/metrics
diff options
context:
space:
mode:
authorStas Vilchik <vilchiks@gmail.com>2016-11-21 10:03:40 +0100
committerStas Vilchik <vilchiks@gmail.com>2016-11-28 13:39:04 +0100
commit3a34147be1e725f71b8e102ba53b1f5b9bd10b13 (patch)
tree16ab51c591f124cf0e34a7005361392493a6ebc5 /server/sonar-web/src/main/js/apps/metrics
parentbd96be1c6c971381952dff396e0e10ae9233a6b7 (diff)
downloadsonarqube-3a34147be1e725f71b8e102ba53b1f5b9bd10b13.tar.gz
sonarqube-3a34147be1e725f71b8e102ba53b1f5b9bd10b13.zip
step towards a single-entry-point js app (#1362)
Diffstat (limited to 'server/sonar-web/src/main/js/apps/metrics')
-rw-r--r--server/sonar-web/src/main/js/apps/metrics/components/MetricsAppContainer.js31
-rw-r--r--server/sonar-web/src/main/js/apps/metrics/init.js (renamed from server/sonar-web/src/main/js/apps/metrics/app.js)14
-rw-r--r--server/sonar-web/src/main/js/apps/metrics/routes.js26
3 files changed, 64 insertions, 7 deletions
diff --git a/server/sonar-web/src/main/js/apps/metrics/components/MetricsAppContainer.js b/server/sonar-web/src/main/js/apps/metrics/components/MetricsAppContainer.js
new file mode 100644
index 00000000000..765ead2248a
--- /dev/null
+++ b/server/sonar-web/src/main/js/apps/metrics/components/MetricsAppContainer.js
@@ -0,0 +1,31 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2016 SonarSource SA
+ * mailto:contact AT sonarsource DOT com
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+import React from 'react';
+import init from '../init';
+
+export default class MetricsAppContainer extends React.Component {
+ componentDidMount () {
+ init(this.refs.container);
+ }
+
+ render () {
+ return <div ref="container"/>;
+ }
+}
diff --git a/server/sonar-web/src/main/js/apps/metrics/app.js b/server/sonar-web/src/main/js/apps/metrics/init.js
index 542a5073d17..06f12f34ff2 100644
--- a/server/sonar-web/src/main/js/apps/metrics/app.js
+++ b/server/sonar-web/src/main/js/apps/metrics/init.js
@@ -26,11 +26,9 @@ import ListView from './list-view';
import ListFooterView from './list-footer-view';
const App = new Marionette.Application();
-const init = function () {
- const options = window.sonarqube;
-
+const init = function (el) {
// Layout
- this.layout = new Layout({ el: options.el });
+ this.layout = new Layout({ el });
this.layout.render();
// Collection
@@ -72,11 +70,13 @@ App.requestTypes = function () {
});
};
-App.on('start', function () {
+App.on('start', function (el) {
$.when(App.requestDomains(), App.requestTypes()).done(function () {
- init.call(App);
+ init.call(App, el);
});
});
-window.sonarqube.appStarted.then(options => App.start(options));
+export default function (el) {
+ App.start(el);
+}
diff --git a/server/sonar-web/src/main/js/apps/metrics/routes.js b/server/sonar-web/src/main/js/apps/metrics/routes.js
new file mode 100644
index 00000000000..84955baa23e
--- /dev/null
+++ b/server/sonar-web/src/main/js/apps/metrics/routes.js
@@ -0,0 +1,26 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2016 SonarSource SA
+ * mailto:contact AT sonarsource DOT com
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+import React from 'react';
+import { IndexRoute } from 'react-router';
+import MetricsAppContainer from './components/MetricsAppContainer';
+
+export default (
+ <IndexRoute component={MetricsAppContainer}/>
+);