Claude-skill-registry dashboard
Мультиаккаунтный дашборд. Статистика по всем аккаунтам с детализацией до уровня объявлений.
git clone https://github.com/majiayu000/claude-skill-registry
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/dashboard-dengineproblem-agents-monorepo" ~/.claude/skills/majiayu000-claude-skill-registry-dashboard && rm -rf "$T"
skills/data/dashboard-dengineproblem-agents-monorepo/SKILL.mdDashboard
Ты — эксперт по формированию мультиаккаунтных дашбордов. Показываешь статистику по рекламным аккаунтам с иерархией Account → Campaign → AdSet → Ad.
Твои задачи
- Сводка по аккаунтам — общая таблица всех активных аккаунтов
- Детализация по кампаниям — раскрытие до уровня кампаний
- Детализация по AdSets — раскрытие до уровня групп объявлений
- Детализация по Ads — полный дашборд до уровня объявлений
- WhatsApp метрики — CPQL, Quality Rate для WhatsApp кампаний
- Custom периоды — любой диапазон дат
Workflow
Шаг 1: Парсинг параметров запроса
Из запроса пользователя определи:
| Параметр | Варианты | Дефолт |
|---|---|---|
| Период | today, yesterday, 7d, 30d, custom | yesterday |
| Аккаунты | все / конкретный по имени | все |
| Уровень | account, campaign, adset, ad | campaign |
ВАЖНО: Если период не указан явно — используй
(вчера).yesterday
Ключевые слова для периода:
- "сегодня", "today" →
today - "вчера", "yesterday" →
yesterday - "7 дней", "неделю", "7d" →
last_7d - "30 дней", "месяц", "30d" →
last_30d - "YYYY-MM-DD — YYYY-MM-DD" → custom
{"since": "...", "until": "..."}
Ключевые слова для уровня:
- "только аккаунты", "account" → уровень
account - "с адсетами", "adset" → уровень
adset - "полный", "детальный", "все уровни", "ads" → уровень
ad - без указания → уровень
(по умолчанию)campaign
Ключевые слова для аккаунта:
- Имя аккаунта (например "Profimed", "Бас дент") → только этот аккаунт
- без указания → все активные аккаунты
Шаг 2: Загрузка конфигурации
1. Прочитай .claude/ads-agent/config/ad_accounts.md 2. Извлеки список аккаунтов со статусом "активен" 3. Для каждого аккаунта запомни: - name (Название) - account_id (Account ID) - page_id (Page ID) - brief_path (путь к брифу) 4. Прочитай бриф каждого аккаунта (briefs/{name}.md) 5. Извлеки target CPL для каждой кампании из таблицы "Активные кампании/направления": | Направление | Campaign ID | Цель CPL | ...
Парсинг секций:
## Аккаунт N: {name} - **Account ID**: act_XXX ← извлечь - **Page ID**: XXX ← извлечь - **Название**: XXX - **Статус**: активен ← фильтровать только "активен"
Шаг 3: Получение данных через MCP
Для уровня Account:
# Для каждого аккаунта параллельно for account in accounts: insights = get_insights( object_id=account.account_id, time_range=period, level="account" )
Для уровня Campaign (если нужно):
# 1. Получить список кампаний campaigns = get_campaigns( account_id=account_id, status_filter="ACTIVE", limit=50 ) # 2. Получить insights на уровне кампаний campaign_insights = get_insights( object_id=account_id, time_range=period, level="campaign" )
Для уровня AdSet (если нужно):
# 1. Получить список adsets adsets = get_adsets(account_id=account_id, campaign_id=campaign_id) # 2. Получить insights на уровне adset adset_insights = get_insights( object_id=account_id, time_range=period, level="adset" ) # 3. Получить daily_budget для каждого adset for adset in adsets: details = get_adset_details(adset_id=adset.id) daily_budget = details.daily_budget / 100 # центы → доллары
Для уровня Ad (если нужно):
# 1. Получить список ads ads = get_ads(account_id=account_id, adset_id=adset_id) # 2. Получить insights на уровне ad ad_insights = get_insights( object_id=account_id, time_range=period, level="ad" )
Шаг 4: Расчёт метрик
Базовые метрики (из API)
| Метрика | Поле API | Описание |
|---|---|---|
| spend | spend | Затраты в $ |
| impressions | impressions | Показы |
| clicks | clicks | Клики |
Подсчёт лидов из actions
def count_leads(actions): leads = 0 messagingLeads = 0 qualityLeads = 0 for action in actions: action_type = action.get("action_type", "") value = int(action.get("value", 0)) if action_type == "onsite_conversion.total_messaging_connection": messagingLeads = value leads += value elif action_type == "onsite_conversion.messaging_user_depth_2_message_send": qualityLeads = value elif action_type in ["offsite_conversion.fb_pixel_lead", "onsite_conversion.lead_grouped"]: leads += value return leads, messagingLeads, qualityLeads
Производные метрики
Базовые (показывать всегда):
cpl = spend / leads if leads > 0 else None ctr = (clicks / impressions) * 100 if impressions > 0 else 0 cpm = (spend / impressions) * 1000 if impressions > 0 else 0 # План-факт (ОБЯЗАТЕЛЬНО для кампаний) target_cpl = brief.campaigns[campaign_id].target_cpl # из брифа cpl_diff = ((cpl - target_cpl) / target_cpl) * 100 if target_cpl and cpl else None # % отклонения
WhatsApp метрики (показывать если messagingLeads > 0):
cpql = spend / qualityLeads if qualityLeads > 0 else None qualityRate = (qualityLeads / messagingLeads) * 100 if messagingLeads > 0 else 0
Шаг 5: Агрегация вверх по иерархии
# Ad → AdSet adset.spend = sum(ad.spend for ad in adset.ads) adset.leads = sum(ad.leads for ad in adset.ads) # ... остальные метрики # AdSet → Campaign campaign.spend = sum(adset.spend for adset in campaign.adsets) campaign.leads = sum(adset.leads for adset in campaign.adsets) campaign.daily_budget = sum(adset.daily_budget for adset in campaign.adsets if adset.status == "ACTIVE") # ... остальные метрики # Campaign → Account account.spend = sum(campaign.spend for campaign in account.campaigns) account.leads = sum(campaign.leads for campaign in account.campaigns) # ... остальные метрики
Шаг 6: Формирование вывода
Выведи таблицы согласно запрошенному уровню детализации.
Форматы таблиц
Заголовок дашборда
# Dashboard 📅 Период: {since} — {until}
Или для single day:
# Dashboard 📅 Период: {date}
Сводка по аккаунтам (уровень Account)
## Сводка по аккаунтам | Аккаунт | Spend | Leads | CPL | CTR | CPM | Статус | |---------|------:|------:|----:|----:|----:|--------| | Бас дент | $450.00 | 120 | $3.75 | 1.2% | $8.50 | ✅ | | Profimed | $320.00 | 85 | $3.76 | 1.1% | $9.20 | ✅ | | **ВСЕГО** | **$770.00** | **205** | **$3.76** | **1.15%** | **$8.85** | — |
Форматирование:
- Spend:
(например $1,234.56)${value:,.2f} - Leads: целое число
- CPL:
${value:.2f} - CTR:
{value:.1f}% - CPM:
${value:.2f} - Статус: ✅ для активных
Кампании (уровень Campaign)
Для каждого аккаунта выводи отдельную таблицу:
## {Account Name} — Кампании | Кампания | Spend | Leads | CPL | Target | Δ% | Budget | Статус | |----------|------:|------:|----:|-------:|---:|-------:|--------| | Импланты | $250.00 | 65 | $3.85 | $4.00 | -4% | $40 | ACTIVE | | Виниры | $200.00 | 55 | $3.64 | $5.00 | -27% | $30 | ACTIVE | | **ИТОГО** | **$450.00** | **120** | **$3.75** | — | — | **$70** | — |
Форматирование Δ% (план-факт):
- Отрицательное значение (CPL < Target) = хорошо, показывать как есть:
-4% - Положительное значение (CPL > Target) = плохо, показывать:
+15% - Если нет target или нет лидов — показывать
—
AdSets (уровень AdSet)
Под каждой кампанией:
### AdSets — {Campaign Name} | AdSet | Spend | Leads | CPL | CTR | Budget | Статус | |-------|------:|------:|----:|----:|-------:|--------| | 30-45_astana | $150.00 | 40 | $3.75 | 1.4% | $25 | ACTIVE | | 25-35_almaty | $100.00 | 25 | $4.00 | 1.1% | $15 | ACTIVE |
Ads (уровень Ad)
Под каждым AdSet:
#### Ads — {AdSet Name} | Ad | Spend | Leads | CPL | CTR | Статус | |----|------:|------:|----:|----:|--------| | video_1_kitchen | $80.00 | 22 | $3.64 | 1.5% | ACTIVE | | video_2_doctor | $70.00 | 18 | $3.89 | 1.3% | ACTIVE |
WhatsApp метрики (опционально)
Если у какого-то аккаунта есть messagingLeads > 0, добавь секцию:
## WhatsApp Quality | Аккаунт | Msg Leads | Quality Leads | CPQL | Quality Rate | |---------|----------:|--------------:|-----:|-------------:| | Profimed | 85 | 42 | $7.62 | 49.4% |
Обработка ошибок
⚠️ Аккаунт {name}: ошибка доступа — пропущен
ℹ️ {name}: нет данных за выбранный период
Примеры запросов
Дашборд без указания периода
Запрос: "Покажи дашборд" или
/dashboard
Парсинг:
- Период: yesterday (по умолчанию)
- Аккаунты: все
- Уровень: campaign (по умолчанию)
Действия:
- Читаю ad_accounts.md → активные аккаунты
- Читаю брифы каждого аккаунта → target CPL для кампаний
- get_insights для каждого аккаунта (level="campaign", time_range="yesterday")
- Формирую таблицы с колонками Target и Δ%
Базовый дашборд
Запрос: "Покажи дашборд за вчера"
Парсинг:
- Период: yesterday
- Аккаунты: все
- Уровень: campaign (по умолчанию)
Действия:
- Читаю ad_accounts.md → 2 активных аккаунта
- get_insights(act_805414428109857, "yesterday", "campaign")
- get_insights(act_1106872004544227, "yesterday", "campaign")
- Формирую сводную таблицу + таблицы кампаний для каждого аккаунта
Конкретный аккаунт с кампаниями
Запрос: "Дашборд Profimed за 7 дней с кампаниями"
Парсинг:
- Период: last_7d
- Аккаунты: Profimed (act_1106872004544227)
- Уровень: campaign
Действия:
- Читаю ad_accounts.md → нахожу Profimed
- get_campaigns(act_1106872004544227, "ACTIVE")
- get_insights(act_1106872004544227, "last_7d", "campaign")
- Формирую таблицу аккаунта + таблицу кампаний
Полный дашборд
Запрос: "Полный дашборд за месяц"
Парсинг:
- Период: last_30d
- Аккаунты: все
- Уровень: ad
Действия:
- Читаю ad_accounts.md → все активные
- Для каждого аккаунта:
- get_campaigns() → список кампаний
- get_adsets() → списки adsets по кампаниям
- get_ads() → списки ads по adsets
- get_insights(level="ad") → метрики по ads
- get_adset_details() → бюджеты
- Формирую полную иерархию таблиц
Custom период
Запрос: "Дашборд с 2026-01-10 по 2026-01-20"
Парсинг:
- Период: {"since": "2026-01-10", "until": "2026-01-20"}
- Аккаунты: все
- Уровень: campaign (по умолчанию)
Чек-лист
- Прочитан ad_accounts.md
- Определены параметры (период, аккаунты, уровень)
- Получены insights для нужного уровня
- Рассчитаны производные метрики (CPL, CTR, CPM)
- Проверены WhatsApp метрики (если есть messagingLeads)
- Сформированы таблицы по шаблонам
- Добавлена строка ИТОГО для групп
MCP команды
Чтение данных
# Список аккаунтов (если нужно проверить доступ) get_ad_accounts(limit=10) # Кампании аккаунта get_campaigns(account_id, status_filter="ACTIVE", limit=50) # AdSets аккаунта или кампании get_adsets(account_id, campaign_id=None, limit=50) # Ads аккаунта или adset get_ads(account_id, adset_id=None, limit=50) # Метрики за период get_insights( object_id, # account_id или конкретный ID time_range, # "yesterday" или {"since": "...", "until": "..."} level="account" # account | campaign | adset | ad ) # Детали adset (для бюджета) get_adset_details(adset_id)
Доступные периоды
| Значение | Описание |
|---|---|
| Сегодня |
| Вчера |
| Последние 3 дня |
| Последние 7 дней |
| Последние 14 дней |
| Последние 30 дней |
| Текущий месяц |
| Прошлый месяц |
| Custom |