| 
									
										
										
										
											2017-02-18 02:37:59 +01:00
										 |  |  | import { connect } from 'react-redux'; | 
					
						
							|  |  |  | import PureRenderMixin from 'react-addons-pure-render-mixin'; | 
					
						
							|  |  |  | import ImmutablePropTypes from 'react-immutable-proptypes'; | 
					
						
							|  |  |  | import { fetchStatus } from '../../actions/statuses'; | 
					
						
							|  |  |  | import Immutable from 'immutable'; | 
					
						
							|  |  |  | import EmbeddedStatus from '../../components/status'; | 
					
						
							| 
									
										
										
										
											2017-02-26 23:06:27 +01:00
										 |  |  | import MissingIndicator from '../../components/missing_indicator'; | 
					
						
							| 
									
										
										
										
											2017-02-18 02:37:59 +01:00
										 |  |  | import DetailedStatus from './components/detailed_status'; | 
					
						
							|  |  |  | import ActionBar from './components/action_bar'; | 
					
						
							|  |  |  | import Column from '../ui/components/column'; | 
					
						
							|  |  |  | import { | 
					
						
							|  |  |  |   favourite, | 
					
						
							|  |  |  |   unfavourite, | 
					
						
							|  |  |  |   reblog, | 
					
						
							|  |  |  |   unreblog | 
					
						
							|  |  |  | } from '../../actions/interactions'; | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  | import { | 
					
						
							|  |  |  |   replyCompose, | 
					
						
							|  |  |  |   mentionCompose | 
					
						
							| 
									
										
										
										
											2017-02-18 02:37:59 +01:00
										 |  |  | } from '../../actions/compose'; | 
					
						
							|  |  |  | import { deleteStatus } from '../../actions/statuses'; | 
					
						
							| 
									
										
										
										
											2017-02-14 20:59:26 +01:00
										 |  |  | import { initReport } from '../../actions/reports'; | 
					
						
							| 
									
										
										
										
											2016-10-08 00:01:22 +02:00
										 |  |  | import { | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |   makeGetStatus, | 
					
						
							| 
									
										
										
										
											2016-10-08 00:01:22 +02:00
										 |  |  |   getStatusAncestors, | 
					
						
							|  |  |  |   getStatusDescendants | 
					
						
							| 
									
										
										
										
											2017-02-18 02:37:59 +01:00
										 |  |  | } from '../../selectors'; | 
					
						
							|  |  |  | import { ScrollContainer } from 'react-router-scroll'; | 
					
						
							|  |  |  | import ColumnBackButton from '../../components/column_back_button'; | 
					
						
							|  |  |  | import StatusContainer from '../../containers/status_container'; | 
					
						
							|  |  |  | import { openMedia } from '../../actions/modal'; | 
					
						
							| 
									
										
										
										
											2017-01-08 05:04:01 -05:00
										 |  |  | import { isMobile } from '../../is_mobile' | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  | const makeMapStateToProps = () => { | 
					
						
							|  |  |  |   const getStatus = makeGetStatus(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   const mapStateToProps = (state, props) => ({ | 
					
						
							|  |  |  |     status: getStatus(state, Number(props.params.statusId)), | 
					
						
							|  |  |  |     ancestorsIds: state.getIn(['timelines', 'ancestors', Number(props.params.statusId)]), | 
					
						
							|  |  |  |     descendantsIds: state.getIn(['timelines', 'descendants', Number(props.params.statusId)]), | 
					
						
							| 
									
										
										
										
											2016-10-30 15:06:43 +01:00
										 |  |  |     me: state.getIn(['meta', 'me']) | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return mapStateToProps; | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | const Status = React.createClass({ | 
					
						
							| 
									
										
										
										
											2016-11-21 10:52:11 +01:00
										 |  |  |   contextTypes: { | 
					
						
							|  |  |  |     router: React.PropTypes.object | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   propTypes: { | 
					
						
							|  |  |  |     params: React.PropTypes.object.isRequired, | 
					
						
							|  |  |  |     dispatch: React.PropTypes.func.isRequired, | 
					
						
							|  |  |  |     status: ImmutablePropTypes.map, | 
					
						
							| 
									
										
										
										
											2016-10-30 15:06:43 +01:00
										 |  |  |     ancestorsIds: ImmutablePropTypes.list, | 
					
						
							| 
									
										
										
										
											2017-01-10 13:50:40 +01:00
										 |  |  |     descendantsIds: ImmutablePropTypes.list, | 
					
						
							|  |  |  |     me: React.PropTypes.number | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   mixins: [PureRenderMixin], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   componentWillMount () { | 
					
						
							| 
									
										
										
										
											2016-09-19 23:25:59 +02:00
										 |  |  |     this.props.dispatch(fetchStatus(Number(this.props.params.statusId))); | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   componentWillReceiveProps (nextProps) { | 
					
						
							|  |  |  |     if (nextProps.params.statusId !== this.props.params.statusId && nextProps.params.statusId) { | 
					
						
							| 
									
										
										
										
											2016-09-19 23:25:59 +02:00
										 |  |  |       this.props.dispatch(fetchStatus(Number(nextProps.params.statusId))); | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-17 17:47:26 +02:00
										 |  |  |   handleFavouriteClick (status) { | 
					
						
							| 
									
										
										
										
											2017-02-17 02:33:10 +01:00
										 |  |  |     if (status.get('favourited')) { | 
					
						
							|  |  |  |       this.props.dispatch(unfavourite(status)); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       this.props.dispatch(favourite(status)); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-17 17:47:26 +02:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   handleReplyClick (status) { | 
					
						
							| 
									
										
										
										
											2016-11-21 10:52:11 +01:00
										 |  |  |     this.props.dispatch(replyCompose(status, this.context.router)); | 
					
						
							| 
									
										
										
										
											2016-09-17 17:47:26 +02:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   handleReblogClick (status) { | 
					
						
							| 
									
										
										
										
											2017-02-17 02:33:10 +01:00
										 |  |  |     if (status.get('reblogged')) { | 
					
						
							|  |  |  |       this.props.dispatch(unreblog(status)); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       this.props.dispatch(reblog(status)); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-09-17 17:47:26 +02:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-09 22:19:15 +02:00
										 |  |  |   handleDeleteClick (status) { | 
					
						
							|  |  |  |     this.props.dispatch(deleteStatus(status.get('id'))); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-30 21:40:55 +01:00
										 |  |  |   handleMentionClick (account, router) { | 
					
						
							|  |  |  |     this.props.dispatch(mentionCompose(account, router)); | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-05 02:48:11 +01:00
										 |  |  |   handleOpenMedia (media, index) { | 
					
						
							|  |  |  |     this.props.dispatch(openMedia(media, index)); | 
					
						
							| 
									
										
										
										
											2016-10-24 18:07:40 +02:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-14 20:59:26 +01:00
										 |  |  |   handleReport (status) { | 
					
						
							|  |  |  |     this.props.dispatch(initReport(status.get('account'), status)); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  |   renderChildren (list) { | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |     return list.map(id => <StatusContainer key={id} id={id} />); | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  |   }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   render () { | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |     let ancestors, descendants; | 
					
						
							|  |  |  |     const { status, ancestorsIds, descendantsIds, me } = this.props; | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (status === null) { | 
					
						
							| 
									
										
										
										
											2016-10-07 16:00:11 +02:00
										 |  |  |       return ( | 
					
						
							|  |  |  |         <Column> | 
					
						
							| 
									
										
										
										
											2017-02-19 07:32:35 +00:00
										 |  |  |           <ColumnBackButton /> | 
					
						
							| 
									
										
										
										
											2017-02-26 23:06:27 +01:00
										 |  |  |           <MissingIndicator /> | 
					
						
							| 
									
										
										
										
											2016-10-07 16:00:11 +02:00
										 |  |  |         </Column> | 
					
						
							|  |  |  |       ); | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 13:03:37 +02:00
										 |  |  |     const account = status.get('account'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-30 15:06:43 +01:00
										 |  |  |     if (ancestorsIds && ancestorsIds.size > 0) { | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |       ancestors = <div>{this.renderChildren(ancestorsIds)}</div>; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-30 15:06:43 +01:00
										 |  |  |     if (descendantsIds && descendantsIds.size > 0) { | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |       descendants = <div>{this.renderChildren(descendantsIds)}</div>; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  |     return ( | 
					
						
							| 
									
										
										
										
											2016-10-07 16:00:11 +02:00
										 |  |  |       <Column> | 
					
						
							| 
									
										
										
										
											2016-10-19 18:20:19 +02:00
										 |  |  |         <ColumnBackButton /> | 
					
						
							| 
									
										
										
										
											2016-09-18 13:03:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-19 18:20:19 +02:00
										 |  |  |         <ScrollContainer scrollKey='thread'> | 
					
						
							| 
									
										
										
										
											2016-11-04 13:32:14 +01:00
										 |  |  |           <div className='scrollable'> | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |             {ancestors} | 
					
						
							| 
									
										
										
										
											2016-09-18 13:03:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-24 18:07:40 +02:00
										 |  |  |             <DetailedStatus status={status} me={me} onOpenMedia={this.handleOpenMedia} /> | 
					
						
							| 
									
										
										
										
											2017-02-14 20:59:26 +01:00
										 |  |  |             <ActionBar status={status} me={me} onReply={this.handleReplyClick} onFavourite={this.handleFavouriteClick} onReblog={this.handleReblogClick} onDelete={this.handleDeleteClick} onMention={this.handleMentionClick} onReport={this.handleReport} /> | 
					
						
							| 
									
										
										
										
											2016-10-19 18:20:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  |             {descendants} | 
					
						
							| 
									
										
										
										
											2016-10-19 18:20:19 +02:00
										 |  |  |           </div> | 
					
						
							|  |  |  |         </ScrollContainer> | 
					
						
							| 
									
										
										
										
											2016-10-07 16:00:11 +02:00
										 |  |  |       </Column> | 
					
						
							| 
									
										
										
										
											2016-09-16 00:21:51 +02:00
										 |  |  |     ); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-24 17:11:02 +02:00
										 |  |  | export default connect(makeMapStateToProps)(Status); |