hexabot/widget/src/UiChatWidget.tsx
2025-01-31 22:32:38 +01:00

68 lines
2.5 KiB
TypeScript

/*
* 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 { PropsWithChildren } from "react";
import Launcher from "./components/Launcher";
import UserSubscription from "./components/UserSubscription";
import BroadcastChannelProvider from "./providers/BroadcastChannelProvider";
import ChatProvider from "./providers/ChatProvider";
import { ColorProvider } from "./providers/ColorProvider";
import { ConfigProvider } from "./providers/ConfigProvider";
import { SettingsProvider } from "./providers/SettingsProvider";
import { SocketProvider } from "./providers/SocketProvider";
import { TranslationProvider } from "./providers/TranslationProvider";
import WidgetProvider, { WidgetContextType } from "./providers/WidgetProvider";
import { Config } from "./types/config.types";
import { ConnectionState } from "./types/state.types";
import "./UiChatWidget.css";
type UiChatWidgetProps = PropsWithChildren<{
CustomLauncher?: (props: { widget: WidgetContextType }) => JSX.Element;
CustomHeader?: () => JSX.Element;
CustomAvatar?: () => JSX.Element;
PreChat?: React.FC;
PostChat?: React.FC;
config: Partial<Config>;
}>;
function UiChatWidget({
CustomHeader,
CustomAvatar,
config,
}: UiChatWidgetProps) {
return (
<ConfigProvider {...config}>
<TranslationProvider>
<SocketProvider>
<SettingsProvider>
<ColorProvider>
<BroadcastChannelProvider channelName="main-channel">
<WidgetProvider defaultScreen="chat">
<ChatProvider
defaultConnectionState={ConnectionState.connected}
>
<Launcher
CustomHeader={CustomHeader}
CustomAvatar={CustomAvatar}
PreChat={UserSubscription}
/>
</ChatProvider>
</WidgetProvider>
</BroadcastChannelProvider>
</ColorProvider>
</SettingsProvider>
</SocketProvider>
</TranslationProvider>
</ConfigProvider>
);
}
export default UiChatWidget;