forked from cybrespace/pinafore
refactor
This commit is contained in:
parent
22399df264
commit
8b282de973
|
@ -5,7 +5,7 @@ import { toast } from '../_utils/toast'
|
||||||
import { StatusStream } from '../_utils/mastodon/StatusStream'
|
import { StatusStream } from '../_utils/mastodon/StatusStream'
|
||||||
import { getInstanceInfo } from '../_utils/mastodon/instance'
|
import { getInstanceInfo } from '../_utils/mastodon/instance'
|
||||||
import { mark, stop } from '../_utils/marks'
|
import { mark, stop } from '../_utils/marks'
|
||||||
import { mergeStatuses } from '../_utils/timelines'
|
import { mergeArrays } from '../_utils/arrays'
|
||||||
|
|
||||||
const FETCH_LIMIT = 20
|
const FETCH_LIMIT = 20
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ async function addStatuses(instanceName, timelineName, newStatuses) {
|
||||||
mark('addStatuses')
|
mark('addStatuses')
|
||||||
let newStatusIds = newStatuses.map(status => status.id)
|
let newStatusIds = newStatuses.map(status => status.id)
|
||||||
let oldStatusIds = store.getForTimeline(instanceName, timelineName, 'statusIds') || []
|
let oldStatusIds = store.getForTimeline(instanceName, timelineName, 'statusIds') || []
|
||||||
let merged = mergeStatuses(oldStatusIds, newStatusIds)
|
let merged = mergeArrays(oldStatusIds, newStatusIds)
|
||||||
store.setForTimeline(instanceName, timelineName, { statusIds: merged })
|
store.setForTimeline(instanceName, timelineName, { statusIds: merged })
|
||||||
stop('addStatuses')
|
stop('addStatuses')
|
||||||
}
|
}
|
||||||
|
|
|
@ -296,7 +296,7 @@
|
||||||
import Toolbar from './Toolbar.html'
|
import Toolbar from './Toolbar.html'
|
||||||
import { mark, stop } from '../../_utils/marks'
|
import { mark, stop } from '../../_utils/marks'
|
||||||
import IntlRelativeFormat from 'intl-relativeformat'
|
import IntlRelativeFormat from 'intl-relativeformat'
|
||||||
import { replaceAll } from '../../_utils/replaceAll'
|
import { replaceAll } from '../../_utils/strings'
|
||||||
import { store } from '../../_store/store'
|
import { store } from '../../_store/store'
|
||||||
|
|
||||||
const relativeFormat = new IntlRelativeFormat('en-US');
|
const relativeFormat = new IntlRelativeFormat('en-US');
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
// Merge two arrays, assuming both input arrays have the same order
|
||||||
|
// and items are comparable
|
||||||
|
export function mergeArrays(leftArray, rightArray) {
|
||||||
|
let leftIndex = 0
|
||||||
|
let rightIndex = 0
|
||||||
|
let merged = []
|
||||||
|
while (leftIndex < leftArray.length || rightIndex < rightArray.length) {
|
||||||
|
if (leftIndex === leftArray.length) {
|
||||||
|
merged.push(rightArray[rightIndex])
|
||||||
|
rightIndex++
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if (rightIndex === rightArray.length) {
|
||||||
|
merged.push(leftArray[leftIndex])
|
||||||
|
leftIndex++
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
let left = leftArray[leftIndex]
|
||||||
|
let right = rightArray[rightIndex]
|
||||||
|
if (right === left) {
|
||||||
|
rightIndex++
|
||||||
|
leftIndex++
|
||||||
|
} else if (parseInt(right, 10) > parseInt(left, 10)) {
|
||||||
|
merged.push(right)
|
||||||
|
rightIndex++
|
||||||
|
} else {
|
||||||
|
merged.push(left)
|
||||||
|
leftIndex++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return merged
|
||||||
|
}
|
|
@ -1,32 +0,0 @@
|
||||||
// Merge two lists of statuses for the same timeline, e.g. one from IDB
|
|
||||||
// and another from the network. In case of duplicates, prefer the fresh.
|
|
||||||
export function mergeStatuses(leftStatusIds, rightStatusIds) {
|
|
||||||
let leftIndex = 0
|
|
||||||
let rightIndex = 0
|
|
||||||
let merged = []
|
|
||||||
while (leftIndex < leftStatusIds.length || rightIndex < rightStatusIds.length) {
|
|
||||||
if (leftIndex === leftStatusIds.length) {
|
|
||||||
merged.push(rightStatusIds[rightIndex])
|
|
||||||
rightIndex++
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if (rightIndex === rightStatusIds.length) {
|
|
||||||
merged.push(leftStatusIds[leftIndex])
|
|
||||||
leftIndex++
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
let left = leftStatusIds[leftIndex]
|
|
||||||
let right = rightStatusIds[rightIndex]
|
|
||||||
if (right === left) {
|
|
||||||
rightIndex++
|
|
||||||
leftIndex++
|
|
||||||
} else if (parseInt(right, 10) > parseInt(left, 10)) {
|
|
||||||
merged.push(right)
|
|
||||||
rightIndex++
|
|
||||||
} else {
|
|
||||||
merged.push(left)
|
|
||||||
leftIndex++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return merged
|
|
||||||
}
|
|
Loading…
Reference in New Issue