aboutsummaryrefslogtreecommitdiff
path: root/src/components/conversation/conversation.js
diff options
context:
space:
mode:
authorHJ <spam@hjkos.com>2019-01-24 22:16:26 +0000
committerHJ <spam@hjkos.com>2019-01-24 22:16:26 +0000
commit63df815dd946be74d23c0d5cc2832c7aa28fbda6 (patch)
tree5ce2a6ab76a2096fec7d7608ea51a0238530b0c6 /src/components/conversation/conversation.js
parent03ffa7e84e648f1114605c338e6b40c214199e9d (diff)
parent9d0d6b86c83a4fad4038077a65149f0f3677fb82 (diff)
Merge branch 'fixSortingSequentials' into 'develop'
Fix TL sorting See merge request pleroma/pleroma-fe!474
Diffstat (limited to 'src/components/conversation/conversation.js')
-rw-r--r--src/components/conversation/conversation.js18
1 files changed, 17 insertions, 1 deletions
diff --git a/src/components/conversation/conversation.js b/src/components/conversation/conversation.js
index 9bf5e136..07b7c692 100644
--- a/src/components/conversation/conversation.js
+++ b/src/components/conversation/conversation.js
@@ -1,9 +1,25 @@
import { reduce, filter, sortBy } from 'lodash'
import Status from '../status/status.vue'
+const sortById = (a, b) => {
+ const seqA = Number(a.action.id)
+ const seqB = Number(b.action.id)
+ const isSeqA = Number.isNaN(seqA)
+ const isSeqB = Number.isNaN(seqB)
+ if (isSeqA && isSeqB) {
+ return seqA > seqB ? -1 : 1
+ } else if (isSeqA && !isSeqB) {
+ return 1
+ } else if (!isSeqA && isSeqB) {
+ return -1
+ } else {
+ return a.action.id > b.action.id ? -1 : 1
+ }
+}
+
const sortAndFilterConversation = (conversation) => {
conversation = filter(conversation, (status) => status.type !== 'retweet')
- return sortBy(conversation, 'id')
+ return sortBy(conversation, sortById)
}
const conversation = {