From shopify-admin-skills
Calculates ROI of Shopify discount codes by comparing incremental revenue against discount cost, including AOV lift/drop, new customer %, and cannibalization risk. Read-only.
How this skill is triggered — by the user, by Claude, or both
Slash command
/shopify-admin-skills:shopify-admin-discount-roi-calculatorThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Evaluates the true return on investment for each discount code and automatic discount by measuring revenue generated, number of orders, average order value with vs. without discount, customer acquisition attributed to discounts, and whether discounted orders cannibalized full-price sales. Goes beyond `discount-hygiene-cleanup` (which finds broken/unused codes) to answer "was this discount worth...
Evaluates the true return on investment for each discount code and automatic discount by measuring revenue generated, number of orders, average order value with vs. without discount, customer acquisition attributed to discounts, and whether discounted orders cannibalized full-price sales. Goes beyond discount-hygiene-cleanup (which finds broken/unused codes) to answer "was this discount worth it?" Read-only — no mutations.
shopify store auth --store <domain> --scopes read_orders,read_discountsread_orders, read_discounts| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
| store | string | yes | — | Store domain |
| days_back | integer | no | 90 | Lookback window |
| min_uses | integer | no | 3 | Minimum uses for a discount to be analyzed |
| format | string | no | human | Output format: human or json |
ℹ️ Read-only skill — no mutations are executed. Safe to run at any time.
OPERATION: discountNodes — query
Inputs: first: 250, select discount details (title, code, type, value, usageCount, startsAt, endsAt), pagination cursor
Expected output: All discount codes and automatic discounts
Filter to discounts with usageCount >= min_uses and active within lookback window
OPERATION: orders — query
Inputs: query: "created_at:>='<NOW - days_back days>' discount_code:<code>", first: 250 for each active discount code, select totalPriceSet, totalDiscountsSet, subtotalPriceSet, customer { id, numberOfOrders }, pagination cursor
Expected output: All orders using each discount
Also query orders WITHOUT any discount in same period for baseline AOV comparison
For each discount, calculate:
# discountNodes:query — validated against api_version 2025-01
query AllDiscounts($after: String) {
discountNodes(first: 250, after: $after) {
edges {
node {
id
discount {
... on DiscountCodeBasic {
title
codes(first: 1) { edges { node { code } } }
usageLimit
asyncUsageCount
startsAt
endsAt
customerGets {
value {
... on DiscountPercentage { percentage }
... on DiscountAmount { amount { amount currencyCode } }
}
}
}
... on DiscountCodeFreeShipping {
title
codes(first: 1) { edges { node { code } } }
asyncUsageCount
startsAt
endsAt
}
... on DiscountAutomaticBasic {
title
asyncUsageCount
startsAt
endsAt
customerGets {
value {
... on DiscountPercentage { percentage }
... on DiscountAmount { amount { amount currencyCode } }
}
}
}
}
}
}
pageInfo { hasNextPage endCursor }
}
}
# orders:query — validated against api_version 2025-01
query OrdersByDiscount($query: String!, $after: String) {
orders(first: 250, after: $after, query: $query) {
edges {
node {
id
name
createdAt
totalPriceSet { shopMoney { amount currencyCode } }
totalDiscountsSet { shopMoney { amount currencyCode } }
subtotalPriceSet { shopMoney { amount currencyCode } }
customer {
id
numberOfOrders
}
discountCodes
}
}
pageInfo { hasNextPage endCursor }
}
}
Claude MUST emit the following output at each stage. This is mandatory.
On start, emit:
╔══════════════════════════════════════════════╗
║ SKILL: Discount ROI Calculator ║
║ Store: <store domain> ║
║ Started: <YYYY-MM-DD HH:MM UTC> ║
╚══════════════════════════════════════════════╝
After each step, emit:
[N/TOTAL] <QUERY|MUTATION> <OperationName>
→ Params: <brief summary of key inputs>
→ Result: <count or outcome>
On completion, emit:
For format: human (default):
══════════════════════════════════════════════
DISCOUNT ROI REPORT (<days_back> days)
Discounts analyzed: <n>
Total discount spend: $<amount>
Total attributed rev: $<amount>
─────────────────────────────
TOP PERFORMERS (by ROI):
"<code>" ROI: <n>% Revenue: $<n> Cost: $<n> New customers: <pct>%
UNDERPERFORMERS:
"<code>" ROI: <n>% Revenue: $<n> Cost: $<n> ⚠️ Cannibalization risk
BASELINE COMPARISON:
Non-discount AOV: $<n> | Avg discount AOV: $<n> | Δ: $<n>
Output: discount_roi_<date>.csv
══════════════════════════════════════════════
CSV file discount_roi_<YYYY-MM-DD>.csv with columns:
discount_id, code_or_title, type, uses, revenue, discount_cost, roi_pct, aov, baseline_aov, aov_delta, new_customer_pct, cannibalization_risk
| Error | Cause | Recovery |
|---|---|---|
THROTTLED | API rate limit exceeded | Wait 2 seconds, retry up to 3 times |
| Automatic discounts | No code to query by | Match via order discount data |
| Stacked discounts | Multiple codes per order | Attribute proportionally or flag as "multi-discount" |
discount-ab-analysis for split-test insights.discount-hygiene-cleanup to find and remove underperforming codes.npx claudepluginhub 40rty-ai/shopify-admin-skills --plugin shopify-admin-skillsTracks total discount dollars over configurable time buckets (week/month/quarter), broken down by discount type and code. Answers whether discount spend is trending up or down.
Triages WooCommerce coupon performance by analyzing discount impact, revenue drivers, acquisition metrics, and effective costs using built-in analytics tools.
Manages Wix coupons and discounts via REST API: query active/expired/usage-based lists, create fixed-amount/percent-off types, detect conflicts, calculate margins.