ui.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. /**
  2. * @param {SlackChan|SlackGroup} chan
  3. * @return {Element}
  4. **/
  5. function createChanListItem(chan) {
  6. var dom = document.createElement("li");
  7. dom.id = chan.id;
  8. dom.className = R.klass.chatList.entry;
  9. dom.textContent = chan.name;
  10. return dom;
  11. }
  12. /**
  13. * @param {SlackIms} ims
  14. * @return {Element}
  15. **/
  16. function createImsListItem(ims) {
  17. var dom = document.createElement("li");
  18. dom.id = ims.id;
  19. dom.className = R.klass.chatList.entry;
  20. dom.textContent = ims.user.name;
  21. return dom;
  22. }
  23. function onContextUpdated() {
  24. var chanListFram = document.createDocumentFragment();
  25. var sortedChans = SLACK.context.self ? Object.keys(SLACK.context.self.channels) : [];
  26. sortedChans.sort(function(a, b) {
  27. if (a[0] !== b[0]) {
  28. return a[0] - b[0];
  29. }
  30. return (SLACK.context.channels[a] || SLACK.context.groups[a]).name.localeCompare((SLACK.context.channels[b] || SLACK.context.groups[b]).name);
  31. });
  32. sortedChans.forEach(function(chanId) {
  33. var chan = SLACK.context.channels[chanId] || SLACK.context.groups[chanId]
  34. ,chanListItem = createChanListItem(chan);
  35. if (chanListItem) {
  36. chanListFram.appendChild(chanListItem);
  37. }
  38. });
  39. var sortedUsers = SLACK.context.users ? Object.keys(SLACK.context.users) : [];
  40. sortedUsers.sort(function(a, b) {
  41. return SLACK.context.users[a].name.localeCompare(SLACK.context.users[b].name);
  42. });
  43. sortedUsers.forEach(function(userId) {
  44. var ims = SLACK.context.users[userId].ims
  45. ,imsListItem = createImsListItem(ims);
  46. if (imsListItem) {
  47. chanListFram.appendChild(imsListItem);
  48. }
  49. });
  50. document.getElementById(R.id.chanList).textContent = "";
  51. document.getElementById(R.id.chanList).appendChild(chanListFram);
  52. }
  53. function onRoomSelected() {
  54. var name = SELECTED_ROOM.name || (SELECTED_ROOM.user ? SELECTED_ROOM.user.name : undefined);
  55. if (!name) {
  56. var members = [];
  57. for (var i in SELECTED_ROOM.members) {
  58. members.push(SELECTED_ROOM.members[i].name);
  59. }
  60. name = members.join(", ");
  61. }
  62. document.getElementById(R.id.currentRoom.title).textContent = name;
  63. onRoomUpdated();
  64. }
  65. function createMessageDom(msg) {
  66. var dom = document.createElement("div")
  67. ,ts = document.createElement("div")
  68. ,text = document.createElement("div")
  69. ,author = document.createElement("div")
  70. ,authorImg = document.createElement("img")
  71. ,authorName = document.createElement("span");
  72. dom.className = R.klass.msg.item;
  73. ts.className = R.klass.msg.ts;
  74. text.className = R.klass.msg.msg;
  75. author.className = R.klass.msg.author;
  76. authorImg.className = R.klass.msg.authorAvatar;
  77. authorName.className = R.klass.msg.authorname;
  78. ts.textContent = (new Date(msg.ts * 1000)).toLocaleTimeString();
  79. text.textContent = msg.raw["text"];
  80. var sender = SLACK.context.getMember(msg.raw["user"]);
  81. authorName.textContent = sender ? sender.name : (msg.raw["username"] || "?");
  82. authorImg.src = sender ? sender.icons.image_48 : "";
  83. author.appendChild(authorImg);
  84. author.appendChild(authorName);
  85. dom.appendChild(author);
  86. dom.appendChild(text);
  87. dom.appendChild(ts);
  88. return dom;
  89. }
  90. function onRoomUpdated() {
  91. var chatFrag = document.createDocumentFragment();
  92. document.getElementById(R.id.currentRoom.content).textContent = "";
  93. if (SLACK.history[SELECTED_ROOM.id])
  94. SLACK.history[SELECTED_ROOM.id].messages.forEach(function(msg) {
  95. chatFrag.appendChild(createMessageDom(msg));
  96. });
  97. document.getElementById(R.id.currentRoom.content).appendChild(chatFrag);
  98. }
  99. function onChanClick(e) {
  100. while (e.target !== e.currentTarget && e.target) {
  101. if (e.target.classList.contains(R.klass.chatList.entry)) {
  102. var room = (SLACK.context.channels[e.target.id] ||
  103. SLACK.context.ims[e.target.id] ||
  104. SLACK.context.groups[e.target.id]);
  105. if (room && room !== SELECTED_ROOM) {
  106. selectRoom(room);
  107. }
  108. return;
  109. }
  110. e.target = e.target.parentElement;
  111. }
  112. }
  113. document.addEventListener('DOMContentLoaded', function() {
  114. document.getElementById(R.id.chatList).addEventListener("click", onChanClick);
  115. document.getElementById(R.id.message.form).addEventListener("submit", function(e) {
  116. e.preventDefault();
  117. var input =document.getElementById(R.id.message.input);
  118. if (SELECTED_ROOM && input.value) {
  119. sendMsg(SELECTED_ROOM, input.value);
  120. input.value = "";
  121. }
  122. return false;
  123. });
  124. startPolling();
  125. });