@badgie/crm-cli 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/AGENTS.md +91 -0
- package/README.md +136 -0
- package/dist/bin.js +149 -0
- package/dist/bin.js.map +1 -0
- package/dist/commands/admin.js +90 -0
- package/dist/commands/admin.js.map +1 -0
- package/dist/commands/clients.js +135 -0
- package/dist/commands/clients.js.map +1 -0
- package/dist/commands/directory.js +175 -0
- package/dist/commands/directory.js.map +1 -0
- package/dist/commands/docs.js +98 -0
- package/dist/commands/docs.js.map +1 -0
- package/dist/commands/finance.js +311 -0
- package/dist/commands/finance.js.map +1 -0
- package/dist/commands/intelligence.js +147 -0
- package/dist/commands/intelligence.js.map +1 -0
- package/dist/commands/leads-list.js +25 -0
- package/dist/commands/leads-list.js.map +1 -0
- package/dist/commands/leads.js +224 -0
- package/dist/commands/leads.js.map +1 -0
- package/dist/commands/login.js +11 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.js +6 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/marketing.js +135 -0
- package/dist/commands/marketing.js.map +1 -0
- package/dist/commands/operations.js +232 -0
- package/dist/commands/operations.js.map +1 -0
- package/dist/commands/outbound.js +172 -0
- package/dist/commands/outbound.js.map +1 -0
- package/dist/commands/query.js +189 -0
- package/dist/commands/query.js.map +1 -0
- package/dist/commands/search.js +71 -0
- package/dist/commands/search.js.map +1 -0
- package/dist/commands/tasks.js +239 -0
- package/dist/commands/tasks.js.map +1 -0
- package/dist/commands/top-clients.js +82 -0
- package/dist/commands/top-clients.js.map +1 -0
- package/dist/commands/webhooks.js +82 -0
- package/dist/commands/webhooks.js.map +1 -0
- package/dist/commands/welcome.js +81 -0
- package/dist/commands/welcome.js.map +1 -0
- package/dist/commands/whoami.js +16 -0
- package/dist/commands/whoami.js.map +1 -0
- package/dist/core/auth.js +107 -0
- package/dist/core/auth.js.map +1 -0
- package/dist/core/config.js +53 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/env.js +46 -0
- package/dist/core/env.js.map +1 -0
- package/dist/core/format.js +88 -0
- package/dist/core/format.js.map +1 -0
- package/dist/core/http.js +42 -0
- package/dist/core/http.js.map +1 -0
- package/dist/core/list-query.js +35 -0
- package/dist/core/list-query.js.map +1 -0
- package/dist/core/services/leads.js +41 -0
- package/dist/core/services/leads.js.map +1 -0
- package/dist/core/supabase.js +53 -0
- package/dist/core/supabase.js.map +1 -0
- package/dist/registry.js +2 -0
- package/dist/registry.js.map +1 -0
- package/package.json +57 -0
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import { getAuthedClient } from '../core/supabase.js';
|
|
2
|
+
import { commonListOptions, output, parseColumns, parseLimit } from '../core/format.js';
|
|
3
|
+
import { callAppApi } from '../core/http.js';
|
|
4
|
+
// Mission control
|
|
5
|
+
async function mcMetrics(_a, opts) {
|
|
6
|
+
const res = await callAppApi('/api/mission-control/metrics');
|
|
7
|
+
output(res, { pretty: !!opts.pretty });
|
|
8
|
+
}
|
|
9
|
+
// Web design projects
|
|
10
|
+
async function listWebDesign(_a, opts) {
|
|
11
|
+
const { client } = await getAuthedClient();
|
|
12
|
+
let q = client
|
|
13
|
+
.from('web_design_projects')
|
|
14
|
+
.select('id, title, status, current_phase, budget, target_date, client_id, assigned_to, created_at')
|
|
15
|
+
.order('created_at', { ascending: false })
|
|
16
|
+
.limit(parseLimit(opts));
|
|
17
|
+
if (typeof opts.status === 'string')
|
|
18
|
+
q = q.eq('status', opts.status);
|
|
19
|
+
if (typeof opts.clientId === 'string')
|
|
20
|
+
q = q.eq('client_id', opts.clientId);
|
|
21
|
+
if (typeof opts.assignedTo === 'string')
|
|
22
|
+
q = q.eq('assigned_to', opts.assignedTo);
|
|
23
|
+
if (typeof opts.phase === 'string')
|
|
24
|
+
q = q.eq('current_phase', opts.phase);
|
|
25
|
+
if (typeof opts.targetBefore === 'string')
|
|
26
|
+
q = q.lte('target_date', opts.targetBefore);
|
|
27
|
+
if (typeof opts.targetAfter === 'string')
|
|
28
|
+
q = q.gte('target_date', opts.targetAfter);
|
|
29
|
+
if (typeof opts.search === 'string')
|
|
30
|
+
q = q.ilike('title', `%${opts.search}%`);
|
|
31
|
+
const { data, error } = await q;
|
|
32
|
+
if (error)
|
|
33
|
+
throw error;
|
|
34
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
35
|
+
}
|
|
36
|
+
// Team
|
|
37
|
+
async function listTeam(_a, opts) {
|
|
38
|
+
const { client } = await getAuthedClient();
|
|
39
|
+
let q = client
|
|
40
|
+
.from('team_members')
|
|
41
|
+
.select('id, full_name, email, role, is_active, last_login_at, created_at')
|
|
42
|
+
.order('full_name', { ascending: true })
|
|
43
|
+
.limit(parseLimit(opts));
|
|
44
|
+
if (opts.activeOnly !== undefined)
|
|
45
|
+
q = q.eq('is_active', true);
|
|
46
|
+
const { data, error } = await q;
|
|
47
|
+
if (error)
|
|
48
|
+
throw error;
|
|
49
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
50
|
+
}
|
|
51
|
+
// Sports
|
|
52
|
+
async function listSports(_a, opts) {
|
|
53
|
+
const { client } = await getAuthedClient();
|
|
54
|
+
const { data, error } = await client
|
|
55
|
+
.from('sports')
|
|
56
|
+
.select('id, name, icon, is_active')
|
|
57
|
+
.order('name', { ascending: true });
|
|
58
|
+
if (error)
|
|
59
|
+
throw error;
|
|
60
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
61
|
+
}
|
|
62
|
+
// Activities
|
|
63
|
+
async function listActivities(_a, opts) {
|
|
64
|
+
const { client } = await getAuthedClient();
|
|
65
|
+
let q = client
|
|
66
|
+
.from('activities')
|
|
67
|
+
.select('id, type, title, description, lead_id, client_id, task_id, created_by, created_at')
|
|
68
|
+
.order('created_at', { ascending: false })
|
|
69
|
+
.limit(parseLimit(opts));
|
|
70
|
+
if (typeof opts.type === 'string')
|
|
71
|
+
q = q.eq('type', opts.type);
|
|
72
|
+
if (typeof opts.leadId === 'string')
|
|
73
|
+
q = q.eq('lead_id', opts.leadId);
|
|
74
|
+
if (typeof opts.clientId === 'string')
|
|
75
|
+
q = q.eq('client_id', opts.clientId);
|
|
76
|
+
if (typeof opts.taskId === 'string')
|
|
77
|
+
q = q.eq('task_id', opts.taskId);
|
|
78
|
+
if (typeof opts.createdBy === 'string')
|
|
79
|
+
q = q.eq('created_by', opts.createdBy);
|
|
80
|
+
if (typeof opts.since === 'string')
|
|
81
|
+
q = q.gte('created_at', opts.since);
|
|
82
|
+
if (typeof opts.until === 'string')
|
|
83
|
+
q = q.lte('created_at', opts.until);
|
|
84
|
+
if (typeof opts.search === 'string')
|
|
85
|
+
q = q.or(`title.ilike.%${opts.search}%,description.ilike.%${opts.search}%`);
|
|
86
|
+
const { data, error } = await q;
|
|
87
|
+
if (error)
|
|
88
|
+
throw error;
|
|
89
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
90
|
+
}
|
|
91
|
+
// Demo schedules
|
|
92
|
+
async function listDemos(_a, opts) {
|
|
93
|
+
const { client } = await getAuthedClient();
|
|
94
|
+
let q = client
|
|
95
|
+
.from('demo_schedules')
|
|
96
|
+
.select('id, lead_id, assigned_to, scheduled_date, scheduled_time, meeting_url, email_sent, created_at')
|
|
97
|
+
.order('scheduled_date', { ascending: false })
|
|
98
|
+
.limit(parseLimit(opts));
|
|
99
|
+
if (typeof opts.leadId === 'string')
|
|
100
|
+
q = q.eq('lead_id', opts.leadId);
|
|
101
|
+
if (typeof opts.assignedTo === 'string')
|
|
102
|
+
q = q.eq('assigned_to', opts.assignedTo);
|
|
103
|
+
if (typeof opts.since === 'string')
|
|
104
|
+
q = q.gte('scheduled_date', opts.since);
|
|
105
|
+
if (typeof opts.until === 'string')
|
|
106
|
+
q = q.lte('scheduled_date', opts.until);
|
|
107
|
+
if (typeof opts.emailSent === 'string')
|
|
108
|
+
q = q.eq('email_sent', opts.emailSent === 'true');
|
|
109
|
+
const { data, error } = await q;
|
|
110
|
+
if (error)
|
|
111
|
+
throw error;
|
|
112
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
113
|
+
}
|
|
114
|
+
// Onboarding
|
|
115
|
+
async function listOnboarding(_a, opts) {
|
|
116
|
+
const { client } = await getAuthedClient();
|
|
117
|
+
let q = client
|
|
118
|
+
.from('client_boardings')
|
|
119
|
+
.select('*')
|
|
120
|
+
.order('created_at', { ascending: false })
|
|
121
|
+
.limit(parseLimit(opts));
|
|
122
|
+
if (typeof opts.clientId === 'string')
|
|
123
|
+
q = q.eq('client_id', opts.clientId);
|
|
124
|
+
if (typeof opts.since === 'string')
|
|
125
|
+
q = q.gte('created_at', opts.since);
|
|
126
|
+
if (typeof opts.until === 'string')
|
|
127
|
+
q = q.lte('created_at', opts.until);
|
|
128
|
+
const { data, error } = await q;
|
|
129
|
+
if (error) {
|
|
130
|
+
// Fallback to onboarding_scores if client_boardings doesnt exist
|
|
131
|
+
const res2 = await client
|
|
132
|
+
.from('onboarding_scores')
|
|
133
|
+
.select('*')
|
|
134
|
+
.order('created_at', { ascending: false })
|
|
135
|
+
.limit(parseLimit(opts));
|
|
136
|
+
if (res2.error)
|
|
137
|
+
throw res2.error;
|
|
138
|
+
output(res2.data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
142
|
+
}
|
|
143
|
+
export const operationsModule = {
|
|
144
|
+
name: 'operations',
|
|
145
|
+
summary: 'Mission control, top clients, web design, team, sports, activities, demos, onboarding',
|
|
146
|
+
specs: [
|
|
147
|
+
{
|
|
148
|
+
path: ['mission-control', 'metrics'],
|
|
149
|
+
summary: 'Fetch mission-control metrics (calls the Next app)',
|
|
150
|
+
tags: ['read', 'http'],
|
|
151
|
+
options: [{ flag: '--pretty', description: 'human output' }],
|
|
152
|
+
handler: mcMetrics,
|
|
153
|
+
},
|
|
154
|
+
{
|
|
155
|
+
path: ['web-design', 'list'],
|
|
156
|
+
summary: 'List web-design projects',
|
|
157
|
+
tags: ['read'],
|
|
158
|
+
options: [
|
|
159
|
+
{ flag: '--status <s>', description: 'project status' },
|
|
160
|
+
{ flag: '--client-id <uuid>', description: 'filter by client' },
|
|
161
|
+
{ flag: '--assigned-to <uuid>', description: 'filter by assignee' },
|
|
162
|
+
{ flag: '--phase <p>', description: 'filter by current_phase' },
|
|
163
|
+
{ flag: '--target-before <date>', description: 'target_date <= YYYY-MM-DD' },
|
|
164
|
+
{ flag: '--target-after <date>', description: 'target_date >= YYYY-MM-DD' },
|
|
165
|
+
{ flag: '--search <text>', description: 'ilike on title' },
|
|
166
|
+
...commonListOptions(),
|
|
167
|
+
],
|
|
168
|
+
handler: listWebDesign,
|
|
169
|
+
},
|
|
170
|
+
{
|
|
171
|
+
path: ['team', 'list'],
|
|
172
|
+
summary: 'List team members',
|
|
173
|
+
tags: ['read'],
|
|
174
|
+
options: [
|
|
175
|
+
{ flag: '--active-only', description: 'is_active=true only' },
|
|
176
|
+
...commonListOptions(),
|
|
177
|
+
],
|
|
178
|
+
handler: listTeam,
|
|
179
|
+
},
|
|
180
|
+
{
|
|
181
|
+
path: ['sports', 'list'],
|
|
182
|
+
summary: 'List sports',
|
|
183
|
+
tags: ['read'],
|
|
184
|
+
options: [{ flag: '--pretty', description: 'human output' }],
|
|
185
|
+
handler: listSports,
|
|
186
|
+
},
|
|
187
|
+
{
|
|
188
|
+
path: ['activities', 'list'],
|
|
189
|
+
summary: 'List activities (timeline entries)',
|
|
190
|
+
tags: ['read'],
|
|
191
|
+
options: [
|
|
192
|
+
{ flag: '--type <t>', description: 'activity type' },
|
|
193
|
+
{ flag: '--lead-id <uuid>', description: 'filter by lead' },
|
|
194
|
+
{ flag: '--client-id <uuid>', description: 'filter by client' },
|
|
195
|
+
{ flag: '--task-id <uuid>', description: 'filter by task' },
|
|
196
|
+
{ flag: '--created-by <uuid>', description: 'filter by author (team_members.id)' },
|
|
197
|
+
{ flag: '--since <date>', description: 'created_at >= YYYY-MM-DD' },
|
|
198
|
+
{ flag: '--until <date>', description: 'created_at <= YYYY-MM-DD' },
|
|
199
|
+
{ flag: '--search <text>', description: 'ilike on title or description' },
|
|
200
|
+
...commonListOptions(),
|
|
201
|
+
],
|
|
202
|
+
handler: listActivities,
|
|
203
|
+
},
|
|
204
|
+
{
|
|
205
|
+
path: ['demos', 'list'],
|
|
206
|
+
summary: 'List demo_schedules',
|
|
207
|
+
tags: ['read'],
|
|
208
|
+
options: [
|
|
209
|
+
{ flag: '--lead-id <uuid>', description: 'filter by lead' },
|
|
210
|
+
{ flag: '--assigned-to <uuid>', description: 'filter by assignee' },
|
|
211
|
+
{ flag: '--since <date>', description: 'scheduled_date >= YYYY-MM-DD' },
|
|
212
|
+
{ flag: '--until <date>', description: 'scheduled_date <= YYYY-MM-DD' },
|
|
213
|
+
{ flag: '--email-sent <bool>', description: 'true|false' },
|
|
214
|
+
...commonListOptions(),
|
|
215
|
+
],
|
|
216
|
+
handler: listDemos,
|
|
217
|
+
},
|
|
218
|
+
{
|
|
219
|
+
path: ['onboarding', 'list'],
|
|
220
|
+
summary: 'List client_boardings (onboarding tracker)',
|
|
221
|
+
tags: ['read'],
|
|
222
|
+
options: [
|
|
223
|
+
{ flag: '--client-id <uuid>', description: 'filter by client' },
|
|
224
|
+
{ flag: '--since <date>', description: 'created_at >= YYYY-MM-DD' },
|
|
225
|
+
{ flag: '--until <date>', description: 'created_at <= YYYY-MM-DD' },
|
|
226
|
+
...commonListOptions(),
|
|
227
|
+
],
|
|
228
|
+
handler: listOnboarding,
|
|
229
|
+
},
|
|
230
|
+
],
|
|
231
|
+
};
|
|
232
|
+
//# sourceMappingURL=operations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"operations.js","sourceRoot":"","sources":["../../src/commands/operations.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { getAuthedClient } from '../core/supabase.js';
|
|
2
|
+
import { commonListOptions, output, parseColumns, parseLimit } from '../core/format.js';
|
|
3
|
+
async function listProspects(_a, opts) {
|
|
4
|
+
const { client } = await getAuthedClient();
|
|
5
|
+
let q = client
|
|
6
|
+
.from('outbound_prospects')
|
|
7
|
+
.select('id, name, sport_type, city, phone, lead_score, outbound_status, assigned_to, campaign_id, created_at')
|
|
8
|
+
.order('created_at', { ascending: false })
|
|
9
|
+
.limit(parseLimit(opts));
|
|
10
|
+
if (typeof opts.status === 'string')
|
|
11
|
+
q = q.eq('outbound_status', opts.status);
|
|
12
|
+
if (typeof opts.campaignId === 'string')
|
|
13
|
+
q = q.eq('campaign_id', opts.campaignId);
|
|
14
|
+
if (typeof opts.assignedTo === 'string')
|
|
15
|
+
q = q.eq('assigned_to', opts.assignedTo);
|
|
16
|
+
if (typeof opts.sport === 'string')
|
|
17
|
+
q = q.ilike('sport_type', `%${opts.sport}%`);
|
|
18
|
+
if (typeof opts.city === 'string')
|
|
19
|
+
q = q.ilike('city', `%${opts.city}%`);
|
|
20
|
+
if (typeof opts.search === 'string')
|
|
21
|
+
q = q.ilike('name', `%${opts.search}%`);
|
|
22
|
+
const { data, error } = await q;
|
|
23
|
+
if (error)
|
|
24
|
+
throw error;
|
|
25
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
26
|
+
}
|
|
27
|
+
async function setProspectStatus(args, opts) {
|
|
28
|
+
const { client } = await getAuthedClient();
|
|
29
|
+
const { data, error } = await client
|
|
30
|
+
.from('outbound_prospects')
|
|
31
|
+
.update({ outbound_status: args.status })
|
|
32
|
+
.eq('id', args.id)
|
|
33
|
+
.select('id, outbound_status')
|
|
34
|
+
.single();
|
|
35
|
+
if (error)
|
|
36
|
+
throw error;
|
|
37
|
+
output(data, { pretty: !!opts.pretty });
|
|
38
|
+
}
|
|
39
|
+
async function assignProspect(args, opts) {
|
|
40
|
+
const { client } = await getAuthedClient();
|
|
41
|
+
const { data, error } = await client
|
|
42
|
+
.from('outbound_prospects')
|
|
43
|
+
.update({ assigned_to: args.memberId })
|
|
44
|
+
.eq('id', args.id)
|
|
45
|
+
.select('id, assigned_to')
|
|
46
|
+
.single();
|
|
47
|
+
if (error)
|
|
48
|
+
throw error;
|
|
49
|
+
output(data, { pretty: !!opts.pretty });
|
|
50
|
+
}
|
|
51
|
+
async function listCampaigns(_a, opts) {
|
|
52
|
+
const { client } = await getAuthedClient();
|
|
53
|
+
let q = client
|
|
54
|
+
.from('outbound_campaigns')
|
|
55
|
+
.select('id, name, status, sport_filter, region_filter, created_by, created_at')
|
|
56
|
+
.order('created_at', { ascending: false })
|
|
57
|
+
.limit(parseLimit(opts));
|
|
58
|
+
if (typeof opts.status === 'string')
|
|
59
|
+
q = q.eq('status', opts.status);
|
|
60
|
+
const { data, error } = await q;
|
|
61
|
+
if (error)
|
|
62
|
+
throw error;
|
|
63
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
64
|
+
}
|
|
65
|
+
async function listInteractions(_a, opts) {
|
|
66
|
+
const { client } = await getAuthedClient();
|
|
67
|
+
let q = client
|
|
68
|
+
.from('outbound_interactions')
|
|
69
|
+
.select('id, type, prospect_id, created_by, notes, created_at')
|
|
70
|
+
.order('created_at', { ascending: false })
|
|
71
|
+
.limit(parseLimit(opts));
|
|
72
|
+
if (typeof opts.prospectId === 'string')
|
|
73
|
+
q = q.eq('prospect_id', opts.prospectId);
|
|
74
|
+
if (typeof opts.type === 'string')
|
|
75
|
+
q = q.eq('type', opts.type);
|
|
76
|
+
const { data, error } = await q;
|
|
77
|
+
if (error)
|
|
78
|
+
throw error;
|
|
79
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
80
|
+
}
|
|
81
|
+
async function logInteraction(_a, opts) {
|
|
82
|
+
const { client } = await getAuthedClient();
|
|
83
|
+
const { data, error } = await client
|
|
84
|
+
.from('outbound_interactions')
|
|
85
|
+
.insert({
|
|
86
|
+
prospect_id: opts.prospectId,
|
|
87
|
+
type: opts.type ?? 'note',
|
|
88
|
+
notes: opts.notes ?? null,
|
|
89
|
+
})
|
|
90
|
+
.select('*')
|
|
91
|
+
.single();
|
|
92
|
+
if (error)
|
|
93
|
+
throw error;
|
|
94
|
+
output(data, { pretty: !!opts.pretty });
|
|
95
|
+
}
|
|
96
|
+
export const outboundModule = {
|
|
97
|
+
name: 'outbound',
|
|
98
|
+
summary: 'Outbound prospecting — prospects, campaigns, interactions',
|
|
99
|
+
specs: [
|
|
100
|
+
{
|
|
101
|
+
path: ['outbound', 'prospects', 'list'],
|
|
102
|
+
summary: 'List outbound prospects',
|
|
103
|
+
tags: ['read'],
|
|
104
|
+
options: [
|
|
105
|
+
{ flag: '--status <s>', description: 'outbound_status filter' },
|
|
106
|
+
{ flag: '--campaign-id <uuid>', description: 'filter by campaign' },
|
|
107
|
+
{ flag: '--assigned-to <uuid>', description: 'filter by assignee' },
|
|
108
|
+
{ flag: '--sport <s>', description: 'ilike sport_type' },
|
|
109
|
+
{ flag: '--city <c>', description: 'ilike city' },
|
|
110
|
+
{ flag: '--search <text>', description: 'ilike name' },
|
|
111
|
+
...commonListOptions(),
|
|
112
|
+
],
|
|
113
|
+
handler: listProspects,
|
|
114
|
+
},
|
|
115
|
+
{
|
|
116
|
+
path: ['outbound', 'prospects', 'set-status'],
|
|
117
|
+
summary: 'Change prospect outbound_status',
|
|
118
|
+
tags: ['write'],
|
|
119
|
+
args: [
|
|
120
|
+
{ name: 'id', required: true, description: 'prospect uuid' },
|
|
121
|
+
{ name: 'status', required: true, description: 'new outbound_status' },
|
|
122
|
+
],
|
|
123
|
+
options: [{ flag: '--pretty', description: 'human output' }],
|
|
124
|
+
handler: setProspectStatus,
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
path: ['outbound', 'prospects', 'assign'],
|
|
128
|
+
summary: 'Assign prospect to a team member',
|
|
129
|
+
tags: ['write'],
|
|
130
|
+
args: [
|
|
131
|
+
{ name: 'id', required: true, description: 'prospect uuid' },
|
|
132
|
+
{ name: 'memberId', required: true, description: 'team_members.id' },
|
|
133
|
+
],
|
|
134
|
+
options: [{ flag: '--pretty', description: 'human output' }],
|
|
135
|
+
handler: assignProspect,
|
|
136
|
+
},
|
|
137
|
+
{
|
|
138
|
+
path: ['outbound', 'campaigns', 'list'],
|
|
139
|
+
summary: 'List outbound campaigns',
|
|
140
|
+
tags: ['read'],
|
|
141
|
+
options: [
|
|
142
|
+
{ flag: '--status <s>', description: 'campaign status' },
|
|
143
|
+
...commonListOptions(),
|
|
144
|
+
],
|
|
145
|
+
handler: listCampaigns,
|
|
146
|
+
},
|
|
147
|
+
{
|
|
148
|
+
path: ['outbound', 'interactions', 'list'],
|
|
149
|
+
summary: 'List outbound interactions',
|
|
150
|
+
tags: ['read'],
|
|
151
|
+
options: [
|
|
152
|
+
{ flag: '--prospect-id <uuid>', description: 'filter by prospect' },
|
|
153
|
+
{ flag: '--type <t>', description: 'interaction type' },
|
|
154
|
+
...commonListOptions(),
|
|
155
|
+
],
|
|
156
|
+
handler: listInteractions,
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
path: ['outbound', 'interactions', 'log'],
|
|
160
|
+
summary: 'Log an outbound interaction',
|
|
161
|
+
tags: ['write'],
|
|
162
|
+
options: [
|
|
163
|
+
{ flag: '--prospect-id <uuid>', description: 'prospect uuid (required)' },
|
|
164
|
+
{ flag: '--type <t>', description: 'note|call|email|whatsapp|…' },
|
|
165
|
+
{ flag: '--notes <text>', description: 'free-text notes' },
|
|
166
|
+
{ flag: '--pretty', description: 'human output' },
|
|
167
|
+
],
|
|
168
|
+
handler: logInteraction,
|
|
169
|
+
},
|
|
170
|
+
],
|
|
171
|
+
};
|
|
172
|
+
//# sourceMappingURL=outbound.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outbound.js","sourceRoot":"","sources":["../../src/commands/outbound.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
import { getAuthedClient } from '../core/supabase.js';
|
|
2
|
+
import { commonListOptions, output, parseColumns, parseLimit } from '../core/format.js';
|
|
3
|
+
/**
|
|
4
|
+
* Parse a --where expression like:
|
|
5
|
+
* category=salarios -> eq
|
|
6
|
+
* invoice_date:gte:2026-03-01 -> gte
|
|
7
|
+
* description:ilike:gym -> ilike (% wrapped automatically)
|
|
8
|
+
* status:in:paid,pending -> in
|
|
9
|
+
* paid_date:is:null -> is null
|
|
10
|
+
*/
|
|
11
|
+
function parseWhere(expr) {
|
|
12
|
+
// explicit op form: column:op:value
|
|
13
|
+
const withOp = /^([^:=]+):(eq|neq|gt|gte|lt|lte|like|ilike|in|is|not):(.+)$/.exec(expr);
|
|
14
|
+
if (withOp) {
|
|
15
|
+
return { column: withOp[1], op: withOp[2], value: withOp[3] };
|
|
16
|
+
}
|
|
17
|
+
// shorthand: column=value (eq)
|
|
18
|
+
const eqForm = /^([^=]+)=(.*)$/.exec(expr);
|
|
19
|
+
if (eqForm)
|
|
20
|
+
return { column: eqForm[1], op: 'eq', value: eqForm[2] };
|
|
21
|
+
throw new Error(`Invalid --where "${expr}". Use column=value or column:op:value (op ∈ eq,neq,gt,gte,lt,lte,like,ilike,in,is,not)`);
|
|
22
|
+
}
|
|
23
|
+
function applyClause(q, c) {
|
|
24
|
+
const v = c.value;
|
|
25
|
+
switch (c.op) {
|
|
26
|
+
case 'eq':
|
|
27
|
+
return q.eq(c.column, coerce(v));
|
|
28
|
+
case 'neq':
|
|
29
|
+
return q.neq(c.column, coerce(v));
|
|
30
|
+
case 'gt':
|
|
31
|
+
return q.gt(c.column, coerce(v));
|
|
32
|
+
case 'gte':
|
|
33
|
+
return q.gte(c.column, coerce(v));
|
|
34
|
+
case 'lt':
|
|
35
|
+
return q.lt(c.column, coerce(v));
|
|
36
|
+
case 'lte':
|
|
37
|
+
return q.lte(c.column, coerce(v));
|
|
38
|
+
case 'like':
|
|
39
|
+
return q.like(c.column, v.includes('%') ? v : `%${v}%`);
|
|
40
|
+
case 'ilike':
|
|
41
|
+
return q.ilike(c.column, v.includes('%') ? v : `%${v}%`);
|
|
42
|
+
case 'in':
|
|
43
|
+
return q.in(c.column, v.split(',').map((s) => coerce(s.trim())));
|
|
44
|
+
case 'is': {
|
|
45
|
+
if (v === 'null')
|
|
46
|
+
return q.is(c.column, null);
|
|
47
|
+
if (v === 'true' || v === 'false')
|
|
48
|
+
return q.is(c.column, v === 'true');
|
|
49
|
+
throw new Error(`is supports null|true|false, got "${v}"`);
|
|
50
|
+
}
|
|
51
|
+
case 'not':
|
|
52
|
+
// column:not:null → not(column,is,null). Limited helper.
|
|
53
|
+
if (v === 'null')
|
|
54
|
+
return q.not(c.column, 'is', null);
|
|
55
|
+
return q.not(c.column, 'eq', coerce(v));
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
function coerce(v) {
|
|
59
|
+
if (v === 'null')
|
|
60
|
+
return null;
|
|
61
|
+
if (v === 'true')
|
|
62
|
+
return true;
|
|
63
|
+
if (v === 'false')
|
|
64
|
+
return false;
|
|
65
|
+
if (/^-?\d+(\.\d+)?$/.test(v))
|
|
66
|
+
return Number(v);
|
|
67
|
+
return v;
|
|
68
|
+
}
|
|
69
|
+
async function queryHandler(args, opts) {
|
|
70
|
+
const table = args.table;
|
|
71
|
+
if (!table)
|
|
72
|
+
throw new Error('table is required');
|
|
73
|
+
const { client } = await getAuthedClient();
|
|
74
|
+
const select = opts.select ?? '*';
|
|
75
|
+
const limit = parseLimit(opts, 50);
|
|
76
|
+
let q = client.from(table).select(select).limit(limit);
|
|
77
|
+
const wheres = asArray(opts.where);
|
|
78
|
+
for (const w of wheres)
|
|
79
|
+
q = applyClause(q, parseWhere(w));
|
|
80
|
+
if (typeof opts.order === 'string') {
|
|
81
|
+
const [col, dir] = opts.order.split(':');
|
|
82
|
+
q = q.order(col, { ascending: (dir ?? 'desc') === 'asc' });
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
q = q.order('created_at', { ascending: false });
|
|
86
|
+
}
|
|
87
|
+
if (typeof opts.offset === 'string') {
|
|
88
|
+
const off = parseInt(opts.offset, 10);
|
|
89
|
+
q = q.range(off, off + limit - 1);
|
|
90
|
+
}
|
|
91
|
+
const { data, error } = await q;
|
|
92
|
+
if (error)
|
|
93
|
+
throw error;
|
|
94
|
+
output(data ?? [], { pretty: !!opts.pretty, columns: parseColumns(opts) });
|
|
95
|
+
}
|
|
96
|
+
async function countHandler(args, opts) {
|
|
97
|
+
const table = args.table;
|
|
98
|
+
if (!table)
|
|
99
|
+
throw new Error('table is required');
|
|
100
|
+
const { client } = await getAuthedClient();
|
|
101
|
+
let q = client.from(table).select('*', { count: 'exact', head: true });
|
|
102
|
+
const wheres = asArray(opts.where);
|
|
103
|
+
for (const w of wheres)
|
|
104
|
+
q = applyClause(q, parseWhere(w));
|
|
105
|
+
const { count, error } = await q;
|
|
106
|
+
if (error)
|
|
107
|
+
throw error;
|
|
108
|
+
output({ table, count: count ?? 0, where: wheres }, { pretty: !!opts.pretty });
|
|
109
|
+
}
|
|
110
|
+
async function describeHandler(args, opts) {
|
|
111
|
+
const table = args.table;
|
|
112
|
+
if (!table)
|
|
113
|
+
throw new Error('table is required');
|
|
114
|
+
const { client } = await getAuthedClient();
|
|
115
|
+
// Grab one row to infer columns
|
|
116
|
+
const { data, error } = await client.from(table).select('*').limit(1);
|
|
117
|
+
if (error)
|
|
118
|
+
throw error;
|
|
119
|
+
const row = data?.[0] ?? {};
|
|
120
|
+
const columns = Object.entries(row).map(([name, value]) => ({
|
|
121
|
+
name,
|
|
122
|
+
type: value === null ? 'unknown (null in sample)' : Array.isArray(value) ? 'array' : typeof value,
|
|
123
|
+
sample: value,
|
|
124
|
+
}));
|
|
125
|
+
output({ table, columns }, { pretty: !!opts.pretty });
|
|
126
|
+
}
|
|
127
|
+
function asArray(v) {
|
|
128
|
+
if (Array.isArray(v))
|
|
129
|
+
return v;
|
|
130
|
+
if (typeof v === 'string')
|
|
131
|
+
return [v];
|
|
132
|
+
return [];
|
|
133
|
+
}
|
|
134
|
+
export const queryModule = {
|
|
135
|
+
name: 'query',
|
|
136
|
+
summary: 'Generic queries against any Supabase table (filter any column)',
|
|
137
|
+
specs: [
|
|
138
|
+
{
|
|
139
|
+
path: ['query'],
|
|
140
|
+
summary: 'Filter any column of any table with --where expressions',
|
|
141
|
+
description: 'Escape hatch for ad-hoc queries. Every --where flag can be repeated.\n\n' +
|
|
142
|
+
'Shorthand: column=value (eq)\n' +
|
|
143
|
+
'Explicit: column:op:value (op ∈ eq,neq,gt,gte,lt,lte,like,ilike,in,is,not)\n\n' +
|
|
144
|
+
'Examples of value handling: "null" → NULL, "true"/"false" → bool, numbers → number, comma-list for `in`.',
|
|
145
|
+
tags: ['read'],
|
|
146
|
+
args: [
|
|
147
|
+
{ name: 'table', required: true, description: 'Supabase table name (e.g. invoices, leads, bank_movements)' },
|
|
148
|
+
],
|
|
149
|
+
options: [
|
|
150
|
+
{ flag: '--where <expr>', description: 'filter expression, repeatable. e.g. "category=salarios"', collect: true },
|
|
151
|
+
{ flag: '--select <cols>', description: 'Supabase select string (default *)' },
|
|
152
|
+
{ flag: '--order <col:dir>', description: 'e.g. invoice_date:desc (default created_at:desc)' },
|
|
153
|
+
{ flag: '--offset <n>', description: 'pagination offset' },
|
|
154
|
+
...commonListOptions(),
|
|
155
|
+
],
|
|
156
|
+
examples: [
|
|
157
|
+
'badgie-crm query invoices --where "category=salarios" --where "invoice_date:gte:2026-03-01" --where "invoice_date:lte:2026-03-31" --pretty',
|
|
158
|
+
'badgie-crm query bank_movements --where "amount:gte:1000" --where "description:ilike:gym" --limit 20',
|
|
159
|
+
'badgie-crm query leads --where "status_id:in:uuid1,uuid2" --pretty',
|
|
160
|
+
'badgie-crm query clients --where "sport=Padel" --where "city:ilike:madrid" --pretty',
|
|
161
|
+
],
|
|
162
|
+
handler: queryHandler,
|
|
163
|
+
},
|
|
164
|
+
{
|
|
165
|
+
path: ['query', 'count'],
|
|
166
|
+
summary: 'Count rows matching filters (no data returned)',
|
|
167
|
+
tags: ['read'],
|
|
168
|
+
args: [{ name: 'table', required: true, description: 'table name' }],
|
|
169
|
+
options: [
|
|
170
|
+
{ flag: '--where <expr>', description: 'filter expression, repeatable', collect: true },
|
|
171
|
+
{ flag: '--pretty', description: 'human output' },
|
|
172
|
+
],
|
|
173
|
+
examples: [
|
|
174
|
+
'badgie-crm query count invoices --where "category=salarios" --where "invoice_date:gte:2026-03-01"',
|
|
175
|
+
],
|
|
176
|
+
handler: countHandler,
|
|
177
|
+
},
|
|
178
|
+
{
|
|
179
|
+
path: ['query', 'describe'],
|
|
180
|
+
summary: 'Show columns (inferred from a sample row) for a table',
|
|
181
|
+
tags: ['read'],
|
|
182
|
+
args: [{ name: 'table', required: true, description: 'table name' }],
|
|
183
|
+
options: [{ flag: '--pretty', description: 'human output' }],
|
|
184
|
+
examples: ['badgie-crm query describe invoices --pretty'],
|
|
185
|
+
handler: describeHandler,
|
|
186
|
+
},
|
|
187
|
+
],
|
|
188
|
+
};
|
|
189
|
+
//# sourceMappingURL=query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../src/commands/query.ts"],"names":[],"mappings":"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"}
|