$(function () {
"use strict";
var UserCounter = React.createClass({displayName: "UserCounter",
render: function () {
return (
React.createElement("li", null,
React.createElement("a", {href: "#"},
React.createElement("i", {className: "fa fa-users fa-fw"}), " Online",
React.createElement("span", {className: "badge add-left"}, " ", this.props.count, " ")
)
)
);
}
});
var UserLogin = React.createClass({displayName: "UserLogin",
authorizeId: function (id) {
id = parseInt(id, 10);
socket.emit("users:authorize", {
id: id
});
},
handleSubmit: function (e) {
e.preventDefault();
var id = React.findDOMNode(this.refs.authorize_id).value.trim();
if (!id) return;
React.findDOMNode(this.refs.authorize_id).value = '';
this.authorizeId(id);
return;
},
render: function () {
return (
React.createElement("form", {onSubmit: this.handleSubmit},
React.createElement("div", {className: "input-group signin"},
React.createElement("input", {
id: "btn-input",
type: "text",
className: "form-control",
ref: "authorize_id",
placeholder: "Choose an ID..."}),
React.createElement("span", {className: "input-group-btn"},
React.createElement("input", {
type: "submit",
className: "btn btn-primary",
id: "btn-chat",
value: "Login"})
)
),
React.createElement("div", {className: "signin"},
React.createElement("p", {className: "text-center"}, React.createElement("small", null, "Just a temporary measure until genuine authentication is implemented"))
)
)
);
}
})
var UserLine = React.createClass({displayName: "UserLine",
render: function () {
return (
React.createElement("li", null,
React.createElement("a", {href: "#"}, this.props.user.username)
)
);
}
});
var UserMenu = React.createClass({displayName: "UserMenu",
getDefaultProps: function () {
return {
count: 0,
users: []
};
},
componentDidMount: function () {
socket.on('userCount', this.updateUsers);
},
updateUsers: function (data) {
this.setProps({
count: data.count,
users: data.users
});
},
render: function () {
var users = this.props.users.map(function (user) {
return (
React.createElement(UserLine, {user: user})
);
});
return (
React.createElement("ul", {className: "nav", id: "side-menu"},
React.createElement(UserCounter, React.__spread({}, this.props)),
users,
React.createElement("li", null, React.createElement("br", null), React.createElement(UserLogin, null), React.createElement("br", null))
)
);
}
});
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 () {
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"})
)
)
)
);
}
});
var Gather = React.createClass({displayName: "Gather",
getDefaultProps: function () {
return {
gather: {
gatherers: []
}
}
},
joinedGather: function () {
var self = this;
return this.props.gather.gatherers.some(function (gatherer) {
return gatherer.user.id === self.props.user.id;
});
},
componentDidMount: function () {
var self = this;
socket.on("gather:refresh", function (data) {
self.setProps({
gather: data.gather,
user: data.user
});
});
},
joinGather: function (e) {
e.preventDefault();
socket.emit("gather:join", {});
},
leaveGather: function (e) {
e.preventDefault();
socket.emit("gather:leave", {});
},
render: function () {
var joinButton;
if (this.joinedGather()) {
joinButton = (React.createElement("button", {
onClick: this.leaveGather,
className: "btn btn-danger"}, "Leave Gather"));
} else {
joinButton = (React.createElement("button", {
onClick: this.joinGather,
className: "btn btn-primary"}, "Join Gather"));
}
return (
React.createElement("div", {className: "panel panel-default"},
React.createElement("div", {className: "panel-heading"},
"Current Gather",
React.createElement("span", {className: "badge add-left"}, " ", this.props.gather.gatherers.length, " ")
),
React.createElement(Gatherers, {gatherers: this.props.gather.gatherers}),
React.createElement("div", {className: "panel-body"}
),
React.createElement("div", {className: "panel-footer text-right"},
joinButton
)
)
);
}
});
// var GatherState = React.createClass({
// getDefaultProps: function () {
// return {
// "state": "none"
// }
// },
// stateDescription: function () {
// switch(this.props.date) {
// case "gathering":
// return "Waiting on more players to join"
// }
// },
// render: function () {
//
//
{this.displayState}
//
// }
// })
var Gatherers = React.createClass({displayName: "Gatherers",
render: function () {
var gatherers = this.props.gatherers.map(function (gatherer) {
var lifeforms = (
gatherer.user.ability.lifeforms.map(function (lifeform) {
return React.createElement("span", {className: "label label-default"}, lifeform);
})
);
var division = (React.createElement("span", {className: "label label-primary"}, gatherer.user.ability.division))
return (
React.createElement("tr", null,
React.createElement("td", null, gatherer.user.username),
React.createElement("td", null, division),
React.createElement("td", null, lifeforms)
)
);
})
return (
React.createElement("table", {className: "table table-striped gatherer-table"},
React.createElement("thead", null,
React.createElement("tr", null,
React.createElement("th", null, "Player"),
React.createElement("th", null, "Ability"),
React.createElement("th", null, "Life Forms")
)
),
React.createElement("tbody", null,
gatherers
)
)
);
}
});
var socket;
function initialiseComponents () {
var socketUrl = window.location.protocol + "//" + window.location.host;
socket = io(socketUrl)
.on("connect", function () {
console.log("Connected");
})
.on("reconnect", function () {
console.log("Reconnected");
})
.on("disconnect", function () {
console.log("Disconnected")
});
React.render(React.createElement(UserMenu, null), document.getElementById('side-menu'));
React.render(React.createElement(Chatroom, null), document.getElementById('chatroom'));
React.render(React.createElement(Gather, null), document.getElementById('gathers'));
};
initialiseComponents();
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transformed.js","sources":[null],"names":[],"mappings":"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","sourcesContent":["$(function () {\n\n\"use strict\";\n\nvar UserCounter = React.createClass({\n\trender: function () {\n\t\treturn (\n\t\t\t<li>\n\t\t\t\t<a href=\"#\">\n\t\t\t\t\t<i className=\"fa fa-users fa-fw\"></i> Online \n\t\t\t\t\t<span className=\"badge add-left\"> {this.props.count} </span>\n\t\t\t\t</a>\n\t\t\t</li>\n\t\t);\n\t}\n});\n\nvar UserLogin = React.createClass({\n\tauthorizeId: function (id) {\n\t\tid = parseInt(id, 10);\n\t\tsocket.emit(\"users:authorize\", {\n\t\t\tid: id\n\t\t});\n\t},\n\thandleSubmit: function (e) {\n\t\te.preventDefault();\n\t\tvar id = React.findDOMNode(this.refs.authorize_id).value.trim();\n\t\tif (!id) return;\n\t\tReact.findDOMNode(this.refs.authorize_id).value = '';\n\t\tthis.authorizeId(id);\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 signin\">\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=\"authorize_id\"\n\t\t\t\t\t\tplaceholder=\"Choose an ID...\" />\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=\"Login\" />\n\t\t\t\t\t</span>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"signin\">\n\t\t\t\t<p className=\"text-center\"><small>Just a temporary measure until genuine authentication is implemented</small></p>\n\t\t\t\t</div>\n\t\t\t</form>\n\t\t);\n\t}\n})\n\nvar UserLine = React.createClass({\n\trender: function () {\n\t\treturn (\n\t\t\t<li>\n\t\t\t\t<a href=\"#\">{this.props.user.username}</a>\n\t\t\t</li>\n\t\t);\n\t}\n});\n\nvar UserMenu = React.createClass({\n\tgetDefaultProps: function () {\n\t\treturn {\n\t\t\tcount: 0,\n\t\t\tusers: []\n\t\t};\n\t},\n\tcomponentDidMount: function () {\n\t\tsocket.on('userCount', this.updateUsers);\n\t},\n\tupdateUsers: function (data) {\n\t\tthis.setProps({\n\t\t\tcount: data.count,\n\t\t\tusers: data.users\n\t\t});\n\t},\n\trender: function () {\n\t\tvar users = this.props.users.map(function (user) {\n\t\t\treturn (\n\t\t\t\t<UserLine user={user} />\n\t\t\t);\n\t\t});\n\t\treturn (\n\t\t\t<ul className=\"nav\" id=\"side-menu\">\n\t\t\t\t<UserCounter {...this.props} />\n\t\t\t\t{users}\n\t\t\t\t<li><br /><UserLogin /><br /></li>\n\t\t\t</ul>\n\t\t);\n\t}\n});\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\tself.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\nvar Gather = React.createClass({\n\tgetDefaultProps: function () {\n\t\treturn {\n\t\t\tgather: {\n\t\t\t\tgatherers: []\n\t\t\t}\n\t\t}\n\t},\n\tjoinedGather: function () {\n\t\tvar self = this;\n\t\treturn this.props.gather.gatherers.some(function (gatherer) {\n\t\t\treturn gatherer.user.id === self.props.user.id;\n\t\t});\n\t},\n\tcomponentDidMount: function () {\n\t\tvar self = this;\n\t\tsocket.on(\"gather:refresh\", function (data) {\n\t\t\tself.setProps({\n\t\t\t\tgather: data.gather,\n\t\t\t\tuser: data.user\n\t\t\t});\n\t\t});\n\t},\n\tjoinGather: function (e) {\n\t\te.preventDefault();\n\t\tsocket.emit(\"gather:join\", {});\n\t},\n\tleaveGather: function (e) {\n\t\te.preventDefault();\n\t\tsocket.emit(\"gather:leave\", {});\n\t},\n\trender: function () {\n\t\tvar joinButton;\n\t\tif (this.joinedGather()) {\n\t\t\tjoinButton = (<button \n\t\t\t\t\t\t\tonClick={this.leaveGather} \n\t\t\t\t\t\t\tclassName=\"btn btn-danger\">Leave Gather</button>);\n\t\t} else {\n\t\t\tjoinButton = (<button \n\t\t\t\t\t\t\tonClick={this.joinGather} \n\t\t\t\t\t\t\tclassName=\"btn btn-primary\">Join Gather</button>);\n\t\t}\n\t\treturn (\n\t\t\t<div className=\"panel panel-default\">\n\t\t\t\t<div className=\"panel-heading\">\n\t\t\t\t\tCurrent Gather \n\t\t\t\t\t<span className=\"badge add-left\"> {this.props.gather.gatherers.length} </span>\n\t\t\t\t</div>\n\t\t\t\t<Gatherers gatherers={this.props.gather.gatherers} />\n\t\t\t\t<div className=\"panel-body\">\n\t\t\t\t</div>\n\t\t\t\t<div className=\"panel-footer text-right\">\n\t\t\t\t\t{joinButton}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\n// var GatherState = React.createClass({\n// \tgetDefaultProps: function () {\n// \t\treturn {\n// \t\t\t\"state\": \"none\"\n// \t\t}\n// \t},\n// \tstateDescription: function () {\n// \t\tswitch(this.props.date) {\n// \t\t\tcase \"gathering\":\n// \t\t\t\treturn \"Waiting on more players to join\"\n// \t\t}\n// \t},\n// \trender: function () {\n// \t\t<div className=\"well\">\n// \t\t\t<p>{this.displayState}</p>\n// \t\t</div>\n// \t}\n// })\n\nvar Gatherers = React.createClass({\n\trender: function () {\n\t\tvar gatherers = this.props.gatherers.map(function (gatherer) {\n\t\t\tvar lifeforms = (\n\t\t\t\tgatherer.user.ability.lifeforms.map(function (lifeform) {\n\t\t\t\t\treturn <span className=\"label label-default\">{lifeform}</span>;\n\t\t\t\t})\n\t\t\t);\n\t\t\tvar division = (<span className=\"label label-primary\">{gatherer.user.ability.division}</span>)\n\n\t\t\treturn (\n\t\t\t\t<tr>\n\t\t\t\t\t<td>{gatherer.user.username}</td>\n\t\t\t\t\t<td>{division}</td>\n\t\t\t\t\t<td>{lifeforms}</td>\n\t\t\t\t</tr>\n\t\t\t);\n\t\t})\n\t\treturn (\n\t\t\t<table className=\"table table-striped gatherer-table\">\n\t\t\t\t<thead>\n\t\t\t\t\t<tr>\n\t\t\t\t\t\t<th>Player</th>\n\t\t\t\t\t\t<th>Ability</th>\n\t\t\t\t\t\t<th>Life Forms</th>\n\t\t\t\t\t</tr>\n\t\t\t\t</thead>\n\t\t\t\t<tbody>\n\t\t\t\t\t{gatherers}\n\t\t\t\t</tbody>\n\t\t\t</table>\n\t\t);\n\t}\n});\n\nvar socket;\n\nfunction initialiseComponents () {\n\tvar socketUrl = window.location.protocol + \"//\" + window.location.host;\n\tsocket = io(socketUrl)\n\t\t.on(\"connect\", function () {\n\t\t\tconsole.log(\"Connected\");\n\t\t})\n\t\t.on(\"reconnect\", function () {\n\t\t\tconsole.log(\"Reconnected\");\n\t\t})\n\t\t.on(\"disconnect\", function () {\n\t\t\tconsole.log(\"Disconnected\")\n\t\t});\n\n\tReact.render(<UserMenu />, document.getElementById('side-menu'));\n\tReact.render(<Chatroom />, document.getElementById('chatroom'));\n\tReact.render(<Gather />, document.getElementById('gathers'));\n};\n\ninitialiseComponents();\n\n\n\n});\n\n"]}