aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps
diff options
context:
space:
mode:
Diffstat (limited to 'server/sonar-web/src/main/js/apps')
-rw-r--r--server/sonar-web/src/main/js/apps/account/change-password-view.js3
-rw-r--r--server/sonar-web/src/main/js/apps/background-tasks/header.js5
-rw-r--r--server/sonar-web/src/main/js/apps/background-tasks/search.js21
-rw-r--r--server/sonar-web/src/main/js/apps/background-tasks/stats.js13
-rw-r--r--server/sonar-web/src/main/js/apps/background-tasks/tasks.js21
-rw-r--r--server/sonar-web/src/main/js/apps/code/actions/index.js9
-rw-r--r--server/sonar-web/src/main/js/apps/code/components/Code.js3
-rw-r--r--server/sonar-web/src/main/js/apps/code/components/ComponentDetach.js3
-rw-r--r--server/sonar-web/src/main/js/apps/code/components/Components.js11
-rw-r--r--server/sonar-web/src/main/js/apps/code/components/ComponentsEmpty.js3
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/app.js3
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/bulk-change-modal-view.js7
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/facets/active-severity-facet.js3
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/facets/custom-values-facet.js9
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/facets/inheritance-facet.js5
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/facets/status-facet.js3
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/rule-details-view.js5
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-creation-view.js5
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-view.js5
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/rule/manual-rule-creation-view.js3
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/rule/rule-description-view.js3
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/rule/rule-profile-view.js9
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/workspace-list-empty-view.js3
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/workspace-list-item-view.js5
-rw-r--r--server/sonar-web/src/main/js/apps/global-permissions/main.js5
-rw-r--r--server/sonar-web/src/main/js/apps/issues/facets/author-facet.js7
-rw-r--r--server/sonar-web/src/main/js/apps/issues/facets/custom-values-facet.js7
-rw-r--r--server/sonar-web/src/main/js/apps/issues/facets/language-facet.js7
-rw-r--r--server/sonar-web/src/main/js/apps/issues/facets/project-facet.js7
-rw-r--r--server/sonar-web/src/main/js/apps/issues/facets/rule-facet.js9
-rw-r--r--server/sonar-web/src/main/js/apps/issues/facets/tag-facet.js5
-rw-r--r--server/sonar-web/src/main/js/apps/issues/workspace-list-empty-view.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/complexity-distribution.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/coverage-measures.js5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/domain-bubble-chart.js8
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/domain-timeline.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/domain-treemap.js7
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/event.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/events-list-filter.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/events-list.js7
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/issue-measure.js11
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/language-distribution.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/ncloc-distribution.js5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/domains/coverage-domain.js5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/domains/debt-domain.js5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/domains/duplications-domain.js5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/domains/structure-domain.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/gate/gate-condition.js5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/gate/gate-empty.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/gate/gate.js11
-rw-r--r--server/sonar-web/src/main/js/apps/overview/helpers/metrics.js4
-rw-r--r--server/sonar-web/src/main/js/apps/overview/helpers/periods.js5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/components.js17
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/coverage.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/debt.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/duplications.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/structure.js3
-rw-r--r--server/sonar-web/src/main/js/apps/overview/meta.js5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/overview.js3
-rw-r--r--server/sonar-web/src/main/js/apps/permission-templates/header.js5
-rw-r--r--server/sonar-web/src/main/js/apps/permission-templates/permission-template-defaults.js3
-rw-r--r--server/sonar-web/src/main/js/apps/permission-templates/permission-template-set-defaults.js3
-rw-r--r--server/sonar-web/src/main/js/apps/project-permissions/main.js5
-rw-r--r--server/sonar-web/src/main/js/apps/project-permissions/qualifier-filter.js3
-rw-r--r--server/sonar-web/src/main/js/apps/projects/search.js5
-rw-r--r--server/sonar-web/src/main/js/apps/quality-gates/gate-condition-view.js3
-rw-r--r--server/sonar-web/src/main/js/apps/quality-gates/gate-conditions-view.js3
-rw-r--r--server/sonar-web/src/main/js/apps/quality-gates/gate-projects-view.js13
-rw-r--r--server/sonar-web/src/main/js/apps/quality-profiles/profile-details-view.js13
-rw-r--r--server/sonar-web/src/main/js/apps/system/item-log-level.js3
-rw-r--r--server/sonar-web/src/main/js/apps/system/main.js3
71 files changed, 244 insertions, 169 deletions
diff --git a/server/sonar-web/src/main/js/apps/account/change-password-view.js b/server/sonar-web/src/main/js/apps/account/change-password-view.js
index f2cca1e60da..289c9e7ac7c 100644
--- a/server/sonar-web/src/main/js/apps/account/change-password-view.js
+++ b/server/sonar-web/src/main/js/apps/account/change-password-view.js
@@ -20,6 +20,7 @@
import $ from 'jquery';
import ModalForm from '../../components/common/modal-form';
import Template from './templates/account-change-password.hbs';
+import { translate } from '../../helpers/l10n';
export default ModalForm.extend({
template: Template,
@@ -29,7 +30,7 @@ export default ModalForm.extend({
if (this.checkPasswords()) {
this.sendRequest();
} else {
- this.showErrors([{ msg: window.t('user.password_doesnt_match_confirmation') }]);
+ this.showErrors([{ msg: translate('user.password_doesnt_match_confirmation') }]);
}
},
diff --git a/server/sonar-web/src/main/js/apps/background-tasks/header.js b/server/sonar-web/src/main/js/apps/background-tasks/header.js
index 2884f9e75fe..ebba7aa2dcf 100644
--- a/server/sonar-web/src/main/js/apps/background-tasks/header.js
+++ b/server/sonar-web/src/main/js/apps/background-tasks/header.js
@@ -18,13 +18,14 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import React from 'react';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
render() {
return (
<header className="page-header">
- <h1 className="page-title">{window.t('background_tasks.page')}</h1>
- <p className="page-description">{window.t('background_tasks.page.description')}</p>
+ <h1 className="page-title">{translate('background_tasks.page')}</h1>
+ <p className="page-description">{translate('background_tasks.page.description')}</p>
</header>
);
}
diff --git a/server/sonar-web/src/main/js/apps/background-tasks/search.js b/server/sonar-web/src/main/js/apps/background-tasks/search.js
index 1c2c3b50147..30cea9ad1e2 100644
--- a/server/sonar-web/src/main/js/apps/background-tasks/search.js
+++ b/server/sonar-web/src/main/js/apps/background-tasks/search.js
@@ -22,6 +22,7 @@ import moment from 'moment';
import React from 'react';
import RadioToggle from '../../components/shared/radio-toggle';
import { STATUSES, CURRENTS, DATE, DATE_FORMAT } from './constants';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
componentDidMount() {
@@ -34,25 +35,25 @@ export default React.createClass({
getCurrentsOptions() {
return [
- { value: CURRENTS.ALL, label: window.t('background_tasks.currents_filter.ALL') },
- { value: CURRENTS.ONLY_CURRENTS, label: window.t('background_tasks.currents_filter.ONLY_CURRENTS') }
+ { value: CURRENTS.ALL, label: translate('background_tasks.currents_filter.ALL') },
+ { value: CURRENTS.ONLY_CURRENTS, label: translate('background_tasks.currents_filter.ONLY_CURRENTS') }
];
},
getStatusOptions() {
return [
- { value: STATUSES.ALL, label: window.t('background_task.status.ALL') },
- { value: STATUSES.SUCCESS, label: window.t('background_task.status.SUCCESS') },
- { value: STATUSES.FAILED, label: window.t('background_task.status.FAILED') },
- { value: STATUSES.CANCELED, label: window.t('background_task.status.CANCELED') }
+ { value: STATUSES.ALL, label: translate('background_task.status.ALL') },
+ { value: STATUSES.SUCCESS, label: translate('background_task.status.SUCCESS') },
+ { value: STATUSES.FAILED, label: translate('background_task.status.FAILED') },
+ { value: STATUSES.CANCELED, label: translate('background_task.status.CANCELED') }
];
},
getDateOptions() {
return [
- { value: DATE.ANY, label: window.t('background_tasks.date_filter.ALL') },
- { value: DATE.TODAY, label: window.t('background_tasks.date_filter.TODAY') },
- { value: DATE.CUSTOM, label: window.t('background_tasks.date_filter.CUSTOM') }
+ { value: DATE.ANY, label: translate('background_tasks.date_filter.ALL') },
+ { value: DATE.TODAY, label: translate('background_tasks.date_filter.TODAY') },
+ { value: DATE.CUSTOM, label: translate('background_tasks.date_filter.CUSTOM') }
];
},
@@ -158,7 +159,7 @@ export default React.createClass({
</li>
<li>{this.renderSearchBox()}</li>
<li className="pull-right">
- <button onClick={this.refresh} ref="reloadButton">{window.t('reload')}</button>
+ <button onClick={this.refresh} ref="reloadButton">{translate('reload')}</button>
</li>
</ul>
</section>
diff --git a/server/sonar-web/src/main/js/apps/background-tasks/stats.js b/server/sonar-web/src/main/js/apps/background-tasks/stats.js
index 51410d559af..dc5b447f291 100644
--- a/server/sonar-web/src/main/js/apps/background-tasks/stats.js
+++ b/server/sonar-web/src/main/js/apps/background-tasks/stats.js
@@ -21,6 +21,7 @@ import React from 'react';
import { formatDuration } from './helpers';
import { TooltipsMixin } from '../../components/mixins/tooltips-mixin';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
@@ -41,7 +42,7 @@ export default React.createClass({
return null;
}
return (
- <span className="huge-spacer-left" title={window.t('background_tasks.in_progress_duration')}
+ <span className="huge-spacer-left" title={translate('background_tasks.in_progress_duration')}
data-toggle="tooltip">
<i className="spinner spacer-right" style={{ verticalAlign: 'text-top' }}/>
<span ref="inProgressDuration" className="emphasised-measure">
@@ -60,9 +61,9 @@ export default React.createClass({
<span>
<span ref="pendingCount" className="emphasised-measure">{this.props.pendingCount}</span>
&nbsp;
- {window.t('background_tasks.pending')}
+ {translate('background_tasks.pending')}
<a ref="cancelPending" onClick={this.onPendingCanceled} className="icon-delete spacer-left"
- title={window.t('background_tasks.cancel_all_tasks')} data-toggle="tooltip" href="#"></a>
+ title={translate('background_tasks.cancel_all_tasks')} data-toggle="tooltip" href="#"></a>
</span>
);
} else {
@@ -70,7 +71,7 @@ export default React.createClass({
<span>
<span ref="pendingCount" className="emphasised-measure">{this.props.pendingCount}</span>
&nbsp;
- {window.t('background_tasks.pending')}
+ {translate('background_tasks.pending')}
</span>
);
}
@@ -95,7 +96,7 @@ export default React.createClass({
title="Count of projects where processing of most recent analysis report failed"
href="#">{this.props.failuresCount}</a>
&nbsp;
- {window.t('background_tasks.failures')}
+ {translate('background_tasks.failures')}
</span>
);
} else {
@@ -106,7 +107,7 @@ export default React.createClass({
{this.props.failuresCount}
</span>
&nbsp;
- {window.t('background_tasks.failures')}
+ {translate('background_tasks.failures')}
</span>
);
}
diff --git a/server/sonar-web/src/main/js/apps/background-tasks/tasks.js b/server/sonar-web/src/main/js/apps/background-tasks/tasks.js
index 064b0a92d23..f93c7f0033c 100644
--- a/server/sonar-web/src/main/js/apps/background-tasks/tasks.js
+++ b/server/sonar-web/src/main/js/apps/background-tasks/tasks.js
@@ -26,6 +26,7 @@ import PendingIcon from '../../components/shared/pending-icon';
import { STATUSES } from './constants';
import { formatDuration } from './helpers';
import { TooltipsMixin } from '../../components/mixins/tooltips-mixin';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
@@ -55,18 +56,18 @@ export default React.createClass({
inner = <i className="spinner"/>;
break;
case STATUSES.SUCCESS:
- inner = <span className="badge badge-success">{window.t('background_task.status.SUCCESS')}</span>;
+ inner = <span className="badge badge-success">{translate('background_task.status.SUCCESS')}</span>;
break;
case STATUSES.FAILED:
- inner = <span className="badge badge-danger">{window.t('background_task.status.FAILED')}</span>;
+ inner = <span className="badge badge-danger">{translate('background_task.status.FAILED')}</span>;
break;
case STATUSES.CANCELED:
- inner = <span className="badge badge-muted">{window.t('background_task.status.CANCELED')}</span>;
+ inner = <span className="badge badge-muted">{translate('background_task.status.CANCELED')}</span>;
break;
default:
inner = '';
}
- return <td className="thin spacer-right" title={window.t('background_task.status', task.status)}
+ return <td className="thin spacer-right" title={translate('background_task.status', task.status)}
data-toggle="tooltip">{inner}</td>;
},
@@ -125,7 +126,7 @@ export default React.createClass({
if (task.status === STATUSES.PENDING) {
return (
<a onClick={this.onTaskCanceled.bind(this, task)} className="icon-delete"
- title={window.t('background_tasks.cancel_task')} data-toggle="tooltip" href="#"></a>
+ title={translate('background_tasks.cancel_task')} data-toggle="tooltip" href="#"></a>
);
} else {
return null;
@@ -135,7 +136,7 @@ export default React.createClass({
renderLogsLink(task) {
if (task.logs) {
let url = `${window.baseUrl}/api/ce/logs?taskId=${task.id}`;
- return <a target="_blank" href={url}>{window.t('background_tasks.logs')}</a>;
+ return <a target="_blank" href={url}>{translate('background_tasks.logs')}</a>;
} else {
return null;
}
@@ -173,10 +174,10 @@ export default React.createClass({
<th>&nbsp;</th>
<th>&nbsp;</th>
<th>&nbsp;</th>
- <th>{window.t('background_tasks.table.submitted')}</th>
- <th>{window.t('background_tasks.table.started')}</th>
- <th>{window.t('background_tasks.table.finished')}</th>
- <th>{window.t('background_tasks.table.duration')}</th>
+ <th>{translate('background_tasks.table.submitted')}</th>
+ <th>{translate('background_tasks.table.started')}</th>
+ <th>{translate('background_tasks.table.finished')}</th>
+ <th>{translate('background_tasks.table.duration')}</th>
<th>&nbsp;</th>
</tr>
</thead>
diff --git a/server/sonar-web/src/main/js/apps/code/actions/index.js b/server/sonar-web/src/main/js/apps/code/actions/index.js
index bfd5216f91b..d9edf8eca7b 100644
--- a/server/sonar-web/src/main/js/apps/code/actions/index.js
+++ b/server/sonar-web/src/main/js/apps/code/actions/index.js
@@ -22,6 +22,7 @@ import { pushPath } from 'redux-simple-router';
import { getChildren, getComponent, getTree } from '../../../api/components';
import { getComponentNavigation } from '../../../api/nav';
+import { translate } from '../../../helpers/l10n';
const METRICS = [
@@ -137,15 +138,15 @@ requestTree = _.debounce(requestTree, 250);
async function getErrorMessage (response) {
switch (response.status) {
case 401:
- return window.t('not_authorized');
+ return translate('not_authorized');
default:
try {
let json = await response.json();
return json['err_msg'] ||
(json.errors && _.pluck(json.errors, 'msg').join('. ')) ||
- window.t('default_error_message');
+ translate('default_error_message');
} catch (e) {
- return window.t('default_error_message');
+ return translate('default_error_message');
}
}
}
@@ -186,5 +187,3 @@ export function search (query, baseComponent) {
}
};
}
-
-
diff --git a/server/sonar-web/src/main/js/apps/code/components/Code.js b/server/sonar-web/src/main/js/apps/code/components/Code.js
index 81f63740de2..9a2dc252558 100644
--- a/server/sonar-web/src/main/js/apps/code/components/Code.js
+++ b/server/sonar-web/src/main/js/apps/code/components/Code.js
@@ -26,6 +26,7 @@ import Breadcrumbs from './Breadcrumbs';
import SourceViewer from './SourceViewer';
import Search from './Search';
import { initComponent, browse } from '../actions';
+import { translate } from '../../../helpers/l10n';
class Code extends Component {
@@ -71,7 +72,7 @@ class Code extends Component {
return (
<div className="page">
<header className="page-header">
- <h1 className="page-title">{window.t('code.page')}</h1>
+ <h1 className="page-title">{translate('code.page')}</h1>
<div
className="pull-left"
diff --git a/server/sonar-web/src/main/js/apps/code/components/ComponentDetach.js b/server/sonar-web/src/main/js/apps/code/components/ComponentDetach.js
index 4d996238c35..37d6f62dc4e 100644
--- a/server/sonar-web/src/main/js/apps/code/components/ComponentDetach.js
+++ b/server/sonar-web/src/main/js/apps/code/components/ComponentDetach.js
@@ -20,13 +20,14 @@
import React from 'react';
import { getComponentUrl } from '../../../helpers/urls';
+import { translate } from '../../../helpers/l10n';
const ComponentDetach = ({ component }) => (
<a
className="icon-detach"
target="_blank"
- title={window.t('code.open_in_new_tab')}
+ title={translate('code.open_in_new_tab')}
href={getComponentUrl(component.key)}/>
);
diff --git a/server/sonar-web/src/main/js/apps/code/components/Components.js b/server/sonar-web/src/main/js/apps/code/components/Components.js
index 2ed8fb607e6..e86d1bf4b8b 100644
--- a/server/sonar-web/src/main/js/apps/code/components/Components.js
+++ b/server/sonar-web/src/main/js/apps/code/components/Components.js
@@ -21,6 +21,7 @@ import React from 'react';
import Component from './Component';
import ComponentsEmpty from './ComponentsEmpty';
+import { translate } from '../../../helpers/l10n';
const Components = ({ baseComponent, components, coverageMetric, onBrowse }) => (
@@ -29,11 +30,11 @@ const Components = ({ baseComponent, components, coverageMetric, onBrowse }) =>
<tr>
<th className="thin nowrap">&nbsp;</th>
<th>&nbsp;</th>
- <th className="thin nowrap text-right">{window.t('metric.ncloc.name')}</th>
- <th className="thin nowrap text-right">{window.t('metric.sqale_index.short_name')}</th>
- <th className="thin nowrap text-right">{window.t('metric.violations.name')}</th>
- <th className="thin nowrap text-right">{window.t('metric.coverage.name')}</th>
- <th className="thin nowrap text-right">{window.t('metric.duplicated_lines_density.short_name')}</th>
+ <th className="thin nowrap text-right">{translate('metric.ncloc.name')}</th>
+ <th className="thin nowrap text-right">{translate('metric.sqale_index.short_name')}</th>
+ <th className="thin nowrap text-right">{translate('metric.violations.name')}</th>
+ <th className="thin nowrap text-right">{translate('metric.coverage.name')}</th>
+ <th className="thin nowrap text-right">{translate('metric.duplicated_lines_density.short_name')}</th>
</tr>
</thead>
{baseComponent && (
diff --git a/server/sonar-web/src/main/js/apps/code/components/ComponentsEmpty.js b/server/sonar-web/src/main/js/apps/code/components/ComponentsEmpty.js
index f792add07ec..f6a5aa577a2 100644
--- a/server/sonar-web/src/main/js/apps/code/components/ComponentsEmpty.js
+++ b/server/sonar-web/src/main/js/apps/code/components/ComponentsEmpty.js
@@ -18,12 +18,13 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import React from 'react';
+import { translate } from '../../../helpers/l10n';
const ComponentsEmpty = () => (
<tr>
<td colSpan="2">
- {window.t('no_results')}
+ {translate('no_results')}
</td>
<td colSpan="5">
&nbsp;
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/app.js b/server/sonar-web/src/main/js/apps/coding-rules/app.js
index 80fe331f8d0..6e94452f88e 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/app.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/app.js
@@ -31,6 +31,7 @@ import WorkspaceListView from './workspace-list-view';
import WorkspaceHeaderView from './workspace-header-view';
import FacetsView from './facets-view';
import FiltersView from './filters-view';
+import { translate } from '../../helpers/l10n';
var App = new Marionette.Application(),
init = function () {
@@ -80,7 +81,7 @@ var App = new Marionette.Application(),
App.manualRepository = function () {
return {
key: 'manual',
- name: window.t('coding_rules.manual_rule'),
+ name: translate('coding_rules.manual_rule'),
language: 'none'
};
};
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/bulk-change-modal-view.js b/server/sonar-web/src/main/js/apps/coding-rules/bulk-change-modal-view.js
index 68f32a1d2e1..893e7d44561 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/bulk-change-modal-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/bulk-change-modal-view.js
@@ -21,6 +21,7 @@ import $ from 'jquery';
import _ from 'underscore';
import ModalFormView from '../../components/common/modal-form';
import Template from './templates/coding-rules-bulk-change-modal.hbs';
+import { translateWithParameters } from '../../helpers/l10n';
export default ModalFormView.extend({
template: Template,
@@ -34,14 +35,16 @@ export default ModalFormView.extend({
showSuccessMessage: function (profile, succeeded) {
var profileBase = _.findWhere(this.options.app.qualityProfiles, { key: profile }),
profileName = profileBase != null ? profileBase.name : profile,
- message = window.tp('coding_rules.bulk_change.success', profileName, profileBase.language, succeeded);
+ message = translateWithParameters('coding_rules.bulk_change.success',
+ profileName, profileBase.language, succeeded);
this.ui.messagesContainer.append('<div class="alert alert-success">' + message + '</div>');
},
showWarnMessage: function (profile, succeeded, failed) {
var profileBase = _.findWhere(this.options.app.qualityProfiles, { key: profile }),
profileName = profileBase != null ? profileBase.name : profile,
- message = window.tp('coding_rules.bulk_change.warning', profileName, profileBase.language, succeeded, failed);
+ message = translateWithParameters('coding_rules.bulk_change.warning',
+ profileName, profileBase.language, succeeded, failed);
this.ui.messagesContainer.append('<div class="alert alert-warning">' + message + '</div>');
},
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/facets/active-severity-facet.js b/server/sonar-web/src/main/js/apps/coding-rules/facets/active-severity-facet.js
index 855b1004c6d..99957a26d38 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/facets/active-severity-facet.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/facets/active-severity-facet.js
@@ -20,6 +20,7 @@
import _ from 'underscore';
import BaseFacet from './base-facet';
import Template from '../templates/facets/coding-rules-severity-facet.hbs';
+import { translate } from '../../../helpers/l10n';
export default BaseFacet.extend({
template: Template,
@@ -45,7 +46,7 @@ export default BaseFacet.extend({
forbid: function () {
BaseFacet.prototype.forbid.apply(this, arguments);
- this.$el.prop('title', window.t('coding_rules.filters.active_severity.inactive'));
+ this.$el.prop('title', translate('coding_rules.filters.active_severity.inactive'));
},
allow: function () {
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/facets/custom-values-facet.js b/server/sonar-web/src/main/js/apps/coding-rules/facets/custom-values-facet.js
index 56ff71d1154..4ddbf74a624 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/facets/custom-values-facet.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/facets/custom-values-facet.js
@@ -20,6 +20,7 @@
import _ from 'underscore';
import BaseFacet from './base-facet';
import Template from '../templates/facets/coding-rules-custom-values-facet.hbs';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export default BaseFacet.extend({
template: Template,
@@ -41,17 +42,17 @@ export default BaseFacet.extend({
prepareSearch: function () {
this.$('.js-custom-value').select2({
- placeholder: window.t('search_verb'),
+ placeholder: translate('search_verb'),
minimumInputLength: 1,
allowClear: false,
formatNoMatches: function () {
- return window.t('select2.noMatches');
+ return translate('select2.noMatches');
},
formatSearching: function () {
- return window.t('select2.searching');
+ return translate('select2.searching');
},
formatInputTooShort: function () {
- return window.tp('select2.tooShort', 1);
+ return translateWithParameters('select2.tooShort', 1);
},
width: '100%',
ajax: this.prepareAjaxSearch()
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/facets/inheritance-facet.js b/server/sonar-web/src/main/js/apps/coding-rules/facets/inheritance-facet.js
index 51926808077..ba48902164b 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/facets/inheritance-facet.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/facets/inheritance-facet.js
@@ -21,6 +21,7 @@ import $ from 'jquery';
import _ from 'underscore';
import BaseFacet from './base-facet';
import Template from '../templates/facets/coding-rules-inheritance-facet.hbs';
+import { translate } from '../../../helpers/l10n';
export default BaseFacet.extend({
template: Template,
@@ -49,7 +50,7 @@ export default BaseFacet.extend({
forbid: function () {
BaseFacet.prototype.forbid.apply(this, arguments);
- this.$el.prop('title', window.t('coding_rules.filters.inheritance.inactive'));
+ this.$el.prop('title', translate('coding_rules.filters.inheritance.inactive'));
},
allow: function () {
@@ -61,7 +62,7 @@ export default BaseFacet.extend({
var values = ['NONE', 'INHERITED', 'OVERRIDES'];
return values.map(function (key) {
return {
- label: window.t('coding_rules.filters.inheritance', key.toLowerCase()),
+ label: translate('coding_rules.filters.inheritance', key.toLowerCase()),
val: key
};
});
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/facets/status-facet.js b/server/sonar-web/src/main/js/apps/coding-rules/facets/status-facet.js
index 03f833d2a51..43895033e86 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/facets/status-facet.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/facets/status-facet.js
@@ -19,6 +19,7 @@
*/
import _ from 'underscore';
import BaseFacet from './base-facet';
+import { translate } from '../../../helpers/l10n';
export default BaseFacet.extend({
statuses: ['READY', 'DEPRECATED', 'BETA'],
@@ -26,7 +27,7 @@ export default BaseFacet.extend({
getValues: function () {
var values = this.model.getValues();
var x = values.map(function (value) {
- return _.extend(value, { label: window.t('rules.status', value.val.toLowerCase()) });
+ return _.extend(value, { label: translate('rules.status', value.val.toLowerCase()) });
});
return x;
},
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/rule-details-view.js b/server/sonar-web/src/main/js/apps/coding-rules/rule-details-view.js
index c44456d9c13..8cff115d460 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/rule-details-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/rule-details-view.js
@@ -32,6 +32,7 @@ import CustomRuleCreationView from './rule/custom-rule-creation-view';
import IssuesView from './rule/rule-issues-view';
import Template from './templates/coding-rules-rule-details.hbs';
import confirmDialog from './confirm-dialog';
+import { translate, translateWithParameters } from '../../helpers/l10n';
export default Marionette.LayoutView.extend({
className: 'coding-rule-details',
@@ -149,8 +150,8 @@ export default Marionette.LayoutView.extend({
var that = this,
ruleType = this.model.has('templateKey') ? 'custom' : 'manual';
confirmDialog({
- title: window.t('delete'),
- html: window.tp('coding_rules.delete.' + ruleType + '.confirm', this.model.get('name')),
+ title: translate('delete'),
+ html: translateWithParameters('coding_rules.delete.' + ruleType + '.confirm', this.model.get('name')),
yesHandler: function () {
var url = baseUrl + '/api/rules/delete',
options = { key: that.model.id };
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-creation-view.js b/server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-creation-view.js
index 5f4cbc72378..2d89ec9d009 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-creation-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-creation-view.js
@@ -23,6 +23,7 @@ import ModalFormView from '../../../components/common/modal-form';
import Template from '../templates/rule/coding-rules-custom-rule-creation.hbs';
import { csvEscape } from '../../../helpers/csv';
import latinize from '../../../helpers/latinize';
+import { translate } from '../../../helpers/l10n';
export default ModalFormView.extend({
template: Template,
@@ -172,7 +173,7 @@ export default ModalFormView.extend({
}).fail(function (jqXHR) {
if (jqXHR.status === 409) {
that.existingRule = jqXHR.responseJSON.rule;
- that.showErrors([], [{ msg: window.t('coding_rules.reactivate.help') }]);
+ that.showErrors([], [{ msg: translate('coding_rules.reactivate.help') }]);
that.ui.customRuleCreationCreate.addClass('hidden');
that.ui.customRuleCreationReactivate.removeClass('hidden');
} else {
@@ -194,7 +195,7 @@ export default ModalFormView.extend({
var statuses = ['READY', 'BETA', 'DEPRECATED'].map(function (status) {
return {
id: status,
- text: window.t('rules.status', status.toLowerCase())
+ text: translate('rules.status', status.toLowerCase())
};
});
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-view.js b/server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-view.js
index 6a0875adee6..f254c02c1b9 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/rule/custom-rule-view.js
@@ -22,6 +22,7 @@ import _ from 'underscore';
import Marionette from 'backbone.marionette';
import Template from '../templates/rule/coding-rules-custom-rule.hbs';
import confirmDialog from '../confirm-dialog';
+import { translate } from '../../../helpers/l10n';
export default Marionette.ItemView.extend({
tagName: 'tr',
@@ -38,8 +39,8 @@ export default Marionette.ItemView.extend({
deleteRule: function () {
var that = this;
confirmDialog({
- title: window.t('delete'),
- html: window.t('are_you_sure'),
+ title: translate('delete'),
+ html: translate('are_you_sure'),
yesHandler: function () {
var url = baseUrl + '/api/rules/delete',
options = { key: that.model.id };
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/rule/manual-rule-creation-view.js b/server/sonar-web/src/main/js/apps/coding-rules/rule/manual-rule-creation-view.js
index 3459339051f..8f177728063 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/rule/manual-rule-creation-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/rule/manual-rule-creation-view.js
@@ -22,6 +22,7 @@ import _ from 'underscore';
import ModalFormView from '../../../components/common/modal-form';
import Template from '../templates/rule/coding-rules-manual-rule-creation.hbs';
import latinize from '../../../helpers/latinize';
+import { translate } from '../../../helpers/l10n';
export default ModalFormView.extend({
template: Template,
@@ -118,7 +119,7 @@ export default ModalFormView.extend({
}).fail(function (jqXHR) {
if (jqXHR.status === 409) {
that.existingRule = jqXHR.responseJSON.rule;
- that.showErrors([], [{ msg: window.t('coding_rules.reactivate.help') }]);
+ that.showErrors([], [{ msg: translate('coding_rules.reactivate.help') }]);
that.ui.manualRuleCreationCreate.addClass('hidden');
that.ui.manualRuleCreationReactivate.removeClass('hidden');
} else {
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/rule/rule-description-view.js b/server/sonar-web/src/main/js/apps/coding-rules/rule/rule-description-view.js
index 0d6570dd997..91f93acb4e5 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/rule/rule-description-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/rule/rule-description-view.js
@@ -22,6 +22,7 @@ import _ from 'underscore';
import Marionette from 'backbone.marionette';
import Template from '../templates/rule/coding-rules-rule-description.hbs';
import confirmDialog from '../confirm-dialog';
+import { translate } from '../../../helpers/l10n';
export default Marionette.ItemView.extend({
template: Template,
@@ -83,7 +84,7 @@ export default Marionette.ItemView.extend({
removeExtendedDescription: function () {
var that = this;
confirmDialog({
- html: window.t('coding_rules.remove_extended_description.confirm'),
+ html: translate('coding_rules.remove_extended_description.confirm'),
yesHandler: function () {
that.ui.extendDescriptionText.val('');
that.submitExtendDescription();
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/rule/rule-profile-view.js b/server/sonar-web/src/main/js/apps/coding-rules/rule/rule-profile-view.js
index 262569496a0..98fabf7f8d4 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/rule/rule-profile-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/rule/rule-profile-view.js
@@ -24,6 +24,7 @@ import Marionette from 'backbone.marionette';
import ProfileActivationView from './profile-activation-view';
import Template from '../templates/rule/coding-rules-rule-profile.hbs';
import confirmDialog from '../confirm-dialog';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export default Marionette.ItemView.extend({
tagName: 'tr',
@@ -69,8 +70,8 @@ export default Marionette.ItemView.extend({
var that = this,
ruleKey = this.options.rule.get('key');
confirmDialog({
- title: window.t('coding_rules.revert_to_parent_definition'),
- html: window.tp('coding_rules.revert_to_parent_definition.confirm', this.getParent().name),
+ title: translate('coding_rules.revert_to_parent_definition'),
+ html: translateWithParameters('coding_rules.revert_to_parent_definition.confirm', this.getParent().name),
yesHandler: function () {
return $.ajax({
type: 'POST',
@@ -91,8 +92,8 @@ export default Marionette.ItemView.extend({
var that = this,
ruleKey = this.options.rule.get('key');
confirmDialog({
- title: window.t('coding_rules.deactivate'),
- html: window.tp('coding_rules.deactivate.confirm'),
+ title: translate('coding_rules.deactivate'),
+ html: translateWithParameters('coding_rules.deactivate.confirm'),
yesHandler: function () {
return $.ajax({
type: 'POST',
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/workspace-list-empty-view.js b/server/sonar-web/src/main/js/apps/coding-rules/workspace-list-empty-view.js
index 20bcfea8d78..f9c33a1ae3b 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/workspace-list-empty-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/workspace-list-empty-view.js
@@ -18,11 +18,12 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import Marionette from 'backbone.marionette';
+import { translate } from '../../helpers/l10n';
export default Marionette.ItemView.extend({
className: 'search-navigator-no-results',
template: function () {
- return window.t('coding_rules.no_results');
+ return translate('coding_rules.no_results');
}
});
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/workspace-list-item-view.js b/server/sonar-web/src/main/js/apps/coding-rules/workspace-list-item-view.js
index e866ee50cf5..3d9d7b6f08b 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/workspace-list-item-view.js
+++ b/server/sonar-web/src/main/js/apps/coding-rules/workspace-list-item-view.js
@@ -25,6 +25,7 @@ import ProfileActivationView from './rule/profile-activation-view';
import RuleFilterMixin from './rule/rule-filter-mixin';
import Template from './templates/coding-rules-workspace-list-item.hbs';
import confirmDialog from './confirm-dialog';
+import { translate, translateWithParameters } from '../../helpers/l10n';
export default WorkspaceListItemView.extend(RuleFilterMixin).extend({
className: 'coding-rule',
@@ -81,8 +82,8 @@ export default WorkspaceListItemView.extend(RuleFilterMixin).extend({
ruleKey = this.model.get('key'),
activation = this.model.get('activation');
confirmDialog({
- title: window.t('coding_rules.deactivate'),
- html: window.tp('coding_rules.deactivate.confirm'),
+ title: translate('coding_rules.deactivate'),
+ html: translateWithParameters('coding_rules.deactivate.confirm'),
yesHandler: function () {
return $.ajax({
type: 'POST',
diff --git a/server/sonar-web/src/main/js/apps/global-permissions/main.js b/server/sonar-web/src/main/js/apps/global-permissions/main.js
index 361a3aab7e4..ea6fdb805c6 100644
--- a/server/sonar-web/src/main/js/apps/global-permissions/main.js
+++ b/server/sonar-web/src/main/js/apps/global-permissions/main.js
@@ -20,6 +20,7 @@
import $ from 'jquery';
import React from 'react';
import PermissionsList from './permissions-list';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
getInitialState() {
@@ -48,9 +49,9 @@ export default React.createClass({
return (
<div className="page">
<header id="global-permissions-header" className="page-header">
- <h1 className="page-title">{window.t('global_permissions.page')}</h1>
+ <h1 className="page-title">{translate('global_permissions.page')}</h1>
{this.renderSpinner()}
- <p className="page-description">{window.t('global_permissions.page.description')}</p>
+ <p className="page-description">{translate('global_permissions.page.description')}</p>
</header>
<PermissionsList ready={this.state.ready} permissions={this.state.permissions}/>
</div>
diff --git a/server/sonar-web/src/main/js/apps/issues/facets/author-facet.js b/server/sonar-web/src/main/js/apps/issues/facets/author-facet.js
index fc4c2f182ae..4d72395a6d2 100644
--- a/server/sonar-web/src/main/js/apps/issues/facets/author-facet.js
+++ b/server/sonar-web/src/main/js/apps/issues/facets/author-facet.js
@@ -18,6 +18,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import CustomValuesFacet from './custom-values-facet';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export default CustomValuesFacet.extend({
getUrl: function () {
@@ -30,13 +31,13 @@ export default CustomValuesFacet.extend({
minimumInputLength: 2,
allowClear: false,
formatNoMatches: function () {
- return window.t('select2.noMatches');
+ return translate('select2.noMatches');
},
formatSearching: function () {
- return window.t('select2.searching');
+ return translate('select2.searching');
},
formatInputTooShort: function () {
- return window.tp('select2.tooShort', 2);
+ return translateWithParameters('select2.tooShort', 2);
},
width: '100%',
ajax: {
diff --git a/server/sonar-web/src/main/js/apps/issues/facets/custom-values-facet.js b/server/sonar-web/src/main/js/apps/issues/facets/custom-values-facet.js
index 11d7336b17c..ccf6ce0f8c4 100644
--- a/server/sonar-web/src/main/js/apps/issues/facets/custom-values-facet.js
+++ b/server/sonar-web/src/main/js/apps/issues/facets/custom-values-facet.js
@@ -20,6 +20,7 @@
import _ from 'underscore';
import BaseFacet from './base-facet';
import Template from '../templates/facets/issues-custom-values-facet.hbs';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export default BaseFacet.extend({
template: Template,
@@ -45,13 +46,13 @@ export default BaseFacet.extend({
minimumInputLength: 2,
allowClear: false,
formatNoMatches: function () {
- return window.t('select2.noMatches');
+ return translate('select2.noMatches');
},
formatSearching: function () {
- return window.t('select2.searching');
+ return translate('select2.searching');
},
formatInputTooShort: function () {
- return window.tp('select2.tooShort', 2);
+ return translateWithParameters('select2.tooShort', 2);
},
width: '100%',
ajax: this.prepareAjaxSearch()
diff --git a/server/sonar-web/src/main/js/apps/issues/facets/language-facet.js b/server/sonar-web/src/main/js/apps/issues/facets/language-facet.js
index 2343860a363..e1c997ff298 100644
--- a/server/sonar-web/src/main/js/apps/issues/facets/language-facet.js
+++ b/server/sonar-web/src/main/js/apps/issues/facets/language-facet.js
@@ -19,6 +19,7 @@
*/
import _ from 'underscore';
import CustomValuesFacet from './custom-values-facet';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export default CustomValuesFacet.extend({
getUrl: function () {
@@ -31,13 +32,13 @@ export default CustomValuesFacet.extend({
minimumInputLength: 2,
allowClear: false,
formatNoMatches: function () {
- return window.t('select2.noMatches');
+ return translate('select2.noMatches');
},
formatSearching: function () {
- return window.t('select2.searching');
+ return translate('select2.searching');
},
formatInputTooShort: function () {
- return window.tp('select2.tooShort', 2);
+ return translateWithParameters('select2.tooShort', 2);
},
width: '100%',
ajax: {
diff --git a/server/sonar-web/src/main/js/apps/issues/facets/project-facet.js b/server/sonar-web/src/main/js/apps/issues/facets/project-facet.js
index a1a462a0f14..cf274a18c5a 100644
--- a/server/sonar-web/src/main/js/apps/issues/facets/project-facet.js
+++ b/server/sonar-web/src/main/js/apps/issues/facets/project-facet.js
@@ -19,6 +19,7 @@
*/
import _ from 'underscore';
import CustomValuesFacet from './custom-values-facet';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export default CustomValuesFacet.extend({
@@ -47,13 +48,13 @@ export default CustomValuesFacet.extend({
minimumInputLength: 2,
allowClear: false,
formatNoMatches: function () {
- return window.t('select2.noMatches');
+ return translate('select2.noMatches');
},
formatSearching: function () {
- return window.t('select2.searching');
+ return translate('select2.searching');
},
formatInputTooShort: function () {
- return window.tp('select2.tooShort', 2);
+ return translateWithParameters('select2.tooShort', 2);
},
width: '100%',
ajax: {
diff --git a/server/sonar-web/src/main/js/apps/issues/facets/rule-facet.js b/server/sonar-web/src/main/js/apps/issues/facets/rule-facet.js
index 24f0494b60b..19458e42da5 100644
--- a/server/sonar-web/src/main/js/apps/issues/facets/rule-facet.js
+++ b/server/sonar-web/src/main/js/apps/issues/facets/rule-facet.js
@@ -19,6 +19,7 @@
*/
import _ from 'underscore';
import CustomValuesFacet from './custom-values-facet';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export default CustomValuesFacet.extend({
prepareSearch: function () {
@@ -32,13 +33,13 @@ export default CustomValuesFacet.extend({
minimumInputLength: 2,
allowClear: false,
formatNoMatches: function () {
- return window.t('select2.noMatches');
+ return translate('select2.noMatches');
},
formatSearching: function () {
- return window.t('select2.searching');
+ return translate('select2.searching');
},
formatInputTooShort: function () {
- return window.tp('select2.tooShort', 2);
+ return translateWithParameters('select2.tooShort', 2);
},
width: '100%',
ajax: {
@@ -50,7 +51,7 @@ export default CustomValuesFacet.extend({
results: function (data) {
var results;
results = data.rules.map(function (rule) {
- var lang = rule.langName || window.t('manual');
+ var lang = rule.langName || translate('manual');
return {
id: rule.key,
text: '(' + lang + ') ' + rule.name
diff --git a/server/sonar-web/src/main/js/apps/issues/facets/tag-facet.js b/server/sonar-web/src/main/js/apps/issues/facets/tag-facet.js
index 788b885cbf4..1b965c202a8 100644
--- a/server/sonar-web/src/main/js/apps/issues/facets/tag-facet.js
+++ b/server/sonar-web/src/main/js/apps/issues/facets/tag-facet.js
@@ -19,6 +19,7 @@
*/
import _ from 'underscore';
import CustomValuesFacet from './custom-values-facet';
+import { translate } from '../../../helpers/l10n';
export default CustomValuesFacet.extend({
prepareSearch: function () {
@@ -32,10 +33,10 @@ export default CustomValuesFacet.extend({
minimumInputLength: 0,
allowClear: false,
formatNoMatches: function () {
- return window.t('select2.noMatches');
+ return translate('select2.noMatches');
},
formatSearching: function () {
- return window.t('select2.searching');
+ return translate('select2.searching');
},
width: '100%',
ajax: {
diff --git a/server/sonar-web/src/main/js/apps/issues/workspace-list-empty-view.js b/server/sonar-web/src/main/js/apps/issues/workspace-list-empty-view.js
index 66023267694..edbb3750e25 100644
--- a/server/sonar-web/src/main/js/apps/issues/workspace-list-empty-view.js
+++ b/server/sonar-web/src/main/js/apps/issues/workspace-list-empty-view.js
@@ -18,11 +18,12 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import Marionette from 'backbone.marionette';
+import { translate } from '../../helpers/l10n';
export default Marionette.ItemView.extend({
className: 'search-navigator-no-results',
template: function () {
- return window.t('issue_filter.no_issues');
+ return translate('issue_filter.no_issues');
}
});
diff --git a/server/sonar-web/src/main/js/apps/overview/components/complexity-distribution.js b/server/sonar-web/src/main/js/apps/overview/components/complexity-distribution.js
index 17f375ae0e7..30a02c32db1 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/complexity-distribution.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/complexity-distribution.js
@@ -21,6 +21,7 @@ import React from 'react';
import { BarChart } from '../../../components/charts/bar-chart';
import { formatMeasure } from '../../../helpers/measures';
+import { translateWithParameters } from '../../../helpers/l10n';
const HEIGHT = 80;
@@ -41,7 +42,7 @@ export const ComplexityDistribution = React.createClass({
x: index,
y: y,
value: value,
- tooltip: window.tp(`overview.complexity_tooltip.${this.props.of}`, y, value)
+ tooltip: translateWithParameters(`overview.complexity_tooltip.${this.props.of}`, y, value)
};
});
diff --git a/server/sonar-web/src/main/js/apps/overview/components/coverage-measures.js b/server/sonar-web/src/main/js/apps/overview/components/coverage-measures.js
index e557d5cf727..3e50df5ac79 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/coverage-measures.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/coverage-measures.js
@@ -23,6 +23,7 @@ import { DetailedMeasure } from './detailed-measure';
import { DonutChart } from '../../../components/charts/donut-chart';
import { DrilldownLink } from '../../../components/shared/drilldown-link';
import { formatMeasure, formatMeasureVariation } from '../../../helpers/measures';
+import { translate } from '../../../helpers/l10n';
export const CoverageMeasures = React.createClass({
@@ -84,7 +85,7 @@ export const CoverageMeasures = React.createClass({
return <div className="overview-detailed-measure" style={{ lineHeight: '30px' }}>
<div className="overview-detailed-measure-nutshell overview-leak">
<span className="overview-detailed-measure-name">
- {window.t('metric', newCoverageMetricName, 'name')}
+ {translate('metric', newCoverageMetricName, 'name')}
</span>
</div>
@@ -127,7 +128,7 @@ export const CoverageMeasures = React.createClass({
<div className="overview-detailed-measure" style={{ lineHeight: '30px' }}>
<div className="overview-detailed-measure-nutshell">
<span className="overview-detailed-measure-name big">
- {window.t('metric', coverageMetricName, 'name')}
+ {translate('metric', coverageMetricName, 'name')}
</span>
<span className="overview-detailed-measure-value">
<span className="spacer-right">{this.renderDonut()}</span>
diff --git a/server/sonar-web/src/main/js/apps/overview/components/domain-bubble-chart.js b/server/sonar-web/src/main/js/apps/overview/components/domain-bubble-chart.js
index 557103f9a74..62859068807 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/domain-bubble-chart.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/domain-bubble-chart.js
@@ -21,7 +21,7 @@ import _ from 'underscore';
import React from 'react';
import { BubbleChart } from '../../../components/charts/bubble-chart';
-import { getComponentUrl } from '../../../helpers/urls';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
import { getFiles } from '../../../api/components';
import { formatMeasure } from '../../../helpers/measures';
import Workspace from '../../../components/workspace/main';
@@ -144,10 +144,10 @@ export class DomainBubbleChart extends React.Component {
return <div className="overview-domain-chart">
<div className="overview-card-header">
- <h2 className="overview-title">{window.t('overview.chart.files')}</h2>
+ <h2 className="overview-title">{translate('overview.chart.files')}</h2>
<ul className="list-inline small">
<li>
- {window.tp('overview.chart.legend.size_x', this.getSizeMetricsTitle())}
+ {translateWithParameters('overview.chart.legend.size_x', this.getSizeMetricsTitle())}
</li>
</ul>
</div>
@@ -160,7 +160,7 @@ export class DomainBubbleChart extends React.Component {
{this.state.xMetric.name}
</div>
{this.state.total > BUBBLES_LIMIT &&
- <div className="note text-center">{window.tp('overview.chart.files.limit_message', BUBBLES_LIMIT)}</div>}
+ <div className="note text-center">{translateWithParameters('overview.chart.files.limit_message', BUBBLES_LIMIT)}</div>}
</div>
</div>;
}
diff --git a/server/sonar-web/src/main/js/apps/overview/components/domain-timeline.js b/server/sonar-web/src/main/js/apps/overview/components/domain-timeline.js
index ad3898d5e17..40e50720eba 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/domain-timeline.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/domain-timeline.js
@@ -27,6 +27,7 @@ import { getEvents } from '../../../api/events';
import { formatMeasure, groupByDomain } from '../../../helpers/measures';
import { getShortType } from '../helpers/metrics';
import { Timeline } from './timeline-chart';
+import { translate } from '../../../helpers/l10n';
const HEIGHT = 280;
@@ -244,7 +245,7 @@ export const DomainTimeline = React.createClass({
return <div className="overview-domain-chart">
<div className="overview-card-header">
<div>
- <h2 className="overview-title">{window.t('overview.chart.history')}</h2>
+ <h2 className="overview-title">{translate('overview.chart.history')}</h2>
{this.renderTimelineMetricSelect()}
</div>
{this.renderComparisonMetricSelect()}
diff --git a/server/sonar-web/src/main/js/apps/overview/components/domain-treemap.js b/server/sonar-web/src/main/js/apps/overview/components/domain-treemap.js
index ef4eb2f3823..1c39fae9b66 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/domain-treemap.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/domain-treemap.js
@@ -24,6 +24,7 @@ import { Treemap } from '../../../components/charts/treemap';
import { getChildren } from '../../../api/components';
import { formatMeasure } from '../../../helpers/measures';
import { getComponentUrl } from '../../../helpers/urls';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
const HEIGHT = 302;
@@ -143,13 +144,13 @@ export class DomainTreemap extends React.Component {
render () {
let color = this.props.colorMetric ?
- <li>{window.tp('overview.chart.legend.color_x', this.state.colorMetric.name)}</li> : null;
+ <li>{translateWithParameters('overview.chart.legend.color_x', this.state.colorMetric.name)}</li> : null;
return <div className="overview-domain-chart">
<div className="overview-card-header">
- <h2 className="overview-title">{window.t('overview.chart.components')}</h2>
+ <h2 className="overview-title">{translate('overview.chart.components')}</h2>
<ul className="list-inline small">
<li>
- {window.tp('overview.chart.legend.size_x', this.state.sizeMetric.name)}
+ {translateWithParameters('overview.chart.legend.size_x', this.state.sizeMetric.name)}
</li>
{color}
</ul>
diff --git a/server/sonar-web/src/main/js/apps/overview/components/event.js b/server/sonar-web/src/main/js/apps/overview/components/event.js
index 26835342ae6..f333643b774 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/event.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/event.js
@@ -21,6 +21,7 @@ import React from 'react';
import moment from 'moment';
import { TooltipsMixin } from '../../../components/mixins/tooltips-mixin';
+import { translate } from '../../../helpers/l10n';
export const Event = React.createClass({
@@ -40,7 +41,7 @@ export const Event = React.createClass({
const { event } = this.props;
return <li className="spacer-top">
<p>
- <strong className="js-event-type">{window.t('event.category', event.type)}</strong>
+ <strong className="js-event-type">{translate('event.category', event.type)}</strong>
:&nbsp;
<span className="js-event-name">{event.name}</span>
{ event.text && <i className="spacer-left icon-help" data-toggle="tooltip" title={event.text}/> }
diff --git a/server/sonar-web/src/main/js/apps/overview/components/events-list-filter.js b/server/sonar-web/src/main/js/apps/overview/components/events-list-filter.js
index 9e13efd0c74..71b5e927b02 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/events-list-filter.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/events-list-filter.js
@@ -19,6 +19,7 @@
*/
import React from 'react';
import Select from 'react-select';
+import { translate } from '../../../helpers/l10n';
const TYPES = ['All', 'Version', 'Alert', 'Profile', 'Other'];
@@ -38,7 +39,7 @@ export const EventsListFilter = React.createClass({
const options = TYPES.map(type => {
return {
value: type,
- label: window.t('event.category', type)
+ label: translate('event.category', type)
};
});
return <Select value={this.props.currentFilter}
diff --git a/server/sonar-web/src/main/js/apps/overview/components/events-list.js b/server/sonar-web/src/main/js/apps/overview/components/events-list.js
index 8d2f4f1b94a..aef93084cd7 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/events-list.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/events-list.js
@@ -21,6 +21,7 @@ import React from 'react';
import { Event } from './event';
import { EventsListFilter } from './events-list-filter';
+import { translate } from '../../../helpers/l10n';
const LIMIT = 5;
@@ -64,7 +65,7 @@ export const EventsList = React.createClass({
renderMoreLink(filteredEvents) {
if (filteredEvents.length > LIMIT) {
- const text = this.state.limited ? window.t('widget.events.show_all') : window.t('hide');
+ const text = this.state.limited ? translate('widget.events.show_all') : translate('hide');
return <p className="spacer-top note">
<a onClick={this.handleClick} href="#">{text}</a>
</p>;
@@ -77,7 +78,7 @@ export const EventsList = React.createClass({
if (events.length) {
return <ul>{events.map(event => <Event key={event.id} event={event}/>)}</ul>;
} else {
- return <p className="spacer-top note">{window.t('no_results')}</p>;
+ return <p className="spacer-top note">{translate('no_results')}</p>;
}
},
@@ -86,7 +87,7 @@ export const EventsList = React.createClass({
const events = this.limitEvents(filteredEvents);
return <div className="overview-meta-card">
<div className="clearfix">
- <h4 className="pull-left overview-meta-header">{window.t('widget.events.name')}</h4>
+ <h4 className="pull-left overview-meta-header">{translate('widget.events.name')}</h4>
<div className="pull-right">
<EventsListFilter currentFilter={this.state.filter} onFilter={this.handleFilter}/>
</div>
diff --git a/server/sonar-web/src/main/js/apps/overview/components/issue-measure.js b/server/sonar-web/src/main/js/apps/overview/components/issue-measure.js
index 7be47e35000..8b6fc0fd9ab 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/issue-measure.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/issue-measure.js
@@ -25,6 +25,7 @@ import { DrilldownLink } from '../../../components/shared/drilldown-link';
import { IssuesLink } from '../../../components/shared/issues-link';
import { getShortType } from '../helpers/metrics';
import SeverityHelper from '../../../components/shared/severity-helper';
+import { translate } from '../../../helpers/l10n';
export const IssueMeasure = React.createClass({
@@ -91,7 +92,7 @@ export const AddedRemovedMeasure = React.createClass({
return <div className="overview-detailed-measure-leak">
<ul>
<li style={{ display: 'flex', alignItems: 'baseline' }}>
- <small className="flex-1 text-left">{window.t('overview.added')}</small>
+ <small className="flex-1 text-left">{translate('overview.added')}</small>
<IssuesLink className="text-danger"
component={this.props.component.key} params={{ resolved: 'false', createdAfter }}>
<span className="overview-detailed-measure-value">
@@ -100,7 +101,7 @@ export const AddedRemovedMeasure = React.createClass({
</IssuesLink>
</li>
<li className="little-spacer-top" style={{ display: 'flex', alignItems: 'baseline' }}>
- <small className="flex-1 text-left">{window.t('overview.removed')}</small>
+ <small className="flex-1 text-left">{translate('overview.removed')}</small>
<span className="text-success">
{formatMeasure(removed, getShortType(this.props.type))}
</span>
@@ -195,7 +196,7 @@ export const OnNewCodeMeasure = React.createClass({
return <div className="overview-detailed-measure-leak">
<ul>
<li className="little-spacer-top" style={{ display: 'flex', alignItems: 'center' }}>
- <small className="flex-1 text-left">{window.t('overview.on_new_code')}</small>
+ <small className="flex-1 text-left">{translate('overview.on_new_code')}</small>
<DrilldownLink component={this.props.component.key} metric={this.props.leakMetric}
period={this.props.leakPeriodIndex}>
<span className="overview-detailed-measure-value">
@@ -253,7 +254,7 @@ export const SeverityMeasure = React.createClass({
return <div className="overview-detailed-measure-leak">
<ul>
<li style={{ display: 'flex', alignItems: 'baseline' }}>
- <small className="flex-1 text-left text-ellipsis">{window.t('overview.added')}</small>
+ <small className="flex-1 text-left text-ellipsis">{translate('overview.added')}</small>
<IssuesLink className="text-danger"
component={this.props.component.key}
params={{ resolved: 'false', severities: this.props.severity, createdAfter: createdAfter }}>
@@ -263,7 +264,7 @@ export const SeverityMeasure = React.createClass({
</IssuesLink>
</li>
<li className="little-spacer-top" style={{ display: 'flex', alignItems: 'baseline' }}>
- <small className="flex-1 text-left text-ellipsis">{window.t('overview.removed')}</small>
+ <small className="flex-1 text-left text-ellipsis">{translate('overview.removed')}</small>
<span className="text-success">
{formatMeasure(removed, 'SHORT_INT')}
</span>
diff --git a/server/sonar-web/src/main/js/apps/overview/components/language-distribution.js b/server/sonar-web/src/main/js/apps/overview/components/language-distribution.js
index 54023da8416..a41c46961d6 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/language-distribution.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/language-distribution.js
@@ -23,6 +23,7 @@ import React from 'react';
import { Histogram } from '../../../components/charts/histogram';
import { formatMeasure } from '../../../helpers/measures';
import { getLanguages } from '../../../api/languages';
+import { translate } from '../../../helpers/l10n';
export const LanguageDistribution = React.createClass({
@@ -42,7 +43,7 @@ export const LanguageDistribution = React.createClass({
getLanguageName (langKey) {
if (this.state && this.state.languages) {
let lang = _.findWhere(this.state.languages, { key: langKey });
- return lang ? lang.name : window.t('unknown');
+ return lang ? lang.name : translate('unknown');
} else {
return langKey;
}
diff --git a/server/sonar-web/src/main/js/apps/overview/components/ncloc-distribution.js b/server/sonar-web/src/main/js/apps/overview/components/ncloc-distribution.js
index c0ed2396f88..5c616443847 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/ncloc-distribution.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/ncloc-distribution.js
@@ -25,6 +25,7 @@ import { formatMeasure } from '../../../helpers/measures';
import { collapsePath } from '../../../helpers/path';
import { getComponentDrilldownUrl } from '../../../helpers/urls';
import { getChildren } from '../../../api/components';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
const HEIGHT = 302;
@@ -105,9 +106,9 @@ export const NclocDistribution = React.createClass({
render () {
return <div className="overview-domain-chart">
<div className="overview-card-header">
- <h2 className="overview-title">{window.t('overview.chart.components')}</h2>
+ <h2 className="overview-title">{translate('overview.chart.components')}</h2>
<span className="small">
- {window.tp('overview.chart.legend.size_x', window.t('metric.ncloc.name'))}
+ {translateWithParameters('overview.chart.legend.size_x', translate('metric.ncloc.name'))}
</span>
</div>
<div className="overview-bar-chart">
diff --git a/server/sonar-web/src/main/js/apps/overview/domains/coverage-domain.js b/server/sonar-web/src/main/js/apps/overview/domains/coverage-domain.js
index e5b9eb00c9c..06eda8f2c48 100644
--- a/server/sonar-web/src/main/js/apps/overview/domains/coverage-domain.js
+++ b/server/sonar-web/src/main/js/apps/overview/domains/coverage-domain.js
@@ -31,6 +31,7 @@ import { filterMetrics, filterMetricsForDomains } from '../helpers/metrics';
import { DomainLeakTitle } from '../main/components';
import { CHART_REVERSED_COLORS_RANGE_PERCENT } from '../../../helpers/constants';
import { CoverageMeasuresList } from '../components/coverage-measures-list';
+import { translate } from '../../../helpers/l10n';
const TEST_DOMAINS = ['Tests', 'Tests (Integration)', 'Tests (Overall)'];
@@ -95,7 +96,7 @@ export const CoverageMain = React.createClass({
renderEmpty() {
return <div className="overview-detailed-page">
<div className="page">
- <p>{window.t('overview.no_coverage')}</p>
+ <p>{translate('overview.no_coverage')}</p>
</div>
</div>;
},
@@ -124,7 +125,7 @@ export const CoverageMain = React.createClass({
<div className="overview-cards-list">
<div className="overview-card overview-card-fixed-width">
<div className="overview-card-header">
- <div className="overview-title">{window.t('overview.domain.coverage')}</div>
+ <div className="overview-title">{translate('overview.domain.coverage')}</div>
{this.renderLegend()}
</div>
<CoverageMeasuresList {...this.props} {...this.state}/>
diff --git a/server/sonar-web/src/main/js/apps/overview/domains/debt-domain.js b/server/sonar-web/src/main/js/apps/overview/domains/debt-domain.js
index f306070c421..bdbff57b114 100644
--- a/server/sonar-web/src/main/js/apps/overview/domains/debt-domain.js
+++ b/server/sonar-web/src/main/js/apps/overview/domains/debt-domain.js
@@ -40,6 +40,7 @@ import { getFacet, extractAssignees } from '../../../api/issues';
import { Rating } from '../../../components/shared/rating';
import { DrilldownLink } from '../../../components/shared/drilldown-link';
import { DomainLeakTitle } from '../main/components';
+import { translate } from '../../../helpers/l10n';
const KNOWN_METRICS = ['violations', 'sqale_index', 'sqale_rating', 'sqale_debt_ratio', 'blocker_violations',
@@ -182,7 +183,7 @@ export const DebtMain = React.createClass({
<div className="overview-cards-list">
<div className="overview-card overview-card-fixed-width">
<div className="overview-card-header">
- <div className="overview-title">{window.t('overview.domain.debt')}</div>
+ <div className="overview-title">{translate('overview.domain.debt')}</div>
{this.renderLegend()}
</div>
@@ -209,7 +210,7 @@ export const DebtMain = React.createClass({
<div className="overview-detailed-measure">
<div className="overview-detailed-measure-nutshell">
<div className="overview-detailed-measure-name">
- {window.t('overview.unmanaged_issues')}
+ {translate('overview.unmanaged_issues')}
</div>
<div className="spacer-top">
<Assignees {...this.props} assignees={this.state.assignees}/>
diff --git a/server/sonar-web/src/main/js/apps/overview/domains/duplications-domain.js b/server/sonar-web/src/main/js/apps/overview/domains/duplications-domain.js
index c048100cc51..ab91ef521b5 100644
--- a/server/sonar-web/src/main/js/apps/overview/domains/duplications-domain.js
+++ b/server/sonar-web/src/main/js/apps/overview/domains/duplications-domain.js
@@ -33,6 +33,7 @@ import { CHART_COLORS_RANGE_PERCENT } from '../../../helpers/constants';
import { formatMeasure, formatMeasureVariation } from '../../../helpers/measures';
import { DonutChart } from '../../../components/charts/donut-chart';
import { DrilldownLink } from '../../../components/shared/drilldown-link';
+import { translate } from '../../../helpers/l10n';
export const DuplicationsMain = React.createClass({
@@ -89,7 +90,7 @@ export const DuplicationsMain = React.createClass({
renderEmpty() {
return <div className="overview-detailed-page">
<div className="page">
- <p>{window.t('overview.no_duplications')}</p>
+ <p>{translate('overview.no_duplications')}</p>
</div>
</div>;
},
@@ -157,7 +158,7 @@ export const DuplicationsMain = React.createClass({
<div className="overview-cards-list">
<div className="overview-card overview-card-fixed-width">
<div className="overview-card-header">
- <div className="overview-title">{window.t('overview.domain.duplications')}</div>
+ <div className="overview-title">{translate('overview.domain.duplications')}</div>
{this.renderLegend()}
</div>
<div className="overview-detailed-measures-list">
diff --git a/server/sonar-web/src/main/js/apps/overview/domains/structure-domain.js b/server/sonar-web/src/main/js/apps/overview/domains/structure-domain.js
index a57eeca5c25..c1199d9732c 100644
--- a/server/sonar-web/src/main/js/apps/overview/domains/structure-domain.js
+++ b/server/sonar-web/src/main/js/apps/overview/domains/structure-domain.js
@@ -29,6 +29,7 @@ import { getPeriodLabel, getPeriodDate } from './../helpers/periods';
import { TooltipsMixin } from '../../../components/mixins/tooltips-mixin';
import { filterMetrics, filterMetricsForDomains } from '../helpers/metrics';
import { DomainLeakTitle } from '../main/components';
+import { translate } from '../../../helpers/l10n';
export const StructureMain = React.createClass({
@@ -168,7 +169,7 @@ export const StructureMain = React.createClass({
return <div className="overview-detailed-page">
<div className="overview-card">
<div className="overview-card-header">
- <div className="overview-title">{window.t('overview.domain.structure')}</div>
+ <div className="overview-title">{translate('overview.domain.structure')}</div>
{this.renderLegend()}
</div>
diff --git a/server/sonar-web/src/main/js/apps/overview/gate/gate-condition.js b/server/sonar-web/src/main/js/apps/overview/gate/gate-condition.js
index f237ba4eff5..bed48f92f7e 100644
--- a/server/sonar-web/src/main/js/apps/overview/gate/gate-condition.js
+++ b/server/sonar-web/src/main/js/apps/overview/gate/gate-condition.js
@@ -22,6 +22,7 @@ import React from 'react';
import { getPeriodLabel, getPeriodDate } from '../helpers/periods';
import { DrilldownLink } from '../../../components/shared/drilldown-link';
import { formatMeasure } from '../../../helpers/measures';
+import { translate } from '../../../helpers/l10n';
const Measure = React.createClass({
@@ -37,7 +38,7 @@ const Measure = React.createClass({
export default React.createClass({
render() {
- let metricName = window.t('metric', this.props.condition.metric.name, 'name');
+ let metricName = translate('metric', this.props.condition.metric.name, 'name');
let threshold = this.props.condition.level === 'ERROR' ?
this.props.condition.error : this.props.condition.warning;
let period = this.props.condition.period ?
@@ -63,7 +64,7 @@ export default React.createClass({
<div className="overview-gate-condition-metric">
<div>{metricName}</div>
<div>
- {window.t('quality_gates.operator', this.props.condition.op, 'short')}
+ {translate('quality_gates.operator', this.props.condition.op, 'short')}
{' '}
<Measure value={threshold} type={this.props.condition.metric.type}/>
</div>
diff --git a/server/sonar-web/src/main/js/apps/overview/gate/gate-empty.js b/server/sonar-web/src/main/js/apps/overview/gate/gate-empty.js
index a915ea17f9b..30368e463f0 100644
--- a/server/sonar-web/src/main/js/apps/overview/gate/gate-empty.js
+++ b/server/sonar-web/src/main/js/apps/overview/gate/gate-empty.js
@@ -18,6 +18,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import React from 'react';
+import { translate } from '../../../helpers/l10n';
export default React.createClass({
render() {
@@ -25,7 +26,7 @@ export default React.createClass({
return (
<div className="overview-gate">
- <h2 className="overview-title">{window.t('overview.quality_gate')}</h2>
+ <h2 className="overview-title">{translate('overview.quality_gate')}</h2>
<p className="overview-gate-warning">
You should <a href={qualityGatesUrl}>define</a> a quality gate on this project.</p>
</div>
diff --git a/server/sonar-web/src/main/js/apps/overview/gate/gate.js b/server/sonar-web/src/main/js/apps/overview/gate/gate.js
index 28e6bc23e19..01830260759 100644
--- a/server/sonar-web/src/main/js/apps/overview/gate/gate.js
+++ b/server/sonar-web/src/main/js/apps/overview/gate/gate.js
@@ -21,6 +21,7 @@ import React from 'react';
import GateConditions from './gate-conditions';
import GateEmpty from './gate-empty';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export default React.createClass({
@@ -31,11 +32,11 @@ export default React.createClass({
renderGateText () {
let text = '';
if (this.props.gate.level === 'ERROR') {
- text = window.tp('overview.gate.view.errors', this.props.gate.text);
+ text = translateWithParameters('overview.gate.view.errors', this.props.gate.text);
} else if (this.props.gate.level === 'WARN') {
- text = window.tp('overview.gate.view.warnings', this.props.gate.text);
+ text = translateWithParameters('overview.gate.view.warnings', this.props.gate.text);
} else {
- text = window.t('overview.gate.view.no_alert');
+ text = translate('overview.gate.view.no_alert');
}
return <div className="overview-card">{text}</div>;
},
@@ -47,12 +48,12 @@ export default React.createClass({
let level = this.props.gate.level.toLowerCase();
let badgeClassName = 'badge badge-' + level;
- let badgeText = window.t('overview.gate', this.props.gate.level);
+ let badgeText = translate('overview.gate', this.props.gate.level);
return (
<div className="overview-gate">
<h2 className="overview-title">
- {window.t('overview.quality_gate')}
+ {translate('overview.quality_gate')}
<span className={badgeClassName}>{badgeText}</span>
</h2>
{this.props.gate.conditions ? this.renderGateConditions() : this.renderGateText()}
diff --git a/server/sonar-web/src/main/js/apps/overview/helpers/metrics.js b/server/sonar-web/src/main/js/apps/overview/helpers/metrics.js
index f1c4ea34522..c224dfcd3af 100644
--- a/server/sonar-web/src/main/js/apps/overview/helpers/metrics.js
+++ b/server/sonar-web/src/main/js/apps/overview/helpers/metrics.js
@@ -17,6 +17,8 @@
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
+import { translate } from '../../../helpers/l10n';
+
function hasRightDomain (metric, domains) {
return domains.indexOf(metric.domain) !== -1;
}
@@ -55,5 +57,5 @@ export function getShortType (type) {
export function getMetricName (metricKey) {
- return window.t('overview.metric', metricKey);
+ return translate('overview.metric', metricKey);
}
diff --git a/server/sonar-web/src/main/js/apps/overview/helpers/periods.js b/server/sonar-web/src/main/js/apps/overview/helpers/periods.js
index 4542500f319..8458eb1298a 100644
--- a/server/sonar-web/src/main/js/apps/overview/helpers/periods.js
+++ b/server/sonar-web/src/main/js/apps/overview/helpers/periods.js
@@ -19,6 +19,7 @@
*/
import _ from 'underscore';
import moment from 'moment';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export function getPeriodLabel (periods, periodIndex) {
@@ -27,9 +28,9 @@ export function getPeriodLabel (periods, periodIndex) {
return null;
}
if (period.mode === 'previous_version' && !period.modeParam) {
- return window.t('overview.period.previous_version_only_date');
+ return translate('overview.period.previous_version_only_date');
}
- return window.tp(`overview.period.${period.mode}`, period.modeParam);
+ return translateWithParameters(`overview.period.${period.mode}`, period.modeParam);
}
diff --git a/server/sonar-web/src/main/js/apps/overview/main/components.js b/server/sonar-web/src/main/js/apps/overview/main/components.js
index e5c7c37ef8b..fe4b6ca2fd6 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/components.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/components.js
@@ -21,6 +21,7 @@ import moment from 'moment';
import React from 'react';
import { Timeline } from './timeline';
+import { translate, translateWithParameters } from '../../../helpers/l10n';
export const Domain = React.createClass({
@@ -39,7 +40,7 @@ export const DomainTitle = React.createClass({
<div className="overview-title">
{this.props.children}
<a className="small big-spacer-left link-no-underline" href={url}>
- {window.t('more')}&nbsp;
+ {translate('more')}&nbsp;
<i className="icon-chevron-right" style={{ position: 'relative', top: -1 }}/>
</a>
</div>
@@ -54,8 +55,8 @@ export const DomainTitle = React.createClass({
export const DomainLeakTitle = React.createClass({
renderInline (tooltip, fromNow) {
return <span className="overview-domain-leak-title" title={tooltip} data-toggle="tooltip">
- <span>{window.tp('overview.leak_period_x', this.props.label)}</span>
- <span className="note spacer-left">{window.tp('overview.started_x', fromNow)}</span>
+ <span>{translateWithParameters('overview.leak_period_x', this.props.label)}</span>
+ <span className="note spacer-left">{translateWithParameters('overview.started_x', fromNow)}</span>
</span>;
},
@@ -70,9 +71,9 @@ export const DomainLeakTitle = React.createClass({
return this.renderInline(tooltip, fromNow);
}
return <span className="overview-domain-leak-title" title={tooltip} data-toggle="tooltip">
- <span>{window.tp('overview.leak_period_x', this.props.label)}</span>
+ <span>{translateWithParameters('overview.leak_period_x', this.props.label)}</span>
<br/>
- <span className="note">{window.tp('overview.started_x', fromNow)}</span>
+ <span className="note">{translateWithParameters('overview.started_x', fromNow)}</span>
</span>;
}
});
@@ -158,7 +159,11 @@ export const DomainMixin = {
renderTimelineStartDate() {
let momentDate = moment(this.props.historyStartDate);
let fromNow = momentDate.fromNow();
- return <span className="overview-domain-timeline-date">{window.tp('overview.started_x', fromNow)}</span>;
+ return (
+ <span className="overview-domain-timeline-date">
+ {translateWithParameters('overview.started_x', fromNow)}
+ </span>
+ );
},
renderTimeline(range, displayDate) {
diff --git a/server/sonar-web/src/main/js/apps/overview/main/coverage.js b/server/sonar-web/src/main/js/apps/overview/main/coverage.js
index 3b6357d1213..1e113516c2c 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/coverage.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/coverage.js
@@ -32,6 +32,7 @@ import { TooltipsMixin } from '../../../components/mixins/tooltips-mixin';
import { DonutChart } from '../../../components/charts/donut-chart';
import { getMetricName } from '../helpers/metrics';
import { formatMeasure } from '../../../helpers/measures';
+import { translate } from '../../../helpers/l10n';
export const GeneralCoverage = React.createClass({
@@ -105,7 +106,7 @@ export const GeneralCoverage = React.createClass({
return <Domain>
<DomainHeader component={this.props.component}
- title={window.t('overview.domain.coverage')}
+ title={translate('overview.domain.coverage')}
linkTo="/coverage"/>
<DomainPanel>
diff --git a/server/sonar-web/src/main/js/apps/overview/main/debt.js b/server/sonar-web/src/main/js/apps/overview/main/debt.js
index 411befd414a..47034a6f6c8 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/debt.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/debt.js
@@ -35,6 +35,7 @@ import { TooltipsMixin } from '../../../components/mixins/tooltips-mixin';
import { Legend } from '../components/legend';
import { getMetricName } from '../helpers/metrics';
import { formatMeasure } from '../../../helpers/measures';
+import { translate } from '../../../helpers/l10n';
export const GeneralDebt = React.createClass({
@@ -76,7 +77,7 @@ export const GeneralDebt = React.createClass({
render () {
return <Domain>
<DomainHeader component={this.props.component}
- title={window.t('overview.domain.debt')}
+ title={translate('overview.domain.debt')}
linkTo="/debt"/>
<DomainPanel>
diff --git a/server/sonar-web/src/main/js/apps/overview/main/duplications.js b/server/sonar-web/src/main/js/apps/overview/main/duplications.js
index f6869971b7e..857c32ca55e 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/duplications.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/duplications.js
@@ -32,6 +32,7 @@ import { TooltipsMixin } from '../../../components/mixins/tooltips-mixin';
import { DonutChart } from '../../../components/charts/donut-chart';
import { getMetricName } from '../helpers/metrics';
import { formatMeasure, formatMeasureVariation } from '../../../helpers/measures';
+import { translate } from '../../../helpers/l10n';
export const GeneralDuplications = React.createClass({
@@ -77,7 +78,7 @@ export const GeneralDuplications = React.createClass({
return <Domain>
<DomainHeader component={this.props.component}
- title={window.t('overview.domain.duplications')}
+ title={translate('overview.domain.duplications')}
linkTo="/duplications"/>
<DomainPanel>
diff --git a/server/sonar-web/src/main/js/apps/overview/main/structure.js b/server/sonar-web/src/main/js/apps/overview/main/structure.js
index d06d14af65c..12a93592b95 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/structure.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/structure.js
@@ -32,6 +32,7 @@ import { TooltipsMixin } from '../../../components/mixins/tooltips-mixin';
import { getMetricName } from '../helpers/metrics';
import { formatMeasure, formatMeasureVariation } from '../../../helpers/measures';
import { LanguageDistribution } from '../components/language-distribution';
+import { translate } from '../../../helpers/l10n';
export const GeneralStructure = React.createClass({
@@ -71,7 +72,7 @@ export const GeneralStructure = React.createClass({
render () {
return <Domain>
<DomainHeader component={this.props.component}
- title={window.t('overview.domain.structure')}
+ title={translate('overview.domain.structure')}
linkTo="/structure"/>
<DomainPanel>
diff --git a/server/sonar-web/src/main/js/apps/overview/meta.js b/server/sonar-web/src/main/js/apps/overview/meta.js
index 5a9a44f84ac..3506f29c1ad 100644
--- a/server/sonar-web/src/main/js/apps/overview/meta.js
+++ b/server/sonar-web/src/main/js/apps/overview/meta.js
@@ -25,6 +25,7 @@ import { QualityProfileLink } from './../../components/shared/quality-profile-li
import { QualityGateLink } from './../../components/shared/quality-gate-link';
import { getEvents } from '../../api/events';
import { EventsList } from './components/events-list';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
@@ -96,14 +97,14 @@ export default React.createClass({
let profilesCard = !this.isView() && !this.isDeveloper() && _.size(this.props.component.profiles) > 0 ? (
<div className="overview-meta-card">
- <h4 className="overview-meta-header">{window.t('overview.quality_profiles')}</h4>
+ <h4 className="overview-meta-header">{translate('overview.quality_profiles')}</h4>
<ul className="overview-meta-list">{profiles}</ul>
</div>
) : null;
let gateCard = !this.isView() && !this.isDeveloper() && this.props.component.gate ? (
<div className="overview-meta-card">
- <h4 className="overview-meta-header">{window.t('overview.quality_gate')}</h4>
+ <h4 className="overview-meta-header">{translate('overview.quality_gate')}</h4>
<ul className="overview-meta-list">
<li>
{this.props.component.gate.isDefault ?
diff --git a/server/sonar-web/src/main/js/apps/overview/overview.js b/server/sonar-web/src/main/js/apps/overview/overview.js
index ca7e46e117f..d9ff5e64543 100644
--- a/server/sonar-web/src/main/js/apps/overview/overview.js
+++ b/server/sonar-web/src/main/js/apps/overview/overview.js
@@ -29,6 +29,7 @@ import { DebtMain } from './domains/debt-domain';
import { getMetrics } from '../../api/metrics';
import { RouterMixin } from '../../components/router/router';
+import { translate } from '../../helpers/l10n';
export const Overview = React.createClass({
@@ -113,7 +114,7 @@ export const EmptyOverview = React.createClass({
return (
<div className="page">
<div className="alert alert-warning">
- {window.t('provisioning.no_analysis')}
+ {translate('provisioning.no_analysis')}
</div>
</div>
);
diff --git a/server/sonar-web/src/main/js/apps/permission-templates/header.js b/server/sonar-web/src/main/js/apps/permission-templates/header.js
index fd496137ba3..95c653fa0b5 100644
--- a/server/sonar-web/src/main/js/apps/permission-templates/header.js
+++ b/server/sonar-web/src/main/js/apps/permission-templates/header.js
@@ -19,6 +19,7 @@
*/
import React from 'react';
import CreateView from './create-view';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
onCreate(e) {
@@ -38,12 +39,12 @@ export default React.createClass({
render() {
return (
<header id="project-permissions-header" className="page-header">
- <h1 className="page-title">{window.t('permission_templates.page')}</h1>
+ <h1 className="page-title">{translate('permission_templates.page')}</h1>
{this.renderSpinner()}
<div className="page-actions">
<button onClick={this.onCreate}>Create</button>
</div>
- <p className="page-description">{window.t('roles.page.description')}</p>
+ <p className="page-description">{translate('roles.page.description')}</p>
</header>
);
}
diff --git a/server/sonar-web/src/main/js/apps/permission-templates/permission-template-defaults.js b/server/sonar-web/src/main/js/apps/permission-templates/permission-template-defaults.js
index 81768d78af1..c3b14929147 100644
--- a/server/sonar-web/src/main/js/apps/permission-templates/permission-template-defaults.js
+++ b/server/sonar-web/src/main/js/apps/permission-templates/permission-template-defaults.js
@@ -20,6 +20,7 @@
import _ from 'underscore';
import React from 'react';
import QualifierIcon from '../../components/shared/qualifier-icon';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
propTypes: {
@@ -37,7 +38,7 @@ export default React.createClass({
renderIfMultipleTopQualifiers() {
let defaults = this.props.permissionTemplate.defaultFor.map(qualifier => {
- return <li key={qualifier}><QualifierIcon qualifier={qualifier}/>&nbsp;{window.t('qualifier', qualifier)}</li>;
+ return <li key={qualifier}><QualifierIcon qualifier={qualifier}/>&nbsp;{translate('qualifier', qualifier)}</li>;
});
return (
<ul className="list-inline nowrap spacer-bottom">
diff --git a/server/sonar-web/src/main/js/apps/permission-templates/permission-template-set-defaults.js b/server/sonar-web/src/main/js/apps/permission-templates/permission-template-set-defaults.js
index b785faf7c64..fdfaf924beb 100644
--- a/server/sonar-web/src/main/js/apps/permission-templates/permission-template-set-defaults.js
+++ b/server/sonar-web/src/main/js/apps/permission-templates/permission-template-set-defaults.js
@@ -21,6 +21,7 @@ import _ from 'underscore';
import React from 'react';
import { setDefaultPermissionTemplate } from '../../api/permissions';
import QualifierIcon from '../../components/shared/qualifier-icon';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
propTypes: {
@@ -55,7 +56,7 @@ export default React.createClass({
return (
<li key={qualifier}>
<a onClick={this.setDefault.bind(this, qualifier)} href="#">
- Set Default for <QualifierIcon qualifier={qualifier}/> {window.t('qualifier', qualifier)}
+ Set Default for <QualifierIcon qualifier={qualifier}/> {translate('qualifier', qualifier)}
</a>
</li>
);
diff --git a/server/sonar-web/src/main/js/apps/project-permissions/main.js b/server/sonar-web/src/main/js/apps/project-permissions/main.js
index 033f6a13f2d..7028384ff6a 100644
--- a/server/sonar-web/src/main/js/apps/project-permissions/main.js
+++ b/server/sonar-web/src/main/js/apps/project-permissions/main.js
@@ -25,6 +25,7 @@ import Permissions from './permissions';
import PermissionsFooter from './permissions-footer';
import Search from './search';
import ApplyTemplateView from './apply-template-view';
+import { translate } from '../../helpers/l10n';
const PERMISSIONS_ORDER = ['user', 'codeviewer', 'issueadmin', 'admin'];
@@ -132,12 +133,12 @@ export default React.createClass({
return (
<div className="page">
<header id="project-permissions-header" className="page-header">
- <h1 className="page-title">{window.t('roles.page')}</h1>
+ <h1 className="page-title">{translate('roles.page')}</h1>
{this.renderSpinner()}
<div className="page-actions">
{this.renderBulkApplyButton()}
</div>
- <p className="page-description">{window.t('roles.page.description2')}</p>
+ <p className="page-description">{translate('roles.page.description2')}</p>
</header>
<Search {...this.props}
diff --git a/server/sonar-web/src/main/js/apps/project-permissions/qualifier-filter.js b/server/sonar-web/src/main/js/apps/project-permissions/qualifier-filter.js
index 563f6a2b9e0..e514803c0ca 100644
--- a/server/sonar-web/src/main/js/apps/project-permissions/qualifier-filter.js
+++ b/server/sonar-web/src/main/js/apps/project-permissions/qualifier-filter.js
@@ -18,6 +18,7 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import React from 'react';
+import { translate } from '../../helpers/l10n';
import RadioToggle from '../../components/shared/radio-toggle';
@@ -26,7 +27,7 @@ const rootQualifiersToOptions = (qualifiers) => {
return qualifiers.map(q => {
return {
value: q,
- label: window.t('qualifiers', q)
+ label: translate('qualifiers', q)
};
});
};
diff --git a/server/sonar-web/src/main/js/apps/projects/search.js b/server/sonar-web/src/main/js/apps/projects/search.js
index 4b17fd2b804..ba94920a966 100644
--- a/server/sonar-web/src/main/js/apps/projects/search.js
+++ b/server/sonar-web/src/main/js/apps/projects/search.js
@@ -23,6 +23,7 @@ import { TYPE, QUALIFIERS_ORDER } from './constants';
import DeleteView from './delete-view';
import RadioToggle from '../../components/shared/radio-toggle';
import Checkbox from '../../components/shared/checkbox';
+import { translate } from '../../helpers/l10n';
export default React.createClass({
propTypes: {
@@ -49,7 +50,7 @@ export default React.createClass({
getQualifierOptions() {
let options = this.props.topLevelQualifiers.map(q => {
- return { value: q, label: window.t('qualifiers', q) };
+ return { value: q, label: translate('qualifiers', q) };
});
return _.sortBy(options, option => {
return QUALIFIERS_ORDER.indexOf(option.value);
@@ -82,7 +83,7 @@ export default React.createClass({
if (this.props.type !== TYPE.GHOSTS || !this.props.ready) {
return null;
}
- return <div className="spacer-top alert alert-info">{window.t('bulk_deletion.ghosts.description')}</div>;
+ return <div className="spacer-top alert alert-info">{translate('bulk_deletion.ghosts.description')}</div>;
},
deleteProjects() {
diff --git a/server/sonar-web/src/main/js/apps/quality-gates/gate-condition-view.js b/server/sonar-web/src/main/js/apps/quality-gates/gate-condition-view.js
index d20325015b8..3b377dc0afd 100644
--- a/server/sonar-web/src/main/js/apps/quality-gates/gate-condition-view.js
+++ b/server/sonar-web/src/main/js/apps/quality-gates/gate-condition-view.js
@@ -21,6 +21,7 @@ import _ from 'underscore';
import Marionette from 'backbone.marionette';
import DeleteConditionView from './gate-conditions-delete-view';
import Template from './templates/quality-gate-detail-condition.hbs';
+import { translate } from '../../helpers/l10n';
export default Marionette.ItemView.extend({
tagName: 'tr',
@@ -109,7 +110,7 @@ export default Marionette.ItemView.extend({
return _.extend(Marionette.ItemView.prototype.serializeData.apply(this, arguments), {
canEdit: this.options.canEdit,
periods: this.options.periods,
- periodText: period ? period.text : window.t('value'),
+ periodText: period ? period.text : translate('value'),
metric: this.getMetric(),
isDiffMetric: this.isDiffMetric()
});
diff --git a/server/sonar-web/src/main/js/apps/quality-gates/gate-conditions-view.js b/server/sonar-web/src/main/js/apps/quality-gates/gate-conditions-view.js
index 542c6ce5f24..b159e42fb2e 100644
--- a/server/sonar-web/src/main/js/apps/quality-gates/gate-conditions-view.js
+++ b/server/sonar-web/src/main/js/apps/quality-gates/gate-conditions-view.js
@@ -23,6 +23,7 @@ import Condition from './condition';
import ConditionView from './gate-condition-view';
import ConditionsEmptyView from './gate-conditions-empty-view';
import Template from './templates/quality-gate-detail-conditions.hbs';
+import { translate } from '../../helpers/l10n';
export default Marionette.CompositeView.extend({
template: Template,
@@ -53,7 +54,7 @@ export default Marionette.CompositeView.extend({
this.ui.metricSelect.select2({
allowClear: false,
width: '250px',
- placeholder: window.t('alerts.select_metric')
+ placeholder: translate('alerts.select_metric')
});
},
diff --git a/server/sonar-web/src/main/js/apps/quality-gates/gate-projects-view.js b/server/sonar-web/src/main/js/apps/quality-gates/gate-projects-view.js
index 7c1d884b4a7..3a655d32778 100644
--- a/server/sonar-web/src/main/js/apps/quality-gates/gate-projects-view.js
+++ b/server/sonar-web/src/main/js/apps/quality-gates/gate-projects-view.js
@@ -21,6 +21,7 @@ import _ from 'underscore';
import Marionette from 'backbone.marionette';
import Template from './templates/quality-gate-detail-projects.hbs';
import '../../components/common/select-list';
+import { translate } from '../../helpers/l10n';
export default Marionette.ItemView.extend({
template: Template,
@@ -44,14 +45,14 @@ export default Marionette.ItemView.extend({
selectParameter: 'projectId',
selectParameterValue: 'id',
labels: {
- selected: window.t('quality_gates.projects.with'),
- deselected: window.t('quality_gates.projects.without'),
- all: window.t('quality_gates.projects.all'),
- noResults: window.t('quality_gates.projects.noResults')
+ selected: translate('quality_gates.projects.with'),
+ deselected: translate('quality_gates.projects.without'),
+ all: translate('quality_gates.projects.all'),
+ noResults: translate('quality_gates.projects.noResults')
},
tooltips: {
- select: window.t('quality_gates.projects.select_hint'),
- deselect: window.t('quality_gates.projects.deselect_hint')
+ select: translate('quality_gates.projects.select_hint'),
+ deselect: translate('quality_gates.projects.deselect_hint')
}
});
}
diff --git a/server/sonar-web/src/main/js/apps/quality-profiles/profile-details-view.js b/server/sonar-web/src/main/js/apps/quality-profiles/profile-details-view.js
index a8b903dd562..0f8e9bbb1c7 100644
--- a/server/sonar-web/src/main/js/apps/quality-profiles/profile-details-view.js
+++ b/server/sonar-web/src/main/js/apps/quality-profiles/profile-details-view.js
@@ -25,6 +25,7 @@ import ProfileChangelogView from './profile-changelog-view';
import ProfileComparisonView from './profile-comparison-view';
import '../../components/common/select-list';
import Template from './templates/quality-profiles-profile-details.hbs';
+import { translate } from '../../helpers/l10n';
export default Marionette.LayoutView.extend({
template: Template,
@@ -92,14 +93,14 @@ export default Marionette.LayoutView.extend({
selectParameter: 'projectUuid',
selectParameterValue: 'uuid',
labels: {
- selected: window.t('quality_gates.projects.with'),
- deselected: window.t('quality_gates.projects.without'),
- all: window.t('quality_gates.projects.all'),
- noResults: window.t('quality_gates.projects.noResults')
+ selected: translate('quality_gates.projects.with'),
+ deselected: translate('quality_gates.projects.without'),
+ all: translate('quality_gates.projects.all'),
+ noResults: translate('quality_gates.projects.noResults')
},
tooltips: {
- select: window.t('quality_profiles.projects.select_hint'),
- deselect: window.t('quality_profiles.projects.deselect_hint')
+ select: translate('quality_profiles.projects.select_hint'),
+ deselect: translate('quality_profiles.projects.deselect_hint')
}
});
this.listenTo(this.projectsSelectList.collection, 'change:selected', this.onProjectsChange);
diff --git a/server/sonar-web/src/main/js/apps/system/item-log-level.js b/server/sonar-web/src/main/js/apps/system/item-log-level.js
index e832bd086eb..e6977c40d5b 100644
--- a/server/sonar-web/src/main/js/apps/system/item-log-level.js
+++ b/server/sonar-web/src/main/js/apps/system/item-log-level.js
@@ -19,6 +19,7 @@
*/
import React from 'react';
import { setLogLevel } from '../../api/system';
+import { translate } from '../../helpers/l10n';
const LOG_LEVELS = ['INFO', 'DEBUG', 'TRACE'];
@@ -40,7 +41,7 @@ export default React.createClass({
});
let warning = this.state.level !== 'INFO' ? (
<div className="alert alert-danger spacer-top" style={{ wordBreak: 'normal' }}>
- {window.t('system.log_level.warning')}
+ {translate('system.log_level.warning')}
</div>
) : null;
return <div>
diff --git a/server/sonar-web/src/main/js/apps/system/main.js b/server/sonar-web/src/main/js/apps/system/main.js
index ef37a6600f0..17615da1265 100644
--- a/server/sonar-web/src/main/js/apps/system/main.js
+++ b/server/sonar-web/src/main/js/apps/system/main.js
@@ -21,6 +21,7 @@ import _ from 'underscore';
import React from 'react';
import { getSystemInfo } from '../../api/system';
import Section from './section';
+import { translate } from '../../helpers/l10n';
const SECTIONS_ORDER = ['SonarQube', 'Database', 'Plugins', 'System', 'ElasticSearch', 'JvmProperties',
'ComputeEngine'];
@@ -62,7 +63,7 @@ export default React.createClass({
return <div className="page">
<header className="page-header">
- <h1 className="page-title">{window.t('system_info.page')}</h1>
+ <h1 className="page-title">{translate('system_info.page')}</h1>
<div className="page-actions">
<a className="spacer-right" href={window.baseUrl + '/api/system/logs'} id="logs-link">Logs</a>
<a href={window.baseUrl + '/api/system/info'} id="download-link">Download</a>