2015-07-26 13:05:54 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
define([
|
|
|
|
'underscore',
|
|
|
|
'react',
|
|
|
|
'templates/app/components/common/progress/index'
|
|
|
|
], function(_, React, template) {
|
|
|
|
return React.createClass({
|
|
|
|
render: template,
|
|
|
|
_computePercent: function() {
|
|
|
|
var build = this.props.build;
|
|
|
|
return Math.round((Date.now() - build.startDate) /
|
|
|
|
build.project.avgBuildDuration * 100);
|
|
|
|
},
|
|
|
|
componentDidMount: function() {
|
2015-11-19 18:24:13 +00:00
|
|
|
var self = this;
|
|
|
|
var updateCallback = function() {
|
2015-07-26 13:05:54 +00:00
|
|
|
if (self.props.build.status === 'in-progress') {
|
2015-11-19 18:24:13 +00:00
|
|
|
if (self.isMounted()) {
|
|
|
|
self.setState({percent: self._computePercent()});
|
|
|
|
_.delay(updateCallback, 100);
|
|
|
|
}
|
2015-07-26 13:05:54 +00:00
|
|
|
}
|
2015-11-19 18:24:13 +00:00
|
|
|
};
|
|
|
|
|
2015-07-26 13:05:54 +00:00
|
|
|
updateCallback();
|
|
|
|
},
|
|
|
|
getInitialState: function() {
|
|
|
|
return {
|
|
|
|
percent: this._computePercent()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|