2015-05-17 13:48:16 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
define([
|
|
|
|
'react',
|
2015-07-11 15:15:18 +00:00
|
|
|
'react-router',
|
2015-05-17 13:48:16 +00:00
|
|
|
'reflux',
|
|
|
|
'app/actions/build',
|
|
|
|
'app/stores/build',
|
|
|
|
'app/components/terminal/terminal',
|
2015-05-19 20:48:20 +00:00
|
|
|
'templates/app/components/builds/view',
|
|
|
|
'app/components/common/index'
|
2015-05-17 13:48:16 +00:00
|
|
|
], function(
|
2015-07-11 15:15:18 +00:00
|
|
|
React, Router, Reflux, BuildActions, buildStore, TerminalComponent, template,
|
2015-05-19 20:48:20 +00:00
|
|
|
CommonComponents
|
2015-05-17 13:48:16 +00:00
|
|
|
) {
|
|
|
|
template = template.locals({
|
2015-05-19 20:48:20 +00:00
|
|
|
DateTime: CommonComponents.DateTime,
|
2015-08-26 19:16:06 +00:00
|
|
|
Duration: CommonComponents.Duration,
|
2015-07-11 15:15:18 +00:00
|
|
|
Scm: CommonComponents.Scm,
|
|
|
|
Terminal: TerminalComponent,
|
|
|
|
Link: Router.Link
|
2015-05-17 13:48:16 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
var Component = React.createClass({
|
|
|
|
mixins: [Reflux.ListenerMixin],
|
2015-07-11 18:31:23 +00:00
|
|
|
statics: {
|
|
|
|
willTransitionTo: function(transition, params, query) {
|
|
|
|
BuildActions.read(Number(params.id));
|
|
|
|
}
|
|
|
|
},
|
2015-05-17 13:48:16 +00:00
|
|
|
componentDidMount: function() {
|
|
|
|
this.listenTo(buildStore, this.updateBuild);
|
|
|
|
},
|
|
|
|
updateBuild: function(build) {
|
|
|
|
if (!this.state.build && build) {
|
|
|
|
BuildActions.readTerminalOutput(build);
|
|
|
|
}
|
|
|
|
this.setState({build: build});
|
|
|
|
},
|
|
|
|
render: template,
|
|
|
|
getInitialState: function() {
|
|
|
|
return {
|
|
|
|
build: null
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return Component;
|
|
|
|
});
|