From 2b448dc596b42df6724443910420ebd1bf4175fe Mon Sep 17 00:00:00 2001 From: yougotwill Date: Fri, 9 Aug 2024 12:16:48 +1000 Subject: [PATCH] fix: if a group is missing a joinedAt value we use fallback value so we can poll for it and display it in the convo list --- ts/components/conversation/Timestamp.tsx | 19 +++++++++++++------ .../leftpane/overlay/OverlayClosedGroup.tsx | 5 +++-- ts/receiver/configMessage.ts | 9 +++++---- 3 files changed, 21 insertions(+), 12 deletions(-) diff --git a/ts/components/conversation/Timestamp.tsx b/ts/components/conversation/Timestamp.tsx index f21913f72..c2eb0abec 100644 --- a/ts/components/conversation/Timestamp.tsx +++ b/ts/components/conversation/Timestamp.tsx @@ -39,14 +39,21 @@ export const Timestamp = (props: Props) => { return null; } - const momentValue = moment(timestamp); - // this is a hack to make the date string shorter, looks like moment does not have a localized way of doing this for now. + let title = ''; + let dateString = ''; - const dateString = momentFromNow - ? momentValue.fromNow().replace('minutes', 'mins').replace('minute', 'min') - : momentValue.format('lll'); + // NOTE some existing groups might not have a joinedAtSeconds and we use a fallback value of 1 in order to poll and show up in the conversations list + if (timestamp !== 1) { + const momentValue = moment(timestamp); + // this is a hack to make the date string shorter, looks like moment does not have a localized way of doing this for now. + + dateString = momentFromNow + ? momentValue.fromNow().replace('minutes', 'mins').replace('minute', 'min') + : momentValue.format('lll'); + + title = moment(timestamp).format('llll'); + } - const title = moment(timestamp).format('llll'); if (props.isConversationListItem) { return {dateString}; } diff --git a/ts/components/leftpane/overlay/OverlayClosedGroup.tsx b/ts/components/leftpane/overlay/OverlayClosedGroup.tsx index 78a858d55..6a27c1e3c 100644 --- a/ts/components/leftpane/overlay/OverlayClosedGroup.tsx +++ b/ts/components/leftpane/overlay/OverlayClosedGroup.tsx @@ -58,7 +58,7 @@ const NoContacts = () => { }; /** - * Makes some validity check and return true if the group was indead created + * Makes some validity check and return true if the group was indeed created */ async function createClosedGroupWithErrorHandling( groupName: string, @@ -75,13 +75,14 @@ async function createClosedGroupWithErrorHandling( return false; } - // >= because we add ourself as a member AFTER this. so a 10 group is already invalid as it will be 11 with ourself + // >= because we add ourself as a member AFTER this. so a 10 group is already invalid as it will be 11 when we are included // the same is valid with groups count < 1 if (groupMemberIds.length < 1) { onError(window.i18n('pickClosedGroupMember')); return false; } + if (groupMemberIds.length >= VALIDATION.CLOSED_GROUP_SIZE_LIMIT) { onError(window.i18n('closedGroupMaxSize')); return false; diff --git a/ts/receiver/configMessage.ts b/ts/receiver/configMessage.ts index 2b680fa07..cc5dc3775 100644 --- a/ts/receiver/configMessage.ts +++ b/ts/receiver/configMessage.ts @@ -603,7 +603,9 @@ async function handleLegacyGroupUpdate(latestEnvelopeTimestamp: number) { const members = fromWrapper.members.map(m => m.pubkeyHex); const admins = fromWrapper.members.filter(m => m.isAdmin).map(m => m.pubkeyHex); - const creationTimestamp = fromWrapper.joinedAtSeconds ? fromWrapper.joinedAtSeconds * 1000 : 0; + // NOTE some existing groups might not have a joinedAtSeconds and we need a truthy fallback value in order to poll and show up in the conversations list + const creationTimestamp = fromWrapper.joinedAtSeconds ? fromWrapper.joinedAtSeconds * 1000 : 1; + // then for all the existing legacy group in the wrapper, we need to override the field of what we have in the DB with what is in the wrapper // We only set group admins on group creation const groupDetails: ClosedGroup.GroupInfo = { @@ -643,13 +645,12 @@ async function handleLegacyGroupUpdate(latestEnvelopeTimestamp: number) { const existingTimestampMs = legacyGroupConvo.get('lastJoinedTimestamp'); const existingJoinedAtSeconds = Math.floor(existingTimestampMs / 1000); - if (existingJoinedAtSeconds !== fromWrapper.joinedAtSeconds) { + if (existingJoinedAtSeconds !== creationTimestamp) { legacyGroupConvo.set({ - lastJoinedTimestamp: fromWrapper.joinedAtSeconds * 1000, + lastJoinedTimestamp: creationTimestamp, }); changes = true; } - // start polling for this group if we haven't left it yet. The wrapper does not store this info for legacy group so we check from the DB entry instead if (!legacyGroupConvo.get('isKickedFromGroup') && !legacyGroupConvo.get('left')) { getSwarmPollingInstance().addGroupId(PubKey.cast(fromWrapper.pubkeyHex));