format channel_store to more closely match style guide and sort channels in channel store over sidebar

This commit is contained in:
JoramWilander
2015-08-11 11:55:23 -04:00
parent e52405f47a
commit 4127c2b258
2 changed files with 230 additions and 226 deletions

View File

@@ -113,22 +113,9 @@ function getStateFromStores() {
});
}
var channels = ChannelStore.getAll();
if (channels) {
channels.sort(function chanSort(a, b) {
if (a.display_name.toLowerCase() < b.display_name.toLowerCase()) {
return -1;
}
if (a.display_name.toLowerCase() > b.display_name.toLowerCase()) {
return 1;
}
return 0;
});
}
return {
activeId: currentId,
channels: channels,
channels: ChannelStore.getAll(),
members: members,
showDirectChannels: showDirectChannels,
hideDirectChannels: readDirectChannels

View File

@@ -10,247 +10,264 @@ var ActionTypes = Constants.ActionTypes;
var BrowserStore = require('../stores/browser_store.jsx');
var CHANGE_EVENT = 'change';
var MORE_CHANGE_EVENT = 'change';
var EXTRA_INFO_EVENT = 'extra_info';
var ChannelStore = assign({}, EventEmitter.prototype, {
_current_id: null,
emitChange: function() {
this.emit(CHANGE_EVENT);
},
addChangeListener: function(callback) {
this.on(CHANGE_EVENT, callback);
},
removeChangeListener: function(callback) {
this.removeListener(CHANGE_EVENT, callback);
},
emitMoreChange: function() {
this.emit(MORE_CHANGE_EVENT);
},
addMoreChangeListener: function(callback) {
this.on(MORE_CHANGE_EVENT, callback);
},
removeMoreChangeListener: function(callback) {
this.removeListener(MORE_CHANGE_EVENT, callback);
},
emitExtraInfoChange: function() {
this.emit(EXTRA_INFO_EVENT);
},
addExtraInfoChangeListener: function(callback) {
this.on(EXTRA_INFO_EVENT, callback);
},
removeExtraInfoChangeListener: function(callback) {
this.removeListener(EXTRA_INFO_EVENT, callback);
},
findFirstBy: function(field, value) {
var channels = this._getChannels();
for (var i = 0; i < channels.length; i++) {
if (channels[i][field] == value) {
return channels[i];
}
}
_currentId: null,
emitChange: function() {
this.emit(CHANGE_EVENT);
},
addChangeListener: function(callback) {
this.on(CHANGE_EVENT, callback);
},
removeChangeListener: function(callback) {
this.removeListener(CHANGE_EVENT, callback);
},
emitMoreChange: function() {
this.emit(MORE_CHANGE_EVENT);
},
addMoreChangeListener: function(callback) {
this.on(MORE_CHANGE_EVENT, callback);
},
removeMoreChangeListener: function(callback) {
this.removeListener(MORE_CHANGE_EVENT, callback);
},
emitExtraInfoChange: function() {
this.emit(EXTRA_INFO_EVENT);
},
addExtraInfoChangeListener: function(callback) {
this.on(EXTRA_INFO_EVENT, callback);
},
removeExtraInfoChangeListener: function(callback) {
this.removeListener(EXTRA_INFO_EVENT, callback);
},
findFirstBy: function(field, value) {
var channels = this._getChannels();
for (var i = 0; i < channels.length; i++) {
if (channels[i][field] === value) {
return channels[i];
}
}
return null;
},
get: function(id) {
return this.findFirstBy('id', id);
},
getMember: function(id) {
return this.getAllMembers()[id];
},
getByName: function(name) {
return this.findFirstBy('name', name);
},
getAll: function() {
return this._getChannels();
},
getAllMembers: function() {
return this._getChannelMembers();
},
getMoreAll: function() {
return this._getMoreChannels();
},
setCurrentId: function(id) {
this._current_id = id;
},
setLastVisitedName: function(name) {
if (name == null)
BrowserStore.removeItem("last_visited_name");
else
BrowserStore.setItem("last_visited_name", name);
},
getLastVisitedName: function() {
return BrowserStore.getItem("last_visited_name");
},
resetCounts: function(id) {
var cm = this._getChannelMembers();
for (var cmid in cm) {
if (cm[cmid].channel_id == id) {
var c = this.get(id);
if (c) {
cm[cmid].msg_count = this.get(id).total_msg_count;
cm[cmid].mention_count = 0;
}
break;
}
}
this._storeChannelMembers(cm);
},
getCurrentId: function() {
return this._current_id;
},
getCurrent: function() {
var currentId = this.getCurrentId();
return null;
},
get: function(id) {
return this.findFirstBy('id', id);
},
getMember: function(id) {
return this.getAllMembers()[id];
},
getByName: function(name) {
return this.findFirstBy('name', name);
},
getAll: function() {
return this._getChannels();
},
getAllMembers: function() {
return this._getChannelMembers();
},
getMoreAll: function() {
return this._getMoreChannels();
},
setCurrentId: function(id) {
this._currentId = id;
},
setLastVisitedName: function(name) {
if (name == null) {
BrowserStore.removeItem('last_visited_name');
} else {
BrowserStore.setItem('last_visited_name', name);
}
},
getLastVisitedName: function() {
return BrowserStore.getItem('last_visited_name');
},
resetCounts: function(id) {
var cm = this._getChannelMembers();
for (var cmid in cm) {
if (cm[cmid].channel_id === id) {
var c = this.get(id);
if (c) {
cm[cmid].msg_count = this.get(id).total_msg_count;
cm[cmid].mention_count = 0;
}
break;
}
}
this._storeChannelMembers(cm);
},
getCurrentId: function() {
return this._currentId;
},
getCurrent: function() {
var currentId = this.getCurrentId();
if (currentId)
return this.get(currentId);
else
return null;
},
getCurrentMember: function() {
var currentId = ChannelStore.getCurrentId();
if (currentId) {
return this.get(currentId);
} else {
return null;
}
},
getCurrentMember: function() {
var currentId = ChannelStore.getCurrentId();
if (currentId)
return this.getAllMembers()[currentId];
else
return null;
},
setChannelMember: function(member) {
var members = this._getChannelMembers();
members[member.channel_id] = member;
this._storeChannelMembers(members);
this.emitChange();
},
getCurrentExtraInfo: function() {
var currentId = ChannelStore.getCurrentId();
var extra = null;
if (currentId) {
return this.getAllMembers()[currentId];
} else {
return null;
}
},
setChannelMember: function(member) {
var members = this._getChannelMembers();
members[member.channel_id] = member;
this._storeChannelMembers(members);
this.emitChange();
},
getCurrentExtraInfo: function() {
var currentId = ChannelStore.getCurrentId();
var extra = null;
if (currentId)
extra = this._getExtraInfos()[currentId];
if (currentId) {
extra = this._getExtraInfos()[currentId];
}
if (extra == null)
extra = {members: []};
if (extra == null) {
extra = {members: []};
}
return extra;
},
getExtraInfo: function(channel_id) {
var extra = null;
return extra;
},
getExtraInfo: function(channelId) {
var extra = null;
if (channel_id)
extra = this._getExtraInfos()[channel_id];
if (channelId) {
extra = this._getExtraInfos()[channelId];
}
if (extra == null)
extra = {members: []};
if (extra == null) {
extra = {members: []};
}
return extra;
},
_storeChannel: function(channel) {
var channels = this._getChannels();
var found;
return extra;
},
_storeChannel: function(channel) {
var channels = this._getChannels();
var found;
for (var i = 0; i < channels.length; i++) {
if (channels[i].id == channel.id) {
channels[i] = channel;
found = true;
break;
}
}
for (var i = 0; i < channels.length; i++) {
if (channels[i].id === channel.id) {
channels[i] = channel;
found = true;
break;
}
}
if (!found) {
channels.push(channel);
channels.sort(function(a,b) {
if (a.display_name < b.display_name) return -1;
if (a.display_name > b.display_name) return 1;
return 0;
if (!found) {
channels.push(channel);
}
channels.sort(function chanSort(a, b) {
if (a.display_name.toLowerCase() < b.display_name.toLowerCase()) {
return -1;
}
if (a.display_name.toLowerCase() > b.display_name.toLowerCase()) {
return 1;
}
return 0;
});
}
this._storeChannels(channels);
},
_storeChannels: function(channels) {
BrowserStore.setItem("channels", channels);
},
_getChannels: function() {
return BrowserStore.getItem("channels", []);
},
_storeChannelMember: function(channelMember) {
var members = this._getChannelMembers();
members[channelMember.channel_id] = channelMember;
this._storeChannelMembers(members);
},
_storeChannelMembers: function(channelMembers) {
BrowserStore.setItem("channel_members", channelMembers);
},
_getChannelMembers: function() {
return BrowserStore.getItem("channel_members", {});
},
_storeMoreChannels: function(channels) {
BrowserStore.setItem("more_channels", channels);
},
_getMoreChannels: function() {
var channels = BrowserStore.getItem("more_channels");
if (channels == null) {
channels = {};
channels.loading = true;
}
this._storeChannels(channels);
},
_storeChannels: function(channels) {
BrowserStore.setItem('channels', channels);
},
_getChannels: function() {
return BrowserStore.getItem('channels', []);
},
_storeChannelMember: function(channelMember) {
var members = this._getChannelMembers();
members[channelMember.channel_id] = channelMember;
this._storeChannelMembers(members);
},
_storeChannelMembers: function(channelMembers) {
BrowserStore.setItem('channel_members', channelMembers);
},
_getChannelMembers: function() {
return BrowserStore.getItem('channel_members', {});
},
_storeMoreChannels: function(channels) {
BrowserStore.setItem('more_channels', channels);
},
_getMoreChannels: function() {
var channels = BrowserStore.getItem('more_channels');
return channels;
},
_storeExtraInfos: function(extraInfos) {
BrowserStore.setItem("extra_infos", extraInfos);
},
_getExtraInfos: function() {
return BrowserStore.getItem("extra_infos", {});
},
isDefault: function(channel) {
return channel.name == Constants.DEFAULT_CHANNEL;
}
if (channels == null) {
channels = {};
channels.loading = true;
}
return channels;
},
_storeExtraInfos: function(extraInfos) {
BrowserStore.setItem('extra_infos', extraInfos);
},
_getExtraInfos: function() {
return BrowserStore.getItem('extra_infos', {});
},
isDefault: function(channel) {
return channel.name === Constants.DEFAULT_CHANNEL;
}
});
ChannelStore.dispatchToken = AppDispatcher.register(function(payload) {
var action = payload.action;
var action = payload.action;
var currentId;
switch(action.type) {
switch(action.type) {
case ActionTypes.CLICK_CHANNEL:
ChannelStore.setCurrentId(action.id);
ChannelStore.setLastVisitedName(action.name);
ChannelStore.resetCounts(action.id);
ChannelStore.emitChange();
break;
case ActionTypes.CLICK_CHANNEL:
ChannelStore.setCurrentId(action.id);
ChannelStore.setLastVisitedName(action.name);
ChannelStore.resetCounts(action.id);
ChannelStore.emitChange();
break;
case ActionTypes.RECIEVED_CHANNELS:
ChannelStore._storeChannels(action.channels);
ChannelStore._storeChannelMembers(action.members);
var currentId = ChannelStore.getCurrentId();
if (currentId) ChannelStore.resetCounts(currentId);
ChannelStore.emitChange();
break;
case ActionTypes.RECIEVED_CHANNELS:
ChannelStore._storeChannels(action.channels);
ChannelStore._storeChannelMembers(action.members);
currentId = ChannelStore.getCurrentId();
if (currentId) {
ChannelStore.resetCounts(currentId);
}
ChannelStore.emitChange();
break;
case ActionTypes.RECIEVED_CHANNEL:
ChannelStore._storeChannel(action.channel);
ChannelStore._storeChannelMember(action.member);
var currentId = ChannelStore.getCurrentId();
if (currentId) ChannelStore.resetCounts(currentId);
ChannelStore.emitChange();
break;
case ActionTypes.RECIEVED_CHANNEL:
ChannelStore._storeChannel(action.channel);
ChannelStore._storeChannelMember(action.member);
currentId = ChannelStore.getCurrentId();
if (currentId) {
ChannelStore.resetCounts(currentId);
}
ChannelStore.emitChange();
break;
case ActionTypes.RECIEVED_MORE_CHANNELS:
ChannelStore._storeMoreChannels(action.channels);
ChannelStore.emitMoreChange();
break;
case ActionTypes.RECIEVED_MORE_CHANNELS:
ChannelStore._storeMoreChannels(action.channels);
ChannelStore.emitMoreChange();
break;
case ActionTypes.RECIEVED_CHANNEL_EXTRA_INFO:
var extra_infos = ChannelStore._getExtraInfos();
extra_infos[action.extra_info.id] = action.extra_info;
ChannelStore._storeExtraInfos(extra_infos);
ChannelStore.emitExtraInfoChange();
break;
case ActionTypes.RECIEVED_CHANNEL_EXTRA_INFO:
var extraInfos = ChannelStore._getExtraInfos();
extraInfos[action.extra_info.id] = action.extra_info;
ChannelStore._storeExtraInfos(extraInfos);
ChannelStore.emitExtraInfoChange();
break;
default:
}
default:
}
});
module.exports = ChannelStore;