minchats.js 8.4 KB

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