fix timeline reloading and favs/boosts/polls showing up at wrong pos (#1374)
This commit is contained in:
parent
d4ec0bb101
commit
db369aec75
2 changed files with 8 additions and 7 deletions
|
@ -74,12 +74,12 @@ AND
|
||||||
abstract fun removeAllPlaceholdersBetween(account: Long, maxId: String, sinceId: String)
|
abstract fun removeAllPlaceholdersBetween(account: Long, maxId: String, sinceId: String)
|
||||||
|
|
||||||
@Query("""UPDATE TimelineStatusEntity SET favourited = :favourited
|
@Query("""UPDATE TimelineStatusEntity SET favourited = :favourited
|
||||||
WHERE timelineUserId = :accountId AND (serverId = :statusId OR reblogServerId - :statusId)""")
|
WHERE timelineUserId = :accountId AND (serverId = :statusId OR reblogServerId = :statusId)""")
|
||||||
abstract fun setFavourited(accountId: Long, statusId: String, favourited: Boolean)
|
abstract fun setFavourited(accountId: Long, statusId: String, favourited: Boolean)
|
||||||
|
|
||||||
|
|
||||||
@Query("""UPDATE TimelineStatusEntity SET reblogged = :reblogged
|
@Query("""UPDATE TimelineStatusEntity SET reblogged = :reblogged
|
||||||
WHERE timelineUserId = :accountId AND (serverId = :statusId OR reblogServerId - :statusId)""")
|
WHERE timelineUserId = :accountId AND (serverId = :statusId OR reblogServerId = :statusId)""")
|
||||||
abstract fun setReblogged(accountId: Long, statusId: String, reblogged: Boolean)
|
abstract fun setReblogged(accountId: Long, statusId: String, reblogged: Boolean)
|
||||||
|
|
||||||
@Query("""DELETE FROM TimelineStatusEntity WHERE timelineUserId = :accountId AND
|
@Query("""DELETE FROM TimelineStatusEntity WHERE timelineUserId = :accountId AND
|
||||||
|
@ -101,6 +101,6 @@ AND authorServerId != :accountServerId AND createdAt < :olderThan""")
|
||||||
abstract fun cleanup(accountId: Long, accountServerId: String, olderThan: Long)
|
abstract fun cleanup(accountId: Long, accountServerId: String, olderThan: Long)
|
||||||
|
|
||||||
@Query("""UPDATE TimelineStatusEntity SET poll = :poll
|
@Query("""UPDATE TimelineStatusEntity SET poll = :poll
|
||||||
WHERE timelineUserId = :accountId AND (serverId = :statusId OR reblogServerId - :statusId)""")
|
WHERE timelineUserId = :accountId AND (serverId = :statusId OR reblogServerId = :statusId)""")
|
||||||
abstract fun setVoted(accountId: Long, statusId: String, poll: String)
|
abstract fun setVoted(accountId: Long, statusId: String, poll: String)
|
||||||
}
|
}
|
|
@ -301,20 +301,21 @@ public class TimelineFragment extends SFragment implements
|
||||||
if (!statuses.isEmpty()) {
|
if (!statuses.isEmpty()) {
|
||||||
filterStatuses(statuses);
|
filterStatuses(statuses);
|
||||||
|
|
||||||
|
|
||||||
if (!this.statuses.isEmpty() && topId != null) {
|
if (!this.statuses.isEmpty() && topId != null) {
|
||||||
// clear old cached statuses
|
// clear old cached statuses
|
||||||
Iterator<Either<Placeholder, Status>> iterator = statuses.iterator();
|
Iterator<Either<Placeholder, Status>> iterator = this.statuses.iterator();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Either<Placeholder, Status> item = iterator.next();
|
Either<Placeholder, Status> item = iterator.next();
|
||||||
if(item.isRight()) {
|
if(item.isRight()) {
|
||||||
Status status = item.asRight();
|
Status status = item.asRight();
|
||||||
if (status.getId().length() < topId.length() || status.getId().compareTo(topId) <= 0) {
|
if (status.getId().length() < topId.length() || status.getId().compareTo(topId) < 0) {
|
||||||
|
|
||||||
iterator.remove();
|
iterator.remove();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Placeholder placeholder = item.asLeft();
|
Placeholder placeholder = item.asLeft();
|
||||||
if (placeholder.getId().length() < topId.length() || placeholder.getId().compareTo(topId) <= 0) {
|
if (placeholder.getId().length() < topId.length() || placeholder.getId().compareTo(topId) < 0) {
|
||||||
|
|
||||||
iterator.remove();
|
iterator.remove();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue