/*** @jsx React.DOM */ var all_players = createReactClass({ getInitialState: function(props) { return { players: window.players, jubility: true, }; }, componentDidMount: function() { this.refreshPlayers(); }, refreshPlayers: function() { AJAX.get( Link.get('refresh'), function(response) { this.setState({ players: response.players, }); // Refresh every 30 seconds setTimeout(this.refreshPlayers, 30000); }.bind(this) ); }, render: function() { return (
{ player.name }; }.bind(this), sort: function(aid, bid) { var a = this.state.players[aid]; var b = this.state.players[bid]; return a.name.localeCompare(b.name); }.bind(this), }, { name: 'Jubeat ID', render: function(userid) { var player = this.state.players[userid]; return player.extid; }.bind(this), sort: function(aid, bid) { var a = this.state.players[aid]; var b = this.state.players[bid]; return a.extid.localeCompare(b.extid); }.bind(this), }, { name: 'Total Rounds', render: function(userid) { var player = this.state.players[userid]; return player.plays; }.bind(this), sort: function(aid, bid) { var a = this.state.players[aid]; var b = this.state.players[bid]; return a.plays - b.plays; }.bind(this), reverse: true, }, { name: Jubility , render: function(userid) { var player = this.state.players[userid]; if (this.state.jubility && (player.common_jubility != 0 || player.pick_up_jubility != 0)) { return (player.common_jubility + player.pick_up_jubility).toFixed(1); } else if (!this.state.jubility && player.jubility != 0) { return player.jubility / 100 } else { return ""; } }.bind(this), sort: function(aid, bid) { var a = this.state.players[aid]; var b = this.state.players[bid]; if (this.state.jubility) { if (a.common_jubility != 0 || a.pick_up_jubility != 0) var ajub = a.common_jubility+a.pick_up_jubility; else var ajub = 0; if (b.common_jubility != 0 || b.pick_up_jubility != 0) var bjub = b.common_jubility+b.pick_up_jubility; else var bjub = 0; } else { if (a.jubility != 0) var ajub = a.jubility / 100; else var ajub = 0; if (b.jubility != 0) var bjub = b.jubility / 100; else var bjub = 0; } return ajub-bjub; }.bind(this), reverse: true, }, ]} rows={Object.keys(this.state.players)} paginate={10} /> ); }, }); ReactDOM.render( React.createElement(all_players, null), document.getElementById('content') );