minchats.js 8.9 KB

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