docs/src/ContainerHome.react.js

132 lines
3.8 KiB
JavaScript

var _ = require('underscore');
var $ = require('jquery');
var React = require('react/addons');
var ContainerStore = require('./ContainerStore');
var Router = require('react-router');
var Radial = require('./Radial.react');
var ContainerHomePreview = require('./ContainerHomePreview.react');
var ContainerHomeLogs = require('./ContainerHomeLogs.react');
var ContainerHomeFolders = require('./ContainerHomeFolders.react');
var ContainerUtil = require('./ContainerUtil');
var resizeWindow = function () {
$('.left .wrapper').height(window.innerHeight - 240);
$('.right .wrapper').height(window.innerHeight / 2 - 100);
};
var ContainerHome = React.createClass({
mixins: [Router.State, Router.Navigation],
getInitialState: function () {
return {
ports: {},
defaultPort: null
};
},
handleResize: function () {
resizeWindow();
},
componentWillReceiveProps: function () {
this.init();
},
componentDidMount: function() {
this.init();
ContainerStore.on(ContainerStore.SERVER_PROGRESS_EVENT, this.updateProgress);
resizeWindow();
window.addEventListener('resize', this.handleResize);
},
componentWillUnmount: function() {
ContainerStore.removeListener(ContainerStore.SERVER_PROGRESS_EVENT, this.updateProgress);
window.removeEventListener('resize', this.handleResize);
},
componentDidUpdate: function () {
resizeWindow();
},
init: function () {
var container = ContainerStore.container(this.getParams().name);
if (!container) {
return;
}
var ports = ContainerUtil.ports(container);
var webPorts = ['80', '8000', '8080', '3000', '5000', '2368'];
this.setState({
ports: ports,
defaultPort: _.find(_.keys(ports), function (port) {
return webPorts.indexOf(port) !== -1;
}),
progress: ContainerStore.progress(this.getParams().name)
});
},
updateProgress: function (name) {
if (name === this.getParams().name) {
this.setState({
progress: ContainerStore.progress(name)
});
}
},
render: function () {
var body;
if (this.props.container && this.props.container.State.Downloading) {
if (this.state.progress) {
body = (
<div className="details-progress">
<h2>Downloading Image</h2>
<Radial progress={Math.min(Math.round(this.state.progress * 100), 99)} thick={true} gray={true}/>
</div>
);
} else {
body = (
<div className="details-progress">
<h2>Connecting to Docker Hub</h2>
<Radial spin="true" progress="90" thick={true} transparent={true}/>
</div>
);
}
} else {
if (this.state.defaultPort) {
body = (
<div className="details-panel home">
<div className="content">
<div className="left">
<ContainerHomePreview />
</div>
<div className="right">
<ContainerHomeLogs/>
<ContainerHomeFolders container={this.props.container} />
</div>
</div>
</div>
);
} else {
var right;
if (_.keys(this.state.ports) > 0) {
right = (
<div className="right">
<ContainerHomePreview />
<ContainerHomeFolders container={this.props.container} />
</div>
);
} else {
right = (
<div className="right">
<ContainerHomeFolders container={this.props.container} />
</div>
);
}
body = (
<div className="details-panel home">
<div className="content">
<div className="left">
<ContainerHomeLogs/>
</div>
{right}
</div>
</div>
);
}
}
return body;
}
});
module.exports = ContainerHome;