forked from Ivasoft/mattermost-mobile
* 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
57 lines
1.4 KiB
TypeScript
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;
|