minchats.js 9.9 KB

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