minchats.js 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. /*global mock */
  2. const _ = converse.env._;
  3. const $msg = converse.env.$msg;
  4. const u = converse.env.utils;
  5. describe("The Minimized Chats Widget", function () {
  6. it("shows chats that have been minimized",
  7. mock.initConverse(
  8. ['rosterGroupsFetched'], {},
  9. async function (done, _converse) {
  10. await mock.waitForRoster(_converse, 'current');
  11. await mock.openControlBox(_converse);
  12. _converse.minimized_chats.initToggle();
  13. let contact_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
  14. await mock.openChatBoxFor(_converse, contact_jid)
  15. let chatview = _converse.chatboxviews.get(contact_jid);
  16. expect(chatview.model.get('minimized')).toBeFalsy();
  17. expect(u.isVisible(_converse.minimized_chats.el)).toBe(false);
  18. chatview.el.querySelector('.toggle-chatbox-button').click();
  19. expect(chatview.model.get('minimized')).toBeTruthy();
  20. expect(u.isVisible(_converse.minimized_chats.el)).toBe(true);
  21. expect(_converse.minimized_chats.keys().length).toBe(1);
  22. expect(_converse.minimized_chats.keys()[0]).toBe(contact_jid);
  23. contact_jid = mock.cur_names[1].replace(/ /g,'.').toLowerCase() + '@montague.lit';
  24. await mock.openChatBoxFor(_converse, contact_jid);
  25. chatview = _converse.chatboxviews.get(contact_jid);
  26. expect(chatview.model.get('minimized')).toBeFalsy();
  27. chatview.el.querySelector('.toggle-chatbox-button').click();
  28. expect(chatview.model.get('minimized')).toBeTruthy();
  29. expect(u.isVisible(_converse.minimized_chats.el)).toBe(true);
  30. expect(_converse.minimized_chats.keys().length).toBe(2);
  31. expect(_.includes(_converse.minimized_chats.keys(), contact_jid)).toBeTruthy();
  32. done();
  33. }));
  34. it("can be toggled to hide or show minimized chats",
  35. mock.initConverse(
  36. ['rosterGroupsFetched'], {},
  37. async function (done, _converse) {
  38. await mock.waitForRoster(_converse, 'current');
  39. await mock.openControlBox(_converse);
  40. _converse.minimized_chats.initToggle();
  41. const contact_jid = mock.cur_names[0].replace(/ /g,'.').toLowerCase() + '@montague.lit';
  42. await mock.openChatBoxFor(_converse, contact_jid);
  43. const chatview = _converse.chatboxviews.get(contact_jid);
  44. expect(u.isVisible(_converse.minimized_chats.el)).toBeFalsy();
  45. chatview.model.set({'minimized': true});
  46. expect(u.isVisible(_converse.minimized_chats.el)).toBeTruthy();
  47. expect(_converse.minimized_chats.keys().length).toBe(1);
  48. expect(_converse.minimized_chats.keys()[0]).toBe(contact_jid);
  49. expect(u.isVisible(_converse.minimized_chats.el.querySelector('.minimized-chats-flyout'))).toBeTruthy();
  50. expect(_converse.minimized_chats.toggleview.model.get('collapsed')).toBeFalsy();
  51. _converse.minimized_chats.el.querySelector('#toggle-minimized-chats').click();
  52. await u.waitUntil(() => u.isVisible(_converse.minimized_chats.el.querySelector('.minimized-chats-flyout')));
  53. expect(_converse.minimized_chats.toggleview.model.get('collapsed')).toBeTruthy();
  54. done();
  55. }));
  56. it("shows the number messages received to minimized chats",
  57. mock.initConverse(
  58. ['rosterGroupsFetched', 'chatBoxesFetched'], {},
  59. async function (done, _converse) {
  60. await mock.waitForRoster(_converse, 'current', 4);
  61. await mock.openControlBox(_converse);
  62. _converse.minimized_chats.initToggle();
  63. var i, contact_jid, chatview, msg;
  64. _converse.minimized_chats.toggleview.model.set({'collapsed': true});
  65. const unread_el = _converse.minimized_chats.toggleview.el.querySelector('.unread-message-count');
  66. expect(unread_el === null).toBe(true);
  67. for (i=0; i<3; i++) {
  68. contact_jid = mock.cur_names[i].replace(/ /g,'.').toLowerCase() + '@montague.lit';
  69. mock.openChatBoxFor(_converse, contact_jid);
  70. }
  71. await u.waitUntil(() => _converse.chatboxes.length == 4);
  72. chatview = _converse.chatboxviews.get(contact_jid);
  73. chatview.model.set({'minimized': true});
  74. for (i=0; i<3; i++) {
  75. msg = $msg({
  76. from: contact_jid,
  77. to: _converse.connection.jid,
  78. type: 'chat',
  79. id: u.getUniqueId()
  80. }).c('body').t('This message is sent to a minimized chatbox').up()
  81. .c('active', {'xmlns': 'http://jabber.org/protocol/chatstates'}).tree();
  82. _converse.handleMessageStanza(msg);
  83. }
  84. await u.waitUntil(() => chatview.model.messages.length === 3, 500);
  85. expect(u.isVisible(_converse.minimized_chats.toggleview.el.querySelector('.unread-message-count'))).toBeTruthy();
  86. expect(_converse.minimized_chats.toggleview.el.querySelector('.unread-message-count').textContent).toBe((3).toString());
  87. // Chat state notifications don't increment the unread messages counter
  88. // <composing> state
  89. _converse.handleMessageStanza($msg({
  90. from: contact_jid,
  91. to: _converse.connection.jid,
  92. type: 'chat',
  93. id: u.getUniqueId()
  94. }).c('composing', {'xmlns': 'http://jabber.org/protocol/chatstates'}).tree());
  95. expect(_converse.minimized_chats.toggleview.el.querySelector('.unread-message-count').textContent).toBe((i).toString());
  96. // <paused> state
  97. _converse.handleMessageStanza($msg({
  98. from: contact_jid,
  99. to: _converse.connection.jid,
  100. type: 'chat',
  101. id: u.getUniqueId()
  102. }).c('paused', {'xmlns': 'http://jabber.org/protocol/chatstates'}).tree());
  103. expect(_converse.minimized_chats.toggleview.el.querySelector('.unread-message-count').textContent).toBe((i).toString());
  104. // <gone> state
  105. _converse.handleMessageStanza($msg({
  106. from: contact_jid,
  107. to: _converse.connection.jid,
  108. type: 'chat',
  109. id: u.getUniqueId()
  110. }).c('gone', {'xmlns': 'http://jabber.org/protocol/chatstates'}).tree());
  111. expect(_converse.minimized_chats.toggleview.el.querySelector('.unread-message-count').textContent).toBe((i).toString());
  112. // <inactive> state
  113. _converse.handleMessageStanza($msg({
  114. from: contact_jid,
  115. to: _converse.connection.jid,
  116. type: 'chat',
  117. id: u.getUniqueId()
  118. }).c('inactive', {'xmlns': 'http://jabber.org/protocol/chatstates'}).tree());
  119. expect(_converse.minimized_chats.toggleview.el.querySelector('.unread-message-count').textContent).toBe((i).toString());
  120. done();
  121. }));
  122. it("shows the number messages received to minimized groupchats",
  123. mock.initConverse(
  124. ['rosterGroupsFetched'], {},
  125. async function (done, _converse) {
  126. const muc_jid = 'kitchen@conference.shakespeare.lit';
  127. await mock.openAndEnterChatRoom(_converse, 'kitchen@conference.shakespeare.lit', 'fires');
  128. const view = _converse.chatboxviews.get(muc_jid);
  129. view.model.set({'minimized': true});
  130. const message = 'fires: Your attention is required';
  131. const nick = mock.chatroom_names[0];
  132. const msg = $msg({
  133. from: muc_jid+'/'+nick,
  134. id: u.getUniqueId(),
  135. to: 'romeo@montague.lit',
  136. type: 'groupchat'
  137. }).c('body').t(message).tree();
  138. view.model.handleMessageStanza(msg);
  139. await u.waitUntil(() => view.model.messages.length);
  140. expect(u.isVisible(_converse.minimized_chats.toggleview.el.querySelector('.unread-message-count'))).toBeTruthy();
  141. expect(_converse.minimized_chats.toggleview.el.querySelector('.unread-message-count').textContent).toBe('1');
  142. done();
  143. }));
  144. });