forked from Ivasoft/mattermost-mobile
147 lines
4.9 KiB
JavaScript
147 lines
4.9 KiB
JavaScript
// Copyright (c) 2016-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
import {GeneralTypes, PostTypes} from 'mattermost-redux/action_types';
|
|
import {Client4} from 'mattermost-redux/client';
|
|
import {General} from 'mattermost-redux/constants';
|
|
import {fetchMyChannelsAndMembers, markChannelAsRead} from 'mattermost-redux/actions/channels';
|
|
import {getClientConfig, getDataRetentionPolicy, getLicenseConfig} from 'mattermost-redux/actions/general';
|
|
import {getPosts} from 'mattermost-redux/actions/posts';
|
|
import {getMyTeams, getMyTeamMembers, selectTeam} from 'mattermost-redux/actions/teams';
|
|
|
|
import {ViewTypes} from 'app/constants';
|
|
import {recordTime} from 'app/utils/segment';
|
|
|
|
import {
|
|
handleSelectChannel,
|
|
setChannelDisplayName,
|
|
retryGetPostsAction,
|
|
} from 'app/actions/views/channel';
|
|
|
|
export function startDataCleanup() {
|
|
return async (dispatch, getState) => {
|
|
dispatch({
|
|
type: ViewTypes.DATA_CLEANUP,
|
|
payload: getState(),
|
|
});
|
|
};
|
|
}
|
|
|
|
export function loadConfigAndLicense() {
|
|
return async (dispatch, getState) => {
|
|
const {currentUserId} = getState().entities.users;
|
|
const [configData, licenseData] = await Promise.all([
|
|
getClientConfig()(dispatch, getState),
|
|
getLicenseConfig()(dispatch, getState),
|
|
]);
|
|
|
|
const config = configData.data || {};
|
|
const license = licenseData.data || {};
|
|
|
|
if (currentUserId) {
|
|
if (config.DataRetentionEnableMessageDeletion && config.DataRetentionEnableMessageDeletion === 'true' &&
|
|
license.IsLicensed === 'true' && license.DataRetention === 'true') {
|
|
getDataRetentionPolicy()(dispatch, getState);
|
|
} else {
|
|
dispatch({type: GeneralTypes.RECEIVED_DATA_RETENTION_POLICY, data: {}});
|
|
}
|
|
}
|
|
|
|
return {config, license};
|
|
};
|
|
}
|
|
|
|
export function loadFromPushNotification(notification) {
|
|
return async (dispatch, getState) => {
|
|
const state = getState();
|
|
const {data} = notification;
|
|
const {currentTeamId, teams, myMembers: myTeamMembers} = state.entities.teams;
|
|
const {currentChannelId, channels} = state.entities.channels;
|
|
const channelId = data.channel_id;
|
|
|
|
// when the notification does not have a team id is because its from a DM or GM
|
|
const teamId = data.team_id || currentTeamId;
|
|
|
|
// load any missing data
|
|
const loading = [];
|
|
|
|
if (teamId && (!teams[teamId] || !myTeamMembers[teamId])) {
|
|
loading.push(dispatch(getMyTeams()));
|
|
loading.push(dispatch(getMyTeamMembers()));
|
|
}
|
|
|
|
if (channelId && !channels[channelId]) {
|
|
loading.push(dispatch(fetchMyChannelsAndMembers(teamId)));
|
|
}
|
|
|
|
if (loading.length > 0) {
|
|
await Promise.all(loading);
|
|
}
|
|
|
|
// when the notification is from a team other than the current team
|
|
if (teamId !== currentTeamId) {
|
|
dispatch(selectTeam({id: teamId}));
|
|
}
|
|
|
|
// when the notification is from the same channel as the current channel
|
|
// we should get the posts
|
|
if (channelId === currentChannelId) {
|
|
dispatch(markChannelAsRead(channelId, null, false));
|
|
await retryGetPostsAction(getPosts(channelId), dispatch, getState);
|
|
} else {
|
|
// when the notification is from a channel other than the current channel
|
|
dispatch(markChannelAsRead(channelId, currentChannelId, false));
|
|
dispatch(setChannelDisplayName(''));
|
|
dispatch(handleSelectChannel(channelId));
|
|
}
|
|
};
|
|
}
|
|
|
|
export function purgeOfflineStore() {
|
|
return {type: General.OFFLINE_STORE_PURGE};
|
|
}
|
|
|
|
export function createPost(post) {
|
|
return (dispatch, getState) => {
|
|
const state = getState();
|
|
const currentUserId = state.entities.users.currentUserId;
|
|
|
|
const timestamp = Date.now();
|
|
const pendingPostId = post.pending_post_id || `${currentUserId}:${timestamp}`;
|
|
|
|
const newPost = {
|
|
...post,
|
|
pending_post_id: pendingPostId,
|
|
create_at: timestamp,
|
|
update_at: timestamp,
|
|
};
|
|
|
|
return Client4.createPost({...newPost, create_at: 0}).then((payload) => {
|
|
dispatch({
|
|
type: PostTypes.RECEIVED_POSTS,
|
|
data: {
|
|
order: [],
|
|
posts: {
|
|
[payload.id]: payload,
|
|
},
|
|
},
|
|
channelId: payload.channel_id,
|
|
});
|
|
});
|
|
};
|
|
}
|
|
|
|
export function recordLoadTime(screenName, category) {
|
|
return async (dispatch, getState) => {
|
|
const {currentUserId} = getState().entities.users;
|
|
|
|
recordTime(screenName, category, currentUserId);
|
|
};
|
|
}
|
|
|
|
export default {
|
|
loadConfigAndLicense,
|
|
loadFromPushNotification,
|
|
purgeOfflineStore,
|
|
};
|