jeremylongshore/claude-code-plugins-plus-skills
gamma-pack
plugins/saas-packs/gamma-pack/skills/gamma-cost-tuning/SKILL.md
January 22, 2026
Select agents to install to:
npx add-skill https://github.com/jeremylongshore/claude-code-plugins-plus-skills/blob/main/plugins/saas-packs/gamma-pack/skills/gamma-cost-tuning/SKILL.md -a claude-code --skill gamma-cost-tuningInstallation paths:
.claude/skills/gamma-cost-tuning/# Gamma Cost Tuning
## Overview
Optimize Gamma API usage to minimize costs while maintaining functionality.
## Prerequisites
- Active Gamma subscription
- Access to usage dashboard
- Understanding of pricing tiers
## Gamma Pricing Model
| Resource | Free | Pro | Team | Enterprise |
|----------|------|-----|------|------------|
| Presentations/mo | 10 | 100 | 500 | Custom |
| AI generations | 5 | 50 | 200 | Unlimited |
| Exports/mo | 10 | 100 | 500 | Unlimited |
| API calls/min | 10 | 60 | 200 | Custom |
| Storage | 1GB | 10GB | 100GB | Custom |
## Instructions
### Step 1: Usage Monitoring
```typescript
// Track usage per operation
interface UsageTracker {
presentations: number;
generations: number;
exports: number;
apiCalls: number;
}
const dailyUsage: UsageTracker = {
presentations: 0,
generations: 0,
exports: 0,
apiCalls: 0,
};
function trackUsage(operation: keyof UsageTracker) {
dailyUsage[operation]++;
// Check if approaching limits
const limits = { presentations: 100, generations: 50, exports: 100, apiCalls: 60 };
const percentage = (dailyUsage[operation] / limits[operation]) * 100;
if (percentage >= 80) {
console.warn(`Warning: ${operation} usage at ${percentage}%`);
alertOps(`Gamma ${operation} usage high: ${percentage}%`);
}
}
// Wrap API calls
async function createPresentation(opts: object) {
trackUsage('apiCalls');
trackUsage('presentations');
if (opts.generateAI) trackUsage('generations');
return gamma.presentations.create(opts);
}
```
### Step 2: Implement Usage Quotas
```typescript
interface UserQuota {
userId: string;
presentationsRemaining: number;
generationsRemaining: number;
exportsRemaining: number;
resetsAt: Date;
}
async function checkQuota(userId: string, operation: string): Promise<boolean> {
const quota = await getQuota(userId);
const quotaField = `${operation}Remaining` as keyof UserQuota;
if (typeof quota[quotaField] === 'number' && quota[quotaField] <= 0) {
thro