business-as-code 0.2.1 → 2.0.1
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/.turbo/turbo-build.log +5 -0
- package/CHANGELOG.md +9 -0
- package/IMPLEMENTATION.md +226 -0
- package/README.md +1133 -193
- package/dist/business.d.ts +62 -0
- package/dist/business.d.ts.map +1 -0
- package/dist/business.js +109 -0
- package/dist/business.js.map +1 -0
- package/dist/dollar.d.ts +60 -0
- package/dist/dollar.d.ts.map +1 -0
- package/dist/dollar.js +107 -0
- package/dist/dollar.js.map +1 -0
- package/dist/entities/assets.d.ts +21 -0
- package/dist/entities/assets.d.ts.map +1 -0
- package/dist/entities/assets.js +323 -0
- package/dist/entities/assets.js.map +1 -0
- package/dist/entities/business.d.ts +36 -0
- package/dist/entities/business.d.ts.map +1 -0
- package/dist/entities/business.js +370 -0
- package/dist/entities/business.js.map +1 -0
- package/dist/entities/communication.d.ts +21 -0
- package/dist/entities/communication.d.ts.map +1 -0
- package/dist/entities/communication.js +255 -0
- package/dist/entities/communication.js.map +1 -0
- package/dist/entities/customers.d.ts +58 -0
- package/dist/entities/customers.d.ts.map +1 -0
- package/dist/entities/customers.js +989 -0
- package/dist/entities/customers.js.map +1 -0
- package/dist/entities/financials.d.ts +59 -0
- package/dist/entities/financials.d.ts.map +1 -0
- package/dist/entities/financials.js +932 -0
- package/dist/entities/financials.js.map +1 -0
- package/dist/entities/goals.d.ts +58 -0
- package/dist/entities/goals.d.ts.map +1 -0
- package/dist/entities/goals.js +800 -0
- package/dist/entities/goals.js.map +1 -0
- package/dist/entities/index.d.ts +299 -0
- package/dist/entities/index.d.ts.map +1 -0
- package/dist/entities/index.js +198 -0
- package/dist/entities/index.js.map +1 -0
- package/dist/entities/legal.d.ts +21 -0
- package/dist/entities/legal.d.ts.map +1 -0
- package/dist/entities/legal.js +301 -0
- package/dist/entities/legal.js.map +1 -0
- package/dist/entities/market.d.ts +21 -0
- package/dist/entities/market.d.ts.map +1 -0
- package/dist/entities/market.js +301 -0
- package/dist/entities/market.js.map +1 -0
- package/dist/entities/marketing.d.ts +67 -0
- package/dist/entities/marketing.d.ts.map +1 -0
- package/dist/entities/marketing.js +1157 -0
- package/dist/entities/marketing.js.map +1 -0
- package/dist/entities/offerings.d.ts +51 -0
- package/dist/entities/offerings.d.ts.map +1 -0
- package/dist/entities/offerings.js +727 -0
- package/dist/entities/offerings.js.map +1 -0
- package/dist/entities/operations.d.ts +58 -0
- package/dist/entities/operations.d.ts.map +1 -0
- package/dist/entities/operations.js +787 -0
- package/dist/entities/operations.js.map +1 -0
- package/dist/entities/organization.d.ts +57 -0
- package/dist/entities/organization.d.ts.map +1 -0
- package/dist/entities/organization.js +807 -0
- package/dist/entities/organization.js.map +1 -0
- package/dist/entities/partnerships.d.ts +21 -0
- package/dist/entities/partnerships.d.ts.map +1 -0
- package/dist/entities/partnerships.js +300 -0
- package/dist/entities/partnerships.js.map +1 -0
- package/dist/entities/planning.d.ts +87 -0
- package/dist/entities/planning.d.ts.map +1 -0
- package/dist/entities/planning.js +271 -0
- package/dist/entities/planning.js.map +1 -0
- package/dist/entities/projects.d.ts +25 -0
- package/dist/entities/projects.d.ts.map +1 -0
- package/dist/entities/projects.js +349 -0
- package/dist/entities/projects.js.map +1 -0
- package/dist/entities/risk.d.ts +21 -0
- package/dist/entities/risk.d.ts.map +1 -0
- package/dist/entities/risk.js +293 -0
- package/dist/entities/risk.js.map +1 -0
- package/dist/entities/sales.d.ts +72 -0
- package/dist/entities/sales.d.ts.map +1 -0
- package/dist/entities/sales.js +1248 -0
- package/dist/entities/sales.js.map +1 -0
- package/dist/financials.d.ts +130 -0
- package/dist/financials.d.ts.map +1 -0
- package/dist/financials.js +297 -0
- package/dist/financials.js.map +1 -0
- package/dist/goals.d.ts +87 -0
- package/dist/goals.d.ts.map +1 -0
- package/dist/goals.js +215 -0
- package/dist/goals.js.map +1 -0
- package/dist/index.d.ts +97 -4
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +131 -1079
- package/dist/index.js.map +1 -1
- package/dist/kpis.d.ts +118 -0
- package/dist/kpis.d.ts.map +1 -0
- package/dist/kpis.js +232 -0
- package/dist/kpis.js.map +1 -0
- package/dist/metrics.d.ts +448 -0
- package/dist/metrics.d.ts.map +1 -0
- package/dist/metrics.js +325 -0
- package/dist/metrics.js.map +1 -0
- package/dist/okrs.d.ts +123 -0
- package/dist/okrs.d.ts.map +1 -0
- package/dist/okrs.js +269 -0
- package/dist/okrs.js.map +1 -0
- package/dist/organization.d.ts +585 -0
- package/dist/organization.d.ts.map +1 -0
- package/dist/organization.js +173 -0
- package/dist/organization.js.map +1 -0
- package/dist/process.d.ts +112 -0
- package/dist/process.d.ts.map +1 -0
- package/dist/process.js +241 -0
- package/dist/process.js.map +1 -0
- package/dist/product.d.ts +85 -0
- package/dist/product.d.ts.map +1 -0
- package/dist/product.js +145 -0
- package/dist/product.js.map +1 -0
- package/dist/queries.d.ts +304 -0
- package/dist/queries.d.ts.map +1 -0
- package/dist/queries.js +415 -0
- package/dist/queries.js.map +1 -0
- package/dist/roles.d.ts +340 -0
- package/dist/roles.d.ts.map +1 -0
- package/dist/roles.js +255 -0
- package/dist/roles.js.map +1 -0
- package/dist/service.d.ts +61 -0
- package/dist/service.d.ts.map +1 -0
- package/dist/service.js +140 -0
- package/dist/service.js.map +1 -0
- package/dist/types.d.ts +459 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +5 -0
- package/dist/types.js.map +1 -0
- package/dist/vision.d.ts +38 -0
- package/dist/vision.d.ts.map +1 -0
- package/dist/vision.js +68 -0
- package/dist/vision.js.map +1 -0
- package/dist/workflow.d.ts +115 -0
- package/dist/workflow.d.ts.map +1 -0
- package/dist/workflow.js +247 -0
- package/dist/workflow.js.map +1 -0
- package/examples/basic-usage.ts +307 -0
- package/package.json +19 -60
- package/src/business.ts +121 -0
- package/src/dollar.ts +132 -0
- package/src/entities/assets.ts +332 -0
- package/src/entities/business.ts +406 -0
- package/src/entities/communication.ts +264 -0
- package/src/entities/customers.ts +1072 -0
- package/src/entities/financials.ts +1011 -0
- package/src/entities/goals.ts +871 -0
- package/src/entities/index.ts +383 -0
- package/src/entities/legal.ts +310 -0
- package/src/entities/market.ts +310 -0
- package/src/entities/marketing.ts +1249 -0
- package/src/entities/offerings.ts +789 -0
- package/src/entities/operations.ts +861 -0
- package/src/entities/organization.ts +876 -0
- package/src/entities/partnerships.ts +309 -0
- package/src/entities/planning.ts +307 -0
- package/src/entities/projects.ts +360 -0
- package/src/entities/risk.ts +302 -0
- package/src/entities/sales.ts +1352 -0
- package/src/financials.ts +352 -0
- package/src/goals.ts +250 -0
- package/src/index.test.ts +336 -0
- package/src/index.ts +530 -0
- package/src/kpis.ts +275 -0
- package/src/metrics.ts +825 -0
- package/src/okrs.ts +325 -0
- package/src/organization.ts +909 -0
- package/src/process.ts +272 -0
- package/src/product.ts +178 -0
- package/src/queries.ts +767 -0
- package/src/roles.ts +686 -0
- package/src/service.ts +164 -0
- package/src/types.ts +493 -0
- package/src/vision.ts +88 -0
- package/src/workflow.ts +280 -0
- package/tsconfig.json +9 -0
- package/dist/loaders/index.d.ts +0 -174
- package/dist/loaders/index.js +0 -366
- package/dist/loaders/index.js.map +0 -1
- package/dist/schema/index.d.ts +0 -146
- package/dist/schema/index.js +0 -716
- package/dist/schema/index.js.map +0 -1
- package/dist/types-CJ9eGS_C.d.ts +0 -86
package/dist/queries.js
ADDED
|
@@ -0,0 +1,415 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Live Queries & Views
|
|
3
|
+
*
|
|
4
|
+
* Query definitions for real-time analytics against ai-database (ClickHouse-backed).
|
|
5
|
+
* These are NOT batch reports - they're live, composable queries that execute
|
|
6
|
+
* in real-time against a performant OLAP database.
|
|
7
|
+
*
|
|
8
|
+
* @packageDocumentation
|
|
9
|
+
*/
|
|
10
|
+
// =============================================================================
|
|
11
|
+
// Metric Definitions (Standard SaaS Metrics as Queries)
|
|
12
|
+
// =============================================================================
|
|
13
|
+
/**
|
|
14
|
+
* Standard SaaS metric dimensions
|
|
15
|
+
*/
|
|
16
|
+
export const StandardDimensions = {
|
|
17
|
+
// Time
|
|
18
|
+
date: { name: 'date', field: 'date', type: 'date', description: 'Event date' },
|
|
19
|
+
month: { name: 'month', field: 'date', type: 'date', granularity: 'month', description: 'Month' },
|
|
20
|
+
quarter: { name: 'quarter', field: 'date', type: 'date', granularity: 'quarter', description: 'Quarter' },
|
|
21
|
+
year: { name: 'year', field: 'date', type: 'date', granularity: 'year', description: 'Year' },
|
|
22
|
+
// Customer
|
|
23
|
+
customerId: { name: 'customerId', field: 'customer_id', type: 'string', description: 'Customer ID' },
|
|
24
|
+
customerSegment: { name: 'customerSegment', field: 'customer_segment', type: 'string', description: 'Customer segment' },
|
|
25
|
+
plan: { name: 'plan', field: 'plan', type: 'string', description: 'Subscription plan' },
|
|
26
|
+
cohort: { name: 'cohort', field: 'cohort', type: 'string', description: 'Customer cohort' },
|
|
27
|
+
// Product
|
|
28
|
+
productId: { name: 'productId', field: 'product_id', type: 'string', description: 'Product ID' },
|
|
29
|
+
productName: { name: 'productName', field: 'product_name', type: 'string', description: 'Product name' },
|
|
30
|
+
feature: { name: 'feature', field: 'feature', type: 'string', description: 'Feature name' },
|
|
31
|
+
// Geography
|
|
32
|
+
country: { name: 'country', field: 'country', type: 'string', description: 'Country' },
|
|
33
|
+
region: { name: 'region', field: 'region', type: 'string', description: 'Region' },
|
|
34
|
+
// Channel
|
|
35
|
+
channel: { name: 'channel', field: 'channel', type: 'string', description: 'Acquisition channel' },
|
|
36
|
+
source: { name: 'source', field: 'source', type: 'string', description: 'Traffic source' },
|
|
37
|
+
campaign: { name: 'campaign', field: 'campaign', type: 'string', description: 'Marketing campaign' },
|
|
38
|
+
};
|
|
39
|
+
/**
|
|
40
|
+
* Standard SaaS metric measures
|
|
41
|
+
*/
|
|
42
|
+
export const StandardMeasures = {
|
|
43
|
+
// Revenue
|
|
44
|
+
revenue: { name: 'revenue', field: 'revenue', aggregate: 'sum', type: 'currency', description: 'Total revenue' },
|
|
45
|
+
mrr: { name: 'mrr', field: 'mrr', aggregate: 'sum', type: 'currency', description: 'Monthly recurring revenue' },
|
|
46
|
+
newMrr: { name: 'newMrr', field: 'new_mrr', aggregate: 'sum', type: 'currency', description: 'New MRR' },
|
|
47
|
+
expansionMrr: { name: 'expansionMrr', field: 'expansion_mrr', aggregate: 'sum', type: 'currency', description: 'Expansion MRR' },
|
|
48
|
+
contractionMrr: { name: 'contractionMrr', field: 'contraction_mrr', aggregate: 'sum', type: 'currency', description: 'Contraction MRR' },
|
|
49
|
+
churnedMrr: { name: 'churnedMrr', field: 'churned_mrr', aggregate: 'sum', type: 'currency', description: 'Churned MRR' },
|
|
50
|
+
// Customers
|
|
51
|
+
customers: { name: 'customers', field: 'customer_id', aggregate: 'countDistinct', type: 'number', description: 'Unique customers' },
|
|
52
|
+
newCustomers: { name: 'newCustomers', field: 'new_customer_id', aggregate: 'countDistinct', type: 'number', description: 'New customers' },
|
|
53
|
+
churnedCustomers: { name: 'churnedCustomers', field: 'churned_customer_id', aggregate: 'countDistinct', type: 'number', description: 'Churned customers' },
|
|
54
|
+
// Usage
|
|
55
|
+
events: { name: 'events', field: 'event_id', aggregate: 'count', type: 'number', description: 'Event count' },
|
|
56
|
+
sessions: { name: 'sessions', field: 'session_id', aggregate: 'countDistinct', type: 'number', description: 'Unique sessions' },
|
|
57
|
+
activeUsers: { name: 'activeUsers', field: 'user_id', aggregate: 'countDistinct', type: 'number', description: 'Active users' },
|
|
58
|
+
// Costs
|
|
59
|
+
cogs: { name: 'cogs', field: 'cogs', aggregate: 'sum', type: 'currency', description: 'Cost of goods sold' },
|
|
60
|
+
salesSpend: { name: 'salesSpend', field: 'sales_spend', aggregate: 'sum', type: 'currency', description: 'Sales spend' },
|
|
61
|
+
marketingSpend: { name: 'marketingSpend', field: 'marketing_spend', aggregate: 'sum', type: 'currency', description: 'Marketing spend' },
|
|
62
|
+
};
|
|
63
|
+
/**
|
|
64
|
+
* Calculated SaaS metrics
|
|
65
|
+
*/
|
|
66
|
+
export const CalculatedMetrics = {
|
|
67
|
+
// Revenue metrics
|
|
68
|
+
arr: {
|
|
69
|
+
name: 'arr',
|
|
70
|
+
expression: 'mrr * 12',
|
|
71
|
+
measures: ['mrr'],
|
|
72
|
+
type: 'currency',
|
|
73
|
+
description: 'Annual recurring revenue',
|
|
74
|
+
},
|
|
75
|
+
netNewMrr: {
|
|
76
|
+
name: 'netNewMrr',
|
|
77
|
+
expression: 'newMrr + expansionMrr - contractionMrr - churnedMrr',
|
|
78
|
+
measures: ['newMrr', 'expansionMrr', 'contractionMrr', 'churnedMrr'],
|
|
79
|
+
type: 'currency',
|
|
80
|
+
description: 'Net new MRR',
|
|
81
|
+
},
|
|
82
|
+
arpu: {
|
|
83
|
+
name: 'arpu',
|
|
84
|
+
expression: 'mrr / customers',
|
|
85
|
+
measures: ['mrr', 'customers'],
|
|
86
|
+
type: 'currency',
|
|
87
|
+
description: 'Average revenue per user',
|
|
88
|
+
},
|
|
89
|
+
// Margin metrics
|
|
90
|
+
grossProfit: {
|
|
91
|
+
name: 'grossProfit',
|
|
92
|
+
expression: 'revenue - cogs',
|
|
93
|
+
measures: ['revenue', 'cogs'],
|
|
94
|
+
type: 'currency',
|
|
95
|
+
description: 'Gross profit',
|
|
96
|
+
},
|
|
97
|
+
grossMargin: {
|
|
98
|
+
name: 'grossMargin',
|
|
99
|
+
expression: '(revenue - cogs) / revenue * 100',
|
|
100
|
+
measures: ['revenue', 'cogs'],
|
|
101
|
+
type: 'percent',
|
|
102
|
+
description: 'Gross margin percentage',
|
|
103
|
+
},
|
|
104
|
+
// Efficiency metrics
|
|
105
|
+
cac: {
|
|
106
|
+
name: 'cac',
|
|
107
|
+
expression: '(salesSpend + marketingSpend) / newCustomers',
|
|
108
|
+
measures: ['salesSpend', 'marketingSpend', 'newCustomers'],
|
|
109
|
+
type: 'currency',
|
|
110
|
+
description: 'Customer acquisition cost',
|
|
111
|
+
},
|
|
112
|
+
ltv: {
|
|
113
|
+
name: 'ltv',
|
|
114
|
+
expression: 'arpu * grossMargin / 100 / churnRate',
|
|
115
|
+
measures: ['arpu', 'grossMargin'],
|
|
116
|
+
type: 'currency',
|
|
117
|
+
description: 'Customer lifetime value',
|
|
118
|
+
},
|
|
119
|
+
ltvCacRatio: {
|
|
120
|
+
name: 'ltvCacRatio',
|
|
121
|
+
expression: 'ltv / cac',
|
|
122
|
+
measures: ['ltv', 'cac'],
|
|
123
|
+
type: 'number',
|
|
124
|
+
description: 'LTV:CAC ratio',
|
|
125
|
+
},
|
|
126
|
+
// Churn metrics
|
|
127
|
+
customerChurnRate: {
|
|
128
|
+
name: 'customerChurnRate',
|
|
129
|
+
expression: 'churnedCustomers / customers * 100',
|
|
130
|
+
measures: ['churnedCustomers', 'customers'],
|
|
131
|
+
type: 'percent',
|
|
132
|
+
description: 'Customer churn rate',
|
|
133
|
+
},
|
|
134
|
+
revenueChurnRate: {
|
|
135
|
+
name: 'revenueChurnRate',
|
|
136
|
+
expression: 'churnedMrr / mrr * 100',
|
|
137
|
+
measures: ['churnedMrr', 'mrr'],
|
|
138
|
+
type: 'percent',
|
|
139
|
+
description: 'Revenue churn rate',
|
|
140
|
+
},
|
|
141
|
+
nrr: {
|
|
142
|
+
name: 'nrr',
|
|
143
|
+
expression: '(mrr + expansionMrr - contractionMrr - churnedMrr) / mrr * 100',
|
|
144
|
+
measures: ['mrr', 'expansionMrr', 'contractionMrr', 'churnedMrr'],
|
|
145
|
+
type: 'percent',
|
|
146
|
+
description: 'Net revenue retention',
|
|
147
|
+
},
|
|
148
|
+
// Growth metrics
|
|
149
|
+
quickRatio: {
|
|
150
|
+
name: 'quickRatio',
|
|
151
|
+
expression: '(newMrr + expansionMrr) / (contractionMrr + churnedMrr)',
|
|
152
|
+
measures: ['newMrr', 'expansionMrr', 'contractionMrr', 'churnedMrr'],
|
|
153
|
+
type: 'number',
|
|
154
|
+
description: 'SaaS Quick Ratio',
|
|
155
|
+
},
|
|
156
|
+
magicNumber: {
|
|
157
|
+
name: 'magicNumber',
|
|
158
|
+
expression: 'netNewMrr * 12 / (salesSpend + marketingSpend)',
|
|
159
|
+
measures: ['netNewMrr', 'salesSpend', 'marketingSpend'],
|
|
160
|
+
type: 'number',
|
|
161
|
+
description: 'Magic Number',
|
|
162
|
+
},
|
|
163
|
+
};
|
|
164
|
+
// =============================================================================
|
|
165
|
+
// Query Builder Functions
|
|
166
|
+
// =============================================================================
|
|
167
|
+
/**
|
|
168
|
+
* Create a query
|
|
169
|
+
*/
|
|
170
|
+
export function query(name, source) {
|
|
171
|
+
return new QueryBuilder(name, source);
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Fluent query builder
|
|
175
|
+
*/
|
|
176
|
+
export class QueryBuilder {
|
|
177
|
+
_query;
|
|
178
|
+
constructor(name, source) {
|
|
179
|
+
this._query = { name, source };
|
|
180
|
+
}
|
|
181
|
+
describe(description) {
|
|
182
|
+
this._query.description = description;
|
|
183
|
+
return this;
|
|
184
|
+
}
|
|
185
|
+
dimensions(...dims) {
|
|
186
|
+
this._query.dimensions = dims;
|
|
187
|
+
return this;
|
|
188
|
+
}
|
|
189
|
+
measures(...measures) {
|
|
190
|
+
this._query.measures = measures;
|
|
191
|
+
return this;
|
|
192
|
+
}
|
|
193
|
+
filter(field, operator, value) {
|
|
194
|
+
if (!this._query.filters)
|
|
195
|
+
this._query.filters = [];
|
|
196
|
+
this._query.filters.push({ field, operator, value });
|
|
197
|
+
return this;
|
|
198
|
+
}
|
|
199
|
+
where(filters) {
|
|
200
|
+
this._query.filters = filters;
|
|
201
|
+
return this;
|
|
202
|
+
}
|
|
203
|
+
timeRange(field, start, end, granularity) {
|
|
204
|
+
this._query.timeRange = { field, start, end, granularity };
|
|
205
|
+
return this;
|
|
206
|
+
}
|
|
207
|
+
last(duration, field = 'date') {
|
|
208
|
+
this._query.timeRange = { field, start: `-${duration}` };
|
|
209
|
+
return this;
|
|
210
|
+
}
|
|
211
|
+
sort(field, direction = 'desc') {
|
|
212
|
+
if (!this._query.sort)
|
|
213
|
+
this._query.sort = [];
|
|
214
|
+
this._query.sort.push({ field, direction });
|
|
215
|
+
return this;
|
|
216
|
+
}
|
|
217
|
+
limit(n) {
|
|
218
|
+
this._query.limit = n;
|
|
219
|
+
return this;
|
|
220
|
+
}
|
|
221
|
+
offset(n) {
|
|
222
|
+
this._query.offset = n;
|
|
223
|
+
return this;
|
|
224
|
+
}
|
|
225
|
+
tags(...tags) {
|
|
226
|
+
this._query.tags = tags;
|
|
227
|
+
return this;
|
|
228
|
+
}
|
|
229
|
+
owner(owner) {
|
|
230
|
+
this._query.owner = owner;
|
|
231
|
+
return this;
|
|
232
|
+
}
|
|
233
|
+
build() {
|
|
234
|
+
return { ...this._query };
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
// =============================================================================
|
|
238
|
+
// Pre-built SaaS Metric Queries
|
|
239
|
+
// =============================================================================
|
|
240
|
+
/**
|
|
241
|
+
* MRR Overview query
|
|
242
|
+
*/
|
|
243
|
+
export const MrrOverview = query('mrr_overview', 'revenue_events')
|
|
244
|
+
.describe('Monthly recurring revenue breakdown')
|
|
245
|
+
.dimensions('month')
|
|
246
|
+
.measures('mrr', 'newMrr', 'expansionMrr', 'contractionMrr', 'churnedMrr', 'netNewMrr')
|
|
247
|
+
.last('12m')
|
|
248
|
+
.sort('month', 'asc')
|
|
249
|
+
.build();
|
|
250
|
+
/**
|
|
251
|
+
* ARR by segment query
|
|
252
|
+
*/
|
|
253
|
+
export const ArrBySegment = query('arr_by_segment', 'revenue_events')
|
|
254
|
+
.describe('Annual recurring revenue by customer segment')
|
|
255
|
+
.dimensions('customerSegment')
|
|
256
|
+
.measures('arr', 'customers', 'arpu')
|
|
257
|
+
.last('1m')
|
|
258
|
+
.sort('arr', 'desc')
|
|
259
|
+
.build();
|
|
260
|
+
/**
|
|
261
|
+
* Customer cohort retention query
|
|
262
|
+
*/
|
|
263
|
+
export const CohortRetention = query('cohort_retention', 'customer_events')
|
|
264
|
+
.describe('Customer retention by signup cohort')
|
|
265
|
+
.dimensions('cohort', 'month')
|
|
266
|
+
.measures('customers', 'mrr')
|
|
267
|
+
.last('12m')
|
|
268
|
+
.sort('cohort', 'asc')
|
|
269
|
+
.build();
|
|
270
|
+
/**
|
|
271
|
+
* Unit economics query
|
|
272
|
+
*/
|
|
273
|
+
export const UnitEconomics = query('unit_economics', 'financial_events')
|
|
274
|
+
.describe('Key unit economics metrics')
|
|
275
|
+
.dimensions('month')
|
|
276
|
+
.measures('cac', 'ltv', 'ltvCacRatio', 'arpu', 'customerChurnRate')
|
|
277
|
+
.last('12m')
|
|
278
|
+
.sort('month', 'asc')
|
|
279
|
+
.build();
|
|
280
|
+
/**
|
|
281
|
+
* Revenue by channel query
|
|
282
|
+
*/
|
|
283
|
+
export const RevenueByChannel = query('revenue_by_channel', 'revenue_events')
|
|
284
|
+
.describe('Revenue breakdown by acquisition channel')
|
|
285
|
+
.dimensions('channel')
|
|
286
|
+
.measures('mrr', 'newCustomers', 'cac')
|
|
287
|
+
.last('3m')
|
|
288
|
+
.sort('mrr', 'desc')
|
|
289
|
+
.build();
|
|
290
|
+
/**
|
|
291
|
+
* Growth metrics query
|
|
292
|
+
*/
|
|
293
|
+
export const GrowthMetrics = query('growth_metrics', 'financial_events')
|
|
294
|
+
.describe('Key growth and efficiency metrics')
|
|
295
|
+
.dimensions('month')
|
|
296
|
+
.measures('mrr', 'netNewMrr', 'quickRatio', 'nrr', 'magicNumber')
|
|
297
|
+
.last('12m')
|
|
298
|
+
.sort('month', 'asc')
|
|
299
|
+
.build();
|
|
300
|
+
// =============================================================================
|
|
301
|
+
// View Builder
|
|
302
|
+
// =============================================================================
|
|
303
|
+
/**
|
|
304
|
+
* Create a view from a query
|
|
305
|
+
*/
|
|
306
|
+
export function view(name, queryDef) {
|
|
307
|
+
return new ViewBuilder(name, queryDef);
|
|
308
|
+
}
|
|
309
|
+
/**
|
|
310
|
+
* Fluent view builder
|
|
311
|
+
*/
|
|
312
|
+
export class ViewBuilder {
|
|
313
|
+
_view;
|
|
314
|
+
constructor(name, queryDef) {
|
|
315
|
+
this._view = { name, query: queryDef };
|
|
316
|
+
}
|
|
317
|
+
describe(description) {
|
|
318
|
+
this._view.description = description;
|
|
319
|
+
return this;
|
|
320
|
+
}
|
|
321
|
+
materialize(refreshInterval, retention) {
|
|
322
|
+
this._view.materialized = true;
|
|
323
|
+
this._view.refreshInterval = refreshInterval;
|
|
324
|
+
this._view.retention = retention;
|
|
325
|
+
return this;
|
|
326
|
+
}
|
|
327
|
+
public() {
|
|
328
|
+
this._view.public = true;
|
|
329
|
+
return this;
|
|
330
|
+
}
|
|
331
|
+
owner(owner) {
|
|
332
|
+
this._view.owner = owner;
|
|
333
|
+
return this;
|
|
334
|
+
}
|
|
335
|
+
tags(...tags) {
|
|
336
|
+
this._view.tags = tags;
|
|
337
|
+
return this;
|
|
338
|
+
}
|
|
339
|
+
build() {
|
|
340
|
+
return { ...this._view };
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
// =============================================================================
|
|
344
|
+
// Dashboard Builder
|
|
345
|
+
// =============================================================================
|
|
346
|
+
/**
|
|
347
|
+
* Create a dashboard
|
|
348
|
+
*/
|
|
349
|
+
export function dashboard(name) {
|
|
350
|
+
return new DashboardBuilder(name);
|
|
351
|
+
}
|
|
352
|
+
/**
|
|
353
|
+
* Fluent dashboard builder
|
|
354
|
+
*/
|
|
355
|
+
export class DashboardBuilder {
|
|
356
|
+
_dashboard;
|
|
357
|
+
constructor(name) {
|
|
358
|
+
this._dashboard = { name, views: [] };
|
|
359
|
+
}
|
|
360
|
+
describe(description) {
|
|
361
|
+
this._dashboard.description = description;
|
|
362
|
+
return this;
|
|
363
|
+
}
|
|
364
|
+
add(viewDef, options) {
|
|
365
|
+
this._dashboard.views.push(viewDef);
|
|
366
|
+
if (options && this._dashboard.layout) {
|
|
367
|
+
this._dashboard.layout.items.push({
|
|
368
|
+
viewName: viewDef.name,
|
|
369
|
+
x: options.x || 0,
|
|
370
|
+
y: options.y || 0,
|
|
371
|
+
width: options.width || 1,
|
|
372
|
+
height: options.height || 1,
|
|
373
|
+
visualization: options.visualization,
|
|
374
|
+
});
|
|
375
|
+
}
|
|
376
|
+
return this;
|
|
377
|
+
}
|
|
378
|
+
layout(columns, rows) {
|
|
379
|
+
this._dashboard.layout = { columns, rows, items: [] };
|
|
380
|
+
return this;
|
|
381
|
+
}
|
|
382
|
+
refresh(interval) {
|
|
383
|
+
this._dashboard.refreshInterval = interval;
|
|
384
|
+
return this;
|
|
385
|
+
}
|
|
386
|
+
owner(owner) {
|
|
387
|
+
this._dashboard.owner = owner;
|
|
388
|
+
return this;
|
|
389
|
+
}
|
|
390
|
+
tags(...tags) {
|
|
391
|
+
this._dashboard.tags = tags;
|
|
392
|
+
return this;
|
|
393
|
+
}
|
|
394
|
+
build() {
|
|
395
|
+
return { ...this._dashboard };
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
// =============================================================================
|
|
399
|
+
// Pre-built Dashboards
|
|
400
|
+
// =============================================================================
|
|
401
|
+
/**
|
|
402
|
+
* Executive SaaS Dashboard
|
|
403
|
+
*/
|
|
404
|
+
export const ExecutiveDashboard = dashboard('executive')
|
|
405
|
+
.describe('Executive overview of key SaaS metrics')
|
|
406
|
+
.layout(4, 3)
|
|
407
|
+
.add(view('mrr', MrrOverview).build(), { x: 0, y: 0, width: 2, height: 1, visualization: 'trend' })
|
|
408
|
+
.add(view('arr_segments', ArrBySegment).build(), { x: 2, y: 0, width: 2, height: 1, visualization: 'bar' })
|
|
409
|
+
.add(view('unit_econ', UnitEconomics).build(), { x: 0, y: 1, width: 2, height: 1, visualization: 'table' })
|
|
410
|
+
.add(view('growth', GrowthMetrics).build(), { x: 2, y: 1, width: 2, height: 1, visualization: 'line' })
|
|
411
|
+
.add(view('cohorts', CohortRetention).build(), { x: 0, y: 2, width: 4, height: 1, visualization: 'cohort' })
|
|
412
|
+
.refresh('5m')
|
|
413
|
+
.tags('executive', 'saas', 'metrics')
|
|
414
|
+
.build();
|
|
415
|
+
//# sourceMappingURL=queries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queries.js","sourceRoot":"","sources":["../src/queries.ts"],"names":[],"mappings":"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"}
|