2018-01-30 11:53:12 -05:00
|
|
|
const bindAll = require('lodash.bindall');
|
|
|
|
const connect = require('react-redux').connect;
|
|
|
|
const PropTypes = require('prop-types');
|
|
|
|
const React = require('react');
|
2017-08-31 17:05:22 -04:00
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
const Page = require('../../components/page/www/page.jsx');
|
|
|
|
const render = require('../../lib/render.jsx');
|
2018-01-25 16:35:38 -05:00
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
const MessagesPresentation = require('./presentation.jsx');
|
2017-08-31 17:05:22 -04:00
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
const messageActions = require('../../redux/messages.js');
|
|
|
|
const sessionActions = require('../../redux/session.js');
|
|
|
|
|
|
|
|
class Messages extends React.Component {
|
|
|
|
constructor (props) {
|
|
|
|
super(props);
|
|
|
|
bindAll(this, [
|
|
|
|
'handleFilterClick',
|
|
|
|
'handleMessageDismiss',
|
|
|
|
'handleLoadMoreMessages'
|
|
|
|
]);
|
|
|
|
this.state = {
|
2017-10-24 13:10:32 -04:00
|
|
|
filter: ''
|
2017-08-31 17:05:22 -04:00
|
|
|
};
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
|
|
|
componentDidMount () {
|
|
|
|
if (this.props.user.token) {
|
|
|
|
this.props.dispatch(
|
|
|
|
messageActions.getMessages(
|
|
|
|
this.props.user.username,
|
|
|
|
this.props.user.token,
|
|
|
|
{
|
|
|
|
messages: this.props.messages,
|
|
|
|
offset: this.props.messageOffset,
|
|
|
|
filter: this.state.filter
|
|
|
|
}
|
|
|
|
)
|
|
|
|
);
|
|
|
|
this.props.dispatch(
|
|
|
|
messageActions.getAdminMessages(
|
|
|
|
this.props.user.username, this.props.user.token, this.props.messageOffset
|
|
|
|
)
|
|
|
|
);
|
|
|
|
this.props.dispatch(
|
|
|
|
messageActions.getScractherInvite(this.props.user.username, this.props.user.token)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
componentDidUpdate (prevProps) {
|
2017-10-24 13:10:32 -04:00
|
|
|
if (this.props.user.username !== prevProps.user.username) {
|
2017-08-31 17:05:22 -04:00
|
|
|
if (this.props.user.token) {
|
|
|
|
this.props.dispatch(
|
|
|
|
messageActions.getMessages(
|
|
|
|
this.props.user.username,
|
|
|
|
this.props.user.token,
|
2017-10-24 13:10:32 -04:00
|
|
|
{
|
|
|
|
messages: this.props.messages,
|
|
|
|
offset: this.props.messageOffset,
|
|
|
|
filter: this.state.filter
|
|
|
|
}
|
2017-08-31 17:05:22 -04:00
|
|
|
)
|
|
|
|
);
|
|
|
|
this.props.dispatch(
|
|
|
|
messageActions.getAdminMessages(
|
|
|
|
this.props.user.username, this.props.user.token, this.props.messageOffset
|
|
|
|
)
|
|
|
|
);
|
|
|
|
this.props.dispatch(
|
|
|
|
messageActions.getScratcherInvite(this.props.user.username, this.props.user.token)
|
|
|
|
);
|
2017-09-05 14:31:10 -04:00
|
|
|
} else {
|
|
|
|
// user is logged out, empty messages
|
|
|
|
this.props.dispatch(messageActions.setMessages([]));
|
|
|
|
this.props.dispatch(messageActions.setAdminMessages([]));
|
|
|
|
this.props.dispatch(messageActions.setScratcherInvite({}));
|
|
|
|
this.props.dispatch(messageActions.setMessagesOffset(0));
|
2017-08-31 17:05:22 -04:00
|
|
|
}
|
|
|
|
}
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
|
|
|
handleFilterClick (field, choice) {
|
2017-10-24 13:10:32 -04:00
|
|
|
if (this.props.user.token) {
|
|
|
|
this.props.dispatch(
|
|
|
|
messageActions.getMessages(
|
|
|
|
this.props.user.username,
|
|
|
|
this.props.user.token,
|
|
|
|
{
|
|
|
|
filter: choice,
|
|
|
|
clearCount: false
|
|
|
|
}
|
|
|
|
)
|
|
|
|
);
|
2017-08-31 17:05:22 -04:00
|
|
|
}
|
2017-10-24 13:10:32 -04:00
|
|
|
this.setState({filter: choice});
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
|
|
|
handleMessageDismiss (messageType, messageId) {
|
|
|
|
let adminMessages = null;
|
2017-08-31 17:05:22 -04:00
|
|
|
if (messageType === 'notification') {
|
|
|
|
adminMessages = this.props.adminMessages;
|
|
|
|
}
|
|
|
|
this.props.dispatch(
|
2017-09-01 11:07:21 -04:00
|
|
|
messageActions.clearAdminMessage(
|
|
|
|
messageType, messageId, this.props.numNewMessages, adminMessages
|
|
|
|
)
|
2017-08-31 17:05:22 -04:00
|
|
|
);
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
|
|
|
handleLoadMoreMessages () {
|
2017-08-31 17:05:22 -04:00
|
|
|
this.props.dispatch(
|
|
|
|
messageActions.getMessages(
|
|
|
|
this.props.user.username,
|
|
|
|
this.props.user.token,
|
2017-10-24 13:10:32 -04:00
|
|
|
{
|
|
|
|
messages: this.props.messages,
|
|
|
|
offset: this.props.messageOffset,
|
|
|
|
filter: this.state.filter,
|
|
|
|
clearCount: false
|
|
|
|
}
|
2017-08-31 17:05:22 -04:00
|
|
|
)
|
|
|
|
);
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
|
|
|
render () {
|
|
|
|
let loadMore = true;
|
2017-08-31 17:05:22 -04:00
|
|
|
if (this.props.messageOffset > this.props.messages.length && this.props.messageOffset > 0) {
|
|
|
|
loadMore = false;
|
|
|
|
}
|
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
return (
|
2017-08-31 17:05:22 -04:00
|
|
|
<MessagesPresentation
|
2018-01-30 09:54:45 -05:00
|
|
|
adminMessages={this.props.adminMessages}
|
2018-01-30 11:53:12 -05:00
|
|
|
filter={this.props.filter}
|
2018-01-30 09:54:45 -05:00
|
|
|
loadMore={loadMore}
|
2018-01-30 11:53:12 -05:00
|
|
|
messages={this.props.messages}
|
|
|
|
numNewMessages={this.props.numNewMessages}
|
2017-08-31 17:05:22 -04:00
|
|
|
requestStatus={this.props.requestStatus}
|
2018-01-30 11:53:12 -05:00
|
|
|
scratcherInvite={this.props.invite}
|
|
|
|
sessionStatus={this.props.sessionStatus}
|
|
|
|
user={this.props.user}
|
|
|
|
onAdminDismiss={this.handleMessageDismiss}
|
|
|
|
onFilterClick={this.handleFilterClick}
|
|
|
|
onLoadMoreMethod={this.handleLoadMoreMessages}
|
2017-08-31 17:05:22 -04:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
Messages.propTypes = {
|
|
|
|
adminMessages: PropTypes.arrayOf(PropTypes.object),
|
|
|
|
dispatch: PropTypes.func.isRequired,
|
|
|
|
filter: PropTypes.string,
|
|
|
|
invite: PropTypes.object.isRequired, // eslint-disable-line react/forbid-prop-types
|
|
|
|
messageOffset: PropTypes.number.isRequired,
|
|
|
|
messages: PropTypes.arrayOf(PropTypes.object),
|
|
|
|
numNewMessages: PropTypes.number.isRequired,
|
|
|
|
requestStatus: PropTypes.shape({
|
|
|
|
admin: PropTypes.string,
|
|
|
|
clear: PropTypes.string,
|
|
|
|
message: PropTypes.string,
|
|
|
|
delete: PropTypes.string
|
|
|
|
}).isRequired,
|
|
|
|
sessionStatus: PropTypes.string.isRequired,
|
|
|
|
user: PropTypes.shape({
|
|
|
|
id: PropTypes.number,
|
|
|
|
banned: PropTypes.bool,
|
|
|
|
username: PropTypes.string,
|
|
|
|
token: PropTypes.string,
|
|
|
|
thumbnailUrl: PropTypes.string,
|
|
|
|
dateJoined: PropTypes.string,
|
|
|
|
email: PropTypes.string,
|
|
|
|
classroomId: PropTypes.string
|
|
|
|
}).isRequired
|
|
|
|
};
|
2018-01-19 14:06:26 -05:00
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
Messages.defaultProps = {
|
|
|
|
messageOffset: 0,
|
|
|
|
numNewMessages: 0,
|
|
|
|
sessionStatus: sessionActions.Status.NOT_FETCHED,
|
|
|
|
user: {}
|
2018-01-30 09:54:45 -05:00
|
|
|
};
|
2018-01-19 14:06:26 -05:00
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
const mapStateToProps = state => ({
|
|
|
|
sessionStatus: state.session.status,
|
|
|
|
user: state.session.session.user,
|
|
|
|
numNewMessages: state.messageCount.messageCount,
|
|
|
|
messages: state.messages.messages.social,
|
|
|
|
adminMessages: state.messages.messages.admin,
|
|
|
|
invite: state.messages.messages.invite,
|
|
|
|
messageOffset: state.messages.messages.socialOffset,
|
|
|
|
requestStatus: state.messages.status
|
|
|
|
});
|
|
|
|
|
|
|
|
const ConnectedMessages = connect(mapStateToProps)(Messages);
|
|
|
|
|
2017-08-31 17:05:22 -04:00
|
|
|
render(
|
|
|
|
<Page><ConnectedMessages /></Page>,
|
|
|
|
document.getElementById('app'),
|
|
|
|
{messages: messageActions.messagesReducer}
|
|
|
|
);
|