mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2025-09-13 23:45:20 +00:00
96 lines
3.5 KiB
TypeScript
96 lines
3.5 KiB
TypeScript
"use client";
|
|
import { Separator } from "@/components/ui/separator";
|
|
import { extractDate } from "@/lib/time";
|
|
import { Script } from "@/lib/types";
|
|
import { X } from "lucide-react";
|
|
import Image from "next/image";
|
|
|
|
import Alerts from "./ScriptItems/Alerts";
|
|
import Buttons from "./ScriptItems/Buttons";
|
|
import DefaultPassword from "./ScriptItems/DefaultPassword";
|
|
import DefaultSettings from "./ScriptItems/DefaultSettings";
|
|
import Description from "./ScriptItems/Description";
|
|
import InstallCommand from "./ScriptItems/InstallCommand";
|
|
import InterFaces from "./ScriptItems/InterFaces";
|
|
import Tooltips from "./ScriptItems/Tooltips";
|
|
|
|
function ScriptItem({
|
|
item,
|
|
setSelectedScript,
|
|
}: {
|
|
item: Script;
|
|
setSelectedScript: (script: string | null) => void;
|
|
}) {
|
|
const closeScript = () => {
|
|
window.history.pushState({}, document.title, window.location.pathname);
|
|
setSelectedScript(null);
|
|
};
|
|
|
|
return (
|
|
<div className="mr-7 mt-0 flex w-full min-w-fit">
|
|
<div className="flex w-full min-w-fit">
|
|
<div className="flex w-full flex-col">
|
|
<div className="flex h-[36px] min-w-max items-center justify-between">
|
|
<h2 className="text-lg font-semibold">Selected Script</h2>
|
|
<X onClick={closeScript} className="cursor-pointer" />
|
|
</div>
|
|
<div className="rounded-lg border bg-accent/20 p-4">
|
|
<div className="flex justify-between">
|
|
<div className="flex">
|
|
<Image
|
|
className="h-32 w-32 rounded-lg bg-accent/60 object-contain p-3 shadow-md"
|
|
src={item.logo}
|
|
width={400}
|
|
onError={(e) =>
|
|
((e.currentTarget as HTMLImageElement).src = "/logo.png")
|
|
}
|
|
height={400}
|
|
alt={item.title}
|
|
unoptimized
|
|
/>
|
|
<div className="ml-4 flex flex-col justify-between">
|
|
<div className="flex h-full w-full flex-col justify-between">
|
|
<div>
|
|
<h1 className="text-lg font-semibold">{item.title}</h1>
|
|
<p className="w-full text-sm text-muted-foreground">
|
|
Date added: {extractDate(item.created)}
|
|
</p>
|
|
</div>
|
|
<div className="flex gap-5">
|
|
<DefaultSettings item={item} />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div className="hidden flex-col justify-between gap-2 sm:flex">
|
|
<InterFaces item={item} />
|
|
<Buttons item={item} />
|
|
</div>
|
|
</div>
|
|
<Separator className="mt-4" />
|
|
<div>
|
|
<div className="mt-4">
|
|
<Description item={item} />
|
|
<Alerts item={item} />
|
|
</div>
|
|
<div className="mt-4 rounded-lg border bg-accent/50">
|
|
<div className="flex gap-3 px-4 py-2">
|
|
<h2 className="text-lg font-semibold">
|
|
How to {item.item_type ? "install" : "use"}
|
|
</h2>
|
|
<Tooltips item={item} />
|
|
</div>
|
|
<Separator className="w-full"></Separator>
|
|
<InstallCommand item={item} />
|
|
</div>
|
|
</div>
|
|
<DefaultPassword item={item} />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export default ScriptItem;
|