summaryrefslogtreecommitdiffstats
path: root/webapp/stores
diff options
context:
space:
mode:
Diffstat (limited to 'webapp/stores')
-rw-r--r--webapp/stores/channel_store.jsx5
-rw-r--r--webapp/stores/notification_store.jsx5
-rw-r--r--webapp/stores/preference_store.jsx5
-rw-r--r--webapp/stores/team_store.jsx77
4 files changed, 85 insertions, 7 deletions
diff --git a/webapp/stores/channel_store.jsx b/webapp/stores/channel_store.jsx
index af7238267..0264ada4a 100644
--- a/webapp/stores/channel_store.jsx
+++ b/webapp/stores/channel_store.jsx
@@ -215,6 +215,10 @@ class ChannelStoreClass extends EventEmitter {
return this.channels;
}
+ getChannelById(id) {
+ return this.channels.filter((c) => c.id === id)[0];
+ }
+
storeMyChannelMember(channelMember) {
const members = Object.assign({}, this.getMyMembers());
members[channelMember.channel_id] = channelMember;
@@ -348,7 +352,6 @@ ChannelStore.dispatchToken = AppDispatcher.register((payload) => {
switch (action.type) {
case ActionTypes.CLICK_CHANNEL:
ChannelStore.setCurrentId(action.id);
- ChannelStore.resetCounts(action.id);
ChannelStore.setPostMode(ChannelStore.POST_MODE_CHANNEL);
ChannelStore.emitChange();
break;
diff --git a/webapp/stores/notification_store.jsx b/webapp/stores/notification_store.jsx
index 9d0e6c790..878ac3c9d 100644
--- a/webapp/stores/notification_store.jsx
+++ b/webapp/stores/notification_store.jsx
@@ -45,7 +45,7 @@ class NotificationStoreClass extends EventEmitter {
}
const teamId = msgProps.team_id;
- const channel = ChannelStore.get(post.channel_id);
+ let channel = ChannelStore.get(post.channel_id);
const user = UserStore.getCurrentUser();
const member = ChannelStore.getMyMember(post.channel_id);
@@ -72,6 +72,9 @@ class NotificationStoreClass extends EventEmitter {
let title = Utils.localizeMessage('channel_loader.posted', 'Posted');
if (!channel) {
title = msgProps.channel_display_name;
+ channel = {
+ name: msgProps.channel_name
+ };
} else if (channel.type === Constants.DM_CHANNEL) {
title = Utils.localizeMessage('notification.dm', 'Direct Message');
} else {
diff --git a/webapp/stores/preference_store.jsx b/webapp/stores/preference_store.jsx
index 8aecfff40..3197ac7e9 100644
--- a/webapp/stores/preference_store.jsx
+++ b/webapp/stores/preference_store.jsx
@@ -140,9 +140,12 @@ class PreferenceStore extends EventEmitter {
}
this.emitChange();
break;
+ case ActionTypes.CLICK_CHANNEL:
+ this.setPreference(action.team_id, 'channel', action.id);
+ break;
}
}
}
global.PreferenceStore = new PreferenceStore();
-export default global.PreferenceStore; \ No newline at end of file
+export default global.PreferenceStore;
diff --git a/webapp/stores/team_store.jsx b/webapp/stores/team_store.jsx
index 7775a4a3a..bb0926ec5 100644
--- a/webapp/stores/team_store.jsx
+++ b/webapp/stores/team_store.jsx
@@ -10,6 +10,7 @@ const ActionTypes = Constants.ActionTypes;
const CHANGE_EVENT = 'change';
const STATS_EVENT = 'stats';
+const UNREAD_EVENT = 'unread';
var Utils;
@@ -53,17 +54,31 @@ class TeamStoreClass extends EventEmitter {
this.removeListener(STATS_EVENT, callback);
}
+ emitUnreadChange() {
+ this.emit(UNREAD_EVENT);
+ }
+
+ addUnreadChangeListener(callback) {
+ this.on(UNREAD_EVENT, callback);
+ }
+
+ removeUnreadChangeListener(callback) {
+ this.removeListener(UNREAD_EVENT, callback);
+ }
+
get(id) {
var c = this.getAll();
return c[id];
}
getByName(name) {
- var t = this.getAll();
+ const t = this.getAll();
- for (var id in t) {
- if (t[id].name === name) {
- return t[id];
+ for (const id in t) {
+ if (t.hasOwnProperty(id)) {
+ if (t[id].name === name) {
+ return t[id];
+ }
}
}
@@ -158,6 +173,25 @@ class TeamStoreClass extends EventEmitter {
this.teams = teams;
}
+ updateTeam(team) {
+ const t = JSON.parse(team);
+ if (this.teams && this.teams[t.id]) {
+ this.teams[t.id] = t;
+ }
+
+ if (this.teamListings && this.teamListings[t.id]) {
+ if (t.allow_open_invite) {
+ this.teamListings[t.id] = t;
+ } else {
+ Reflect.deleteProperty(this.teamListings, t.id);
+ }
+ } else if (t.allow_open_invite) {
+ this.teamListings[t.id] = t;
+ }
+
+ this.emitChange();
+ }
+
saveMyTeam(team) {
this.saveTeam(team);
this.currentTeamId = team.id;
@@ -175,12 +209,29 @@ class TeamStoreClass extends EventEmitter {
this.my_team_members.push(member);
}
+ saveMyTeamMembersUnread(members) {
+ for (let i = 0; i < this.my_team_members.length; i++) {
+ const team = this.my_team_members[i];
+ const member = members.filter((m) => m.team_id === team.team_id)[0];
+
+ if (member) {
+ this.my_team_members[i] = Object.assign({},
+ team,
+ {
+ msg_count: member.msg_count,
+ mention_count: member.mention_count
+ });
+ }
+ }
+ }
+
removeMyTeamMember(teamId) {
for (let i = 0; i < this.my_team_members.length; i++) {
if (this.my_team_members[i].team_id === teamId) {
this.my_team_members.splice(i, 1);
}
}
+ this.emitChange();
}
getMyTeamMembers() {
@@ -248,6 +299,14 @@ class TeamStoreClass extends EventEmitter {
return false;
}
+
+ updateUnreadCount(teamId, totalMsgCount, channelMember) {
+ const member = this.my_team_members.filter((m) => m.team_id === teamId)[0];
+ if (member) {
+ member.msg_count -= (totalMsgCount - channelMember.msg_count);
+ member.mention_count -= channelMember.mention_count;
+ }
+ }
}
var TeamStore = new TeamStoreClass();
@@ -277,6 +336,10 @@ TeamStore.dispatchToken = AppDispatcher.register((payload) => {
TeamStore.saveMyTeamMembers(action.team_members);
TeamStore.emitChange();
break;
+ case ActionTypes.RECEIVED_MY_TEAMS_UNREAD:
+ TeamStore.saveMyTeamMembersUnread(action.team_members);
+ TeamStore.emitChange();
+ break;
case ActionTypes.RECEIVED_ALL_TEAM_LISTINGS:
TeamStore.saveTeamListings(action.teams);
TeamStore.emitChange();
@@ -292,6 +355,12 @@ TeamStore.dispatchToken = AppDispatcher.register((payload) => {
TeamStore.saveStats(action.team_id, action.stats);
TeamStore.emitStatsChange();
break;
+ case ActionTypes.CLICK_CHANNEL:
+ if (action.channelMember) {
+ TeamStore.updateUnreadCount(action.team_id, action.total_msg_count, action.channelMember);
+ TeamStore.emitUnreadChange();
+ }
+ break;
default:
}
});