mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-06-20 06:35:22 +02:00
feat: add keyboard shortcuts to application page
This commit is contained in:
77
apps/dokploy/hooks/use-keyboard-nav.tsx
Normal file
77
apps/dokploy/hooks/use-keyboard-nav.tsx
Normal file
@@ -0,0 +1,77 @@
|
||||
"use client";
|
||||
|
||||
import { usePathname, useRouter, useSearchParams } from "next/navigation";
|
||||
import { useCallback, useEffect, useState } from "react";
|
||||
|
||||
const SHORTCUTS = {
|
||||
g: "general",
|
||||
e: "environment",
|
||||
u: "domains",
|
||||
p: "preview-deployments",
|
||||
s: "schedules",
|
||||
v: "volume-backups",
|
||||
d: "deployments",
|
||||
l: "logs",
|
||||
m: "monitoring",
|
||||
a: "advanced",
|
||||
};
|
||||
|
||||
/**
|
||||
* Use this to register keyboard shortcuts for the application page. Each
|
||||
* shortcut must be prefixed with `g` (like GitHub).
|
||||
*
|
||||
* - `g g` "General",
|
||||
* - `g e` "Environment",
|
||||
* - `g u` "Domains",
|
||||
* - `g p` "Preview Deployments",
|
||||
* - `g s` "Schedules",
|
||||
* - `g v` "Volume Backups",
|
||||
* - `g d` "Deployments",
|
||||
* - `g l` "Logs",
|
||||
* - `g m` "Monitoring",
|
||||
* - `g a` "Advanced"
|
||||
*/
|
||||
export function UseKeyboardNavForApplications() {
|
||||
const [isModPressed, setModPressed] = useState(false);
|
||||
const [timer, setTimer] = useState<NodeJS.Timeout | null>(null);
|
||||
|
||||
const sp = useSearchParams();
|
||||
const router = useRouter();
|
||||
const pathname = usePathname();
|
||||
|
||||
const updateSearchParam = useCallback(
|
||||
(name: string, value: string) => {
|
||||
const params = new URLSearchParams(sp.toString());
|
||||
params.set(name, value);
|
||||
|
||||
return params.toString();
|
||||
},
|
||||
[sp],
|
||||
);
|
||||
|
||||
useEffect(() => {
|
||||
const handleKeyDown = ({ key }: KeyboardEvent) => {
|
||||
if (isModPressed) {
|
||||
if (timer) clearTimeout(timer);
|
||||
setModPressed(false);
|
||||
|
||||
if (key in SHORTCUTS) {
|
||||
const tab = SHORTCUTS[key];
|
||||
router.push(
|
||||
`${pathname}?${updateSearchParam("tab", tab.toLowerCase())}`,
|
||||
);
|
||||
}
|
||||
} else {
|
||||
if (key === "g") {
|
||||
setModPressed(true);
|
||||
setTimer(setTimeout(() => setModPressed(false), 5000));
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
window.addEventListener("keydown", handleKeyDown);
|
||||
return () => window.removeEventListener("keydown", handleKeyDown);
|
||||
}, [isModPressed, timer, updateSearchParam, router, pathname]);
|
||||
|
||||
return null;
|
||||
}
|
||||
@@ -51,6 +51,7 @@ import {
|
||||
TooltipProvider,
|
||||
TooltipTrigger,
|
||||
} from "@/components/ui/tooltip";
|
||||
import { UseKeyboardNavForApplications } from "@/hooks/use-keyboard-nav";
|
||||
import { appRouter } from "@/server/api/root";
|
||||
import { api } from "@/utils/api";
|
||||
|
||||
@@ -91,6 +92,7 @@ const Service = (
|
||||
|
||||
return (
|
||||
<div className="pb-10">
|
||||
<UseKeyboardNavForApplications />
|
||||
<BreadcrumbSidebar
|
||||
list={[
|
||||
{ name: "Projects", href: "/dashboard/projects" },
|
||||
|
||||
Reference in New Issue
Block a user