/** * Copyright 2024 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { createContext, FC, type ReactNode, useContext } from "react"; import { useLiveAPI, type UseLiveAPIResults } from "../hooks/use-live-api"; const LiveAPIContext = createContext(undefined); export type LiveAPIProviderProps = { children: ReactNode; url?: string; }; export const LiveAPIProvider: FC = ({ url = process.env.NODE_ENV === 'development' ? `${window.location.protocol === 'https:' ? 'wss:' : 'ws:'}//localhost:3001/ws` : `${window.location.protocol === 'https:' ? 'wss:' : 'ws:'}//${window.location.host}/ws`, children, }) => { const liveAPI = useLiveAPI({ url }); return ( {children} ); }; export const useLiveAPIContext = () => { const context = useContext(LiveAPIContext); if (!context) { throw new Error("useLiveAPIContext must be used within a LiveAPIProvider"); } return context; };