aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/domain-timeline.js10
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/timeline-chart.js83
2 files changed, 17 insertions, 76 deletions
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 220aff4556a..7275a408e0b 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
@@ -33,10 +33,6 @@ export const DomainTimeline = React.createClass({
};
},
- componentWillMount () {
- this.handleScan = _.debounce(this.handleScan, 10, true);
- },
-
componentDidMount () {
Promise.all([
this.requestTimeMachineData(this.state.currentMetric, this.state.comparisonMetric),
@@ -93,10 +89,6 @@ export const DomainTimeline = React.createClass({
return groupByDomain(this.props.metrics);
},
- handleScan(scanner) {
- this.setState({ scanner });
- },
-
renderLoading () {
return <div className="overview-chart-placeholder" style={{ height: HEIGHT }}>
<i className="spinner"/>
@@ -149,8 +141,6 @@ export const DomainTimeline = React.createClass({
formatValue={formatValue}
formatYTick={formatYTick}
leakPeriodDate={this.props.leakPeriodDate}
- scanner={this.state.scanner}
- onScan={this.handleScan}
padding={[25, 25, 25, 60]}/>
</div>;
},
diff --git a/server/sonar-web/src/main/js/apps/overview/components/timeline-chart.js b/server/sonar-web/src/main/js/apps/overview/components/timeline-chart.js
index c9783bdfc34..62610c2f190 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/timeline-chart.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/timeline-chart.js
@@ -26,7 +26,7 @@ export const Timeline = React.createClass({
},
getInitialState() {
- return { width: this.props.width, height: this.props.height, scanner: 0 };
+ return { width: this.props.width, height: this.props.height };
},
getRatingScale(availableHeight) {
@@ -54,14 +54,12 @@ export const Timeline = React.createClass({
}
},
- handleMouseMove(xScale, e) {
- const x = e.pageX - this.refs.container.getBoundingClientRect().left;
- const scanner = this.props.data
- .reduce((previousValue, currentValue) => {
- return Math.abs(xScale(currentValue.x) - x) < Math.abs(xScale(previousValue.x) - x) ?
- currentValue : previousValue;
- }, _.first(this.props.data));
- this.props.onScan(scanner.x);
+ handleEventMouseEnter(event) {
+ $(`.js-event-circle-${event.date.getTime()}`).tooltip('show');
+ },
+
+ handleEventMouseLeave(event) {
+ $(`.js-event-circle-${event.date.getTime()}`).tooltip('hide');
},
renderHorizontalGrid (xScale, yScale) {
@@ -100,36 +98,6 @@ export const Timeline = React.createClass({
return <g>{ticks}</g>;
},
- renderBackdrop (xScale, yScale) {
- let opts = {
- x: _.first(xScale.range()),
- y: _.last(yScale.range()),
- width: _.last(xScale.range()) - _.first(xScale.range()),
- height: _.first(yScale.range()) - _.last(yScale.range()),
- style: {
- opacity: 0
- }
- };
- return <rect {...opts} ref="container" onMouseMove={this.handleMouseMove.bind(this, xScale)}/>;
- },
-
- renderScanner (xScale, yScale) {
- if (this.props.scanner == null) {
- return null;
- }
- let snapshotIndex = this.props.data.findIndex(snapshot => {
- return snapshot.x.getTime() === this.props.scanner.getTime();
- });
- $(this.refs[`snapshot${snapshotIndex}`]).tooltip('show');
- return <line
- style={{ opacity: 0 }}
- className="line-chart-grid"
- x1={xScale(this.props.scanner)}
- y1={_.first(yScale.range())}
- x2={xScale(this.props.scanner)}
- y2={_.last(yScale.range())}/>;
- },
-
renderLeak (xScale, yScale) {
if (!this.props.leakPeriodDate) {
return null;
@@ -152,27 +120,6 @@ export const Timeline = React.createClass({
return <path className="line-chart-path" d={path(this.props.data)}/>;
},
- renderTooltips(xScale, yScale) {
- let points = this.props.data
- .map(snapshot => {
- let event = this.props.events.find(e => snapshot.x.getTime() === e.date.getTime());
- return _.extend(snapshot, { event });
- })
- .map((snapshot, index) => {
- let tooltipLines = [];
- if (snapshot.event) {
- tooltipLines.push(`<span class="nowrap">${snapshot.event.version}</span>`);
- }
- tooltipLines.push(`<span class="nowrap">${moment(snapshot.x).format('LL')}</span>`);
- tooltipLines.push(`<span class="nowrap">${snapshot.y ? this.props.formatValue(snapshot.y) : '—'}</span>`);
- let tooltip = tooltipLines.join('<br>');
- return <circle key={index} ref={`snapshot${index}`} style={{ opacity: 0 }}
- r="4" cx={xScale(snapshot.x)} cy={yScale(snapshot.y)}
- data-toggle="tooltip" title={tooltip}/>;
- });
- return <g>{points}</g>;
- },
-
renderEvents(xScale, yScale) {
let points = this.props.events
.map(event => {
@@ -182,14 +129,21 @@ export const Timeline = React.createClass({
.filter(event => event.snapshot)
.map(event => {
let key = `${event.date.getTime()}-${event.snapshot.y}`;
+ let className = `line-chart-point js-event-circle-${event.date.getTime()}`;
let tooltip = [
`<span class="nowrap">${event.version}</span>`,
`<span class="nowrap">${moment(event.date).format('LL')}</span>`,
`<span class="nowrap">${event.snapshot.y ? this.props.formatValue(event.snapshot.y) : '—'}</span>`
].join('<br>');
- return <circle key={key} className="line-chart-point"
- r="4" cx={xScale(event.snapshot.x)} cy={yScale(event.snapshot.y)}
- data-toggle="tooltip" data-title={tooltip}/>;
+ return <circle key={key}
+ className={className}
+ r="4"
+ cx={xScale(event.snapshot.x)}
+ cy={yScale(event.snapshot.y)}
+ onMouseEnter={this.handleEventMouseEnter.bind(this, event)}
+ onMouseLeave={this.handleEventMouseLeave.bind(this, event)}
+ data-toggle="tooltip"
+ data-title={tooltip}/>;
});
return <g>{points}</g>;
},
@@ -214,10 +168,7 @@ export const Timeline = React.createClass({
{this.renderHorizontalGrid(xScale, yScale)}
{this.renderTicks(xScale, yScale)}
{this.renderLine(xScale, yScale)}
- {this.renderTooltips(xScale, yScale)}
{this.renderEvents(xScale, yScale)}
- {this.renderScanner(xScale, yScale)}
- {this.renderBackdrop(xScale, yScale)}
</g>
</svg>;
}