mirror of
https://github.com/LukeHagar/dokploy.git
synced 2025-12-09 20:37:45 +00:00
* fix: dashboard layout scroll * feat: dashboard nav style animation * chore: code input font * style: format code * pref: alert component extraction * fix: global font var not found * fix: code path beak line * chore: remove framer-motion * fix: status color
70 lines
1.9 KiB
TypeScript
70 lines
1.9 KiB
TypeScript
import React, { useEffect, useRef } from "react";
|
|
import { Terminal } from "@xterm/xterm";
|
|
import { FitAddon } from "xterm-addon-fit";
|
|
import "@xterm/xterm/css/xterm.css";
|
|
import { AttachAddon } from "@xterm/addon-attach";
|
|
import { Tabs, TabsList, TabsTrigger } from "@/components/ui/tabs";
|
|
|
|
interface Props {
|
|
id: string;
|
|
containerId: string;
|
|
}
|
|
|
|
export const DockerTerminal: React.FC<Props> = ({ id, containerId }) => {
|
|
const termRef = useRef(null);
|
|
const [activeWay, setActiveWay] = React.useState<string | undefined>("bash");
|
|
useEffect(() => {
|
|
const container = document.getElementById(id);
|
|
if (container) {
|
|
container.innerHTML = "";
|
|
}
|
|
const term = new Terminal({
|
|
cursorBlink: true,
|
|
cols: 80,
|
|
rows: 30,
|
|
lineHeight: 1.4,
|
|
convertEol: true,
|
|
theme: {
|
|
cursor: "transparent",
|
|
background: "rgba(0, 0, 0, 0)",
|
|
},
|
|
});
|
|
const addonFit = new FitAddon();
|
|
|
|
const protocol = window.location.protocol === "https:" ? "wss:" : "ws:";
|
|
|
|
const wsUrl = `${protocol}//${window.location.host}/docker-container-terminal?containerId=${containerId}&activeWay=${activeWay}`;
|
|
|
|
const ws = new WebSocket(wsUrl);
|
|
|
|
const addonAttach = new AttachAddon(ws);
|
|
// @ts-ignore
|
|
term.open(termRef.current);
|
|
term.loadAddon(addonFit);
|
|
term.loadAddon(addonAttach);
|
|
addonFit.fit();
|
|
return () => {
|
|
ws.readyState === WebSocket.OPEN && ws.close();
|
|
};
|
|
}, [containerId, activeWay, id]);
|
|
|
|
return (
|
|
<div className="flex flex-col gap-4">
|
|
<div className="flex flex-col gap-2">
|
|
<span>
|
|
Select way to connect to <b>{containerId}</b>
|
|
</span>
|
|
<Tabs value={activeWay} onValueChange={setActiveWay}>
|
|
<TabsList>
|
|
<TabsTrigger value="bash">Bash</TabsTrigger>
|
|
<TabsTrigger value="sh">/bin/sh</TabsTrigger>
|
|
</TabsList>
|
|
</Tabs>
|
|
</div>
|
|
<div className="w-full h-full rounded-lg p-2 bg-[#19191A]">
|
|
<div id={id} ref={termRef} />
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|