Files
astuto/app/javascript/containers/Post.tsx

109 lines
3.1 KiB
TypeScript
Raw Normal View History

2019-09-12 15:51:45 +02:00
import { connect } from 'react-redux';
2022-05-07 11:27:07 +02:00
import { requestPost } from '../actions/Post/requestPost';
import { deletePost } from '../actions/Post/deletePost';
import { togglePostEditMode } from '../actions/Post/togglePostEditMode';
import {
changePostEditFormBoard,
changePostEditFormDescription,
changePostEditFormPostStatus,
changePostEditFormTitle
} from '../actions/Post/changePostEditForm';
2022-05-07 11:27:07 +02:00
import { requestLikes } from '../actions/Like/requestLikes';
import { submitFollow } from '../actions/Follow/submitFollow';
import { requestFollow } from '../actions/Follow/requestFollow';
import { requestPostStatusChanges } from '../actions/PostStatusChange/requestPostStatusChanges';
import { postStatusChangeSubmitted } from '../actions/PostStatusChange/submittedPostStatusChange';
2019-09-12 15:51:45 +02:00
import { State } from '../reducers/rootReducer';
import PostP from '../components/Post/PostP';
import { fromJavascriptDateToRailsString } from '../helpers/datetime';
import { updatePost } from '../actions/Post/updatePost';
2019-09-12 15:51:45 +02:00
const mapStateToProps = (state: State) => ({
post: state.currentPost.item,
editMode: state.currentPost.editMode,
editForm: state.currentPost.editForm,
2019-09-30 16:54:37 +02:00
likes: state.currentPost.likes,
followed: state.currentPost.followed,
2019-10-01 19:15:03 +02:00
comments: state.currentPost.comments,
postStatusChanges: state.currentPost.postStatusChanges,
2019-09-12 15:51:45 +02:00
});
const mapDispatchToProps = (dispatch) => ({
requestPost(postId: number) {
dispatch(requestPost(postId));
},
updatePost(
postId: number,
title: string,
description: string,
boardId: number,
postStatusId: number,
authenticityToken: string,
) {
return dispatch(updatePost(postId, title, description, boardId, postStatusId, authenticityToken));
},
toggleEditMode() {
dispatch(togglePostEditMode());
},
handleChangeEditFormTitle(title: string) {
dispatch(changePostEditFormTitle(title));
},
handleChangeEditFormDescription(description: string) {
dispatch(changePostEditFormDescription(description));
},
handleChangeEditFormBoard(boardId: number) {
dispatch(changePostEditFormBoard(boardId));
},
handleChangeEditFormPostStatus(postStatusId: number) {
dispatch(changePostEditFormPostStatus(postStatusId));
},
2019-09-30 16:54:37 +02:00
requestLikes(postId: number) {
dispatch(requestLikes(postId));
},
requestFollow(postId: number) {
dispatch(requestFollow(postId));
},
requestPostStatusChanges(postId: number) {
dispatch(requestPostStatusChanges(postId));
},
deletePost(postId: number, authenticityToken: string) {
return dispatch(deletePost(postId, authenticityToken));
2019-09-21 12:54:57 +02:00
},
postStatusChangeSubmitted(
newPostStatusId: number,
userFullName: string,
userEmail: string,
) {
dispatch(postStatusChangeSubmitted({
postStatusId: newPostStatusId,
userFullName,
userEmail,
createdAt: fromJavascriptDateToRailsString(new Date()),
}));
},
submitFollow(postId: number, isFollow: boolean, authenticityToken: string) {
dispatch(submitFollow(postId, isFollow, authenticityToken));
2019-09-12 15:51:45 +02:00
},
});
export default connect(
mapStateToProps,
mapDispatchToProps,
)(PostP);