minchats.js 8.8 KB

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