Files
mattermost-mobile/app/components/post_list/post/index.ts
Mattermost Build 962a1759a5 MM-36881 Fix scroll perf degradation with pull to refresh enabled (#5525) (#5535)
* Fix scroll perf degradation with pull to refresh enabled

* Update app/components/post_list/post_list_refresh_control.tsx

Co-authored-by: Anurag Shivarathri <anurag6713@gmail.com>

Co-authored-by: Anurag Shivarathri <anurag6713@gmail.com>
(cherry picked from commit 58d9c2e9f0)

Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
2021-07-12 16:13:42 -04:00

95 lines
3.6 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import {connect} from 'react-redux';
import {showPermalink} from '@actions/views/permalink';
import {removePost} from '@mm-redux/actions/posts';
import {getChannel} from '@mm-redux/selectors/entities/channels';
import {getConfig} from '@mm-redux/selectors/entities/general';
import {getPost, isRootPost} from '@mm-redux/selectors/entities/posts';
import {getMyPreferences, getTeammateNameDisplaySetting} from '@mm-redux/selectors/entities/preferences';
import {getCurrentTeamId} from '@mm-redux/selectors/entities/teams';
import {getUser} from '@mm-redux/selectors/entities/users';
import {isPostFlagged, isSystemMessage} from '@mm-redux/utils/post_utils';
import {canDeletePost} from '@selectors/permissions';
import {areConsecutivePosts, postUserDisplayName} from '@utils/post';
import type {StyleProp, ViewStyle} from 'react-native';
import type {Post as PostType} from '@mm-redux/types/posts';
import type {Theme} from '@mm-redux/types/preferences';
import type {GlobalState} from '@mm-redux/types/store';
import Post from './post';
type OwnProps = {
highlight?: boolean;
postId: string;
post?: PostType;
previousPostId?: string;
nextPostId?: string;
style?: StyleProp<ViewStyle>;
testID: string;
theme: Theme;
}
function mapSateToProps(state: GlobalState, ownProps: OwnProps) {
const {nextPostId, postId, previousPostId} = ownProps;
const post = ownProps.post || getPost(state, postId);
const myPreferences = getMyPreferences(state);
const channel = getChannel(state, post.channel_id);
const teamId = getCurrentTeamId(state);
const author = getUser(state, post.user_id);
const previousPost = previousPostId ? getPost(state, previousPostId) : undefined;
const config = getConfig(state);
const teammateNameDisplay = getTeammateNameDisplaySetting(state);
const enablePostUsernameOverride = config.EnablePostUsernameOverride === 'true';
const isConsecutivePost = post && previousPost && !author?.is_bot && !isRootPost(state, post.id) && areConsecutivePosts(post, previousPost);
let isFirstReply = true;
let isLastReply = true;
let canDelete = false;
let rootPostAuthor;
if (post && channel?.delete_at === 0) {
canDelete = canDeletePost(state, channel?.team_id || teamId, post?.channel_id, post, false);
}
if (post.root_id) {
const nextPost = nextPostId ? getPost(state, nextPostId) : undefined;
isFirstReply = (previousPost?.id === post.root_id || previousPost?.root_id === post.root_id);
isLastReply = !(nextPost?.root_id === post.root_id);
}
if (!isSystemMessage(post)) {
const rootPost = post.root_id ? getPost(state, post.root_id) : undefined;
const rootPostUser = rootPost?.user_id ? getUser(state, rootPost.user_id) : undefined;
const differentThreadSequence = previousPost?.root_id ? previousPost?.root_id !== post.root_id : previousPost?.id !== post.root_id;
if (rootPost?.user_id &&
previousPostId &&
differentThreadSequence
) {
rootPostAuthor = postUserDisplayName(rootPost, rootPostUser, teammateNameDisplay, enablePostUsernameOverride);
}
}
return {
canDelete,
enablePostUsernameOverride,
isConsecutivePost,
isFirstReply,
isFlagged: isPostFlagged(post.id, myPreferences),
isLastReply,
post,
rootPostAuthor,
teammateNameDisplay,
};
}
const mapDispatchToProps = {
removePost,
showPermalink,
};
export default connect(mapSateToProps, mapDispatchToProps)(Post);