Files
mattermost-mobile/app/context/server/index.tsx
Christopher Poile 5bb240dec8 MM-43300: Calls v2 first cut (#6475)
* Android and iOS requirements

* external types

* babel config for calls, package.json for calls dependencies

* state in rxJS; tests

* actions, client/rest, websocket events, constants

* webrtc connection logic

* calls components / screens

* handle peer destroyed gracefully

* PR comments

* remove ViewPropTypes from mocks; no need to ignore error in LogBox

* calls.d.ts -> calls.ts; i18-extract

* @app/products/calls -> @calls

* PR comments; test cleanup

* Revert "remove ViewPropTypes from mocks; no need to ignore error in LogBox"

This reverts commit f9bd171a54.

* working on typing withServerUrl

* added exportedForInternalUse instead of commenting "internal export"

* better switchToThread in call_screen

* i18n

* typed withServerUrl
2022-07-22 15:57:12 -04:00

57 lines
1.4 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React, {createContext} from 'react';
type Props = {
server: ServerContext;
children: React.ReactNode;
}
type WithServerUrlProps = {
serverUrl: string;
}
type GetProps<C> = C extends React.ComponentType<infer P & WithServerUrlProps> ? P : never
type ServerContext = {
displayName: string;
url: string;
}
const ServerContext = createContext<ServerContext>({displayName: '', url: ''});
const {Provider, Consumer} = ServerContext;
function ServerUrlProvider({server, children}: Props) {
return (
<Provider value={server}>{children}</Provider>
);
}
export function withServerUrl<C extends React.ComponentType<P>, P = GetProps<C>>(Component: C) {
return function ServerUrlComponent(props: JSX.LibraryManagedAttributes<C, P>) {
return (
<Consumer>
{(server: ServerContext) => (
<Component
{...props}
serverUrl={server.url}
/>
)}
</Consumer>
);
};
}
export function useServerDisplayName(): string {
const server = React.useContext(ServerContext);
return server.displayName;
}
export function useServerUrl(): string {
const server = React.useContext(ServerContext);
return server.url;
}
export default ServerUrlProvider;