2023-02-22 20:13:33 +00:00
|
|
|
import { ComponentType, useMemo } from 'react';
|
|
|
|
|
|
|
|
import { UserContext } from '@/react/hooks/useUser';
|
|
|
|
import { User } from '@/portainer/users/types';
|
|
|
|
|
|
|
|
const mockUser: User = {
|
|
|
|
EndpointAuthorizations: [],
|
|
|
|
Id: 1,
|
|
|
|
Role: 1,
|
|
|
|
Username: 'mock',
|
2023-11-22 01:21:07 +00:00
|
|
|
UseCache: false,
|
2023-02-22 20:13:33 +00:00
|
|
|
ThemeSettings: {
|
|
|
|
color: 'auto',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2023-09-20 06:04:26 +00:00
|
|
|
/**
|
|
|
|
* A helper function to wrap a component with a UserContext.Provider.
|
|
|
|
*
|
|
|
|
* should only be used in tests
|
|
|
|
*/
|
2023-02-22 20:13:33 +00:00
|
|
|
export function withUserProvider<T>(
|
|
|
|
WrappedComponent: ComponentType<T>,
|
|
|
|
user = mockUser
|
|
|
|
): ComponentType<T> {
|
|
|
|
// Try to create a nice displayName for React Dev Tools.
|
|
|
|
const displayName =
|
|
|
|
WrappedComponent.displayName || WrappedComponent.name || 'Component';
|
|
|
|
|
2023-05-14 09:24:37 +00:00
|
|
|
function WrapperComponent(props: T & JSX.IntrinsicAttributes) {
|
2023-02-22 20:13:33 +00:00
|
|
|
const state = useMemo(() => ({ user }), []);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<UserContext.Provider value={state}>
|
|
|
|
{/* eslint-disable-next-line react/jsx-props-no-spreading */}
|
|
|
|
<WrappedComponent {...props} />
|
|
|
|
</UserContext.Provider>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
WrapperComponent.displayName = `withUserProvider(${displayName})`;
|
|
|
|
|
|
|
|
return WrapperComponent;
|
|
|
|
}
|