12345678910111213141516171819202122 |
- /**
- * Copyright (c) 2018-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
- *
- * @author David Sehnal <david.sehnal@gmail.com>
- * @author Alexander Rose <alexander.rose@weirdbyte.de>
- */
- import { createElement } from 'react';
- import { createRoot } from 'react-dom/client';
- import { Plugin } from './plugin';
- import { PluginUIContext } from './context';
- import { DefaultPluginUISpec, PluginUISpec } from './spec';
- export async function createPluginUI(target: HTMLElement, spec?: PluginUISpec, options?: { onBeforeUIRender?: (ctx: PluginUIContext) => (Promise<void> | void) }) {
- const ctx = new PluginUIContext(spec || DefaultPluginUISpec());
- await ctx.init();
- if (options?.onBeforeUIRender) {
- await options.onBeforeUIRender(ctx);
- }
- createRoot(target).render(createElement(Plugin, { plugin: ctx }));
- return ctx;
- }
|