waveterm/frontend/app/modals/tipsmodal.tsx
Sylvie Crowe 555ab07861
Add Tips Modal for Directory (#374)
This is an experimental modal to show tips. If it helps improve
discoverability, it will be improved in the future.
2024-09-13 03:36:15 -07:00

72 lines
2.3 KiB
TypeScript

// Copyright 2024, Command Line Inc.
// SPDX-License-Identifier: Apache-2.0
import { Modal } from "@/app/modals/modal";
import { Markdown } from "@/element/markdown";
import { modalsModel } from "@/store/modalmodel";
import * as keyutil from "@/util/keyutil";
import { useCallback, useMemo, useRef, useState } from "react";
import "./tipsmodal.less";
const TipsModal = (tipsContent: UserInputRequest) => {
const [responseText, setResponseText] = useState("");
const checkboxStatus = useRef(false);
const handleClose = useCallback(() => {
modalsModel.popModal();
}, []);
const handleKeyDown = useCallback(
(waveEvent: WaveKeyboardEvent): boolean => {
if (keyutil.checkKeyPressed(waveEvent, "Escape")) {
handleClose();
return;
}
if (keyutil.checkKeyPressed(waveEvent, "Enter")) {
handleClose();
return true;
}
},
[handleClose]
);
const queryText = useMemo(() => {
if (tipsContent.markdown) {
return <Markdown text={tipsContent.querytext} className="userinput-markdown" />;
}
return <span className="userinput-text">{tipsContent.querytext}</span>;
}, [tipsContent.markdown, tipsContent.querytext]);
const inputBox = useMemo(() => {
if (tipsContent.responsetype === "confirm") {
return <></>;
}
return (
<input
type={tipsContent.publictext ? "text" : "password"}
onChange={(e) => setResponseText(e.target.value)}
value={responseText}
maxLength={400}
className="userinput-inputbox"
autoFocus={true}
onKeyDown={(e) => keyutil.keydownWrapper(handleKeyDown)(e)}
/>
);
}, [tipsContent.responsetype, tipsContent.publictext, responseText, handleKeyDown, setResponseText]);
return (
<Modal onOk={() => handleClose()} onCancel={() => handleClose()} onClose={() => handleClose()}>
<div className="userinput-header">{tipsContent.title}</div>
<div className="userinput-body">
{queryText}
{inputBox}
</div>
</Modal>
);
};
TipsModal.displayName = "TipsModal";
export { TipsModal };