From 47324f15bf823ece421fc293f307d474c942ed36 Mon Sep 17 00:00:00 2001 From: Hamzat Victor Date: Thu, 5 Sep 2024 13:30:24 +0100 Subject: [PATCH 1/2] feat: add support for syntax highlighting for 290+ languages --- frontend/lib/file-extension-to-language.json | 295 +++++++++++++++++++ frontend/lib/utils.ts | 30 +- 2 files changed, 312 insertions(+), 13 deletions(-) create mode 100644 frontend/lib/file-extension-to-language.json diff --git a/frontend/lib/file-extension-to-language.json b/frontend/lib/file-extension-to-language.json new file mode 100644 index 0000000..a959737 --- /dev/null +++ b/frontend/lib/file-extension-to-language.json @@ -0,0 +1,295 @@ +{ + "_coffee": "coffeescript", + "_js": "javascript", + "adp": "tcl", + "al": "perl", + "ant": "xml", + "aw": "php", + "axml": "xml", + "bash": "shell", + "bats": "shell", + "bones": "javascript", + "boot": "clojure", + "builder": "ruby", + "bzl": "python", + "c": "c", + "c++": "cpp", + "cake": "coffeescript", + "cats": "c", + "cc": "cpp", + "ccxml": "xml", + "cfg": "ini", + "cgi": "shell", + "cjsx": "coffeescript", + "cl2": "clojure", + "clixml": "xml", + "clj": "clojure", + "cljc": "clojure", + "cljs.hl": "clojure", + "cljs": "clojure", + "cljscm": "clojure", + "cljx": "clojure", + "coffee": "coffeescript", + "command": "shell", + "cp": "cpp", + "cpp": "cpp", + "cproject": "xml", + "cql": "sql", + "csl": "xml", + "cson": "coffeescript", + "csproj": "xml", + "ct": "xml", + "ctp": "php", + "cxx": "cpp", + "ddl": "sql", + "dfm": "pascal", + "dita": "xml", + "ditamap": "xml", + "ditaval": "xml", + "dll.config": "xml", + "dotsettings": "xml", + "dpr": "pascal", + "ecl": "ecl", + "eclxml": "ecl", + "es": "javascript", + "es6": "javascript", + "ex": "elixir", + "exs": "elixir", + "fcgi": "shell", + "filters": "xml", + "frag": "javascript", + "fsproj": "xml", + "fxml": "xml", + "gemspec": "ruby", + "geojson": "json", + "glade": "xml", + "gml": "xml", + "god": "ruby", + "grxml": "xml", + "gs": "javascript", + "gyp": "python", + "h": "cpp", + "h++": "cpp", + "handlebars": "handlebars", + "hbs": "handlebars", + "hcl": "hcl", + "hh": "cpp", + "hic": "clojure", + "hpp": "cpp", + "htm": "html", + "html.hl": "html", + "html": "html", + "hxx": "cpp", + "iced": "coffeescript", + "idc": "c", + "iml": "xml", + "inc": "sql", + "ini": "ini", + "inl": "cpp", + "ipp": "cpp", + "irbrc": "ruby", + "ivy": "xml", + "j2": "python", + "jake": "javascript", + "jbuilder": "ruby", + "jelly": "xml", + "jinja": "python", + "jinja2": "python", + "js": "javascript", + "jsb": "javascript", + "jscad": "javascript", + "jsfl": "javascript", + "jsm": "javascript", + "json": "json", + "jsproj": "xml", + "jss": "javascript", + "kml": "xml", + "ksh": "shell", + "kt": "kotlin", + "ktm": "kotlin", + "kts": "kotlin", + "launch": "xml", + "lmi": "python", + "lock": "json", + "lpr": "pascal", + "lua": "lua", + "markdown": "markdown", + "md": "markdown", + "mdpolicy": "xml", + "mkd": "markdown", + "mkdn": "markdown", + "mkdown": "markdown", + "mm": "xml", + "mod": "xml", + "mspec": "ruby", + "mustache": "python", + "mxml": "xml", + "njs": "javascript", + "nproj": "xml", + "nse": "lua", + "nuspec": "xml", + "odd": "xml", + "osm": "xml", + "pac": "javascript", + "pas": "pascal", + "pd_lua": "lua", + "perl": "perl", + "ph": "perl", + "php": "php", + "php3": "php", + "php4": "php", + "php5": "php", + "phps": "php", + "phpt": "php", + "pl": "perl", + "plist": "xml", + "pluginspec": "xml", + "plx": "perl", + "pm": "perl", + "pod": "perl", + "podspec": "ruby", + "pp": "pascal", + "prc": "sql", + "prefs": "ini", + "pro": "ini", + "properties": "ini", + "props": "xml", + "ps1": "powershell", + "ps1xml": "xml", + "psc1": "xml", + "psd1": "powershell", + "psgi": "perl", + "psm1": "powershell", + "pt": "xml", + "py": "python", + "pyde": "python", + "pyp": "python", + "pyt": "python", + "pyw": "python", + "r": "r", + "rabl": "ruby", + "rake": "ruby", + "rb": "ruby", + "rbuild": "ruby", + "rbw": "ruby", + "rbx": "ruby", + "rbxs": "lua", + "rd": "r", + "rdf": "xml", + "reek": "yaml", + "rest.txt": "restructuredtext", + "rest": "restructuredtext", + "ron": "markdown", + "rpy": "python", + "rq": "sparql", + "rs.in": "rust", + "rs": "rust", + "rss": "xml", + "rst.txt": "restructuredtext", + "rst": "restructuredtext", + "rsx": "r", + "ru": "ruby", + "ruby": "ruby", + "rviz": "yaml", + "sbt": "scala", + "sc": "scala", + "scala": "scala", + "scm": "scheme", + "scxml": "xml", + "sh.in": "shell", + "sh": "shell", + "sjs": "javascript", + "sld": "scheme", + "sls": "scheme", + "sparql": "sparql", + "sps": "scheme", + "sql": "sql", + "srdf": "xml", + "ss": "scheme", + "ssjs": "javascript", + "st": "html", + "storyboard": "xml", + "sttheme": "xml", + "sublime_metrics": "javascript", + "sublime_session": "javascript", + "sublime-build": "javascript", + "sublime-commands": "javascript", + "sublime-completions": "javascript", + "sublime-keymap": "javascript", + "sublime-macro": "javascript", + "sublime-menu": "javascript", + "sublime-mousemap": "javascript", + "sublime-project": "javascript", + "sublime-settings": "javascript", + "sublime-snippet": "xml", + "sublime-syntax": "yaml", + "sublime-theme": "javascript", + "sublime-workspace": "javascript", + "sv": "systemverilog", + "svh": "systemverilog", + "syntax": "yaml", + "t": "perl", + "tab": "sql", + "tac": "python", + "targets": "xml", + "tcc": "cpp", + "tcl": "tcl", + "tf": "hcl", + "thor": "ruby", + "tm": "tcl", + "tmcommand": "xml", + "tml": "xml", + "tmlanguage": "xml", + "tmpreferences": "xml", + "tmsnippet": "xml", + "tmtheme": "xml", + "tmux": "shell", + "tool": "shell", + "topojson": "json", + "tpp": "cpp", + "ts": "typescript", + "tsx": "typescript", + "udf": "sql", + "ui": "xml", + "urdf": "xml", + "ux": "xml", + "v": "verilog", + "vbproj": "xml", + "vcxproj": "xml", + "veo": "verilog", + "vh": "systemverilog", + "viw": "sql", + "vssettings": "xml", + "vxml": "xml", + "w": "c", + "watchr": "ruby", + "wlua": "lua", + "wsdl": "xml", + "wsf": "xml", + "wsgi": "python", + "wxi": "xml", + "wxl": "xml", + "wxs": "xml", + "x3d": "xml", + "xacro": "xml", + "xaml": "xml", + "xht": "html", + "xhtml": "html", + "xib": "xml", + "xlf": "xml", + "xliff": "xml", + "xmi": "xml", + "xml.dist": "xml", + "xml": "xml", + "xproj": "xml", + "xpy": "python", + "xsd": "xml", + "xsjs": "javascript", + "xsjslib": "javascript", + "xul": "xml", + "yaml-tmlanguage": "yaml", + "yaml": "yaml", + "yml": "yaml", + "zcml": "xml", + "zsh": "shell" +} diff --git a/frontend/lib/utils.ts b/frontend/lib/utils.ts index 85cc434..63b3764 100644 --- a/frontend/lib/utils.ts +++ b/frontend/lib/utils.ts @@ -2,18 +2,19 @@ import { type ClassValue, clsx } from "clsx" // import { toast } from "sonner" import { twMerge } from "tailwind-merge" import { Sandbox, TFile, TFolder } from "./types" +import fileExtToLang from "./file-extension-to-language.json" export function cn(...inputs: ClassValue[]) { return twMerge(clsx(inputs)) } export function processFileType(file: string) { - const ending = file.split(".").pop() + const extension = file.split(".").pop() + const fileExtToLangMap = fileExtToLang as Record + if (extension && fileExtToLangMap[extension]) { + return fileExtToLangMap[extension] + } - if (ending === "ts" || ending === "tsx") return "typescript" - if (ending === "js" || ending === "jsx") return "javascript" - - if (ending) return ending return "plaintext" } @@ -62,12 +63,15 @@ export function addNew( } } -export function debounce void>(func: T, wait: number): T { - let timeout: NodeJS.Timeout | null = null; +export function debounce void>( + func: T, + wait: number +): T { + let timeout: NodeJS.Timeout | null = null return function (...args: Parameters) { - if (timeout) { - clearTimeout(timeout); - } - timeout = setTimeout(() => func(...args), wait); - } as T; -} \ No newline at end of file + if (timeout) { + clearTimeout(timeout) + } + timeout = setTimeout(() => func(...args), wait) + } as T +} From bf79893dfa562ba64b479077873602a9fc04bf01 Mon Sep 17 00:00:00 2001 From: Hamzat Victor Date: Thu, 5 Sep 2024 13:30:41 +0100 Subject: [PATCH 2/2] feat(a11y): add Esc key functionality to close modal --- frontend/components/editor/generate.tsx | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/frontend/components/editor/generate.tsx b/frontend/components/editor/generate.tsx index aef3c33..6366ba4 100644 --- a/frontend/components/editor/generate.tsx +++ b/frontend/components/editor/generate.tsx @@ -93,6 +93,17 @@ export default function GenerateInput({ } }, [code]) + useEffect(() => { + //listen to when Esc key is pressed and close the modal + const handleKeyDown = (e: KeyboardEvent) => { + if (e.key === "Escape") { + onClose() + } + } + window.addEventListener("keydown", handleKeyDown) + return () => window.removeEventListener("keydown", handleKeyDown) + }, []) + return (