mirror of
https://github.com/portainer/portainer.git
synced 2025-07-19 13:29:41 +02:00
Some checks failed
ci / build_images (map[arch:amd64 platform:windows version:ltsc2022]) (push) Has been cancelled
ci / build_images (map[arch:arm platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:arm64 platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:ppc64le platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:s390x platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:amd64 platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:amd64 platform:windows version:1809]) (push) Has been cancelled
/ triage (push) Has been cancelled
Lint / Run linters (push) Has been cancelled
Test / test-client (push) Has been cancelled
Test / test-server (map[arch:amd64 platform:linux]) (push) Has been cancelled
Test / test-server (map[arch:amd64 platform:windows version:1809]) (push) Has been cancelled
Test / test-server (map[arch:amd64 platform:windows version:ltsc2022]) (push) Has been cancelled
Test / test-server (map[arch:arm64 platform:linux]) (push) Has been cancelled
ci / build_manifests (push) Has been cancelled
39 lines
817 B
TypeScript
39 lines
817 B
TypeScript
import clsx from 'clsx';
|
|
import { createContext, PropsWithChildren, Ref, useContext } from 'react';
|
|
|
|
const Context = createContext<null | boolean>(null);
|
|
Context.displayName = 'WidgetContext';
|
|
|
|
export function useWidgetContext() {
|
|
const context = useContext(Context);
|
|
|
|
if (context == null) {
|
|
throw new Error('Should be inside a Widget component');
|
|
}
|
|
}
|
|
|
|
export function Widget({
|
|
children,
|
|
className,
|
|
mRef,
|
|
id,
|
|
'aria-label': ariaLabel,
|
|
}: PropsWithChildren<{
|
|
className?: string;
|
|
mRef?: Ref<HTMLDivElement>;
|
|
id?: string;
|
|
'aria-label'?: string;
|
|
}>) {
|
|
return (
|
|
<Context.Provider value>
|
|
<section
|
|
id={id}
|
|
className={clsx('widget', className)}
|
|
ref={mRef}
|
|
aria-label={ariaLabel}
|
|
>
|
|
{children}
|
|
</section>
|
|
</Context.Provider>
|
|
);
|
|
}
|