mirror of
https://github.com/prowler-cloud/prowler.git
synced 2025-12-19 05:17:47 +00:00
40 lines
1.1 KiB
TypeScript
40 lines
1.1 KiB
TypeScript
import { AttackSurfaceItem } from "@/actions/overview";
|
|
import { Card, CardContent, CardTitle } from "@/components/shadcn";
|
|
|
|
import { AttackSurfaceCardItem } from "./attack-surface-card-item";
|
|
|
|
interface AttackSurfaceProps {
|
|
items: AttackSurfaceItem[];
|
|
filters?: Record<string, string | string[] | undefined>;
|
|
}
|
|
|
|
export function AttackSurface({ items, filters }: AttackSurfaceProps) {
|
|
const isEmpty = items.length === 0;
|
|
|
|
return (
|
|
<Card variant="base" className="flex w-full flex-col">
|
|
<CardTitle>Attack Surface</CardTitle>
|
|
<CardContent className="mt-4 flex flex-wrap gap-4">
|
|
{isEmpty ? (
|
|
<div
|
|
className="flex w-full items-center justify-center py-8"
|
|
role="status"
|
|
>
|
|
<p className="text-text-neutral-tertiary text-sm">
|
|
No attack surface data available.
|
|
</p>
|
|
</div>
|
|
) : (
|
|
items.map((item) => (
|
|
<AttackSurfaceCardItem
|
|
key={item.id}
|
|
item={item}
|
|
filters={filters}
|
|
/>
|
|
))
|
|
)}
|
|
</CardContent>
|
|
</Card>
|
|
);
|
|
}
|