From 4daf59f3dc520f37d5551c24a097f280ad791cd1 Mon Sep 17 00:00:00 2001 From: Chris Laplante Date: Sat, 18 May 2024 11:55:53 -0400 Subject: [PATCH] fix StrictMode issues with JQueryTerminal --- src/main/components/JQueryTerminal.tsx | 32 ++++++++++---------------- 1 file changed, 12 insertions(+), 20 deletions(-) diff --git a/src/main/components/JQueryTerminal.tsx b/src/main/components/JQueryTerminal.tsx index 0f362ea..3ddfbcc 100644 --- a/src/main/components/JQueryTerminal.tsx +++ b/src/main/components/JQueryTerminal.tsx @@ -1,20 +1,16 @@ -import React, {useImperativeHandle, forwardRef, useRef, useEffect} from "react"; -import * as $ from "jquery"; +import React, {forwardRef, useEffect, useImperativeHandle, useRef} from "react"; +import $ from "jquery"; import 'jquery.terminal'; import 'jquery.terminal/css/jquery.terminal.min.css'; -import {terminal} from "jquery"; -import {usePyodide} from "../hooks/usePyodide"; interface Props { interpreter?: TypeOrArray, options?: JQueryTerminal.TerminalOptions } -const BANNER = ` -Copyright (C) Agilent Technologies 2024 -`; +const BANNER = `Copyright (C) Agilent Technologies 2024`; -export const JQueryTerminal: React.ForwardRefExoticComponent & React.RefAttributes> = forwardRef(function JQueryTerminal(props, ref) { +export const JQueryTerminal: React.ForwardRefExoticComponent & React.RefAttributes> = forwardRef(function JQueryTerminal(props: Props, ref) { const terminalContainerRef = useRef(null); const terminalObjectRef = useRef(null); @@ -46,24 +42,20 @@ export const JQueryTerminal: React.ForwardRefExoticComponent { - const currentTerminal = terminalContainerRef.current; + const obj: JQueryTerminal | null = terminalObjectRef.current; - if (currentTerminal) { - terminalObjectRef.current = $(currentTerminal).terminal(props.interpreter, { - greetings: BANNER, - ...props.options - }); - } + terminalObjectRef.current = $(terminalContainerRef.current).terminal(props.interpreter, { + greetings: BANNER, + ...props.options + }); return () => { - if (currentTerminal) { - $(currentTerminal).remove(); - } - if (terminalObjectRef.current) { + if (obj) { + obj.destroy(); terminalObjectRef.current = null; } }; }, [props.interpreter, props.options]); - return
; + return (
); }); \ No newline at end of file