mirror of
https://github.com/PhyreApps/PhyrePanel.git
synced 2024-11-21 15:10:25 +00:00
update
This commit is contained in:
parent
d9e474e397
commit
ccbc10ac2f
4 changed files with 71 additions and 25 deletions
|
@ -1,3 +1,3 @@
|
||||||
import './bootstrap';
|
import './bootstrap';
|
||||||
|
|
||||||
import { Terminal } from '@xterm/xterm';
|
|
||||||
|
|
63
web/resources/js/web-terminal.js
Normal file
63
web/resources/js/web-terminal.js
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
import '@xterm/xterm/css/xterm.css';
|
||||||
|
import { Terminal } from '@xterm/xterm';
|
||||||
|
import { WebglAddon } from '@xterm/addon-webgl';
|
||||||
|
import { CanvasAddon } from '@xterm/addon-canvas';
|
||||||
|
import { FitAddon } from '@xterm/addon-fit';
|
||||||
|
|
||||||
|
let terminalElement = document.getElementById('js-web-terminal');
|
||||||
|
if (terminalElement !== null) {
|
||||||
|
|
||||||
|
const terminal = new Terminal({
|
||||||
|
allowTransparency: true,
|
||||||
|
theme: {
|
||||||
|
background: '#09090b',
|
||||||
|
foreground: '#cccccc',
|
||||||
|
selectionBackground: '#399ef440',
|
||||||
|
black: '#666666',
|
||||||
|
blue: '#399ef4',
|
||||||
|
brightBlack: '#666666',
|
||||||
|
brightBlue: '#399ef4',
|
||||||
|
brightCyan: '#21c5c7',
|
||||||
|
brightGreen: '#4eb071',
|
||||||
|
brightMagenta: '#b168df',
|
||||||
|
brightRed: '#da6771',
|
||||||
|
brightWhite: '#efefef',
|
||||||
|
brightYellow: '#fff099',
|
||||||
|
cyan: '#21c5c7',
|
||||||
|
green: '#4eb071',
|
||||||
|
magenta: '#b168df',
|
||||||
|
red: '#da6771',
|
||||||
|
white: '#efefef',
|
||||||
|
yellow: '#fff099'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (typeof WebGL2RenderingContext !== 'undefined') {
|
||||||
|
terminal.loadAddon(new WebglAddon());
|
||||||
|
} else {
|
||||||
|
terminal.loadAddon(new CanvasAddon());
|
||||||
|
}
|
||||||
|
|
||||||
|
const fitAddon = new FitAddon();
|
||||||
|
terminal.loadAddon(fitAddon);
|
||||||
|
|
||||||
|
terminal.open(terminalElement);
|
||||||
|
|
||||||
|
fitAddon.fit();
|
||||||
|
|
||||||
|
const socket = new WebSocket(`ws://49.13.166.115:3311`);
|
||||||
|
socket.addEventListener('open', (_) => {
|
||||||
|
terminal.onData((data) => socket.send(data));
|
||||||
|
socket.addEventListener('message', (evt) => terminal.write(evt.data));
|
||||||
|
});
|
||||||
|
socket.addEventListener('error', (_) => {
|
||||||
|
terminal.reset();
|
||||||
|
terminal.writeln('Connection error.');
|
||||||
|
});
|
||||||
|
socket.addEventListener('close', (evt) => {
|
||||||
|
if (evt.wasClean) {
|
||||||
|
terminal.reset();
|
||||||
|
terminal.writeln(evt.reason ?? 'Connection closed.');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
|
@ -2,31 +2,10 @@
|
||||||
|
|
||||||
<div>
|
<div>
|
||||||
|
|
||||||
|
@vite('resources/js/web-terminal.js')
|
||||||
|
|
||||||
<div id="js-web-terminal"></div>
|
<div id="js-web-terminal"></div>
|
||||||
|
|
||||||
<script>
|
|
||||||
|
|
||||||
const terminal = new Terminal();
|
|
||||||
terminal.open(document.getElementById('js-web-terminal'));
|
|
||||||
//terminal.resize(160, 30);
|
|
||||||
|
|
||||||
const socket = new WebSocket(`ws://49.13.166.115:3311`);
|
|
||||||
socket.addEventListener('open', (_) => {
|
|
||||||
terminal.onData((data) => socket.send(data));
|
|
||||||
socket.addEventListener('message', (evt) => terminal.write(evt.data));
|
|
||||||
});
|
|
||||||
socket.addEventListener('error', (_) => {
|
|
||||||
terminal.reset();
|
|
||||||
terminal.writeln('Connection error.');
|
|
||||||
});
|
|
||||||
socket.addEventListener('close', (evt) => {
|
|
||||||
if (evt.wasClean) {
|
|
||||||
terminal.reset();
|
|
||||||
terminal.writeln(evt.reason ?? 'Connection closed.');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</x-filament-panels::page>
|
</x-filament-panels::page>
|
||||||
|
|
|
@ -4,7 +4,11 @@ import laravel, { refreshPaths } from 'laravel-vite-plugin'
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
plugins: [
|
plugins: [
|
||||||
laravel({
|
laravel({
|
||||||
input: ['resources/css/app.css', 'resources/js/app.js'],
|
input: [
|
||||||
|
'resources/css/app.css',
|
||||||
|
'resources/js/app.js',
|
||||||
|
'resources/js/web-terminal.js',
|
||||||
|
],
|
||||||
refresh: [
|
refresh: [
|
||||||
...refreshPaths,
|
...refreshPaths,
|
||||||
'app/Livewire/**',
|
'app/Livewire/**',
|
||||||
|
|
Loading…
Reference in a new issue