| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- /**
- * @param {SlackChan|SlackGroup} chan
- * @return {Element}
- **/
- function createChanListItem(chan) {
- var dom = document.createElement("li");
- dom.id = chan.id;
- dom.className = R.klass.chatList.entry;
- dom.textContent = chan.name;
- return dom;
- }
- /**
- * @param {SlackIms} ims
- * @return {Element}
- **/
- function createImsListItem(ims) {
- var dom = document.createElement("li");
- dom.id = ims.id;
- dom.className = R.klass.chatList.entry;
- dom.textContent = ims.user.name;
- return dom;
- }
- function onContextUpdated() {
- var chanListFram = document.createDocumentFragment();
- var sortedChans = SLACK.context.self ? Object.keys(SLACK.context.self.channels) : [];
- sortedChans.sort(function(a, b) {
- if (a[0] !== b[0]) {
- return a[0] - b[0];
- }
- return (SLACK.context.channels[a] || SLACK.context.groups[a]).name.localeCompare((SLACK.context.channels[b] || SLACK.context.groups[b]).name);
- });
- sortedChans.forEach(function(chanId) {
- var chan = SLACK.context.channels[chanId] || SLACK.context.groups[chanId]
- ,chanListItem = createChanListItem(chan);
- if (chanListItem) {
- chanListFram.appendChild(chanListItem);
- }
- });
- var sortedUsers = SLACK.context.users ? Object.keys(SLACK.context.users) : [];
- sortedUsers.sort(function(a, b) {
- return SLACK.context.users[a].name.localeCompare(SLACK.context.users[b].name);
- });
- sortedUsers.forEach(function(userId) {
- var ims = SLACK.context.users[userId].ims
- ,imsListItem = createImsListItem(ims);
- if (imsListItem) {
- chanListFram.appendChild(imsListItem);
- }
- });
- document.getElementById(R.id.chanList).textContent = "";
- document.getElementById(R.id.chanList).appendChild(chanListFram);
- }
- function onRoomSelected() {
- var name = SELECTED_ROOM.name || (SELECTED_ROOM.user ? SELECTED_ROOM.user.name : undefined);
- if (!name) {
- var members = [];
- for (var i in SELECTED_ROOM.members) {
- members.push(SELECTED_ROOM.members[i].name);
- }
- name = members.join(", ");
- }
- document.getElementById(R.id.currentRoom.title).textContent = name;
- onRoomUpdated();
- }
- function createMessageDom(msg) {
- var dom = document.createElement("div")
- ,ts = document.createElement("div")
- ,text = document.createElement("div")
- ,author = document.createElement("div")
- ,authorImg = document.createElement("img")
- ,authorName = document.createElement("span");
- dom.className = R.klass.msg.item;
- ts.className = R.klass.msg.ts;
- text.className = R.klass.msg.msg;
- author.className = R.klass.msg.author;
- authorImg.className = R.klass.msg.authorAvatar;
- authorName.className = R.klass.msg.authorname;
- ts.textContent = (new Date(msg.ts * 1000)).toLocaleTimeString();
- text.textContent = msg.raw["text"];
- var sender = SLACK.context.getMember(msg.raw["user"]);
- authorName.textContent = sender ? sender.name : (msg.raw["username"] || "?");
- authorImg.src = sender ? sender.icons.image_48 : "";
- author.appendChild(authorImg);
- author.appendChild(authorName);
- dom.appendChild(author);
- dom.appendChild(text);
- dom.appendChild(ts);
- return dom;
- }
- function onRoomUpdated() {
- var chatFrag = document.createDocumentFragment();
- document.getElementById(R.id.currentRoom.content).textContent = "";
- if (SLACK.history[SELECTED_ROOM.id])
- SLACK.history[SELECTED_ROOM.id].messages.forEach(function(msg) {
- chatFrag.appendChild(createMessageDom(msg));
- });
- document.getElementById(R.id.currentRoom.content).appendChild(chatFrag);
- }
- function onChanClick(e) {
- while (e.target !== e.currentTarget && e.target) {
- if (e.target.classList.contains(R.klass.chatList.entry)) {
- var room = (SLACK.context.channels[e.target.id] ||
- SLACK.context.ims[e.target.id] ||
- SLACK.context.groups[e.target.id]);
- if (room && room !== SELECTED_ROOM) {
- selectRoom(room);
- }
- return;
- }
- e.target = e.target.parentElement;
- }
- }
- document.addEventListener('DOMContentLoaded', function() {
- document.getElementById(R.id.chatList).addEventListener("click", onChanClick);
- document.getElementById(R.id.message.form).addEventListener("submit", function(e) {
- e.preventDefault();
- var input =document.getElementById(R.id.message.input);
- if (SELECTED_ROOM && input.value) {
- sendMsg(SELECTED_ROOM, input.value);
- input.value = "";
- }
- return false;
- });
- startPolling();
- });
|