Fix shared media new & deleted messages

This commit is contained in:
morethanwords 2020-10-28 19:49:58 +02:00
parent c1a419909b
commit 1796dff9ce
2 changed files with 40 additions and 26 deletions

View File

@ -201,15 +201,20 @@ export default class AppSharedMediaTab implements SliderTab {
}); */
}
public renderNewMessages(mids: number[]) {
public renderNewMessages(peerID: number, mids: number[]) {
if(this.init) return; // * not inited yet
if(!this.historiesStorage[peerID]) return;
mids = mids.slice().reverse(); // ! because it will be ascend sorted array
for(const sharedMediaType of this.sharedMediaTypes) {
const filtered = this.filterMessagesByType(mids, sharedMediaType);
if(filtered.length) {
if(this.usedFromHistory[sharedMediaType] !== -1) {
this.historiesStorage[this.peerID][sharedMediaType].unshift(...mids);
if(this.historiesStorage[peerID][sharedMediaType]) {
this.historiesStorage[peerID][sharedMediaType].unshift(...mids);
}
if(this.peerID == peerID && this.usedFromHistory[sharedMediaType] !== -1) {
this.usedFromHistory[sharedMediaType] += filtered.length;
this.performSearchResult(filtered, sharedMediaType, false);
}
@ -219,30 +224,34 @@ export default class AppSharedMediaTab implements SliderTab {
}
}
public deleteDeletedMessages(mids: number[]) {
public deleteDeletedMessages(peerID: number, mids: number[]) {
if(this.init) return; // * not inited yet
if(!this.historiesStorage[peerID]) return;
for(const mid of mids) {
for(const sharedMediaType of this.sharedMediaTypes) {
if(!this.historiesStorage[this.peerID] || !this.historiesStorage[this.peerID][sharedMediaType]) continue;
if(!this.historiesStorage[peerID][sharedMediaType]) continue;
const history = this.historiesStorage[this.peerID][sharedMediaType];
const history = this.historiesStorage[peerID][sharedMediaType];
const idx = history.findIndex(m => m == mid);
if(idx !== -1) {
history.splice(idx, 1);
const container = this.sharedMedia[sharedMediaType];
const div = container.querySelector(`div[data-mid="${mid}"]`);
if(div) {
if(sharedMediaType == 'inputMessagesFilterPhotoVideo') {
delete this.mediaDivsByIDs[mid];
if(this.peerID == peerID) {
const container = this.sharedMedia[sharedMediaType];
const div = container.querySelector(`div[data-mid="${mid}"]`);
if(div) {
if(sharedMediaType == 'inputMessagesFilterPhotoVideo') {
delete this.mediaDivsByIDs[mid];
}
div.remove();
}
if(this.usedFromHistory[sharedMediaType] >= (idx + 1)) {
this.usedFromHistory[sharedMediaType]--;
}
div.remove();
}
if(this.usedFromHistory[sharedMediaType] >= (idx + 1)) {
this.usedFromHistory[sharedMediaType]--;
}
break;

View File

@ -222,20 +222,25 @@ export class AppImManager {
$rootScope.$on('history_multiappend', (e) => {
const msgIDsByPeer = e.detail;
for(const peerID in msgIDsByPeer) {
appSidebarRight.sharedMediaTab.renderNewMessages(+peerID, msgIDsByPeer[peerID]);
}
if(!(this.peerID in msgIDsByPeer)) return;
const msgIDs = msgIDsByPeer[this.peerID];
this.renderNewMessagesByIDs(msgIDs);
appSidebarRight.sharedMediaTab.renderNewMessages(msgIDs);
});
$rootScope.$on('history_delete', (e) => {
const detail = e.detail;
const mids = Object.keys(detail.msgs).map(s => +s);
this.deleteMessagesByIDs(mids);
appSidebarRight.sharedMediaTab.deleteDeletedMessages(mids);
const {peerID, msgs} = e.detail;
const mids = Object.keys(msgs).map(s => +s);
appSidebarRight.sharedMediaTab.deleteDeletedMessages(peerID, mids);
if(peerID == this.peerID) {
this.deleteMessagesByIDs(mids);
}
});
$rootScope.$on('dialog_flush', (e) => {
@ -282,7 +287,7 @@ export class AppImManager {
}
}
appSidebarRight.sharedMediaTab.renderNewMessages([mid]);
appSidebarRight.sharedMediaTab.renderNewMessages(message.peerID, [mid]);
let bubble = this.bubbles[tempID];
if(bubble) {