twister-react/jsx/common/ProfileBoard.js
2015-04-30 11:22:58 +02:00

46 lines
1.2 KiB
JavaScript

var ReactBootstrap = require('react-bootstrap')
, NavItem = ReactBootstrap.NavItem
, Nav = ReactBootstrap.Nav
, ListGroup = ReactBootstrap.ListGroup
, ListGroupItem = ReactBootstrap.ListGroupItem
, Panel = ReactBootstrap.Panel
, Glyphicon = ReactBootstrap.Glyphicon
, Button = ReactBootstrap.Button
var React = require('react/addons');
var ReactCSSTransitionGroup = React.addons.CSSTransitionGroup;
var Post = require("../common/Post.js");
module.exports = Postboard = React.createClass({
render: function() {
var thisComponent = this;
var profiles = this.props.data.map(function(username, index) {
return (
<MiniProfile username={username} key={"miniprofile:"+username} pollIntervalProfile={thisComponent.props.pollIntervalProfile}/>
);
});
if (this.props.loading) {
var spinner = (
<ListGroupItem><p className="text-center"><img src="img/bouncing_ball.gif"/></p></ListGroupItem>
);
} else {
var spinner = (<span/>);
}
return (
<ListGroup fill>
{this.props.header}
{spinner}
<ReactCSSTransitionGroup transitionName="item">
{profiles}
</ReactCSSTransitionGroup>
</ListGroup>
);
}
});