aboutsummaryrefslogtreecommitdiff
path: root/client/src/components/Editor/Editor.jsx
diff options
context:
space:
mode:
authorBlaster4385 <blaster4385@tablaster.dev>2024-05-15 22:55:13 +0530
committerBlaster4385 <venkatesh@tablaster.dev>2024-06-09 14:10:27 +0530
commit731453588b93e02a113332d68f81e48bc11f7da7 (patch)
tree6b16d80ba200862ea71842b04de49298316551a2 /client/src/components/Editor/Editor.jsx
parent189ef9ef816d60fab71c0a12cdaaad245c988f37 (diff)
feat: added keyboard accessibility
Diffstat (limited to 'client/src/components/Editor/Editor.jsx')
-rw-r--r--client/src/components/Editor/Editor.jsx65
1 files changed, 62 insertions, 3 deletions
diff --git a/client/src/components/Editor/Editor.jsx b/client/src/components/Editor/Editor.jsx
index dac633c..976c1b2 100644
--- a/client/src/components/Editor/Editor.jsx
+++ b/client/src/components/Editor/Editor.jsx
@@ -5,13 +5,13 @@ import React, {
useCallback,
useMemo,
} from "react";
+import { Link } from "react-router-dom";
import { useLocation, useNavigate, useParams } from "react-router-dom";
import Prism from "prismjs";
import styles from "./Editor.module.css";
import "../prism-themes/prism-gruvbox-dark.css";
import "../prism-themes/prism-line-numbers.css";
import { URL_REGEX } from "../../utils/constants";
-import Header from "../Header/Header";
import {
generateAESKey,
keyToString,
@@ -20,6 +20,9 @@ import {
decryptAES,
} from "../../utils/encryption";
import Modal from "../Modal/Modal";
+import AlertToast from "../AlertToast/AlertToast";
+import CustomSelect from "../CustomSelect/CustomSelect";
+import KeyboardModal from "../KeyboardModal/KeyboardModal";
const Editor = () => {
const { id } = useParams();
@@ -28,6 +31,8 @@ const Editor = () => {
const [text, setText] = useState("");
const [language, setLanguage] = useState("none");
const [openModal, setOpenModal] = useState(false);
+ const [openKeyboardModal, setOpenKeyboardModal] = useState(false);
+ const [openAlertToast, setOpenAlertToast] = useState(false);
const textareaRef = useRef(null);
const lineNumberRef = useRef(null);
const queryParams = useMemo(
@@ -48,7 +53,7 @@ const Editor = () => {
const handleSaveClick = useCallback(async () => {
if (!text) {
- alert("Please enter some text!");
+ setOpenAlertToast(true);
return;
}
if (URL_REGEX.test(text)) {
@@ -189,14 +194,67 @@ const Editor = () => {
});
}, []);
+ useEffect(() => {
+ const handleKeyDown = (event) => {
+ if (!id && event.ctrlKey && event.key.toLowerCase() === "s") {
+ event.preventDefault();
+ handleSaveClick();
+ }
+ };
+
+ document.addEventListener("keydown", handleKeyDown);
+
+ return () => {
+ document.removeEventListener("keydown", handleKeyDown);
+ };
+ }, [handleSaveClick]);
+
return (
<>
- <Header isSelectVisible={!id} onLanguageChange={handleLanguageChange} />
+ {!id && (
+ <>
+ <KeyboardModal
+ textAreaRef={textareaRef}
+ isOpen={openKeyboardModal}
+ setIsOpen={setOpenKeyboardModal}
+ isModalOpen={openModal}
+ />
+ <AlertToast
+ openAlertToast={openAlertToast}
+ setOpenAlertToast={setOpenAlertToast}
+ />
+ </>
+ )}
+ <div className={styles.header}>
+ <Link to="/">
+ <h1>
+ <span className={styles.header__mini}>mini</span>bin
+ </h1>
+ </Link>
+ {!id && (
+ <div className={styles.header__right}>
+ <CustomSelect
+ onSelect={handleLanguageChange}
+ textAreaRef={textareaRef}
+ isModalOpen={openModal}
+ />
+ <button className={styles.btn__help}>
+ <img
+ src="assets/icons/question.png"
+ className={styles.btn__help__icon}
+ alt="Help"
+ onClick={() => setOpenKeyboardModal(true)}
+ />
+ </button>
+ </div>
+ )}
+ </div>
<Modal
openModal={openModal}
setOpenModal={setOpenModal}
onSuccessClick={handleSuccessClick}
onCancelClick={handleCancelClick}
+ textAreaRef={textareaRef}
/>
<div className={styles.container}>
{!id && (
@@ -220,6 +278,7 @@ const Editor = () => {
ref={textareaRef}
placeholder="</> Paste, save, share! (Pasting just a URL will shorten it!)"
value={text}
+ disabled={openModal}
/>
<pre className="line-numbers" ref={lineNumberRef}>
<code