var React = require('react'); var Reflux = require('reflux'); var _ = require('lodash'); var channelStore = require('../stores/channel'); var privateChatStore = require('../stores/privateChat'); var serverStore = require('../stores/server'); var selectedTabStore = require('../stores/selectedTab'); var tabActions = require('../actions/tab'); var routeActions = require('../actions/route'); var TabList = React.createClass({ mixins: [ Reflux.connect(channelStore, 'channels'), Reflux.connect(privateChatStore, 'privateChats'), Reflux.connect(selectedTabStore, 'selectedTab'), Reflux.connect(serverStore, 'servers') ], getInitialState: function() { return { channels: channelStore.getState(), privateChats: privateChatStore.getState(), selectedTab: selectedTabStore.getState(), servers: serverStore.getState() }; }, handleConnectClick: function() { routeActions.navigate('connect'); }, handleSettingsClick: function() { routeActions.navigate('settings'); }, render: function() { var self = this; var tabClass; var selected = this.state.selectedTab; var tabs = _.map(this.state.channels, function(server, address) { var channels = _.map(server, function(channel, name) { if (address === selected.server && name === selected.channel) { tabClass = 'selected'; } else { tabClass = ''; } return (
{name}
); }); _.each(self.state.privateChats[address], function(chat, nick) { if (address === selected.server && nick === selected.channel) { tabClass = 'selected'; } else { tabClass = ''; } channels.push({nick}
); }); if (address === selected.server && selected.channel === null) { tabClass = 'tab-server selected'; } else { tabClass = 'tab-server'; } channels.unshift({serverStore.getName(address)}
); return channels; }); return (