Skip to content

Commit

Permalink
Merge pull request #619 from Hexastack/fix/re-subscribe-on-reconnect
Browse files Browse the repository at this point in the history
fix: re-subscribe on ws reconnect
  • Loading branch information
marrouchi authored Jan 23, 2025
2 parents 6ff6c5a + fcacd62 commit af7b8e7
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 7 deletions.
5 changes: 3 additions & 2 deletions widget/src/components/UserSubscription.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
/*
* Copyright © 2024 Hexastack. All rights reserved.
* Copyright © 2025 Hexastack. All rights reserved.
*
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
*/


import React, {
SyntheticEvent,
useCallback,
Expand Down Expand Up @@ -75,7 +76,7 @@ const UserSubscription: React.FC = () => {
});
setMessages(messages);
setParticipants([
...participants,
participants[0],
{
id: profile.foreign_id,
foreign_id: profile.foreign_id,
Expand Down
33 changes: 29 additions & 4 deletions widget/src/providers/ChatProvider.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
/*
* Copyright © 2024 Hexastack. All rights reserved.
* Copyright © 2025 Hexastack. All rights reserved.
*
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
*/


import React, {
createContext,
ReactNode,
Expand Down Expand Up @@ -268,7 +269,7 @@ const ChatProvider: React.FC<{
content_type: QuickReplyType.text,
text: qr.title,
payload: qr.payload,
}) as ISuggestion,
} as ISuggestion),
),
);
} else {
Expand Down Expand Up @@ -308,11 +309,17 @@ const ChatProvider: React.FC<{
async (firstName?: string, lastName?: string) => {
try {
setConnectionState(2);
const queryParams: Record<string, string> =
firstName && lastName
? { first_name: firstName, last_name: lastName }
: {};
const { body } = await socketCtx.socket.get<{
messages: TMessage[];
profile: ISubscriber;
}>(
`/webhook/${config.channel}/?first_name=${firstName}&last_name=${lastName}`,
`/webhook/${config.channel}/?${new URLSearchParams(
queryParams,
).toString()}`,
);

localStorage.setItem("profile", JSON.stringify(body.profile));
Expand All @@ -332,7 +339,7 @@ const ChatProvider: React.FC<{
}),
);
setParticipants([
...participants,
participants[0],
{
id: body.profile.foreign_id,
foreign_id: body.profile.foreign_id,
Expand Down Expand Up @@ -382,6 +389,24 @@ const ChatProvider: React.FC<{
if (screen === "chat" && connectionState === ConnectionState.connected) {
handleSubscription();
}

// When user loses internet connection, on reconnect
// we will need to subscribe him again (join the io room)
const reSubscribe = () => {
const item = localStorage.getItem("profile");

if (item) {
const profile = JSON.parse(item) as ISubscriber;

handleSubscription(profile.first_name, profile.last_name);
}
};

socketCtx.socket.io.on("reconnect", reSubscribe);

return () => {
socketCtx.socket.io.off("reconnect", reSubscribe);
};
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);

Expand Down
7 changes: 6 additions & 1 deletion widget/src/utils/SocketIoClient.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
/*
* Copyright © 2024 Hexastack. All rights reserved.
* Copyright © 2025 Hexastack. All rights reserved.
*
* Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms:
* 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission.
* 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file).
*/


import { io, ManagerOptions, Socket, SocketOptions } from "socket.io-client";

import { Config } from "../types/config.types";
Expand Down Expand Up @@ -72,6 +73,10 @@ export class SocketIoClient {
this.init(handlers);
}

get io() {
return this.socket.io;
}

/**
* Initializes the socket client and sets up event handlers.
* @param handlers Event handlers for connection, disconnection, and connection errors
Expand Down

0 comments on commit af7b8e7

Please sign in to comment.