minchats.js 9.5 KB

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