PluginBench
Skill
Pass
Audit score 90

kpi-dashboard-design

wshobson/agents

Design executive KPI dashboards with metrics selection, visualization patterns, and real-time monitoring best practices.

What is kpi-dashboard-design?

This skill provides frameworks for building effective KPI dashboards across strategic, tactical, and operational levels. Use it when designing executive dashboards, selecting meaningful metrics, establishing real-time monitoring, or troubleshooting dashboard issues like metric contradictions or alert fatigue.

  • Apply SMART KPI framework to define specific, measurable, achievable, relevant, and time-bound metrics
  • Structure dashboards hierarchically from executive summary through department views to detailed drilldowns
  • Select 5-7 focused KPIs with context, trends, and targets rather than vanity metrics
  • Implement consistent color coding and enable drill-down navigation from summary to detail
  • Separate OLAP workloads from production databases using pre-aggregated summary tables for real-time dashboards
  • Use dynamic alert thresholds based on rolling averages to prevent alert fatigue

How to install kpi-dashboard-design

npx skills add https://github.com/wshobson/agents --skill kpi-dashboard-design
Claude Code
Cursor
Windsurf
Cline

How to use kpi-dashboard-design

  1. 1.Define your KPIs using the SMART framework (Specific, Measurable, Achievable, Relevant, Time-bound)
  2. 2.Classify metrics into strategic (monthly/quarterly), tactical (weekly/monthly), or operational (real-time/daily) levels
  3. 3.Design dashboard hierarchy with 4-6 headline KPIs on executive summary, department-specific views, and detailed drilldowns
  4. 4.Document metric calculation methodology explicitly on dashboard cards or in tooltips to prevent contradictions
  5. 5.For real-time dashboards, implement pre-aggregated summary tables updated via scheduled jobs instead of querying production directly
  6. 6.Set up dynamic alert thresholds using rolling averages and standard deviation rather than static values

Use cases

Good for
  • Building an executive SaaS dashboard tracking MRR, churn, and LTV/CAC ratios with monthly updates
  • Designing an operations center with live service health, API uptime, and request throughput metrics
  • Creating cohort retention analysis views for product teams with correct date partitioning
  • Debugging dashboards where MRR contradicts finance due to inconsistent annual plan treatment
  • Fixing real-time dashboards that hammer the database by implementing pre-aggregated metrics snapshots
Who it's for
  • Executives and business leaders building strategic dashboards
  • Operations and SRE teams designing real-time monitoring displays
  • Product managers creating cohort and retention analysis views
  • Finance teams establishing metric governance and calculation methodology
  • Engineering teams optimizing dashboard performance and alert systems

kpi-dashboard-design FAQ

How many KPIs should I include on a dashboard?

Limit to 5-7 KPIs on the executive summary level. More metrics dilute focus and reduce comprehension. Use department-specific views and drilldowns for additional detail.

Why does my MRR dashboard number differ from finance's reported MRR?

The most common cause is inconsistent treatment of annual plans. Finance may prorate to daily rates while dashboards normalize to monthly. Align on a single formula (e.g., divide annual contracts by 12) and document it directly on the dashboard card.

My real-time dashboard is slowing down the database. How do I fix it?

Separate OLAP workloads from OLTP by writing pre-aggregated metrics to a summary table via a scheduled job (every 5 minutes), then have the dashboard read from that snapshot instead of querying production directly.

How do I prevent alert fatigue from constant false positives?

Replace static thresholds with dynamic thresholds based on rolling averages. Alert only when the current value deviates significantly (e.g., >2 standard deviations) from the 30-day rolling mean.

My retention cohort shows no variation between cohorts. What's wrong?

Check your cohort query partitioning. A common bug is using DATE_TRUNC('day', created_at) instead of DATE_TRUNC('month', created_at), which creates cohorts too small to show trends.

Full instructions (SKILL.md)

Source of truth, from wshobson/agents.


name: kpi-dashboard-design description: Design effective KPI dashboards with metrics selection, visualization best practices, and real-time monitoring patterns. Use this skill when building an executive SaaS metrics dashboard tracking MRR, churn, and LTV/CAC ratios; designing an operations center with live service health and request throughput; creating a cohort retention analysis view for a product team; or debugging a dashboard where metrics contradict each other due to inconsistent calculation methodology.

KPI Dashboard Design

Comprehensive patterns for designing effective Key Performance Indicator (KPI) dashboards that drive business decisions.

When to Use This Skill

  • Designing executive dashboards
  • Selecting meaningful KPIs
  • Building real-time monitoring displays
  • Creating department-specific metrics views
  • Improving existing dashboard layouts
  • Establishing metric governance

Core Concepts

1. KPI Framework

LevelFocusUpdate FrequencyAudience
StrategicLong-term goalsMonthly/QuarterlyExecutives
TacticalDepartment goalsWeekly/MonthlyManagers
OperationalDay-to-dayReal-time/DailyTeams

2. SMART KPIs

Specific: Clear definition
Measurable: Quantifiable
Achievable: Realistic targets
Relevant: Aligned to goals
Time-bound: Defined period

3. Dashboard Hierarchy

├── Executive Summary (1 page)
│   ├── 4-6 headline KPIs
│   ├── Trend indicators
│   └── Key alerts
├── Department Views
│   ├── Sales Dashboard
│   ├── Marketing Dashboard
│   ├── Operations Dashboard
│   └── Finance Dashboard
└── Detailed Drilldowns
    ├── Individual metrics
    └── Root cause analysis

Detailed worked examples and patterns

Detailed sections (starting with ## Common KPIs by Department) live in references/details.md. Read that file when the navigation summary above is insufficient.

Best Practices

Do's

  • Limit to 5-7 KPIs - Focus on what matters
  • Show context - Comparisons, trends, targets
  • Use consistent colors - Red=bad, green=good
  • Enable drilldown - From summary to detail
  • Update appropriately - Match metric frequency

Don'ts

  • Don't show vanity metrics - Focus on actionable data
  • Don't overcrowd - White space aids comprehension
  • Don't use 3D charts - They distort perception
  • Don't hide methodology - Document calculations
  • Don't ignore mobile - Ensure responsive design

Troubleshooting

MRR shown on dashboard contradicts finance's number

The most common cause is inconsistent treatment of annual plans. Finance may prorate to a daily rate while the dashboard normalizes to monthly. Align on a single formula and document it directly on the dashboard card:

-- Explicit formula shown in tooltip / data dictionary
-- Annual plans: divide total contract value by 12
-- Quarterly plans: divide by 3
-- Monthly plans: use as-is
CASE subscription_interval
    WHEN 'monthly'   THEN amount
    WHEN 'quarterly' THEN amount / 3.0
    WHEN 'yearly'    THEN amount / 12.0
END AS normalized_mrr

Dashboard shows green but product team reports users complaining

The dashboard likely tracks system uptime (a lagging indicator) but not user-facing quality metrics. Add customer-perceived metrics alongside infrastructure metrics:

Infrastructure (green)User-perceived (add these)
API uptime 99.9%P95 page load time
Error rate 0.1%Task completion rate
Queue depth normalSupport ticket volume

Retention cohort looks flat — no variation between cohorts

Check whether the cohort query is partitioning by signup month correctly. A common bug is using created_at::date instead of DATE_TRUNC('month', created_at), which groups by day and produces cohorts too small to show trends:

-- Wrong: too granular, cohorts are too small
DATE_TRUNC('day', created_at) AS cohort_date

-- Correct: monthly cohorts
DATE_TRUNC('month', created_at) AS cohort_month

Real-time dashboard hammers the database

A live dashboard refreshing every 10 seconds with complex cohort SQL will degrade production query performance. Separate OLAP workloads from OLTP by writing pre-aggregated metrics to a summary table via a scheduled job, and have the dashboard read from that:

# Scheduled every 5 minutes via cron/Celery
def refresh_mrr_summary():
    conn.execute("""
        INSERT INTO kpi_snapshot (metric, value, snapshot_at)
        SELECT 'mrr', SUM(...), NOW()
        FROM subscriptions WHERE status = 'active'
        ON CONFLICT (metric) DO UPDATE SET value = EXCLUDED.value
    """)

Alert thresholds fire constantly, team ignores them

Static thresholds set once and never reviewed cause alert fatigue. Use dynamic thresholds based on rolling averages so alerts fire only when the metric deviates significantly from its own baseline:

# Alert if current value is > 2 standard deviations from 30-day rolling mean
def is_anomalous(current: float, history: list[float]) -> bool:
    mean = statistics.mean(history)
    stdev = statistics.stdev(history)
    return abs(current - mean) > 2 * stdev

Related Skills

  • data-storytelling - Turn dashboard findings into narratives that drive executive decisions