Files
mattermost-mobile/app/database/operator/utils/thread.ts
Elias Nahum 2621d921d6 [Gekidou] Performance & UI fixes (#6122)
* Fix search bar style

* MM-42983 Align mention badge on channel list item

* MM-42985 polish channel intro UI

* MM-42984 update fonts on 'Show' bottom sheet

* MM-42982 Increase tap area of back button on channel view

* Set StatusBar style based on theme sidebarBg

* Reconnect other WS after 20 seconds insted of 5

* Only fetch missing profiles for DM/GMs

* Database prepare records optimization

* Do not use fallbackUsername for storing GM/DM in the database

* fix filter for fetching missing dm/gm

* remove use of indexOf inside another loop

* remove use of includes inside another loop

* remove use of find inside another loop

* Add missing translations

* disable Flipper on iOS

* Remove Flipper code from AppDelegate

* feedback review

* trim DM display name to make sure is not empty

* fixing missing direct channels display name

* UI/UX feedback

* fix WS channel viewed and mark as unread

* Remove duplicate emojis from reaction bar
2022-04-04 17:09:26 -04:00

71 lines
2.8 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import {Q} from '@nozbe/watermelondb';
import {MM_TABLES} from '@constants/database';
import type {Clause} from '@nozbe/watermelondb/QueryDescription';
import type {RecordPair, SanitizeThreadParticipantsArgs} from '@typings/database/database';
import type ThreadParticipantModel from '@typings/database/models/servers/thread_participant';
const {THREAD_PARTICIPANT} = MM_TABLES.SERVER;
/**
* sanitizeThreadParticipants: Treats participants in a Thread. For example, a user can participate/not. Hence, this function
* tell us which participants to create/delete in the ThreadParticipants table.
* @param {SanitizeThreadParticipantsArgs} sanitizeThreadParticipants
* @param {Database} sanitizeThreadParticipants.database
* @param {string} sanitizeThreadParticipants.thread_id
* @param {UserProfile[]} sanitizeThreadParticipants.rawParticipants
* @returns {Promise<{createParticipants: ThreadParticipant[], deleteParticipants: ThreadParticipantModel[]}>}
*/
export const sanitizeThreadParticipants = async ({database, skipSync, thread_id, rawParticipants}: SanitizeThreadParticipantsArgs) => {
const clauses: Clause[] = [Q.where('thread_id', thread_id)];
// Check if we already have the participants
if (skipSync) {
clauses.push(
Q.where('user_id', Q.oneOf(
rawParticipants.map((participant) => participant.id),
)),
);
}
const participants = (await database.collections.
get(THREAD_PARTICIPANT).
query(...clauses).
fetch()) as ThreadParticipantModel[];
// similarObjects: Contains objects that are in both the RawParticipant array and in the ThreadParticipant table
const similarObjects = new Set<ThreadParticipantModel>();
const createParticipants: RecordPair[] = [];
const participantsMap = participants.reduce((result: Record<string, ThreadParticipantModel>, participant) => {
result[participant.userId] = participant;
return result;
}, {});
for (let i = 0; i < rawParticipants.length; i++) {
const rawParticipant = rawParticipants[i];
// If the participant is not present let's add them to the db
const exists = participantsMap[rawParticipant.id];
if (exists) {
similarObjects.add(exists);
} else {
createParticipants.push({raw: rawParticipant});
}
}
if (skipSync) {
return {createParticipants, deleteParticipants: []};
}
// finding out elements to delete using array subtract
const deleteParticipants = participants.
filter((participant) => !similarObjects.has(participant)).
map((outCast) => outCast.prepareDestroyPermanently());
return {createParticipants, deleteParticipants};
};