mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2025-12-16 12:13:29 +01:00
* Update ScriptAccordion and ScriptItem components for improved styling * Add README.md for Proxmox VE Helper-Scripts Frontend * Remove testing dependencies and related test files from the frontend project * Update analytics URL in siteConfig to point to community-scripts.org * Refactor ESLint configuration to have one source of truth and run "npm lint" to apply new changes * Update lint script in package.json to remove npm * Add 'next' option to ESLint configuration for improved compatibility * Update package dependencies and versions in package.json and package-lock.json * Refactor theme provider import and enhance calendar component for dynamic icon rendering * rename sidebar, alerts and buttons * rename description and interfaces files * rename more files * change folder name * Refactor tooltip logic to improve updateable condition handling * Enhance CommandMenu to prevent duplicate scripts across categories * Remove test step from frontend CI/CD workflow
52 lines
1.6 KiB
TypeScript
52 lines
1.6 KiB
TypeScript
import type { Script } from "@/lib/types";
|
|
|
|
import { Separator } from "@/components/ui/separator";
|
|
import handleCopy from "@/components/handle-copy";
|
|
import { Button } from "@/components/ui/button";
|
|
|
|
export default function DefaultPassword({ item }: { item: Script }) {
|
|
const { username, password } = item.default_credentials;
|
|
const hasDefaultLogin = username || password;
|
|
|
|
if (!hasDefaultLogin)
|
|
return null;
|
|
|
|
const copyCredential = (type: "username" | "password") => {
|
|
handleCopy(type, item.default_credentials[type] ?? "");
|
|
};
|
|
|
|
return (
|
|
<div className="mt-4 rounded-lg border shadow-sm">
|
|
<div className="flex gap-3 px-4 py-2 bg-accent/25">
|
|
<h2 className="text-lg font-semibold">Default Login Credentials</h2>
|
|
</div>
|
|
<Separator className="w-full" />
|
|
<div className="flex flex-col gap-2 p-4">
|
|
<p className="mb-2 text-sm">
|
|
You can use the following credentials to login to the
|
|
{" "}
|
|
{item.name}
|
|
{" "}
|
|
{item.type}
|
|
.
|
|
</p>
|
|
{["username", "password"].map((type) => {
|
|
const value = item.default_credentials[type as "username" | "password"];
|
|
return value && value.trim() !== ""
|
|
? (
|
|
<div key={type} className="text-sm">
|
|
{type.charAt(0).toUpperCase() + type.slice(1)}
|
|
:
|
|
{" "}
|
|
<Button variant="secondary" size="null" onClick={() => copyCredential(type as "username" | "password")}>
|
|
{value}
|
|
</Button>
|
|
</div>
|
|
)
|
|
: null;
|
|
})}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|