// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved. // See License.txt for license information. var PostHeader = require('./post_header.jsx'); var PostBody = require('./post_body.jsx'); var AppDispatcher = require('../dispatcher/app_dispatcher.jsx'); var Constants = require('../utils/constants.jsx'); var UserStore = require('../stores/user_store.jsx'); var PostStore = require('../stores/post_store.jsx'); var ChannelStore = require('../stores/channel_store.jsx'); var client = require('../utils/client.jsx'); var AsyncClient = require('../utils/async_client.jsx'); var ActionTypes = Constants.ActionTypes; var utils = require('../utils/utils.jsx'); var PostInfo = require('./post_info.jsx'); module.exports = React.createClass({ displayName: 'Post', handleCommentClick: function(e) { e.preventDefault(); var data = {}; data.order = [this.props.post.id]; data.posts = this.props.posts; AppDispatcher.handleServerAction({ type: ActionTypes.RECIEVED_POST_SELECTED, post_list: data }); AppDispatcher.handleServerAction({ type: ActionTypes.RECIEVED_SEARCH, results: null }); }, forceUpdateInfo: function() { this.refs.info.forceUpdate(); this.refs.header.forceUpdate(); }, retryPost: function(e) { e.preventDefault(); var post = this.props.post; client.createPost(post, post.channel_id, function(data) { AsyncClient.getPosts(); var channel = ChannelStore.get(post.channel_id); var member = ChannelStore.getMember(post.channel_id); member.msg_count = channel.total_msg_count; member.last_viewed_at = (new Date).getTime(); ChannelStore.setChannelMember(member); AppDispatcher.handleServerAction({ type: ActionTypes.RECIEVED_POST, post: data }); }.bind(this), function(err) { post.state = Constants.POST_FAILED; PostStore.updatePendingPost(post); this.forceUpdate(); }.bind(this) ); post.state = Constants.POST_LOADING; PostStore.updatePendingPost(post); this.forceUpdate(); }, shouldComponentUpdate: function(nextProps) { if (!utils.areStatesEqual(nextProps.post, this.props.post)) { return true; } return false; }, getInitialState: function() { return { }; }, render: function() { var post = this.props.post; var parentPost = this.props.parentPost; var posts = this.props.posts; var type = 'Post'; if (post.root_id && post.root_id.length > 0) { type = 'Comment'; } var commentCount = 0; var commentRootId = parentPost ? post.root_id : post.id; for (var postId in posts) { if (posts[postId].root_id == commentRootId) { commentCount += 1; } } var error = this.state.error ?
: null; var rootUser = this.props.sameRoot ? 'same--root' : 'other--root'; var postType = ''; if (type != 'Post'){ postType = 'post--comment'; } var currentUserCss = ''; if (UserStore.getCurrentId() === post.user_id) { currentUserCss = 'current--user'; } var userProfile = UserStore.getProfile(post.user_id); var timestamp = UserStore.getCurrentUser().update_at; if (userProfile) { timestamp = userProfile.update_at; } var sameUserClass = ''; if (this.props.sameUser) { sameUserClass = 'same--user'; } return (