1 | "use strict";
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 | Object.defineProperty(exports, "__esModule", { value: true });
|
18 | exports.ReactRenderer = exports.RendererHost = void 0;
|
19 | const tslib_1 = require("tslib");
|
20 | const inversify_1 = require("inversify");
|
21 | const React = require("react");
|
22 | const client_1 = require("react-dom/client");
|
23 | const common_1 = require("../../common");
|
24 | exports.RendererHost = Symbol('RendererHost');
|
25 | let ReactRenderer = class ReactRenderer {
|
26 | constructor(host) {
|
27 | this.toDispose = new common_1.DisposableCollection();
|
28 | this.host = host || document.createElement('div');
|
29 | this.hostRoot = (0, client_1.createRoot)(this.host);
|
30 | this.toDispose.push(common_1.Disposable.create(() => this.hostRoot.unmount()));
|
31 | }
|
32 | dispose() {
|
33 | this.toDispose.dispose();
|
34 | }
|
35 | render() {
|
36 | this.hostRoot.render(React.createElement(React.Fragment, null, this.doRender()));
|
37 | }
|
38 | doRender() {
|
39 | return undefined;
|
40 | }
|
41 | };
|
42 | ReactRenderer = (0, tslib_1.__decorate)([
|
43 | (0, inversify_1.injectable)(),
|
44 | (0, tslib_1.__param)(0, (0, inversify_1.inject)(exports.RendererHost)),
|
45 | (0, tslib_1.__param)(0, (0, inversify_1.optional)()),
|
46 | (0, tslib_1.__metadata)("design:paramtypes", [Object])
|
47 | ], ReactRenderer);
|
48 | exports.ReactRenderer = ReactRenderer;
|
49 |
|
\ | No newline at end of file |