forked from Ivasoft/mattermost-mobile
* Add column last_fetched_at to MyChannel & Thread tables and the migration * Fix schema tests * Handle lastFetchAt, retrieve threads on init and properly observe thread unreads (#6436) * [Gekidou] Set lastFetchAt when fetching posts for a channel (#6437) * Set lastFetchAt when fetching posts for a channel * When resetting _preparedState set always to null * Revert changes in WS * Handle and set lastFetchedAt for MyChannel in iOS push notification * feedback review * iOS fallback to last post createAt if no lastFetchAt set * Handle lastFetchAt on Android push notifications * create storePostsForChannel local action * Fix iOS fallback to last post create_at Co-authored-by: Daniel Espino García <larkox@gmail.com>
88 lines
3.3 KiB
TypeScript
88 lines
3.3 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import {Post} from '@constants';
|
|
import {POST_TIME_TO_FAIL} from '@constants/post';
|
|
import {DEFAULT_LOCALE} from '@i18n';
|
|
import {displayUsername} from '@utils/user';
|
|
|
|
import type PostModel from '@typings/database/models/servers/post';
|
|
import type UserModel from '@typings/database/models/servers/user';
|
|
|
|
export function areConsecutivePosts(post: PostModel, previousPost: PostModel) {
|
|
let consecutive = false;
|
|
|
|
if (post && previousPost) {
|
|
const postFromWebhook = Boolean(post?.props?.from_webhook); // eslint-disable-line camelcase
|
|
const prevPostFromWebhook = Boolean(previousPost?.props?.from_webhook); // eslint-disable-line camelcase
|
|
const isFromSameUser = previousPost.userId === post.userId;
|
|
const isNotSystemMessage = !isSystemMessage(post) && !isSystemMessage(previousPost);
|
|
const isInTimeframe = (post.createAt - previousPost.createAt) <= Post.POST_COLLAPSE_TIMEOUT;
|
|
|
|
// Were the last post and this post made by the same user within some time?
|
|
consecutive = previousPost && isFromSameUser && isInTimeframe && !postFromWebhook &&
|
|
!prevPostFromWebhook && isNotSystemMessage;
|
|
}
|
|
|
|
return consecutive;
|
|
}
|
|
|
|
export function isFromWebhook(post: PostModel | Post): boolean {
|
|
return post.props && post.props.from_webhook === 'true';
|
|
}
|
|
|
|
export function isEdited(post: PostModel): boolean {
|
|
return post.editAt > 0;
|
|
}
|
|
|
|
export function isPostEphemeral(post: PostModel): boolean {
|
|
return post.type === Post.POST_TYPES.EPHEMERAL || post.type === Post.POST_TYPES.EPHEMERAL_ADD_TO_CHANNEL || post.deleteAt > 0;
|
|
}
|
|
|
|
export function isPostFailed(post: PostModel): boolean {
|
|
return post.props?.failed || ((post.pendingPostId === post.id) && (Date.now() > post.updateAt + POST_TIME_TO_FAIL));
|
|
}
|
|
|
|
export function isPostPendingOrFailed(post: PostModel): boolean {
|
|
return post.pendingPostId === post.id || isPostFailed(post);
|
|
}
|
|
|
|
export function isSystemMessage(post: PostModel | Post): boolean {
|
|
return Boolean(post.type && post.type?.startsWith(Post.POST_TYPES.SYSTEM_MESSAGE_PREFIX));
|
|
}
|
|
|
|
export function fromAutoResponder(post: PostModel): boolean {
|
|
return Boolean(post.type && (post.type === Post.POST_TYPES.SYSTEM_AUTO_RESPONDER));
|
|
}
|
|
|
|
export function postUserDisplayName(post: PostModel, author?: UserModel, teammateNameDisplay?: string, enablePostUsernameOverride = false) {
|
|
if (isFromWebhook(post) && post.props?.override_username && enablePostUsernameOverride) {
|
|
return post.props.override_username;
|
|
}
|
|
|
|
return displayUsername(author, author?.locale || DEFAULT_LOCALE, teammateNameDisplay, true);
|
|
}
|
|
|
|
export function shouldIgnorePost(post: Post): boolean {
|
|
return Post.IGNORE_POST_TYPES.includes(post.type);
|
|
}
|
|
|
|
export const processPostsFetched = (data: PostResponse) => {
|
|
const order = data.order;
|
|
const posts = Object.values(data.posts);
|
|
const previousPostId = data.prev_post_id;
|
|
|
|
return {
|
|
posts,
|
|
order,
|
|
previousPostId,
|
|
};
|
|
};
|
|
|
|
export const getLastFetchedAtFromPosts = (posts?: Post[]) => {
|
|
return posts?.reduce((timestamp: number, p) => {
|
|
const maxTimestamp = Math.max(p.create_at, p.update_at, p.delete_at);
|
|
return Math.max(maxTimestamp, timestamp);
|
|
}, 0) || 0;
|
|
};
|