Files
mockupAWS/frontend/src/components/charts/CostBreakdown.tsx
Luca Sacchi Ricciardi 38fd6cb562
Some checks failed
CI/CD - Build & Test / Backend Tests (push) Has been cancelled
CI/CD - Build & Test / Frontend Tests (push) Has been cancelled
CI/CD - Build & Test / Security Scans (push) Has been cancelled
CI/CD - Build & Test / Docker Build Test (push) Has been cancelled
CI/CD - Build & Test / Terraform Validate (push) Has been cancelled
Deploy to Production / Build & Test (push) Has been cancelled
Deploy to Production / Security Scan (push) Has been cancelled
Deploy to Production / Build Docker Images (push) Has been cancelled
Deploy to Production / Deploy to Staging (push) Has been cancelled
Deploy to Production / E2E Tests (push) Has been cancelled
Deploy to Production / Deploy to Production (push) Has been cancelled
E2E Tests / Run E2E Tests (push) Has been cancelled
E2E Tests / Visual Regression Tests (push) Has been cancelled
E2E Tests / Smoke Tests (push) Has been cancelled
release: v1.0.0 - Production Ready
Complete production-ready release with all v1.0.0 features:

Architecture & Planning (@spec-architect):
- Production architecture design with scalability and HA
- Security audit plan and compliance review
- Technical debt assessment and refactoring roadmap

Database (@db-engineer):
- 17 performance indexes and 3 materialized views
- PgBouncer connection pooling
- Automated backup/restore with PITR (RTO<1h, RPO<5min)
- Data archiving strategy (~65% storage savings)

Backend (@backend-dev):
- Redis caching layer with 3-tier strategy
- Celery async jobs with Flower monitoring
- API v2 with rate limiting (tiered: free/premium/enterprise)
- Prometheus metrics and OpenTelemetry tracing
- Security hardening (headers, audit logging)

Frontend (@frontend-dev):
- Bundle optimization: 308KB (code splitting, lazy loading)
- Onboarding tutorial (react-joyride)
- Command palette (Cmd+K) and keyboard shortcuts
- Analytics dashboard with cost predictions
- i18n (English + Italian) and WCAG 2.1 AA compliance

DevOps (@devops-engineer):
- Complete deployment guide (Docker, K8s, AWS ECS)
- Terraform AWS infrastructure (Multi-AZ RDS, ElastiCache, ECS)
- CI/CD pipelines with blue-green deployment
- Prometheus + Grafana monitoring with 15+ alert rules
- SLA definition and incident response procedures

QA (@qa-engineer):
- 153+ E2E test cases (85% coverage)
- k6 performance tests (1000+ concurrent users, p95<200ms)
- Security testing (0 critical vulnerabilities)
- Cross-browser and mobile testing
- Official QA sign-off

Production Features:
 Horizontal scaling ready
 99.9% uptime target
 <200ms response time (p95)
 Enterprise-grade security
 Complete observability
 Disaster recovery
 SLA monitoring

Ready for production deployment! 🚀
2026-04-07 20:14:51 +02:00

129 lines
3.9 KiB
TypeScript

import { memo } from 'react';
import {
PieChart,
Pie,
Cell,
ResponsiveContainer,
Tooltip,
} from 'recharts';
import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';
import type { CostBreakdown as CostBreakdownType } from '@/types/api';
import { CHART_COLORS, formatCurrency } from './chart-utils';
interface CostBreakdownChartProps {
data: CostBreakdownType[];
title?: string;
description?: string;
}
// Map services to colors
const SERVICE_COLORS: Record<string, string> = {
sqs: CHART_COLORS.sqs,
lambda: CHART_COLORS.lambda,
bedrock: CHART_COLORS.bedrock,
s3: CHART_COLORS.blue,
cloudwatch: CHART_COLORS.green,
default: CHART_COLORS.secondary,
};
const getServiceColor = (service: string): string => {
const normalized = service.toLowerCase().replace(/[^a-z]/g, '');
return SERVICE_COLORS[normalized] || SERVICE_COLORS.default;
};
interface CostTooltipProps {
active?: boolean;
payload?: Array<{ payload: CostBreakdownType }>;
}
const CostTooltip = memo(function CostTooltip({ active, payload }: CostTooltipProps) {
if (active && payload && payload.length) {
const item = payload[0].payload;
return (
<div className="rounded-lg border bg-popover p-3 shadow-md">
<p className="font-medium text-popover-foreground">{item.service}</p>
<p className="text-sm text-muted-foreground">
Cost: {formatCurrency(item.cost_usd)}
</p>
<p className="text-sm text-muted-foreground">
Percentage: {item.percentage.toFixed(1)}%
</p>
</div>
);
}
return null;
});
export const CostBreakdownChart = memo(function CostBreakdownChart({
data,
title = 'Cost Breakdown',
description = 'Cost distribution by service',
}: CostBreakdownChartProps) {
const totalCost = data.reduce((sum, item) => sum + item.cost_usd, 0);
return (
<Card className="w-full">
<CardHeader className="pb-2">
<CardTitle className="text-lg font-semibold">{title}</CardTitle>
{description && (
<p className="text-sm text-muted-foreground">{description}</p>
)}
<p className="text-2xl font-bold mt-2">{formatCurrency(totalCost)}</p>
</CardHeader>
<CardContent>
<div className="h-[300px]">
<ResponsiveContainer width="100%" height="100%">
<PieChart>
<Pie
data={data}
cx="50%"
cy="45%"
innerRadius={60}
outerRadius={100}
paddingAngle={2}
dataKey="cost_usd"
nameKey="service"
animationBegin={0}
animationDuration={800}
isAnimationActive={true}
>
{data.map((entry) => (
<Cell
key={`cell-${entry.service}`}
fill={getServiceColor(entry.service)}
stroke="hsl(var(--card))"
strokeWidth={2}
/>
))}
</Pie>
<Tooltip content={<CostTooltip />} />
</PieChart>
</ResponsiveContainer>
</div>
<div
className="flex flex-wrap justify-center gap-4 mt-4"
role="list"
aria-label="Cost breakdown by service"
>
{data.map((item) => (
<div
key={item.service}
className="flex items-center gap-2 text-sm"
role="listitem"
>
<span
className="h-3 w-3 rounded-full"
style={{ backgroundColor: getServiceColor(item.service) }}
aria-hidden="true"
/>
<span className="text-muted-foreground">
{item.service} ({item.percentage.toFixed(1)}%)
</span>
</div>
))}
</div>
</CardContent>
</Card>
);
});