aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps/component-measures/details/drilldown/ComponentCell.js
diff options
context:
space:
mode:
Diffstat (limited to 'server/sonar-web/src/main/js/apps/component-measures/details/drilldown/ComponentCell.js')
-rw-r--r--server/sonar-web/src/main/js/apps/component-measures/details/drilldown/ComponentCell.js78
1 files changed, 78 insertions, 0 deletions
diff --git a/server/sonar-web/src/main/js/apps/component-measures/details/drilldown/ComponentCell.js b/server/sonar-web/src/main/js/apps/component-measures/details/drilldown/ComponentCell.js
new file mode 100644
index 00000000000..558c80219d4
--- /dev/null
+++ b/server/sonar-web/src/main/js/apps/component-measures/details/drilldown/ComponentCell.js
@@ -0,0 +1,78 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2016 SonarSource SA
+ * mailto:contact AT sonarsource DOT com
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+import React from 'react';
+import classNames from 'classnames';
+
+import QualifierIcon from '../../../../components/shared/qualifier-icon';
+import { splitPath } from '../../../../helpers/path';
+import { getComponentUrl } from '../../../../helpers/urls';
+
+const ComponentCell = ({ component, isSelected, onClick }) => {
+ const linkClassName = classNames('link-no-underline', {
+ 'selected': isSelected
+ });
+
+ const handleClick = (e) => {
+ e.preventDefault();
+ onClick();
+ };
+
+ const { head, tail } = splitPath(component.path || component.name);
+
+ const inner = (
+ <span title={component.refKey || component.key}>
+ <QualifierIcon qualifier={component.qualifier}/>
+ &nbsp;
+ {head.length > 0 && (
+ <span className="note">{head}/</span>
+ )}
+ <span>{tail}</span>
+ </span>
+ );
+
+ return (
+ <td style={{ maxWidth: 0 }}>
+ <div style={{ maxWidth: '100%', whiteSpace: 'nowrap', overflow: 'hidden', textOverflow: 'ellipsis' }}>
+ {component.refId == null ? (
+ <a
+ id={'component-measures-component-link-' + component.key}
+ className={linkClassName}
+ href="#"
+ onClick={handleClick}>
+ {inner}
+ </a>
+ ) : (
+ <a
+ id={'component-measures-component-link-' + component.key}
+ className={linkClassName}
+ href={getComponentUrl(component.key)}>
+ <span className="big-spacer-right">
+ <i className="icon-detach"/>
+ </span>
+
+ {inner}
+ </a>
+ )}
+ </div>
+ </td>
+ );
+};
+
+export default ComponentCell;