1
0

ui.js 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /**
  2. * @param {SlackChan} 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. for (var chanId in SLACK.context.self.channels) {
  26. var chan = SLACK.context.channels[chanId]
  27. ,chanListItem = createChanListItem(chan);
  28. if (chanListItem) {
  29. chanListFram.appendChild(chanListItem);
  30. }
  31. }
  32. for (var userId in SLACK.context.users) {
  33. var ims = SLACK.context.users[userId].ims
  34. ,imsListItem = createImsListItem(ims);
  35. if (imsListItem) {
  36. chanListFram.appendChild(imsListItem);
  37. }
  38. }
  39. document.getElementById(R.id.chanList).textContent = "";
  40. document.getElementById(R.id.chanList).appendChild(chanListFram);
  41. }
  42. function onRoomSelected() {
  43. var name = SELECTED_ROOM.name || (SELECTED_ROOM.user ? SELECTED_ROOM.user.name : undefined);
  44. if (!name) {
  45. var members = [];
  46. for (var i in SELECTED_ROOM.members) {
  47. members.push(SELECTED_ROOM.members[i].name);
  48. }
  49. name = members.join(", ");
  50. }
  51. document.getElementById(R.id.currentRoom.title).textContent = name;
  52. }
  53. function onChanClick(e) {
  54. while (e.target !== e.currentTarget && e.target) {
  55. if (e.target.classList.contains(R.klass.chatList.entry)) {
  56. var room = (SLACK.context.channels[e.target.id] ||
  57. SLACK.context.ims[e.target.id] ||
  58. SLACK.context.groups[e.target.id]);
  59. if (room && room !== SELECTED_ROOM) {
  60. selectRoom(room);
  61. }
  62. return;
  63. }
  64. e.target = e.target.parentElement;
  65. }
  66. }
  67. document.addEventListener('DOMContentLoaded', function() {
  68. document.getElementById(R.id.chatList).addEventListener("click", onChanClick);
  69. startPolling();
  70. });