mirror of
https://github.com/zulip/zulip.git
synced 2025-11-15 19:31:58 +00:00
recent senders: Use message ids instead of timestamps for sorting.
This matches the convention that we use everywhere else in Zulip. Fixes: #5956.
This commit is contained in:
committed by
Tim Abbott
parent
ebe16e064e
commit
9cd7f59c9b
@@ -16,13 +16,13 @@ var rs = zrequire('recent_senders');
|
|||||||
// New stream
|
// New stream
|
||||||
var message1 = {
|
var message1 = {
|
||||||
stream_id: stream1,
|
stream_id: stream1,
|
||||||
timestamp: _.uniqueId(),
|
id: _.uniqueId(),
|
||||||
subject: topic1,
|
subject: topic1,
|
||||||
sender_id: sender1,
|
sender_id: sender1,
|
||||||
};
|
};
|
||||||
var message2 = {
|
var message2 = {
|
||||||
stream_id: stream2,
|
stream_id: stream2,
|
||||||
timestamp: _.uniqueId(),
|
id: _.uniqueId(),
|
||||||
subject: topic1,
|
subject: topic1,
|
||||||
sender_id: sender2,
|
sender_id: sender2,
|
||||||
};
|
};
|
||||||
@@ -45,7 +45,7 @@ var rs = zrequire('recent_senders');
|
|||||||
// New topic
|
// New topic
|
||||||
var message3 = {
|
var message3 = {
|
||||||
stream_id: stream1,
|
stream_id: stream1,
|
||||||
timestamp: _.uniqueId(),
|
id: _.uniqueId(),
|
||||||
subject: topic2,
|
subject: topic2,
|
||||||
sender_id: sender3,
|
sender_id: sender3,
|
||||||
};
|
};
|
||||||
@@ -57,7 +57,7 @@ var rs = zrequire('recent_senders');
|
|||||||
// New sender
|
// New sender
|
||||||
var message4 = {
|
var message4 = {
|
||||||
stream_id: stream1,
|
stream_id: stream1,
|
||||||
timestamp: _.uniqueId(),
|
id: _.uniqueId(),
|
||||||
subject: topic1,
|
subject: topic1,
|
||||||
sender_id: sender2,
|
sender_id: sender2,
|
||||||
};
|
};
|
||||||
@@ -69,7 +69,7 @@ var rs = zrequire('recent_senders');
|
|||||||
// More recent message
|
// More recent message
|
||||||
var message5 = {
|
var message5 = {
|
||||||
stream_id: stream1,
|
stream_id: stream1,
|
||||||
timestamp: _.uniqueId(),
|
id: _.uniqueId(),
|
||||||
subject: topic1,
|
subject: topic1,
|
||||||
sender_id: sender1,
|
sender_id: sender1,
|
||||||
};
|
};
|
||||||
@@ -81,19 +81,19 @@ var rs = zrequire('recent_senders');
|
|||||||
// Same stream, but different topics
|
// Same stream, but different topics
|
||||||
var message6 = {
|
var message6 = {
|
||||||
stream_id: stream3,
|
stream_id: stream3,
|
||||||
timestamp: _.uniqueId(),
|
id: _.uniqueId(),
|
||||||
subject: topic1,
|
subject: topic1,
|
||||||
sender_id: sender1,
|
sender_id: sender1,
|
||||||
};
|
};
|
||||||
var message7 = {
|
var message7 = {
|
||||||
stream_id: stream3,
|
stream_id: stream3,
|
||||||
timestamp: _.uniqueId(),
|
id: _.uniqueId(),
|
||||||
subject: topic2,
|
subject: topic2,
|
||||||
sender_id: sender2,
|
sender_id: sender2,
|
||||||
};
|
};
|
||||||
var message8 = {
|
var message8 = {
|
||||||
stream_id: stream3,
|
stream_id: stream3,
|
||||||
timestamp: _.uniqueId(),
|
id: _.uniqueId(),
|
||||||
subject: topic3,
|
subject: topic3,
|
||||||
sender_id: sender3,
|
sender_id: sender3,
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -180,19 +180,19 @@ _.each(matches, function (person) {
|
|||||||
sender_id : 7,
|
sender_id : 7,
|
||||||
stream_id : 1,
|
stream_id : 1,
|
||||||
subject : "Dev Topic",
|
subject : "Dev Topic",
|
||||||
timestamp : _.uniqueId(),
|
id : _.uniqueId(),
|
||||||
});
|
});
|
||||||
global.recent_senders.process_message_for_senders({
|
global.recent_senders.process_message_for_senders({
|
||||||
sender_id : 5,
|
sender_id : 5,
|
||||||
stream_id : 1,
|
stream_id : 1,
|
||||||
subject : "Dev Topic",
|
subject : "Dev Topic",
|
||||||
timestamp : _.uniqueId(),
|
id : _.uniqueId(),
|
||||||
});
|
});
|
||||||
global.recent_senders.process_message_for_senders({
|
global.recent_senders.process_message_for_senders({
|
||||||
sender_id : 6,
|
sender_id : 6,
|
||||||
stream_id : 1,
|
stream_id : 1,
|
||||||
subject : "Dev Topic",
|
subject : "Dev Topic",
|
||||||
timestamp : _.uniqueId(),
|
id : _.uniqueId(),
|
||||||
});
|
});
|
||||||
|
|
||||||
// Typeahead for stream message [query, stream-name, topic-name]
|
// Typeahead for stream message [query, stream-name, topic-name]
|
||||||
@@ -210,13 +210,13 @@ _.each(matches, function (person) {
|
|||||||
sender_id : 5,
|
sender_id : 5,
|
||||||
stream_id : 2,
|
stream_id : 2,
|
||||||
subject : "Linux Topic",
|
subject : "Linux Topic",
|
||||||
timestamp : _.uniqueId(),
|
id : _.uniqueId(),
|
||||||
});
|
});
|
||||||
global.recent_senders.process_message_for_senders({
|
global.recent_senders.process_message_for_senders({
|
||||||
sender_id : 7,
|
sender_id : 7,
|
||||||
stream_id : 2,
|
stream_id : 2,
|
||||||
subject : "Linux Topic",
|
subject : "Linux Topic",
|
||||||
timestamp : _.uniqueId(),
|
id : _.uniqueId(),
|
||||||
});
|
});
|
||||||
|
|
||||||
// No match
|
// No match
|
||||||
|
|||||||
@@ -10,42 +10,42 @@ exports.process_message_for_senders = function (message) {
|
|||||||
|
|
||||||
// Process most recent sender to topic
|
// Process most recent sender to topic
|
||||||
var topic_dict = topic_senders.get(stream_id) || new Dict({fold_case: true});
|
var topic_dict = topic_senders.get(stream_id) || new Dict({fold_case: true});
|
||||||
var sender_timestamps = topic_dict.get(message.subject) || new Dict();
|
var sender_message_ids = topic_dict.get(message.subject) || new Dict();
|
||||||
var old_timestamp = sender_timestamps.get(message.sender_id);
|
var old_message_id = sender_message_ids.get(message.sender_id);
|
||||||
|
|
||||||
if (old_timestamp === undefined || old_timestamp < message.timestamp) {
|
if (old_message_id === undefined || old_message_id < message.id) {
|
||||||
sender_timestamps.set(message.sender_id, message.timestamp);
|
sender_message_ids.set(message.sender_id, message.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
topic_dict.set(message.subject, sender_timestamps);
|
topic_dict.set(message.subject, sender_message_ids);
|
||||||
topic_senders.set(stream_id, topic_dict);
|
topic_senders.set(stream_id, topic_dict);
|
||||||
|
|
||||||
// Process most recent sender to whole stream
|
// Process most recent sender to whole stream
|
||||||
sender_timestamps = stream_senders.get(stream_id) || new Dict();
|
sender_message_ids = stream_senders.get(stream_id) || new Dict();
|
||||||
old_timestamp = sender_timestamps.get(message.sender_id);
|
old_message_id = sender_message_ids.get(message.sender_id);
|
||||||
|
|
||||||
if (old_timestamp === undefined || old_timestamp < message.timestamp) {
|
if (old_message_id === undefined || old_message_id < message.id) {
|
||||||
sender_timestamps.set(message.sender_id, message.timestamp);
|
sender_message_ids.set(message.sender_id, message.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
stream_senders.set(stream_id, sender_timestamps);
|
stream_senders.set(stream_id, sender_message_ids);
|
||||||
};
|
};
|
||||||
|
|
||||||
exports.compare_by_recency = function (user_a, user_b, stream_id, topic) {
|
exports.compare_by_recency = function (user_a, user_b, stream_id, topic) {
|
||||||
stream_id = stream_id.toString();
|
stream_id = stream_id.toString();
|
||||||
|
|
||||||
var a_timestamp;
|
var a_message_id;
|
||||||
var b_timestamp;
|
var b_message_id;
|
||||||
|
|
||||||
var topic_dict = topic_senders.get(stream_id);
|
var topic_dict = topic_senders.get(stream_id);
|
||||||
if (topic !== undefined && topic_dict !== undefined) {
|
if (topic !== undefined && topic_dict !== undefined) {
|
||||||
var sender_timestamps = topic_dict.get(topic);
|
var sender_message_ids = topic_dict.get(topic);
|
||||||
if (sender_timestamps !== undefined) {
|
if (sender_message_ids !== undefined) {
|
||||||
b_timestamp = sender_timestamps.get(user_b.user_id) || Number.NEGATIVE_INFINITY;
|
b_message_id = sender_message_ids.get(user_b.user_id) || Number.NEGATIVE_INFINITY;
|
||||||
a_timestamp = sender_timestamps.get(user_a.user_id) || Number.NEGATIVE_INFINITY;
|
a_message_id = sender_message_ids.get(user_a.user_id) || Number.NEGATIVE_INFINITY;
|
||||||
|
|
||||||
if (a_timestamp !== b_timestamp) {
|
if (a_message_id !== b_message_id) {
|
||||||
return b_timestamp - a_timestamp;
|
return b_message_id - a_message_id;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -53,11 +53,11 @@ exports.compare_by_recency = function (user_a, user_b, stream_id, topic) {
|
|||||||
// Check recency for whole stream as tiebreaker
|
// Check recency for whole stream as tiebreaker
|
||||||
var stream_dict = stream_senders.get(stream_id);
|
var stream_dict = stream_senders.get(stream_id);
|
||||||
if (stream_dict !== undefined) {
|
if (stream_dict !== undefined) {
|
||||||
b_timestamp = stream_dict.get(user_b.user_id) || Number.NEGATIVE_INFINITY;
|
b_message_id = stream_dict.get(user_b.user_id) || Number.NEGATIVE_INFINITY;
|
||||||
a_timestamp = stream_dict.get(user_a.user_id) || Number.NEGATIVE_INFINITY;
|
a_message_id = stream_dict.get(user_a.user_id) || Number.NEGATIVE_INFINITY;
|
||||||
|
|
||||||
if (a_timestamp !== b_timestamp) {
|
if (a_message_id !== b_message_id) {
|
||||||
return b_timestamp - a_timestamp;
|
return b_message_id - a_message_id;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user