mirror of
https://github.com/scratchfoundation/scratch-www.git
synced 2025-01-23 04:19:56 -05:00
a9cb7bbd99
thanks @chrisgarrity !
189 lines
6.6 KiB
JavaScript
189 lines
6.6 KiB
JavaScript
var connect = require('react-redux').connect;
|
|
var React = require('react');
|
|
|
|
var messageActions = require('../../redux/messages.js');
|
|
var render = require('../../lib/render.jsx');
|
|
var sessionActions = require('../../redux/session.js');
|
|
|
|
var Page = require('../../components/page/www/page.jsx');
|
|
var MessagesPresentation = require('./presentation.jsx');
|
|
|
|
var Messages = React.createClass({
|
|
type: 'ConnectedMessages',
|
|
getInitialState: function () {
|
|
return {
|
|
filterValues: [],
|
|
displayedMessages: []
|
|
};
|
|
},
|
|
getDefaultProps: function () {
|
|
return {
|
|
sessionStatus: sessionActions.Status.NOT_FETCHED,
|
|
user: {},
|
|
flags: {},
|
|
messageOffset: 0,
|
|
numNewMessages: 0
|
|
};
|
|
},
|
|
componentDidUpdate: function (prevProps) {
|
|
if (this.props.user != prevProps.user) {
|
|
if (this.props.user.token) {
|
|
this.props.dispatch(
|
|
messageActions.getMessages(
|
|
this.props.user.username,
|
|
this.props.user.token,
|
|
this.props.messages,
|
|
this.props.messageOffset
|
|
)
|
|
);
|
|
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)
|
|
);
|
|
} 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));
|
|
}
|
|
}
|
|
},
|
|
componentDidMount: function () {
|
|
if (this.props.user.token) {
|
|
this.props.dispatch(
|
|
messageActions.getMessages(
|
|
this.props.user.username,
|
|
this.props.user.token,
|
|
this.props.messages,
|
|
this.props.messageOffset
|
|
)
|
|
);
|
|
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)
|
|
);
|
|
}
|
|
},
|
|
handleFilterClick: function (field, choice) {
|
|
switch (choice) {
|
|
case 'comments':
|
|
return this.setState({filterValues: ['addcomment']});
|
|
case 'projects':
|
|
return this.setState({filterValues: [
|
|
'loveproject',
|
|
'favoriteproject',
|
|
'remixproject'
|
|
]});
|
|
case 'studios':
|
|
return this.setState({filterValues: [
|
|
'curatorinvite',
|
|
'studioactivity',
|
|
'becomeownerstudio'
|
|
]});
|
|
case 'forums':
|
|
return this.setState({filterValues: ['forumpost']});
|
|
default:
|
|
return this.setState({filterValues: []});
|
|
}
|
|
},
|
|
handleMessageDismiss: function (messageType, messageId) {
|
|
var adminMessages = null;
|
|
if (messageType === 'notification') {
|
|
adminMessages = this.props.adminMessages;
|
|
}
|
|
this.props.dispatch(
|
|
messageActions.clearAdminMessage(
|
|
messageType, messageId, this.props.numNewMessages, adminMessages
|
|
)
|
|
);
|
|
},
|
|
handleLoadMoreMessages: function () {
|
|
this.props.dispatch(
|
|
messageActions.getMessages(
|
|
this.props.user.username,
|
|
this.props.user.token,
|
|
this.props.messages,
|
|
this.props.messageOffset
|
|
)
|
|
);
|
|
},
|
|
filterMessages: function (messages, typesAllowed, unreadCount) {
|
|
var filteredMessages = [];
|
|
if (typesAllowed.length > 0) {
|
|
for (var i in messages) {
|
|
// check to see if the position of the message in the list is earlier
|
|
// than the unread count. If it is, then the message is totally unread.
|
|
messages[i].unread = false;
|
|
if (i < unreadCount) messages[i].unread = true;
|
|
|
|
if (typesAllowed.indexOf(messages[i].type) > -1) {
|
|
filteredMessages.push(messages[i]);
|
|
}
|
|
}
|
|
} else {
|
|
filteredMessages = messages;
|
|
for (var j = 0; j < unreadCount; j++) {
|
|
filteredMessages[j].unread = true;
|
|
}
|
|
}
|
|
return filteredMessages;
|
|
},
|
|
render: function () {
|
|
var loadMore = true;
|
|
if (this.props.messageOffset > this.props.messages.length && this.props.messageOffset > 0) {
|
|
loadMore = false;
|
|
}
|
|
|
|
var messages = this.filterMessages(
|
|
this.props.messages,
|
|
this.state.filterValues,
|
|
this.props.numNewMessages
|
|
);
|
|
|
|
return(
|
|
<MessagesPresentation
|
|
sessionStatus={this.props.sessionStatus}
|
|
user={this.props.user}
|
|
messages={messages}
|
|
adminMessages={this.props.adminMessages}
|
|
scratcherInvite={this.props.invite}
|
|
numNewMessages={this.props.numNewMessages}
|
|
handleFilterClick={this.handleFilterClick}
|
|
handleAdminDismiss={this.handleMessageDismiss}
|
|
loadMore={loadMore}
|
|
loadMoreMethod={this.handleLoadMoreMessages}
|
|
requestStatus={this.props.requestStatus}
|
|
/>
|
|
);
|
|
}
|
|
});
|
|
|
|
var mapStateToProps = function (state) {
|
|
return {
|
|
sessionStatus: state.session.status,
|
|
user: state.session.session.user,
|
|
flags: state.session.session.flags,
|
|
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
|
|
};
|
|
};
|
|
|
|
var ConnectedMessages = connect(mapStateToProps)(Messages);
|
|
render(
|
|
<Page><ConnectedMessages /></Page>,
|
|
document.getElementById('app'),
|
|
{messages: messageActions.messagesReducer}
|
|
);
|