You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
bazarr/frontend/src/modules/modals/WithModal.tsx

37 lines
1002 B

/* eslint-disable @typescript-eslint/ban-types */
import { ContextModalProps } from "@mantine/modals";
import { ModalSettings } from "@mantine/modals/lib/context";
import { createContext, FunctionComponent } from "react";
export type ModalComponent<P extends Record<string, unknown> = {}> =
FunctionComponent<ContextModalProps<P>> & {
modalKey: string;
settings?: ModalSettings;
};
export const StaticModals: ModalComponent[] = [];
export const ModalIdContext = createContext<string | null>(null);
export default function withModal<T extends {}>(
Content: FunctionComponent<T>,
key: string,
defaultSettings?: ModalSettings
) {
const Comp: ModalComponent<T> = (props) => {
const { id, innerProps } = props;
return (
<ModalIdContext.Provider value={id}>
<Content {...innerProps}></Content>
</ModalIdContext.Provider>
);
};
Comp.modalKey = key;
Comp.settings = defaultSettings;
StaticModals.push(Comp as ModalComponent);
return Comp;
}