| 
									
										
										
										
											2023-01-03 11:55:46 -08:00
										 |  |  | // Copyright 2021 Signal Messenger, LLC
 | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { assert } from 'chai'; | 
					
						
							|  |  |  | import * as sinon from 'sinon'; | 
					
						
							|  |  |  | import { times } from 'lodash'; | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  | import { RowType, _testHeaderText } from '../../../components/ConversationList'; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  | import { ContactCheckboxDisabledReason } from '../../../components/conversationList/ContactCheckbox'; | 
					
						
							| 
									
										
										
										
											2025-06-26 12:24:07 -04:00
										 |  |  | import { getDefaultConversation } from '../../../test-helpers/getDefaultConversation'; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | import { LeftPaneChooseGroupMembersHelper } from '../../../components/leftPane/LeftPaneChooseGroupMembersHelper'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe('LeftPaneChooseGroupMembersHelper', () => { | 
					
						
							|  |  |  |   const defaults = { | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |     uuidFetchState: {}, | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |     candidateContacts: [], | 
					
						
							|  |  |  |     isShowingRecommendedGroupSizeModal: false, | 
					
						
							|  |  |  |     isShowingMaximumGroupSizeModal: false, | 
					
						
							| 
									
										
										
										
											2024-01-05 14:47:29 -08:00
										 |  |  |     ourE164: undefined, | 
					
						
							| 
									
										
										
										
											2023-11-08 00:45:33 +01:00
										 |  |  |     ourUsername: undefined, | 
					
						
							| 
									
										
										
										
											2022-10-24 13:46:36 -07:00
										 |  |  |     groupSizeRecommendedLimit: 22, | 
					
						
							|  |  |  |     groupSizeHardLimit: 33, | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |     searchTerm: '', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |     username: undefined, | 
					
						
							| 
									
										
										
										
											2022-04-04 17:38:22 -07:00
										 |  |  |     regionCode: 'US', | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |     selectedContacts: [], | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-02 16:43:39 -05:00
										 |  |  |   describe('getBackAction', () => { | 
					
						
							|  |  |  |     it('returns the "show composer" action', () => { | 
					
						
							|  |  |  |       const startComposing = sinon.fake(); | 
					
						
							|  |  |  |       const helper = new LeftPaneChooseGroupMembersHelper(defaults); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       assert.strictEqual( | 
					
						
							|  |  |  |         helper.getBackAction({ startComposing }), | 
					
						
							|  |  |  |         startComposing | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   describe('getRowCount', () => { | 
					
						
							|  |  |  |     it('returns 0 if there are no contacts', () => { | 
					
						
							|  |  |  |       assert.strictEqual( | 
					
						
							|  |  |  |         new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |           ...defaults, | 
					
						
							|  |  |  |           candidateContacts: [], | 
					
						
							|  |  |  |           searchTerm: '', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |           username: undefined, | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           selectedContacts: [getDefaultConversation()], | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         }).getRowCount(), | 
					
						
							|  |  |  |         0 | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       assert.strictEqual( | 
					
						
							|  |  |  |         new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |           ...defaults, | 
					
						
							|  |  |  |           candidateContacts: [], | 
					
						
							|  |  |  |           searchTerm: 'foo bar', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |           username: undefined, | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           selectedContacts: [getDefaultConversation()], | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         }).getRowCount(), | 
					
						
							|  |  |  |         0 | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('returns the number of candidate contacts + 2 if there are any', () => { | 
					
						
							|  |  |  |       assert.strictEqual( | 
					
						
							|  |  |  |         new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |           ...defaults, | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           candidateContacts: [ | 
					
						
							|  |  |  |             getDefaultConversation(), | 
					
						
							|  |  |  |             getDefaultConversation(), | 
					
						
							|  |  |  |           ], | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |           searchTerm: '', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |           username: undefined, | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           selectedContacts: [getDefaultConversation()], | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         }).getRowCount(), | 
					
						
							|  |  |  |         4 | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   describe('getRow', () => { | 
					
						
							|  |  |  |     it('returns undefined if there are no contacts', () => { | 
					
						
							|  |  |  |       assert.isUndefined( | 
					
						
							|  |  |  |         new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |           ...defaults, | 
					
						
							|  |  |  |           candidateContacts: [], | 
					
						
							|  |  |  |           searchTerm: '', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |           username: undefined, | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           selectedContacts: [getDefaultConversation()], | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         }).getRow(0) | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       assert.isUndefined( | 
					
						
							|  |  |  |         new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |           ...defaults, | 
					
						
							|  |  |  |           candidateContacts: [], | 
					
						
							|  |  |  |           searchTerm: '', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |           username: undefined, | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           selectedContacts: [getDefaultConversation()], | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         }).getRow(99) | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |       assert.isUndefined( | 
					
						
							|  |  |  |         new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |           ...defaults, | 
					
						
							|  |  |  |           candidateContacts: [], | 
					
						
							|  |  |  |           searchTerm: 'foo bar', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |           username: undefined, | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |           selectedContacts: [getDefaultConversation()], | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         }).getRow(0) | 
					
						
							|  |  |  |       ); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('returns a header, then the contacts, then a blank space if there are contacts', () => { | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |       const candidateContacts = [ | 
					
						
							|  |  |  |         getDefaultConversation(), | 
					
						
							|  |  |  |         getDefaultConversation(), | 
					
						
							|  |  |  |       ]; | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |       const helper = new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |         ...defaults, | 
					
						
							|  |  |  |         candidateContacts, | 
					
						
							|  |  |  |         searchTerm: 'foo bar', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |         username: undefined, | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         selectedContacts: [candidateContacts[1]], | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |       assert.deepEqual(_testHeaderText(helper.getRow(0)), 'icu:contactsHeader'); | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |       assert.deepEqual(helper.getRow(1), { | 
					
						
							|  |  |  |         type: RowType.ContactCheckbox, | 
					
						
							|  |  |  |         contact: candidateContacts[0], | 
					
						
							|  |  |  |         isChecked: false, | 
					
						
							|  |  |  |         disabledReason: undefined, | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       assert.deepEqual(helper.getRow(2), { | 
					
						
							|  |  |  |         type: RowType.ContactCheckbox, | 
					
						
							|  |  |  |         contact: candidateContacts[1], | 
					
						
							|  |  |  |         isChecked: true, | 
					
						
							|  |  |  |         disabledReason: undefined, | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       assert.deepEqual(helper.getRow(3), { type: RowType.Blank }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it("disables non-selected contact checkboxes if you've selected the maximum number of contacts", () => { | 
					
						
							| 
									
										
										
										
											2021-05-07 17:21:10 -05:00
										 |  |  |       const candidateContacts = times(50, () => getDefaultConversation()); | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |       const helper = new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |         ...defaults, | 
					
						
							|  |  |  |         candidateContacts, | 
					
						
							|  |  |  |         searchTerm: 'foo bar', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |         username: undefined, | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |         selectedContacts: candidateContacts.slice(1, 33), | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       assert.deepEqual(helper.getRow(1), { | 
					
						
							|  |  |  |         type: RowType.ContactCheckbox, | 
					
						
							|  |  |  |         contact: candidateContacts[0], | 
					
						
							|  |  |  |         isChecked: false, | 
					
						
							|  |  |  |         disabledReason: ContactCheckboxDisabledReason.MaximumContactsSelected, | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       assert.deepEqual(helper.getRow(2), { | 
					
						
							|  |  |  |         type: RowType.ContactCheckbox, | 
					
						
							|  |  |  |         contact: candidateContacts[1], | 
					
						
							|  |  |  |         isChecked: true, | 
					
						
							|  |  |  |         disabledReason: undefined, | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     it('returns a header, then the phone number, then a blank space if there are contacts', () => { | 
					
						
							|  |  |  |       const helper = new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |         ...defaults, | 
					
						
							|  |  |  |         candidateContacts: [], | 
					
						
							|  |  |  |         searchTerm: '212 555', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |         username: undefined, | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |         selectedContacts: [], | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |       assert.deepEqual( | 
					
						
							|  |  |  |         _testHeaderText(helper.getRow(0)), | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |         'icu:findByPhoneNumberHeader' | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |       ); | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |       assert.deepEqual(helper.getRow(1), { | 
					
						
							|  |  |  |         type: RowType.PhoneNumberCheckbox, | 
					
						
							|  |  |  |         phoneNumber: { | 
					
						
							|  |  |  |           isValid: false, | 
					
						
							|  |  |  |           userInput: '212 555', | 
					
						
							|  |  |  |           e164: '+1212555', | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         isChecked: false, | 
					
						
							|  |  |  |         isFetching: false, | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       assert.deepEqual(helper.getRow(2), { type: RowType.Blank }); | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     it('returns a header, then the username, then a blank space if there are contacts', () => { | 
					
						
							|  |  |  |       const helper = new LeftPaneChooseGroupMembersHelper({ | 
					
						
							|  |  |  |         ...defaults, | 
					
						
							|  |  |  |         candidateContacts: [], | 
					
						
							| 
									
										
										
										
											2023-05-24 02:07:59 +02:00
										 |  |  |         searchTerm: 'signal.01', | 
					
						
							| 
									
										
										
										
											2024-02-14 10:18:49 -08:00
										 |  |  |         username: 'signal.01', | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |         selectedContacts: [], | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |       assert.deepEqual( | 
					
						
							|  |  |  |         _testHeaderText(helper.getRow(0)), | 
					
						
							| 
									
										
										
										
											2023-03-29 17:03:25 -07:00
										 |  |  |         'icu:findByUsernameHeader' | 
					
						
							| 
									
										
										
										
											2023-03-29 10:15:54 -07:00
										 |  |  |       ); | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |       assert.deepEqual(helper.getRow(1), { | 
					
						
							|  |  |  |         type: RowType.UsernameCheckbox, | 
					
						
							| 
									
										
										
										
											2023-05-24 02:07:59 +02:00
										 |  |  |         username: 'signal.01', | 
					
						
							| 
									
										
										
										
											2022-06-16 17:38:28 -07:00
										 |  |  |         isChecked: false, | 
					
						
							|  |  |  |         isFetching: false, | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       assert.deepEqual(helper.getRow(2), { type: RowType.Blank }); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2021-03-03 14:09:58 -06:00
										 |  |  |   }); | 
					
						
							|  |  |  | }); |