@thinkhive/sdk 3.1.0 → 3.3.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/README.md +279 -128
- package/dist/api/apiKeys.d.ts +252 -0
- package/dist/api/apiKeys.js +298 -0
- package/dist/api/business-metrics.d.ts +188 -0
- package/dist/api/business-metrics.js +213 -0
- package/dist/api/conversation-eval.d.ts +200 -0
- package/dist/api/conversation-eval.js +235 -0
- package/dist/api/deterministic-graders.d.ts +205 -0
- package/dist/api/deterministic-graders.js +191 -0
- package/dist/api/eval-health.d.ts +250 -0
- package/dist/api/eval-health.js +224 -0
- package/dist/api/human-review.d.ts +275 -0
- package/dist/api/human-review.js +236 -0
- package/dist/api/nondeterminism.d.ts +300 -0
- package/dist/api/nondeterminism.js +250 -0
- package/dist/api/quality-metrics.d.ts +303 -0
- package/dist/api/quality-metrics.js +198 -0
- package/dist/api/roi-analytics.d.ts +263 -0
- package/dist/api/roi-analytics.js +204 -0
- package/dist/api/transcript-patterns.d.ts +204 -0
- package/dist/api/transcript-patterns.js +227 -0
- package/dist/core/client.d.ts +82 -8
- package/dist/core/client.js +223 -32
- package/dist/core/config.d.ts +1 -1
- package/dist/core/config.js +2 -2
- package/dist/core/types.d.ts +27 -2
- package/dist/core/types.js +1 -1
- package/dist/index.d.ts +415 -62
- package/dist/index.js +253 -37
- package/package.json +8 -4
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ThinkHive SDK v3.1 - ROI Analytics API
|
|
3
|
+
*
|
|
4
|
+
* Business ROI & Metrics Engine for calculating financial impact
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* Industry-specific ROI configuration
|
|
8
|
+
*/
|
|
9
|
+
export interface IndustryConfig {
|
|
10
|
+
id: string;
|
|
11
|
+
name: string;
|
|
12
|
+
avgTransactionValue: number;
|
|
13
|
+
avgCustomerLTV: number;
|
|
14
|
+
avgSupportCost: number;
|
|
15
|
+
avgEscalationCost: number;
|
|
16
|
+
avgResolutionTime: number;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Custom industry config input
|
|
20
|
+
*/
|
|
21
|
+
export interface CustomIndustryConfig {
|
|
22
|
+
industry?: string;
|
|
23
|
+
avgTransactionValue?: number;
|
|
24
|
+
avgCustomerLTV?: number;
|
|
25
|
+
avgSupportCost?: number;
|
|
26
|
+
avgEscalationCost?: number;
|
|
27
|
+
churnImpactMultiplier?: number;
|
|
28
|
+
avgResolutionTime?: number;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* ROI metrics summary
|
|
32
|
+
*/
|
|
33
|
+
export interface ROIMetrics {
|
|
34
|
+
roiCategory: string;
|
|
35
|
+
totalFinancialImpact: number;
|
|
36
|
+
revenueProtected: number;
|
|
37
|
+
costSavings: number;
|
|
38
|
+
efficiencyGain: number;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Business impact analysis result
|
|
42
|
+
*/
|
|
43
|
+
export interface BusinessImpact {
|
|
44
|
+
impactScore: number;
|
|
45
|
+
revenueRisk: number;
|
|
46
|
+
brandRisk: number;
|
|
47
|
+
complianceRisk: number;
|
|
48
|
+
operationalImpact: number;
|
|
49
|
+
customerSatisfaction: number;
|
|
50
|
+
recommendations: string[];
|
|
51
|
+
roi: ROIMetrics;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* ROI summary for a date range
|
|
55
|
+
*/
|
|
56
|
+
export interface ROISummary {
|
|
57
|
+
dateRange: {
|
|
58
|
+
start: string;
|
|
59
|
+
end: string;
|
|
60
|
+
};
|
|
61
|
+
traceCount: number;
|
|
62
|
+
successfulInteractions: number;
|
|
63
|
+
failedInteractions: number;
|
|
64
|
+
successRate: number;
|
|
65
|
+
roi: ROIMetrics;
|
|
66
|
+
revenueProtected: number;
|
|
67
|
+
estimatedSavings: number;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Daily trend data point
|
|
71
|
+
*/
|
|
72
|
+
export interface TrendDataPoint {
|
|
73
|
+
date: string;
|
|
74
|
+
traceCount: number;
|
|
75
|
+
successCount: number;
|
|
76
|
+
failureCount: number;
|
|
77
|
+
successRate: number;
|
|
78
|
+
avgImpactScore: number;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Correlation finding
|
|
82
|
+
*/
|
|
83
|
+
export interface Correlation {
|
|
84
|
+
type: string;
|
|
85
|
+
strength: string;
|
|
86
|
+
coefficient: number;
|
|
87
|
+
confidence: number;
|
|
88
|
+
description: string;
|
|
89
|
+
insight: string;
|
|
90
|
+
recommendation: string;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Pattern cluster
|
|
94
|
+
*/
|
|
95
|
+
export interface PatternCluster {
|
|
96
|
+
id: string;
|
|
97
|
+
name: string;
|
|
98
|
+
matchCount: number;
|
|
99
|
+
avgImpactScore: number;
|
|
100
|
+
avgChurnRisk: number;
|
|
101
|
+
trend: string;
|
|
102
|
+
examples: string[];
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Correlation analysis result
|
|
106
|
+
*/
|
|
107
|
+
export interface CorrelationAnalysis {
|
|
108
|
+
analysisId: string;
|
|
109
|
+
analyzedAt: string;
|
|
110
|
+
traceCount: number;
|
|
111
|
+
timeRange: {
|
|
112
|
+
start: string;
|
|
113
|
+
end: string;
|
|
114
|
+
};
|
|
115
|
+
overallHealthScore: number;
|
|
116
|
+
topInsights: string[];
|
|
117
|
+
recommendations: string[];
|
|
118
|
+
correlations: Correlation[];
|
|
119
|
+
patternClusters: PatternCluster[];
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* ROI Analytics API client for business impact analysis
|
|
123
|
+
*/
|
|
124
|
+
export declare const roiAnalytics: {
|
|
125
|
+
/**
|
|
126
|
+
* Get aggregated ROI summary for traces in date range
|
|
127
|
+
*
|
|
128
|
+
* @example
|
|
129
|
+
* ```typescript
|
|
130
|
+
* const summary = await roiAnalytics.summary({
|
|
131
|
+
* startDate: '2024-01-01',
|
|
132
|
+
* endDate: '2024-01-31',
|
|
133
|
+
* });
|
|
134
|
+
* console.log(`Revenue protected: $${summary.revenueProtected}`);
|
|
135
|
+
* ```
|
|
136
|
+
*/
|
|
137
|
+
summary(options?: {
|
|
138
|
+
startDate?: string | Date;
|
|
139
|
+
endDate?: string | Date;
|
|
140
|
+
agentId?: string;
|
|
141
|
+
}): Promise<ROISummary>;
|
|
142
|
+
/**
|
|
143
|
+
* Get ROI metrics for a specific agent
|
|
144
|
+
*
|
|
145
|
+
* @example
|
|
146
|
+
* ```typescript
|
|
147
|
+
* const agentROI = await roiAnalytics.byAgent('agent_123', {
|
|
148
|
+
* startDate: '2024-01-01',
|
|
149
|
+
* });
|
|
150
|
+
* console.log(`Agent: ${agentROI.agent.name}`);
|
|
151
|
+
* console.log(`ROI: ${agentROI.roi.totalFinancialImpact}`);
|
|
152
|
+
* ```
|
|
153
|
+
*/
|
|
154
|
+
byAgent(agentId: string, options?: {
|
|
155
|
+
startDate?: string | Date;
|
|
156
|
+
endDate?: string | Date;
|
|
157
|
+
}): Promise<{
|
|
158
|
+
agent: {
|
|
159
|
+
id: string;
|
|
160
|
+
name: string;
|
|
161
|
+
industry: string;
|
|
162
|
+
};
|
|
163
|
+
industryConfig: Partial<IndustryConfig>;
|
|
164
|
+
roi: ROIMetrics;
|
|
165
|
+
recentImpacts: Array<{
|
|
166
|
+
impactScore: number;
|
|
167
|
+
revenueRisk: number;
|
|
168
|
+
roiCategory: string;
|
|
169
|
+
totalFinancialImpact: number;
|
|
170
|
+
}>;
|
|
171
|
+
}>;
|
|
172
|
+
/**
|
|
173
|
+
* Get ROI trends over time
|
|
174
|
+
*
|
|
175
|
+
* @example
|
|
176
|
+
* ```typescript
|
|
177
|
+
* const trends = await roiAnalytics.trends({
|
|
178
|
+
* startDate: '2024-01-01',
|
|
179
|
+
* endDate: '2024-01-31',
|
|
180
|
+
* });
|
|
181
|
+
* for (const day of trends) {
|
|
182
|
+
* console.log(`${day.date}: ${day.successRate}% success`);
|
|
183
|
+
* }
|
|
184
|
+
* ```
|
|
185
|
+
*/
|
|
186
|
+
trends(options?: {
|
|
187
|
+
startDate?: string | Date;
|
|
188
|
+
endDate?: string | Date;
|
|
189
|
+
agentId?: string;
|
|
190
|
+
}): Promise<TrendDataPoint[]>;
|
|
191
|
+
/**
|
|
192
|
+
* Calculate ROI for a trace or provided message data
|
|
193
|
+
*
|
|
194
|
+
* @example
|
|
195
|
+
* ```typescript
|
|
196
|
+
* // Calculate for existing trace
|
|
197
|
+
* const impact = await roiAnalytics.calculate({
|
|
198
|
+
* traceId: 'trace_abc123',
|
|
199
|
+
* });
|
|
200
|
+
*
|
|
201
|
+
* // Calculate for new data with custom config
|
|
202
|
+
* const impact = await roiAnalytics.calculate({
|
|
203
|
+
* userMessage: 'Help me cancel my subscription',
|
|
204
|
+
* agentResponse: 'I can help with that...',
|
|
205
|
+
* industryConfig: { industry: 'saas', avgCustomerLTV: 10000 },
|
|
206
|
+
* });
|
|
207
|
+
* ```
|
|
208
|
+
*/
|
|
209
|
+
calculate(options: {
|
|
210
|
+
traceId?: string;
|
|
211
|
+
userMessage?: string;
|
|
212
|
+
agentResponse?: string;
|
|
213
|
+
industryConfig?: CustomIndustryConfig;
|
|
214
|
+
}): Promise<BusinessImpact>;
|
|
215
|
+
/**
|
|
216
|
+
* Get available industry configurations
|
|
217
|
+
*
|
|
218
|
+
* @example
|
|
219
|
+
* ```typescript
|
|
220
|
+
* const industries = await roiAnalytics.industries();
|
|
221
|
+
* for (const config of industries) {
|
|
222
|
+
* console.log(`${config.name}: $${config.avgCustomerLTV} LTV`);
|
|
223
|
+
* }
|
|
224
|
+
* ```
|
|
225
|
+
*/
|
|
226
|
+
industries(): Promise<IndustryConfig[]>;
|
|
227
|
+
/**
|
|
228
|
+
* Get correlation analysis for traces
|
|
229
|
+
*
|
|
230
|
+
* @example
|
|
231
|
+
* ```typescript
|
|
232
|
+
* const analysis = await roiAnalytics.correlations({
|
|
233
|
+
* startDate: '2024-01-01',
|
|
234
|
+
* agentId: 'agent_123',
|
|
235
|
+
* });
|
|
236
|
+
* console.log(`Health score: ${analysis.overallHealthScore}`);
|
|
237
|
+
* for (const insight of analysis.topInsights) {
|
|
238
|
+
* console.log(`- ${insight}`);
|
|
239
|
+
* }
|
|
240
|
+
* ```
|
|
241
|
+
*/
|
|
242
|
+
correlations(options?: {
|
|
243
|
+
startDate?: string | Date;
|
|
244
|
+
endDate?: string | Date;
|
|
245
|
+
agentId?: string;
|
|
246
|
+
}): Promise<CorrelationAnalysis>;
|
|
247
|
+
};
|
|
248
|
+
/**
|
|
249
|
+
* Calculate estimated revenue at risk
|
|
250
|
+
*/
|
|
251
|
+
export declare function calculateRevenueAtRisk(failureRate: number, avgTransactionValue: number, totalInteractions: number): number;
|
|
252
|
+
/**
|
|
253
|
+
* Calculate estimated savings from automation
|
|
254
|
+
*/
|
|
255
|
+
export declare function calculateAutomationSavings(successfulInteractions: number, avgSupportCost: number): number;
|
|
256
|
+
/**
|
|
257
|
+
* Format currency for display
|
|
258
|
+
*/
|
|
259
|
+
export declare function formatCurrency(amount: number, currency?: string): string;
|
|
260
|
+
/**
|
|
261
|
+
* Get ROI quality label
|
|
262
|
+
*/
|
|
263
|
+
export declare function getROIQuality(totalFinancialImpact: number): 'excellent' | 'good' | 'moderate' | 'poor';
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK v3.1 - ROI Analytics API
|
|
4
|
+
*
|
|
5
|
+
* Business ROI & Metrics Engine for calculating financial impact
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.roiAnalytics = void 0;
|
|
9
|
+
exports.calculateRevenueAtRisk = calculateRevenueAtRisk;
|
|
10
|
+
exports.calculateAutomationSavings = calculateAutomationSavings;
|
|
11
|
+
exports.formatCurrency = formatCurrency;
|
|
12
|
+
exports.getROIQuality = getROIQuality;
|
|
13
|
+
const client_1 = require("../core/client");
|
|
14
|
+
// ============================================================================
|
|
15
|
+
// ROI ANALYTICS API CLIENT
|
|
16
|
+
// ============================================================================
|
|
17
|
+
/**
|
|
18
|
+
* ROI Analytics API client for business impact analysis
|
|
19
|
+
*/
|
|
20
|
+
exports.roiAnalytics = {
|
|
21
|
+
/**
|
|
22
|
+
* Get aggregated ROI summary for traces in date range
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* ```typescript
|
|
26
|
+
* const summary = await roiAnalytics.summary({
|
|
27
|
+
* startDate: '2024-01-01',
|
|
28
|
+
* endDate: '2024-01-31',
|
|
29
|
+
* });
|
|
30
|
+
* console.log(`Revenue protected: $${summary.revenueProtected}`);
|
|
31
|
+
* ```
|
|
32
|
+
*/
|
|
33
|
+
async summary(options = {}) {
|
|
34
|
+
const params = new URLSearchParams();
|
|
35
|
+
if (options.startDate) {
|
|
36
|
+
params.set('startDate', new Date(options.startDate).toISOString());
|
|
37
|
+
}
|
|
38
|
+
if (options.endDate) {
|
|
39
|
+
params.set('endDate', new Date(options.endDate).toISOString());
|
|
40
|
+
}
|
|
41
|
+
if (options.agentId) {
|
|
42
|
+
params.set('agentId', options.agentId);
|
|
43
|
+
}
|
|
44
|
+
const response = await (0, client_1.apiRequest)(`/analytics/roi/summary?${params.toString()}`, { apiVersion: 'v1' });
|
|
45
|
+
return response.data.summary;
|
|
46
|
+
},
|
|
47
|
+
/**
|
|
48
|
+
* Get ROI metrics for a specific agent
|
|
49
|
+
*
|
|
50
|
+
* @example
|
|
51
|
+
* ```typescript
|
|
52
|
+
* const agentROI = await roiAnalytics.byAgent('agent_123', {
|
|
53
|
+
* startDate: '2024-01-01',
|
|
54
|
+
* });
|
|
55
|
+
* console.log(`Agent: ${agentROI.agent.name}`);
|
|
56
|
+
* console.log(`ROI: ${agentROI.roi.totalFinancialImpact}`);
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
async byAgent(agentId, options = {}) {
|
|
60
|
+
const params = new URLSearchParams();
|
|
61
|
+
if (options.startDate) {
|
|
62
|
+
params.set('startDate', new Date(options.startDate).toISOString());
|
|
63
|
+
}
|
|
64
|
+
if (options.endDate) {
|
|
65
|
+
params.set('endDate', new Date(options.endDate).toISOString());
|
|
66
|
+
}
|
|
67
|
+
return (0, client_1.apiRequestWithData)(`/analytics/roi/by-agent/${agentId}?${params.toString()}`, { apiVersion: 'v1' });
|
|
68
|
+
},
|
|
69
|
+
/**
|
|
70
|
+
* Get ROI trends over time
|
|
71
|
+
*
|
|
72
|
+
* @example
|
|
73
|
+
* ```typescript
|
|
74
|
+
* const trends = await roiAnalytics.trends({
|
|
75
|
+
* startDate: '2024-01-01',
|
|
76
|
+
* endDate: '2024-01-31',
|
|
77
|
+
* });
|
|
78
|
+
* for (const day of trends) {
|
|
79
|
+
* console.log(`${day.date}: ${day.successRate}% success`);
|
|
80
|
+
* }
|
|
81
|
+
* ```
|
|
82
|
+
*/
|
|
83
|
+
async trends(options = {}) {
|
|
84
|
+
const params = new URLSearchParams();
|
|
85
|
+
if (options.startDate) {
|
|
86
|
+
params.set('startDate', new Date(options.startDate).toISOString());
|
|
87
|
+
}
|
|
88
|
+
if (options.endDate) {
|
|
89
|
+
params.set('endDate', new Date(options.endDate).toISOString());
|
|
90
|
+
}
|
|
91
|
+
if (options.agentId) {
|
|
92
|
+
params.set('agentId', options.agentId);
|
|
93
|
+
}
|
|
94
|
+
const response = await (0, client_1.apiRequest)(`/analytics/roi/trends?${params.toString()}`, { apiVersion: 'v1' });
|
|
95
|
+
return response.data.trends;
|
|
96
|
+
},
|
|
97
|
+
/**
|
|
98
|
+
* Calculate ROI for a trace or provided message data
|
|
99
|
+
*
|
|
100
|
+
* @example
|
|
101
|
+
* ```typescript
|
|
102
|
+
* // Calculate for existing trace
|
|
103
|
+
* const impact = await roiAnalytics.calculate({
|
|
104
|
+
* traceId: 'trace_abc123',
|
|
105
|
+
* });
|
|
106
|
+
*
|
|
107
|
+
* // Calculate for new data with custom config
|
|
108
|
+
* const impact = await roiAnalytics.calculate({
|
|
109
|
+
* userMessage: 'Help me cancel my subscription',
|
|
110
|
+
* agentResponse: 'I can help with that...',
|
|
111
|
+
* industryConfig: { industry: 'saas', avgCustomerLTV: 10000 },
|
|
112
|
+
* });
|
|
113
|
+
* ```
|
|
114
|
+
*/
|
|
115
|
+
async calculate(options) {
|
|
116
|
+
const response = await (0, client_1.apiRequest)('/analytics/roi/calculate', {
|
|
117
|
+
method: 'POST',
|
|
118
|
+
body: options,
|
|
119
|
+
apiVersion: 'v1',
|
|
120
|
+
});
|
|
121
|
+
return response.data.impact;
|
|
122
|
+
},
|
|
123
|
+
/**
|
|
124
|
+
* Get available industry configurations
|
|
125
|
+
*
|
|
126
|
+
* @example
|
|
127
|
+
* ```typescript
|
|
128
|
+
* const industries = await roiAnalytics.industries();
|
|
129
|
+
* for (const config of industries) {
|
|
130
|
+
* console.log(`${config.name}: $${config.avgCustomerLTV} LTV`);
|
|
131
|
+
* }
|
|
132
|
+
* ```
|
|
133
|
+
*/
|
|
134
|
+
async industries() {
|
|
135
|
+
const response = await (0, client_1.apiRequest)('/analytics/roi/industries', { apiVersion: 'v1' });
|
|
136
|
+
return response.data.industries;
|
|
137
|
+
},
|
|
138
|
+
/**
|
|
139
|
+
* Get correlation analysis for traces
|
|
140
|
+
*
|
|
141
|
+
* @example
|
|
142
|
+
* ```typescript
|
|
143
|
+
* const analysis = await roiAnalytics.correlations({
|
|
144
|
+
* startDate: '2024-01-01',
|
|
145
|
+
* agentId: 'agent_123',
|
|
146
|
+
* });
|
|
147
|
+
* console.log(`Health score: ${analysis.overallHealthScore}`);
|
|
148
|
+
* for (const insight of analysis.topInsights) {
|
|
149
|
+
* console.log(`- ${insight}`);
|
|
150
|
+
* }
|
|
151
|
+
* ```
|
|
152
|
+
*/
|
|
153
|
+
async correlations(options = {}) {
|
|
154
|
+
const params = new URLSearchParams();
|
|
155
|
+
if (options.startDate) {
|
|
156
|
+
params.set('startDate', new Date(options.startDate).toISOString());
|
|
157
|
+
}
|
|
158
|
+
if (options.endDate) {
|
|
159
|
+
params.set('endDate', new Date(options.endDate).toISOString());
|
|
160
|
+
}
|
|
161
|
+
if (options.agentId) {
|
|
162
|
+
params.set('agentId', options.agentId);
|
|
163
|
+
}
|
|
164
|
+
const response = await (0, client_1.apiRequest)(`/analytics/correlations?${params.toString()}`, { apiVersion: 'v1' });
|
|
165
|
+
return response.data.analysis;
|
|
166
|
+
},
|
|
167
|
+
};
|
|
168
|
+
// ============================================================================
|
|
169
|
+
// HELPER FUNCTIONS
|
|
170
|
+
// ============================================================================
|
|
171
|
+
/**
|
|
172
|
+
* Calculate estimated revenue at risk
|
|
173
|
+
*/
|
|
174
|
+
function calculateRevenueAtRisk(failureRate, avgTransactionValue, totalInteractions) {
|
|
175
|
+
return failureRate * avgTransactionValue * totalInteractions;
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Calculate estimated savings from automation
|
|
179
|
+
*/
|
|
180
|
+
function calculateAutomationSavings(successfulInteractions, avgSupportCost) {
|
|
181
|
+
return successfulInteractions * avgSupportCost;
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* Format currency for display
|
|
185
|
+
*/
|
|
186
|
+
function formatCurrency(amount, currency = 'USD') {
|
|
187
|
+
return new Intl.NumberFormat('en-US', {
|
|
188
|
+
style: 'currency',
|
|
189
|
+
currency,
|
|
190
|
+
}).format(amount);
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Get ROI quality label
|
|
194
|
+
*/
|
|
195
|
+
function getROIQuality(totalFinancialImpact) {
|
|
196
|
+
if (totalFinancialImpact > 100000)
|
|
197
|
+
return 'excellent';
|
|
198
|
+
if (totalFinancialImpact > 50000)
|
|
199
|
+
return 'good';
|
|
200
|
+
if (totalFinancialImpact > 10000)
|
|
201
|
+
return 'moderate';
|
|
202
|
+
return 'poor';
|
|
203
|
+
}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"roi-analytics.js","sourceRoot":"","sources":["../../src/api/roi-analytics.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK v3.1 - ROI Analytics API\n *\n * Business ROI & Metrics Engine for calculating financial impact\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\nimport type { ApiResponse } from '../core/types';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\n/**\n * Industry-specific ROI configuration\n */\nexport interface IndustryConfig {\n  id: string;\n  name: string;\n  avgTransactionValue: number;\n  avgCustomerLTV: number;\n  avgSupportCost: number;\n  avgEscalationCost: number;\n  avgResolutionTime: number;\n}\n\n/**\n * Custom industry config input\n */\nexport interface CustomIndustryConfig {\n  industry?: string;\n  avgTransactionValue?: number;\n  avgCustomerLTV?: number;\n  avgSupportCost?: number;\n  avgEscalationCost?: number;\n  churnImpactMultiplier?: number;\n  avgResolutionTime?: number;\n}\n\n/**\n * ROI metrics summary\n */\nexport interface ROIMetrics {\n  roiCategory: string;\n  totalFinancialImpact: number;\n  revenueProtected: number;\n  costSavings: number;\n  efficiencyGain: number;\n}\n\n/**\n * Business impact analysis result\n */\nexport interface BusinessImpact {\n  impactScore: number;\n  revenueRisk: number;\n  brandRisk: number;\n  complianceRisk: number;\n  operationalImpact: number;\n  customerSatisfaction: number;\n  recommendations: string[];\n  roi: ROIMetrics;\n}\n\n/**\n * ROI summary for a date range\n */\nexport interface ROISummary {\n  dateRange: { start: string; end: string };\n  traceCount: number;\n  successfulInteractions: number;\n  failedInteractions: number;\n  successRate: number;\n  roi: ROIMetrics;\n  revenueProtected: number;\n  estimatedSavings: number;\n}\n\n/**\n * Daily trend data point\n */\nexport interface TrendDataPoint {\n  date: string;\n  traceCount: number;\n  successCount: number;\n  failureCount: number;\n  successRate: number;\n  avgImpactScore: number;\n}\n\n/**\n * Correlation finding\n */\nexport interface Correlation {\n  type: string;\n  strength: string;\n  coefficient: number;\n  confidence: number;\n  description: string;\n  insight: string;\n  recommendation: string;\n}\n\n/**\n * Pattern cluster\n */\nexport interface PatternCluster {\n  id: string;\n  name: string;\n  matchCount: number;\n  avgImpactScore: number;\n  avgChurnRisk: number;\n  trend: string;\n  examples: string[];\n}\n\n/**\n * Correlation analysis result\n */\nexport interface CorrelationAnalysis {\n  analysisId: string;\n  analyzedAt: string;\n  traceCount: number;\n  timeRange: { start: string; end: string };\n  overallHealthScore: number;\n  topInsights: string[];\n  recommendations: string[];\n  correlations: Correlation[];\n  patternClusters: PatternCluster[];\n}\n\n// ============================================================================\n// ROI ANALYTICS API CLIENT\n// ============================================================================\n\n/**\n * ROI Analytics API client for business impact analysis\n */\nexport const roiAnalytics = {\n  /**\n   * Get aggregated ROI summary for traces in date range\n   *\n   * @example\n   * ```typescript\n   * const summary = await roiAnalytics.summary({\n   *   startDate: '2024-01-01',\n   *   endDate: '2024-01-31',\n   * });\n   * console.log(`Revenue protected: $${summary.revenueProtected}`);\n   * ```\n   */\n  async summary(options: {\n    startDate?: string | Date;\n    endDate?: string | Date;\n    agentId?: string;\n  } = {}): Promise<ROISummary> {\n    const params = new URLSearchParams();\n    if (options.startDate) {\n      params.set('startDate', new Date(options.startDate).toISOString());\n    }\n    if (options.endDate) {\n      params.set('endDate', new Date(options.endDate).toISOString());\n    }\n    if (options.agentId) {\n      params.set('agentId', options.agentId);\n    }\n\n    const response = await apiRequest<ApiResponse<{ summary: ROISummary }>>(\n      `/analytics/roi/summary?${params.toString()}`,\n      { apiVersion: 'v1' }\n    );\n    return response.data!.summary;\n  },\n\n  /**\n   * Get ROI metrics for a specific agent\n   *\n   * @example\n   * ```typescript\n   * const agentROI = await roiAnalytics.byAgent('agent_123', {\n   *   startDate: '2024-01-01',\n   * });\n   * console.log(`Agent: ${agentROI.agent.name}`);\n   * console.log(`ROI: ${agentROI.roi.totalFinancialImpact}`);\n   * ```\n   */\n  async byAgent(\n    agentId: string,\n    options: {\n      startDate?: string | Date;\n      endDate?: string | Date;\n    } = {}\n  ): Promise<{\n    agent: { id: string; name: string; industry: string };\n    industryConfig: Partial<IndustryConfig>;\n    roi: ROIMetrics;\n    recentImpacts: Array<{\n      impactScore: number;\n      revenueRisk: number;\n      roiCategory: string;\n      totalFinancialImpact: number;\n    }>;\n  }> {\n    const params = new URLSearchParams();\n    if (options.startDate) {\n      params.set('startDate', new Date(options.startDate).toISOString());\n    }\n    if (options.endDate) {\n      params.set('endDate', new Date(options.endDate).toISOString());\n    }\n\n    return apiRequestWithData(\n      `/analytics/roi/by-agent/${agentId}?${params.toString()}`,\n      { apiVersion: 'v1' }\n    );\n  },\n\n  /**\n   * Get ROI trends over time\n   *\n   * @example\n   * ```typescript\n   * const trends = await roiAnalytics.trends({\n   *   startDate: '2024-01-01',\n   *   endDate: '2024-01-31',\n   * });\n   * for (const day of trends) {\n   *   console.log(`${day.date}: ${day.successRate}% success`);\n   * }\n   * ```\n   */\n  async trends(options: {\n    startDate?: string | Date;\n    endDate?: string | Date;\n    agentId?: string;\n  } = {}): Promise<TrendDataPoint[]> {\n    const params = new URLSearchParams();\n    if (options.startDate) {\n      params.set('startDate', new Date(options.startDate).toISOString());\n    }\n    if (options.endDate) {\n      params.set('endDate', new Date(options.endDate).toISOString());\n    }\n    if (options.agentId) {\n      params.set('agentId', options.agentId);\n    }\n\n    const response = await apiRequest<ApiResponse<{ trends: TrendDataPoint[] }>>(\n      `/analytics/roi/trends?${params.toString()}`,\n      { apiVersion: 'v1' }\n    );\n    return response.data!.trends;\n  },\n\n  /**\n   * Calculate ROI for a trace or provided message data\n   *\n   * @example\n   * ```typescript\n   * // Calculate for existing trace\n   * const impact = await roiAnalytics.calculate({\n   *   traceId: 'trace_abc123',\n   * });\n   *\n   * // Calculate for new data with custom config\n   * const impact = await roiAnalytics.calculate({\n   *   userMessage: 'Help me cancel my subscription',\n   *   agentResponse: 'I can help with that...',\n   *   industryConfig: { industry: 'saas', avgCustomerLTV: 10000 },\n   * });\n   * ```\n   */\n  async calculate(options: {\n    traceId?: string;\n    userMessage?: string;\n    agentResponse?: string;\n    industryConfig?: CustomIndustryConfig;\n  }): Promise<BusinessImpact> {\n    const response = await apiRequest<ApiResponse<{ impact: BusinessImpact }>>(\n      '/analytics/roi/calculate',\n      {\n        method: 'POST',\n        body: options,\n        apiVersion: 'v1',\n      }\n    );\n    return response.data!.impact;\n  },\n\n  /**\n   * Get available industry configurations\n   *\n   * @example\n   * ```typescript\n   * const industries = await roiAnalytics.industries();\n   * for (const config of industries) {\n   *   console.log(`${config.name}: $${config.avgCustomerLTV} LTV`);\n   * }\n   * ```\n   */\n  async industries(): Promise<IndustryConfig[]> {\n    const response = await apiRequest<ApiResponse<{ industries: IndustryConfig[] }>>(\n      '/analytics/roi/industries',\n      { apiVersion: 'v1' }\n    );\n    return response.data!.industries;\n  },\n\n  /**\n   * Get correlation analysis for traces\n   *\n   * @example\n   * ```typescript\n   * const analysis = await roiAnalytics.correlations({\n   *   startDate: '2024-01-01',\n   *   agentId: 'agent_123',\n   * });\n   * console.log(`Health score: ${analysis.overallHealthScore}`);\n   * for (const insight of analysis.topInsights) {\n   *   console.log(`- ${insight}`);\n   * }\n   * ```\n   */\n  async correlations(options: {\n    startDate?: string | Date;\n    endDate?: string | Date;\n    agentId?: string;\n  } = {}): Promise<CorrelationAnalysis> {\n    const params = new URLSearchParams();\n    if (options.startDate) {\n      params.set('startDate', new Date(options.startDate).toISOString());\n    }\n    if (options.endDate) {\n      params.set('endDate', new Date(options.endDate).toISOString());\n    }\n    if (options.agentId) {\n      params.set('agentId', options.agentId);\n    }\n\n    const response = await apiRequest<ApiResponse<{ analysis: CorrelationAnalysis }>>(\n      `/analytics/correlations?${params.toString()}`,\n      { apiVersion: 'v1' }\n    );\n    return response.data!.analysis;\n  },\n};\n\n// ============================================================================\n// HELPER FUNCTIONS\n// ============================================================================\n\n/**\n * Calculate estimated revenue at risk\n */\nexport function calculateRevenueAtRisk(\n  failureRate: number,\n  avgTransactionValue: number,\n  totalInteractions: number\n): number {\n  return failureRate * avgTransactionValue * totalInteractions;\n}\n\n/**\n * Calculate estimated savings from automation\n */\nexport function calculateAutomationSavings(\n  successfulInteractions: number,\n  avgSupportCost: number\n): number {\n  return successfulInteractions * avgSupportCost;\n}\n\n/**\n * Format currency for display\n */\nexport function formatCurrency(amount: number, currency = 'USD'): string {\n  return new Intl.NumberFormat('en-US', {\n    style: 'currency',\n    currency,\n  }).format(amount);\n}\n\n/**\n * Get ROI quality label\n */\nexport function getROIQuality(\n  totalFinancialImpact: number\n): 'excellent' | 'good' | 'moderate' | 'poor' {\n  if (totalFinancialImpact > 100000) return 'excellent';\n  if (totalFinancialImpact > 50000) return 'good';\n  if (totalFinancialImpact > 10000) return 'moderate';\n  return 'poor';\n}\n"]}
|