kibana/examples/state_containers_examples/public/todo/app.tsx
Tim Sullivan 68174f8705
[SharedUX] Replace KibanaRenderContextProvider usage (#220170)
## Summary

Closes https://github.com/elastic/kibana/issues/220175

---------

Co-authored-by: kibanamachine <42973632+kibanamachine@users.noreply.github.com>
2025-06-12 08:39:59 -07:00

50 lines
1.6 KiB
TypeScript

/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the "Elastic License
* 2.0", the "GNU Affero General Public License v3.0 only", and the "Server Side
* Public License v 1"; you may not use this file except in compliance with, at
* your election, the "Elastic License 2.0", the "GNU Affero General Public
* License v3.0 only", or the "Server Side Public License, v 1".
*/
import ReactDOM from 'react-dom';
import React from 'react';
import { AppMountParameters, CoreStart } from '@kbn/core/public';
import { createHashHistory } from 'history';
import { TodoAppPage } from './todo';
import { StateContainersExamplesPage, ExampleLink } from '../common/example_page';
export interface AppOptions {
appTitle: string;
historyType: History;
}
export enum History {
Browser,
Hash,
}
export interface Deps {
navigateToApp: CoreStart['application']['navigateToApp'];
exampleLinks: ExampleLink[];
}
export const renderApp = (
core: CoreStart,
{ appBasePath, element, history: platformHistory }: AppMountParameters,
{ appTitle, historyType }: AppOptions,
{ navigateToApp, exampleLinks }: Deps
) => {
const history = historyType === History.Browser ? platformHistory : createHashHistory();
ReactDOM.render(
core.rendering.addContext(
<StateContainersExamplesPage navigateToApp={navigateToApp} exampleLinks={exampleLinks}>
<TodoAppPage history={history} appTitle={appTitle} appBasePath={appBasePath} />
</StateContainersExamplesPage>
),
element
);
return () => ReactDOM.unmountComponentAtNode(element);
};