-
Notifications
You must be signed in to change notification settings - Fork 24
/
renderer.tsx
54 lines (49 loc) · 1.57 KB
/
renderer.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import isDocker from "is-docker";
import React from "react";
import { ReactComponentServer } from "./component-server";
import { ScreenshotRenderer } from "./screenshot-renderer/api";
import { DockerRenderer } from "./screenshot-renderer/docker-renderer";
import { LocalChromeRenderer } from "./screenshot-renderer/local-chrome-renderer";
/**
* ReactScreenshotRenderer renders screenshots of React components.
*/
export class ReactScreenshotRenderer {
private readonly server: ReactComponentServer;
private readonly browser: ScreenshotRenderer;
private readonly mode: "local" | "docker";
constructor(
options: {
port?: number;
mode?: "default" | "local" | "docker";
} = {}
) {
this.server = new ReactComponentServer(options.port || 3037);
switch (options.mode || "default") {
case "local":
this.mode = "local";
break;
case "docker":
this.mode = "docker";
break;
default:
this.mode = isDocker() ? "local" : "docker";
}
this.browser =
this.mode === "local" ? new LocalChromeRenderer() : new DockerRenderer();
}
async start() {
await Promise.all([this.server.start(), this.browser.start()]);
}
async stop() {
await Promise.all([this.server.stop(), this.browser.stop()]);
}
async render(node: React.ReactNode) {
return this.server.serve(node, async (port, path) => {
const url =
this.mode === "local"
? `http://localhost:${port}${path}`
: `http://host.docker.internal:${port}${path}`;
return this.browser.render(url);
});
}
}