business-as-code 0.2.1 → 2.0.2

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.
Files changed (190) hide show
  1. package/.turbo/turbo-build.log +5 -0
  2. package/CHANGELOG.md +17 -0
  3. package/IMPLEMENTATION.md +226 -0
  4. package/README.md +1133 -193
  5. package/dist/business.d.ts +62 -0
  6. package/dist/business.d.ts.map +1 -0
  7. package/dist/business.js +109 -0
  8. package/dist/business.js.map +1 -0
  9. package/dist/dollar.d.ts +60 -0
  10. package/dist/dollar.d.ts.map +1 -0
  11. package/dist/dollar.js +107 -0
  12. package/dist/dollar.js.map +1 -0
  13. package/dist/entities/assets.d.ts +21 -0
  14. package/dist/entities/assets.d.ts.map +1 -0
  15. package/dist/entities/assets.js +323 -0
  16. package/dist/entities/assets.js.map +1 -0
  17. package/dist/entities/business.d.ts +36 -0
  18. package/dist/entities/business.d.ts.map +1 -0
  19. package/dist/entities/business.js +370 -0
  20. package/dist/entities/business.js.map +1 -0
  21. package/dist/entities/communication.d.ts +21 -0
  22. package/dist/entities/communication.d.ts.map +1 -0
  23. package/dist/entities/communication.js +255 -0
  24. package/dist/entities/communication.js.map +1 -0
  25. package/dist/entities/customers.d.ts +58 -0
  26. package/dist/entities/customers.d.ts.map +1 -0
  27. package/dist/entities/customers.js +989 -0
  28. package/dist/entities/customers.js.map +1 -0
  29. package/dist/entities/financials.d.ts +59 -0
  30. package/dist/entities/financials.d.ts.map +1 -0
  31. package/dist/entities/financials.js +932 -0
  32. package/dist/entities/financials.js.map +1 -0
  33. package/dist/entities/goals.d.ts +58 -0
  34. package/dist/entities/goals.d.ts.map +1 -0
  35. package/dist/entities/goals.js +800 -0
  36. package/dist/entities/goals.js.map +1 -0
  37. package/dist/entities/index.d.ts +299 -0
  38. package/dist/entities/index.d.ts.map +1 -0
  39. package/dist/entities/index.js +198 -0
  40. package/dist/entities/index.js.map +1 -0
  41. package/dist/entities/legal.d.ts +21 -0
  42. package/dist/entities/legal.d.ts.map +1 -0
  43. package/dist/entities/legal.js +301 -0
  44. package/dist/entities/legal.js.map +1 -0
  45. package/dist/entities/market.d.ts +21 -0
  46. package/dist/entities/market.d.ts.map +1 -0
  47. package/dist/entities/market.js +301 -0
  48. package/dist/entities/market.js.map +1 -0
  49. package/dist/entities/marketing.d.ts +67 -0
  50. package/dist/entities/marketing.d.ts.map +1 -0
  51. package/dist/entities/marketing.js +1157 -0
  52. package/dist/entities/marketing.js.map +1 -0
  53. package/dist/entities/offerings.d.ts +51 -0
  54. package/dist/entities/offerings.d.ts.map +1 -0
  55. package/dist/entities/offerings.js +727 -0
  56. package/dist/entities/offerings.js.map +1 -0
  57. package/dist/entities/operations.d.ts +58 -0
  58. package/dist/entities/operations.d.ts.map +1 -0
  59. package/dist/entities/operations.js +787 -0
  60. package/dist/entities/operations.js.map +1 -0
  61. package/dist/entities/organization.d.ts +57 -0
  62. package/dist/entities/organization.d.ts.map +1 -0
  63. package/dist/entities/organization.js +807 -0
  64. package/dist/entities/organization.js.map +1 -0
  65. package/dist/entities/partnerships.d.ts +21 -0
  66. package/dist/entities/partnerships.d.ts.map +1 -0
  67. package/dist/entities/partnerships.js +300 -0
  68. package/dist/entities/partnerships.js.map +1 -0
  69. package/dist/entities/planning.d.ts +87 -0
  70. package/dist/entities/planning.d.ts.map +1 -0
  71. package/dist/entities/planning.js +271 -0
  72. package/dist/entities/planning.js.map +1 -0
  73. package/dist/entities/projects.d.ts +25 -0
  74. package/dist/entities/projects.d.ts.map +1 -0
  75. package/dist/entities/projects.js +349 -0
  76. package/dist/entities/projects.js.map +1 -0
  77. package/dist/entities/risk.d.ts +21 -0
  78. package/dist/entities/risk.d.ts.map +1 -0
  79. package/dist/entities/risk.js +293 -0
  80. package/dist/entities/risk.js.map +1 -0
  81. package/dist/entities/sales.d.ts +72 -0
  82. package/dist/entities/sales.d.ts.map +1 -0
  83. package/dist/entities/sales.js +1248 -0
  84. package/dist/entities/sales.js.map +1 -0
  85. package/dist/financials.d.ts +130 -0
  86. package/dist/financials.d.ts.map +1 -0
  87. package/dist/financials.js +297 -0
  88. package/dist/financials.js.map +1 -0
  89. package/dist/goals.d.ts +87 -0
  90. package/dist/goals.d.ts.map +1 -0
  91. package/dist/goals.js +215 -0
  92. package/dist/goals.js.map +1 -0
  93. package/dist/index.d.ts +97 -4
  94. package/dist/index.d.ts.map +1 -0
  95. package/dist/index.js +131 -1079
  96. package/dist/index.js.map +1 -1
  97. package/dist/kpis.d.ts +118 -0
  98. package/dist/kpis.d.ts.map +1 -0
  99. package/dist/kpis.js +232 -0
  100. package/dist/kpis.js.map +1 -0
  101. package/dist/metrics.d.ts +448 -0
  102. package/dist/metrics.d.ts.map +1 -0
  103. package/dist/metrics.js +325 -0
  104. package/dist/metrics.js.map +1 -0
  105. package/dist/okrs.d.ts +123 -0
  106. package/dist/okrs.d.ts.map +1 -0
  107. package/dist/okrs.js +269 -0
  108. package/dist/okrs.js.map +1 -0
  109. package/dist/organization.d.ts +585 -0
  110. package/dist/organization.d.ts.map +1 -0
  111. package/dist/organization.js +173 -0
  112. package/dist/organization.js.map +1 -0
  113. package/dist/process.d.ts +112 -0
  114. package/dist/process.d.ts.map +1 -0
  115. package/dist/process.js +241 -0
  116. package/dist/process.js.map +1 -0
  117. package/dist/product.d.ts +85 -0
  118. package/dist/product.d.ts.map +1 -0
  119. package/dist/product.js +145 -0
  120. package/dist/product.js.map +1 -0
  121. package/dist/queries.d.ts +304 -0
  122. package/dist/queries.d.ts.map +1 -0
  123. package/dist/queries.js +415 -0
  124. package/dist/queries.js.map +1 -0
  125. package/dist/roles.d.ts +340 -0
  126. package/dist/roles.d.ts.map +1 -0
  127. package/dist/roles.js +255 -0
  128. package/dist/roles.js.map +1 -0
  129. package/dist/service.d.ts +61 -0
  130. package/dist/service.d.ts.map +1 -0
  131. package/dist/service.js +140 -0
  132. package/dist/service.js.map +1 -0
  133. package/dist/types.d.ts +459 -0
  134. package/dist/types.d.ts.map +1 -0
  135. package/dist/types.js +5 -0
  136. package/dist/types.js.map +1 -0
  137. package/dist/vision.d.ts +38 -0
  138. package/dist/vision.d.ts.map +1 -0
  139. package/dist/vision.js +68 -0
  140. package/dist/vision.js.map +1 -0
  141. package/dist/workflow.d.ts +115 -0
  142. package/dist/workflow.d.ts.map +1 -0
  143. package/dist/workflow.js +247 -0
  144. package/dist/workflow.js.map +1 -0
  145. package/examples/basic-usage.ts +307 -0
  146. package/package.json +19 -60
  147. package/src/business.ts +121 -0
  148. package/src/dollar.ts +132 -0
  149. package/src/entities/assets.ts +332 -0
  150. package/src/entities/business.ts +406 -0
  151. package/src/entities/communication.ts +264 -0
  152. package/src/entities/customers.ts +1072 -0
  153. package/src/entities/financials.ts +1011 -0
  154. package/src/entities/goals.ts +871 -0
  155. package/src/entities/index.ts +383 -0
  156. package/src/entities/legal.ts +310 -0
  157. package/src/entities/market.ts +310 -0
  158. package/src/entities/marketing.ts +1249 -0
  159. package/src/entities/offerings.ts +789 -0
  160. package/src/entities/operations.ts +861 -0
  161. package/src/entities/organization.ts +876 -0
  162. package/src/entities/partnerships.ts +309 -0
  163. package/src/entities/planning.ts +307 -0
  164. package/src/entities/projects.ts +360 -0
  165. package/src/entities/risk.ts +302 -0
  166. package/src/entities/sales.ts +1352 -0
  167. package/src/financials.ts +352 -0
  168. package/src/goals.ts +250 -0
  169. package/src/index.test.ts +336 -0
  170. package/src/index.ts +530 -0
  171. package/src/kpis.ts +275 -0
  172. package/src/metrics.ts +825 -0
  173. package/src/okrs.ts +325 -0
  174. package/src/organization.ts +909 -0
  175. package/src/process.ts +272 -0
  176. package/src/product.ts +178 -0
  177. package/src/queries.ts +767 -0
  178. package/src/roles.ts +686 -0
  179. package/src/service.ts +164 -0
  180. package/src/types.ts +493 -0
  181. package/src/vision.ts +88 -0
  182. package/src/workflow.ts +280 -0
  183. package/tsconfig.json +9 -0
  184. package/dist/loaders/index.d.ts +0 -174
  185. package/dist/loaders/index.js +0 -366
  186. package/dist/loaders/index.js.map +0 -1
  187. package/dist/schema/index.d.ts +0 -146
  188. package/dist/schema/index.js +0 -716
  189. package/dist/schema/index.js.map +0 -1
  190. package/dist/types-CJ9eGS_C.d.ts +0 -86
package/src/kpis.ts ADDED
@@ -0,0 +1,275 @@
1
+ /**
2
+ * Key Performance Indicators (KPIs) management
3
+ */
4
+
5
+ import type { KPIDefinition, TimePeriod } from './types.js'
6
+
7
+ /**
8
+ * Define Key Performance Indicators for tracking business metrics
9
+ *
10
+ * @example
11
+ * ```ts
12
+ * const businessKPIs = kpis([
13
+ * {
14
+ * name: 'Monthly Recurring Revenue',
15
+ * description: 'Total predictable revenue per month',
16
+ * category: 'financial',
17
+ * unit: 'USD',
18
+ * target: 100000,
19
+ * current: 85000,
20
+ * frequency: 'monthly',
21
+ * dataSource: 'Billing System',
22
+ * formula: 'SUM(active_subscriptions.price)',
23
+ * },
24
+ * {
25
+ * name: 'Customer Churn Rate',
26
+ * description: 'Percentage of customers lost per month',
27
+ * category: 'customer',
28
+ * unit: 'percent',
29
+ * target: 5,
30
+ * current: 3.2,
31
+ * frequency: 'monthly',
32
+ * dataSource: 'CRM',
33
+ * formula: '(churned_customers / total_customers) * 100',
34
+ * },
35
+ * {
36
+ * name: 'Net Promoter Score',
37
+ * description: 'Customer satisfaction and loyalty metric',
38
+ * category: 'customer',
39
+ * unit: 'score',
40
+ * target: 50,
41
+ * current: 48,
42
+ * frequency: 'quarterly',
43
+ * dataSource: 'Survey Platform',
44
+ * },
45
+ * ])
46
+ * ```
47
+ */
48
+ export function kpis(definitions: KPIDefinition[]): KPIDefinition[] {
49
+ return definitions.map(kpi => validateAndNormalizeKPI(kpi))
50
+ }
51
+
52
+ /**
53
+ * Define a single KPI
54
+ */
55
+ export function kpi(definition: KPIDefinition): KPIDefinition {
56
+ return validateAndNormalizeKPI(definition)
57
+ }
58
+
59
+ /**
60
+ * Validate and normalize a KPI definition
61
+ */
62
+ function validateAndNormalizeKPI(kpi: KPIDefinition): KPIDefinition {
63
+ if (!kpi.name) {
64
+ throw new Error('KPI name is required')
65
+ }
66
+
67
+ return {
68
+ ...kpi,
69
+ category: kpi.category || 'operations',
70
+ frequency: kpi.frequency || 'monthly',
71
+ metadata: kpi.metadata || {},
72
+ }
73
+ }
74
+
75
+ /**
76
+ * Calculate KPI achievement percentage
77
+ */
78
+ export function calculateAchievement(kpi: KPIDefinition): number {
79
+ if (kpi.target === undefined || kpi.current === undefined) return 0
80
+ if (kpi.target === 0) return 100
81
+ return (kpi.current / kpi.target) * 100
82
+ }
83
+
84
+ /**
85
+ * Check if KPI meets target
86
+ */
87
+ export function meetsTarget(kpi: KPIDefinition): boolean {
88
+ if (kpi.target === undefined || kpi.current === undefined) return false
89
+
90
+ // For metrics where lower is better (like churn rate)
91
+ const lowerIsBetter = ['churn', 'cost', 'time', 'error', 'downtime'].some(term =>
92
+ kpi.name.toLowerCase().includes(term)
93
+ )
94
+
95
+ if (lowerIsBetter) {
96
+ return kpi.current <= kpi.target
97
+ }
98
+
99
+ return kpi.current >= kpi.target
100
+ }
101
+
102
+ /**
103
+ * Update KPI current value
104
+ */
105
+ export function updateCurrent(kpi: KPIDefinition, value: number): KPIDefinition {
106
+ return {
107
+ ...kpi,
108
+ current: value,
109
+ }
110
+ }
111
+
112
+ /**
113
+ * Update KPI target
114
+ */
115
+ export function updateTarget(kpi: KPIDefinition, target: number): KPIDefinition {
116
+ return {
117
+ ...kpi,
118
+ target,
119
+ }
120
+ }
121
+
122
+ /**
123
+ * Get KPIs by category
124
+ */
125
+ export function getKPIsByCategory(
126
+ kpis: KPIDefinition[],
127
+ category: KPIDefinition['category']
128
+ ): KPIDefinition[] {
129
+ return kpis.filter(k => k.category === category)
130
+ }
131
+
132
+ /**
133
+ * Get KPIs by frequency
134
+ */
135
+ export function getKPIsByFrequency(kpis: KPIDefinition[], frequency: TimePeriod): KPIDefinition[] {
136
+ return kpis.filter(k => k.frequency === frequency)
137
+ }
138
+
139
+ /**
140
+ * Get KPIs that meet their targets
141
+ */
142
+ export function getKPIsOnTarget(kpis: KPIDefinition[]): KPIDefinition[] {
143
+ return kpis.filter(meetsTarget)
144
+ }
145
+
146
+ /**
147
+ * Get KPIs that don't meet their targets
148
+ */
149
+ export function getKPIsOffTarget(kpis: KPIDefinition[]): KPIDefinition[] {
150
+ return kpis.filter(kpi => !meetsTarget(kpi))
151
+ }
152
+
153
+ /**
154
+ * Calculate overall KPI health score (0-100)
155
+ */
156
+ export function calculateHealthScore(kpis: KPIDefinition[]): number {
157
+ if (kpis.length === 0) return 0
158
+
159
+ const onTarget = getKPIsOnTarget(kpis).length
160
+ return (onTarget / kpis.length) * 100
161
+ }
162
+
163
+ /**
164
+ * Group KPIs by category
165
+ */
166
+ export function groupByCategory(kpis: KPIDefinition[]): Map<string, KPIDefinition[]> {
167
+ const groups = new Map<string, KPIDefinition[]>()
168
+
169
+ for (const kpi of kpis) {
170
+ const category = kpi.category || 'other'
171
+ const existing = groups.get(category) || []
172
+ groups.set(category, [...existing, kpi])
173
+ }
174
+
175
+ return groups
176
+ }
177
+
178
+ /**
179
+ * Calculate variance from target
180
+ */
181
+ export function calculateVariance(kpi: KPIDefinition): number {
182
+ if (kpi.target === undefined || kpi.current === undefined) return 0
183
+ return kpi.current - kpi.target
184
+ }
185
+
186
+ /**
187
+ * Calculate variance percentage from target
188
+ */
189
+ export function calculateVariancePercentage(kpi: KPIDefinition): number {
190
+ if (kpi.target === undefined || kpi.current === undefined) return 0
191
+ if (kpi.target === 0) return 0
192
+ return ((kpi.current - kpi.target) / kpi.target) * 100
193
+ }
194
+
195
+ /**
196
+ * Format KPI value with unit
197
+ */
198
+ export function formatValue(kpi: KPIDefinition, value?: number): string {
199
+ const val = value ?? kpi.current
200
+ if (val === undefined) return 'N/A'
201
+
202
+ const formatted = val.toLocaleString(undefined, {
203
+ minimumFractionDigits: 0,
204
+ maximumFractionDigits: 2,
205
+ })
206
+
207
+ if (!kpi.unit) return formatted
208
+
209
+ switch (kpi.unit.toLowerCase()) {
210
+ case 'usd':
211
+ case 'eur':
212
+ case 'gbp':
213
+ return `$${formatted}`
214
+ case 'percent':
215
+ case '%':
216
+ return `${formatted}%`
217
+ default:
218
+ return `${formatted} ${kpi.unit}`
219
+ }
220
+ }
221
+
222
+ /**
223
+ * Compare KPI performance over time
224
+ */
225
+ export function comparePerformance(
226
+ current: KPIDefinition,
227
+ previous: KPIDefinition
228
+ ): {
229
+ change: number
230
+ changePercent: number
231
+ improved: boolean
232
+ } {
233
+ if (current.current === undefined || previous.current === undefined) {
234
+ return { change: 0, changePercent: 0, improved: false }
235
+ }
236
+
237
+ const change = current.current - previous.current
238
+ const changePercent =
239
+ previous.current !== 0 ? (change / previous.current) * 100 : 0
240
+
241
+ // Determine if change is an improvement
242
+ const lowerIsBetter = ['churn', 'cost', 'time', 'error', 'downtime'].some(term =>
243
+ current.name.toLowerCase().includes(term)
244
+ )
245
+
246
+ const improved = lowerIsBetter ? change < 0 : change > 0
247
+
248
+ return { change, changePercent, improved }
249
+ }
250
+
251
+ /**
252
+ * Validate KPI definitions
253
+ */
254
+ export function validateKPIs(kpis: KPIDefinition[]): { valid: boolean; errors: string[] } {
255
+ const errors: string[] = []
256
+
257
+ for (const kpi of kpis) {
258
+ if (!kpi.name) {
259
+ errors.push('KPI name is required')
260
+ }
261
+
262
+ if (kpi.target !== undefined && kpi.target < 0) {
263
+ errors.push(`KPI ${kpi.name} target cannot be negative`)
264
+ }
265
+
266
+ if (kpi.current !== undefined && kpi.current < 0) {
267
+ errors.push(`KPI ${kpi.name} current value cannot be negative`)
268
+ }
269
+ }
270
+
271
+ return {
272
+ valid: errors.length === 0,
273
+ errors,
274
+ }
275
+ }