@aliemir/react-live
Version:
A production-focused playground for live editing React code
74 lines (59 loc) • 1.78 kB
TypeScript
import { ComponentClass, HTMLProps, ComponentType, Context } from "react";
import type { Options } from "sucrase";
import { PrismTheme, Language } from "prism-react-renderer";
// Helper types
type Omit<T, K extends keyof T> = Pick<T, Exclude<keyof T, K>>;
// React Element Props
type DivProps = HTMLProps<HTMLDivElement>;
type PreProps = HTMLProps<HTMLPreElement>;
// LiveProvider
export type LiveProviderProps = Omit<DivProps, "scope"> & {
Context?: Context<ContextProps>;
transformOptions?: Options;
scope?: { [key: string]: any };
code?: string;
noInline?: boolean;
transformCode?: (code: string) => string | Promise<string>;
language?: Language;
disabled?: boolean;
theme?: PrismTheme;
};
export const theme: PrismTheme;
export const LiveProvider: ComponentClass<LiveProviderProps>;
// Editor
export type EditorProps = Omit<PreProps, "onChange"> & {
Context?: Context<ContextProps>;
code?: string;
disabled?: boolean;
language?: Language;
onChange?: (code: string) => void;
theme?: PrismTheme;
prism?: unknown;
};
export const Editor: ComponentClass<EditorProps>;
// Context
export interface ContextProps {
code?: string;
language?: Language;
theme: PrismTheme;
disabled?: boolean;
error?: string;
}
export const LiveContext: Context<ContextProps>;
// LiveEditor
export type LiveEditorProps = EditorProps;
export const LiveEditor: ComponentClass<
LiveEditorProps & { Context?: Context<ContextProps> }
>;
// LiveError
export const LiveError: ComponentClass<
DivProps & { Context?: Context<ContextProps> }
>;
// LivePreview
export const LivePreview: ComponentClass<
DivProps & { Context?: Context<ContextProps> }
>;
// withLive HOC
export function withLive<P>(
wrappedComponent: ComponentType<P>
): ComponentClass<P>;