mirror of
https://github.com/ENSL/ensl_gathers.git
synced 2024-11-26 22:31:08 +00:00
148 lines
No EOL
15 KiB
JavaScript
148 lines
No EOL
15 KiB
JavaScript
"use strict";
|
|
|
|
var Chatroom = React.createClass({displayName: "Chatroom",
|
|
getDefaultProps: function () {
|
|
return {
|
|
history: []
|
|
};
|
|
},
|
|
componentDidMount: function () {
|
|
var self = this;
|
|
var TIMER_INTERVAL = 60000; // Every minute
|
|
|
|
socket.on("message:new", function (data) {
|
|
var history = self.props.history;
|
|
history.push(data);
|
|
self.setProps({
|
|
history: history
|
|
});
|
|
self.scrollToBottom();
|
|
});
|
|
|
|
// Message History Retrieved
|
|
socket.on("message:refresh", function (data) {
|
|
self.setProps({
|
|
history: data.chatHistory
|
|
});
|
|
self.scrollToBottom();
|
|
});
|
|
|
|
socket.emit("message:refresh", {});
|
|
|
|
self.timer = setInterval(function () {
|
|
if (self.refs.messages) self.refs.messages.refreshTime();
|
|
}, TIMER_INTERVAL);
|
|
},
|
|
|
|
componentDidUnmount: function () {
|
|
clearInterval(this.timer);
|
|
},
|
|
sendMessage: function (message) {
|
|
socket.emit("newMessage", {message: message});
|
|
},
|
|
scrollToBottom: function () {
|
|
var node = React.findDOMNode(this.refs.messageContainer);
|
|
node.scrollTop = node.scrollHeight;
|
|
},
|
|
render: function () {
|
|
var messages = this.props.history.map(function (message) {
|
|
return (
|
|
React.createElement(ChatMessage, {
|
|
avatar: message.author.avatar,
|
|
username: message.author.username,
|
|
content: message.content,
|
|
ref: "messages",
|
|
createdAt: message.createdAt})
|
|
);
|
|
});
|
|
return (
|
|
React.createElement("div", {className: "panel panel-default"},
|
|
React.createElement("div", {className: "panel-heading"}, "Gather Chat"),
|
|
React.createElement("div", {className: "panel-body"},
|
|
React.createElement("ul", {className: "chat", id: "chatmessages", ref: "messageContainer"},
|
|
messages
|
|
)
|
|
),
|
|
React.createElement("div", {className: "panel-footer"},
|
|
React.createElement(MessageBar, null)
|
|
)
|
|
)
|
|
);
|
|
}
|
|
});
|
|
|
|
var ChatMessage = React.createClass({displayName: "ChatMessage",
|
|
getInitialState: function () {
|
|
return {
|
|
timeAgo: $.timeago(this.props.createdAt)
|
|
}
|
|
},
|
|
refreshTime: function () {
|
|
var self = this;
|
|
self.setState({
|
|
timeAgo: $.timeago(self.props.createdAt)
|
|
});
|
|
},
|
|
render: function () {
|
|
return (
|
|
React.createElement("li", {className: "left clearfix"},
|
|
React.createElement("span", {className: "chat-img pull-left"},
|
|
React.createElement("img", {
|
|
src: this.props.avatar,
|
|
alt: "User Avatar",
|
|
height: "40",
|
|
width: "40",
|
|
className: "img-circle"})
|
|
),
|
|
React.createElement("div", {className: "chat-body clearfix"},
|
|
React.createElement("div", {className: "header"},
|
|
React.createElement("strong", {className: "primary-font"}, this.props.username),
|
|
React.createElement("small", {className: "pull-right text-muted"},
|
|
React.createElement("i", {className: "fa fa-clock-o fa-fw"}), " ", this.state.timeAgo
|
|
)
|
|
),
|
|
React.createElement("p", null, this.props.content)
|
|
)
|
|
)
|
|
);
|
|
}
|
|
});
|
|
|
|
var MessageBar = React.createClass({displayName: "MessageBar",
|
|
sendMessage: function (content) {
|
|
socket.emit("message:new", {
|
|
content: content
|
|
});
|
|
},
|
|
handleSubmit: function (e) {
|
|
e.preventDefault();
|
|
var content = React.findDOMNode(this.refs.content).value.trim();
|
|
if (!content) return;
|
|
React.findDOMNode(this.refs.content).value = '';
|
|
this.sendMessage(content);
|
|
return;
|
|
},
|
|
render: function () {
|
|
return (
|
|
React.createElement("form", {onSubmit: this.handleSubmit},
|
|
React.createElement("div", {className: "input-group"},
|
|
React.createElement("input", {
|
|
id: "btn-input",
|
|
type: "text",
|
|
className: "form-control",
|
|
ref: "content",
|
|
placeholder: "Be polite please..."}),
|
|
React.createElement("span", {className: "input-group-btn"},
|
|
React.createElement("input", {
|
|
type: "submit",
|
|
className: "btn btn-primary",
|
|
id: "btn-chat",
|
|
value: "Send"})
|
|
)
|
|
)
|
|
)
|
|
);
|
|
}
|
|
});
|
|
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transformed.js","sources":[null],"names":[],"mappings":"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","sourcesContent":["\"use strict\";\n\nvar Chatroom = React.createClass({\n\tgetDefaultProps: function () {\n\t\treturn {\n\t\t\thistory: []\n\t\t};\n\t},\n\tcomponentDidMount: function () {\n\t\tvar self = this;\n\t\tvar TIMER_INTERVAL = 60000; // Every minute\n\n\t\tsocket.on(\"message:new\", function (data) {\n\t\t\tvar history = self.props.history;\n\t\t\thistory.push(data);\n\t\t\tself.setProps({\n\t\t\t\thistory: history\n\t\t\t});\n\t\t\tself.scrollToBottom();\n\t\t});\n\n\t\t// Message History Retrieved\n\t\tsocket.on(\"message:refresh\", function (data) {\n\t\t\tself.setProps({\n\t\t\t\thistory: data.chatHistory\n\t\t\t});\n\t\t\tself.scrollToBottom();\n\t\t});\n\n\t\tsocket.emit(\"message:refresh\", {});\n\n\t\tself.timer = setInterval(function () {\n\t\t\tif (self.refs.messages) self.refs.messages.refreshTime();\n\t\t}, TIMER_INTERVAL);\n\t},\n\n\tcomponentDidUnmount: function () {\n\t\tclearInterval(this.timer);\n\t},\n\tsendMessage: function (message) {\n\t\tsocket.emit(\"newMessage\", {message: message});\n\t},\n\tscrollToBottom: function () {\n\t\tvar node = React.findDOMNode(this.refs.messageContainer);\n\t  node.scrollTop = node.scrollHeight;\n\t},\n\trender: function () {\n\t\tvar messages = this.props.history.map(function (message) {\n\t\t\treturn (\n\t\t\t\t<ChatMessage \n\t\t\t\t\tavatar={message.author.avatar} \n\t\t\t\t\tusername={message.author.username}\n\t\t\t\t\tcontent={message.content}\n\t\t\t\t\tref=\"messages\"\n\t\t\t\t\tcreatedAt={message.createdAt} />\n\t\t\t);\n\t\t});\n\t\treturn (\n\t\t\t<div className=\"panel panel-default\">\n\t\t\t\t<div className=\"panel-heading\">Gather Chat</div>\n\t\t\t\t<div className=\"panel-body\">\n\t\t\t\t\t<ul className=\"chat\" id=\"chatmessages\" ref=\"messageContainer\">\n\t\t\t\t\t\t{messages}\n\t\t\t\t\t</ul>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"panel-footer\">\n\t\t\t\t\t<MessageBar />\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nvar ChatMessage = React.createClass({\n\tgetInitialState: function () {\n\t\treturn {\n\t\t\ttimeAgo: $.timeago(this.props.createdAt)\n\t\t}\n\t},\n\trefreshTime: function () {\n\t\tvar self = this;\n\t\tself.setState({\n\t\t\ttimeAgo: $.timeago(self.props.createdAt)\n\t\t});\n\t},\n\trender: function () {\n\t\treturn (\n\t\t\t<li className=\"left clearfix\">\n\t\t\t\t<span className=\"chat-img pull-left\">\n\t\t\t\t\t\t<img \n\t\t\t\t\t\t\tsrc={this.props.avatar} \n\t\t\t\t\t\t\talt=\"User Avatar\" \n\t\t\t\t\t\t\theight=\"40\"\n\t\t\t\t\t\t\twidth=\"40\"\n\t\t\t\t\t\t\tclassName=\"img-circle\" />\n\t\t\t\t</span>\n\t\t\t\t<div className=\"chat-body clearfix\">\n\t\t\t\t\t<div className=\"header\">\n\t\t\t\t\t\t<strong className=\"primary-font\">{this.props.username}</strong>\n\t\t\t\t\t\t<small className=\"pull-right text-muted\">\n\t\t\t\t\t\t\t<i className=\"fa fa-clock-o fa-fw\"></i> {this.state.timeAgo}\n\t\t\t\t\t\t</small>\n\t\t\t\t\t</div>\n\t\t\t\t\t<p>{this.props.content}</p>\n\t\t\t\t</div>\n\t\t\t</li>\n\t\t);\n\t}\n});\n\nvar MessageBar = React.createClass({\n\tsendMessage: function (content) {\n\t\tsocket.emit(\"message:new\", {\n\t\t\tcontent: content\n\t\t});\n\t},\n\thandleSubmit: function (e) {\n\t\te.preventDefault();\n\t\tvar content = React.findDOMNode(this.refs.content).value.trim();\n\t\tif (!content) return;\n\t\tReact.findDOMNode(this.refs.content).value = '';\n\t\tthis.sendMessage(content);\n\t\treturn;\n\t},\n\trender: function () {\n\t\treturn (\n\t\t\t<form onSubmit={this.handleSubmit} >\n\t\t\t\t<div className=\"input-group\">\n\t\t\t\t\t<input \n\t\t\t\t\t\tid=\"btn-input\" \n\t\t\t\t\t\ttype=\"text\" \n\t\t\t\t\t\tclassName=\"form-control\" \n\t\t\t\t\t\tref=\"content\"\n\t\t\t\t\t\tplaceholder=\"Be polite please...\" />\n\t\t\t\t\t<span className=\"input-group-btn\">\n\t\t\t\t\t\t<input \n\t\t\t\t\t\t\ttype=\"submit\" \n\t\t\t\t\t\t\tclassName=\"btn btn-primary\" \n\t\t\t\t\t\t\tid=\"btn-chat\" \n\t\t\t\t\t\t\tvalue=\"Send\" />\n\t\t\t\t\t</span>\n\t\t\t\t</div>\n\t\t\t</form>\n\t\t);\n\t}\n});\n"]}
|