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
@@ -0,0 +1,360 @@
1
+ import type { Noun } from 'ai-database'
2
+
3
+ /**
4
+ * Project Management Entities
5
+ * Project, Task, Milestone, Sprint, Deliverable, Epic, Story, Resource
6
+ */
7
+
8
+ export const Project: Noun = {
9
+ singular: 'project',
10
+ plural: 'projects',
11
+ description: 'A project with defined scope, timeline, and deliverables',
12
+ properties: {
13
+ name: { type: 'string', description: 'Project name' },
14
+ description: { type: 'string', description: 'Project description' },
15
+ type: { type: 'string', description: 'Type of project', examples: ['product', 'internal', 'client', 'research', 'infrastructure', 'migration', 'integration', 'transformation'] },
16
+ status: { type: 'string', description: 'Project status', examples: ['proposed', 'planning', 'approved', 'active', 'on-hold', 'completed', 'cancelled', 'archived'] },
17
+ phase: { type: 'string', description: 'Current phase', examples: ['initiation', 'planning', 'execution', 'monitoring', 'closure'] },
18
+ priority: { type: 'string', description: 'Project priority', examples: ['critical', 'high', 'medium', 'low'] },
19
+ methodology: { type: 'string', description: 'Project methodology', examples: ['agile', 'scrum', 'kanban', 'waterfall', 'hybrid', 'lean'] },
20
+ code: { type: 'string', description: 'Project code or identifier' },
21
+ objectives: { type: 'string[]', description: 'Project objectives' },
22
+ scope: { type: 'string', description: 'Project scope' },
23
+ outOfScope: { type: 'string[]', description: 'Out of scope items' },
24
+ assumptions: { type: 'string[]', description: 'Project assumptions' },
25
+ constraints: { type: 'string[]', description: 'Project constraints' },
26
+ dependencies: { type: 'string[]', description: 'External dependencies' },
27
+ startDate: { type: 'date', description: 'Planned start date' },
28
+ endDate: { type: 'date', description: 'Planned end date' },
29
+ actualStartDate: { type: 'date', description: 'Actual start date', optional: true },
30
+ actualEndDate: { type: 'date', description: 'Actual end date', optional: true },
31
+ deadline: { type: 'date', description: 'Hard deadline', optional: true },
32
+ progress: { type: 'number', description: 'Progress percentage' },
33
+ health: { type: 'string', description: 'Project health', examples: ['on-track', 'at-risk', 'off-track', 'blocked'] },
34
+ budget: { type: 'number', description: 'Total budget' },
35
+ spent: { type: 'number', description: 'Amount spent' },
36
+ remaining: { type: 'number', description: 'Budget remaining' },
37
+ forecast: { type: 'number', description: 'Forecasted total cost' },
38
+ variance: { type: 'number', description: 'Budget variance' },
39
+ currency: { type: 'string', description: 'Budget currency' },
40
+ sponsor: { type: 'string', description: 'Executive sponsor' },
41
+ owner: { type: 'string', description: 'Project owner' },
42
+ manager: { type: 'string', description: 'Project manager' },
43
+ teamLead: { type: 'string', description: 'Technical lead' },
44
+ teamSize: { type: 'number', description: 'Team size' },
45
+ stakeholders: { type: 'string[]', description: 'Key stakeholders' },
46
+ businessUnit: { type: 'string', description: 'Business unit' },
47
+ portfolio: { type: 'string', description: 'Portfolio or program' },
48
+ category: { type: 'string', description: 'Project category' },
49
+ tags: { type: 'string[]', description: 'Project tags' },
50
+ notes: { type: 'string', description: 'Internal notes', optional: true },
51
+ metadata: { type: 'object', description: 'Additional metadata', optional: true },
52
+ },
53
+ relationships: {
54
+ tasks: { type: 'task[]', description: 'Project tasks', backref: 'project' },
55
+ milestones: { type: 'milestone[]', description: 'Project milestones', backref: 'project' },
56
+ deliverables: { type: 'deliverable[]', description: 'Project deliverables', backref: 'project' },
57
+ sprints: { type: 'sprint[]', description: 'Project sprints', backref: 'project' },
58
+ epics: { type: 'epic[]', description: 'Project epics', backref: 'project' },
59
+ resources: { type: 'resource[]', description: 'Assigned resources', backref: 'projects' },
60
+ risks: { type: 'risk[]', description: 'Project risks', backref: 'project' },
61
+ team: { type: 'team', description: 'Project team', backref: 'projects' },
62
+ parentProject: { type: 'project', description: 'Parent project', backref: 'subProjects' },
63
+ subProjects: { type: 'project[]', description: 'Sub-projects', backref: 'parentProject' },
64
+ },
65
+ actions: ['create', 'update', 'plan', 'approve', 'start', 'pause', 'resume', 'complete', 'cancel', 'archive', 'replan', 'review'],
66
+ events: ['created', 'updated', 'planned', 'approved', 'started', 'paused', 'resumed', 'completed', 'cancelled', 'archived', 'replanned', 'reviewed'],
67
+ }
68
+
69
+ export const Task: Noun = {
70
+ singular: 'task',
71
+ plural: 'tasks',
72
+ description: 'A task or work item to be completed',
73
+ properties: {
74
+ name: { type: 'string', description: 'Task name' },
75
+ description: { type: 'string', description: 'Task description' },
76
+ type: { type: 'string', description: 'Type of task', examples: ['task', 'bug', 'feature', 'improvement', 'research', 'documentation', 'test', 'review', 'deployment'] },
77
+ status: { type: 'string', description: 'Task status', examples: ['backlog', 'todo', 'in-progress', 'review', 'blocked', 'done', 'cancelled'] },
78
+ priority: { type: 'string', description: 'Task priority', examples: ['critical', 'high', 'medium', 'low'] },
79
+ resolution: { type: 'string', description: 'Resolution status', examples: ['unresolved', 'fixed', 'wont-fix', 'duplicate', 'cannot-reproduce', 'deferred'] },
80
+ estimate: { type: 'number', description: 'Estimated hours/points' },
81
+ timeSpent: { type: 'number', description: 'Time spent' },
82
+ remaining: { type: 'number', description: 'Time remaining' },
83
+ storyPoints: { type: 'number', description: 'Story points' },
84
+ complexity: { type: 'string', description: 'Complexity level', examples: ['trivial', 'simple', 'medium', 'complex', 'unknown'] },
85
+ startDate: { type: 'date', description: 'Start date' },
86
+ dueDate: { type: 'date', description: 'Due date' },
87
+ completedDate: { type: 'date', description: 'Completion date', optional: true },
88
+ assignee: { type: 'string', description: 'Assigned person' },
89
+ reporter: { type: 'string', description: 'Task reporter' },
90
+ reviewer: { type: 'string', description: 'Task reviewer' },
91
+ labels: { type: 'string[]', description: 'Task labels' },
92
+ components: { type: 'string[]', description: 'Affected components' },
93
+ acceptanceCriteria: { type: 'string[]', description: 'Acceptance criteria' },
94
+ blockedReason: { type: 'string', description: 'Blocked reason', optional: true },
95
+ pullRequest: { type: 'string', description: 'PR/MR link', optional: true },
96
+ branch: { type: 'string', description: 'Git branch', optional: true },
97
+ progress: { type: 'number', description: 'Progress percentage' },
98
+ externalId: { type: 'string', description: 'External system ID', optional: true },
99
+ notes: { type: 'string', description: 'Internal notes', optional: true },
100
+ tags: { type: 'string[]', description: 'Task tags' },
101
+ metadata: { type: 'object', description: 'Additional metadata', optional: true },
102
+ },
103
+ relationships: {
104
+ project: { type: 'project', description: 'Parent project', backref: 'tasks' },
105
+ epic: { type: 'epic', description: 'Parent epic', backref: 'tasks' },
106
+ story: { type: 'story', description: 'Parent story', backref: 'tasks' },
107
+ sprint: { type: 'sprint', description: 'Assigned sprint', backref: 'tasks' },
108
+ milestone: { type: 'milestone', description: 'Target milestone', backref: 'tasks' },
109
+ parentTask: { type: 'task', description: 'Parent task', backref: 'subtasks' },
110
+ subtasks: { type: 'task[]', description: 'Subtasks', backref: 'parentTask' },
111
+ blockedBy: { type: 'task[]', description: 'Blocked by tasks', backref: 'blocks' },
112
+ blocks: { type: 'task[]', description: 'Tasks this blocks', backref: 'blockedBy' },
113
+ relatedTasks: { type: 'task[]', description: 'Related tasks', backref: 'relatedTasks' },
114
+ },
115
+ actions: ['create', 'update', 'assign', 'start', 'pause', 'resume', 'complete', 'cancel', 'reopen', 'block', 'unblock', 'estimate', 'review'],
116
+ events: ['created', 'updated', 'assigned', 'started', 'paused', 'resumed', 'completed', 'cancelled', 'reopened', 'blocked', 'unblocked', 'estimated', 'reviewed'],
117
+ }
118
+
119
+ export const Milestone: Noun = {
120
+ singular: 'milestone',
121
+ plural: 'milestones',
122
+ description: 'A project milestone or checkpoint',
123
+ properties: {
124
+ name: { type: 'string', description: 'Milestone name' },
125
+ description: { type: 'string', description: 'Milestone description' },
126
+ type: { type: 'string', description: 'Type of milestone', examples: ['phase-gate', 'release', 'delivery', 'review', 'approval', 'launch', 'go-live'] },
127
+ status: { type: 'string', description: 'Milestone status', examples: ['planned', 'in-progress', 'completed', 'delayed', 'at-risk', 'cancelled'] },
128
+ targetDate: { type: 'date', description: 'Target date' },
129
+ actualDate: { type: 'date', description: 'Actual completion date', optional: true },
130
+ progress: { type: 'number', description: 'Progress percentage' },
131
+ deliverables: { type: 'string[]', description: 'Expected deliverables' },
132
+ criteria: { type: 'string[]', description: 'Completion criteria' },
133
+ owner: { type: 'string', description: 'Milestone owner' },
134
+ approver: { type: 'string', description: 'Milestone approver' },
135
+ approved: { type: 'boolean', description: 'Has been approved' },
136
+ approvalDate: { type: 'date', description: 'Approval date', optional: true },
137
+ blockers: { type: 'string[]', description: 'Current blockers' },
138
+ dependencies: { type: 'string[]', description: 'Dependencies' },
139
+ notes: { type: 'string', description: 'Internal notes', optional: true },
140
+ tags: { type: 'string[]', description: 'Milestone tags' },
141
+ metadata: { type: 'object', description: 'Additional metadata', optional: true },
142
+ },
143
+ relationships: {
144
+ project: { type: 'project', description: 'Parent project', backref: 'milestones', required: true },
145
+ tasks: { type: 'task[]', description: 'Milestone tasks', backref: 'milestone' },
146
+ deliverables: { type: 'deliverable[]', description: 'Milestone deliverables', backref: 'milestone' },
147
+ previousMilestone: { type: 'milestone', description: 'Previous milestone', backref: 'nextMilestone' },
148
+ nextMilestone: { type: 'milestone', description: 'Next milestone', backref: 'previousMilestone' },
149
+ },
150
+ actions: ['create', 'update', 'start', 'complete', 'delay', 'approve', 'cancel', 'review'],
151
+ events: ['created', 'updated', 'started', 'completed', 'delayed', 'approved', 'cancelled', 'reviewed'],
152
+ }
153
+
154
+ export const Sprint: Noun = {
155
+ singular: 'sprint',
156
+ plural: 'sprints',
157
+ description: 'A time-boxed iteration in agile development',
158
+ properties: {
159
+ name: { type: 'string', description: 'Sprint name' },
160
+ number: { type: 'number', description: 'Sprint number' },
161
+ goal: { type: 'string', description: 'Sprint goal' },
162
+ status: { type: 'string', description: 'Sprint status', examples: ['planning', 'active', 'review', 'completed', 'cancelled'] },
163
+ startDate: { type: 'date', description: 'Sprint start date' },
164
+ endDate: { type: 'date', description: 'Sprint end date' },
165
+ duration: { type: 'number', description: 'Duration in days' },
166
+ capacity: { type: 'number', description: 'Team capacity (points/hours)' },
167
+ commitment: { type: 'number', description: 'Committed points/hours' },
168
+ completed: { type: 'number', description: 'Completed points/hours' },
169
+ velocity: { type: 'number', description: 'Sprint velocity' },
170
+ completionRate: { type: 'number', description: 'Completion rate percentage' },
171
+ carryOver: { type: 'number', description: 'Points carried over' },
172
+ addedScope: { type: 'number', description: 'Scope added during sprint' },
173
+ removedScope: { type: 'number', description: 'Scope removed during sprint' },
174
+ totalTasks: { type: 'number', description: 'Total tasks' },
175
+ completedTasks: { type: 'number', description: 'Completed tasks' },
176
+ inProgressTasks: { type: 'number', description: 'In-progress tasks' },
177
+ blockedTasks: { type: 'number', description: 'Blocked tasks' },
178
+ retroNotes: { type: 'string', description: 'Retrospective notes', optional: true },
179
+ retroUrl: { type: 'string', description: 'Retrospective document URL', optional: true },
180
+ reviewUrl: { type: 'string', description: 'Sprint review document URL', optional: true },
181
+ notes: { type: 'string', description: 'Internal notes', optional: true },
182
+ tags: { type: 'string[]', description: 'Sprint tags' },
183
+ metadata: { type: 'object', description: 'Additional metadata', optional: true },
184
+ },
185
+ relationships: {
186
+ project: { type: 'project', description: 'Parent project', backref: 'sprints', required: true },
187
+ tasks: { type: 'task[]', description: 'Sprint tasks', backref: 'sprint' },
188
+ stories: { type: 'story[]', description: 'Sprint stories', backref: 'sprint' },
189
+ team: { type: 'team', description: 'Sprint team', backref: 'sprints' },
190
+ previousSprint: { type: 'sprint', description: 'Previous sprint', backref: 'nextSprint' },
191
+ nextSprint: { type: 'sprint', description: 'Next sprint', backref: 'previousSprint' },
192
+ },
193
+ actions: ['create', 'update', 'plan', 'start', 'complete', 'cancel', 'review', 'retrospect'],
194
+ events: ['created', 'updated', 'planned', 'started', 'completed', 'cancelled', 'reviewed', 'retrospected'],
195
+ }
196
+
197
+ export const Deliverable: Noun = {
198
+ singular: 'deliverable',
199
+ plural: 'deliverables',
200
+ description: 'A project deliverable or output',
201
+ properties: {
202
+ name: { type: 'string', description: 'Deliverable name' },
203
+ description: { type: 'string', description: 'Deliverable description' },
204
+ type: { type: 'string', description: 'Type of deliverable', examples: ['document', 'software', 'report', 'design', 'prototype', 'training', 'process', 'artifact'] },
205
+ status: { type: 'string', description: 'Deliverable status', examples: ['planned', 'in-progress', 'review', 'approved', 'delivered', 'rejected'] },
206
+ format: { type: 'string', description: 'Deliverable format' },
207
+ version: { type: 'string', description: 'Current version' },
208
+ dueDate: { type: 'date', description: 'Due date' },
209
+ deliveredDate: { type: 'date', description: 'Delivery date', optional: true },
210
+ owner: { type: 'string', description: 'Deliverable owner' },
211
+ reviewer: { type: 'string', description: 'Deliverable reviewer' },
212
+ acceptor: { type: 'string', description: 'Acceptance authority' },
213
+ acceptanceCriteria: { type: 'string[]', description: 'Acceptance criteria' },
214
+ accepted: { type: 'boolean', description: 'Has been accepted' },
215
+ acceptanceDate: { type: 'date', description: 'Acceptance date', optional: true },
216
+ comments: { type: 'string', description: 'Review comments', optional: true },
217
+ url: { type: 'string', description: 'Deliverable URL' },
218
+ progress: { type: 'number', description: 'Progress percentage' },
219
+ notes: { type: 'string', description: 'Internal notes', optional: true },
220
+ tags: { type: 'string[]', description: 'Deliverable tags' },
221
+ metadata: { type: 'object', description: 'Additional metadata', optional: true },
222
+ },
223
+ relationships: {
224
+ project: { type: 'project', description: 'Parent project', backref: 'deliverables', required: true },
225
+ milestone: { type: 'milestone', description: 'Target milestone', backref: 'deliverables' },
226
+ tasks: { type: 'task[]', description: 'Related tasks', backref: 'deliverable' },
227
+ dependencies: { type: 'deliverable[]', description: 'Dependent deliverables', backref: 'dependents' },
228
+ dependents: { type: 'deliverable[]', description: 'Deliverables that depend on this', backref: 'dependencies' },
229
+ },
230
+ actions: ['create', 'update', 'start', 'submit', 'review', 'approve', 'reject', 'revise', 'deliver', 'accept'],
231
+ events: ['created', 'updated', 'started', 'submitted', 'reviewed', 'approved', 'rejected', 'revised', 'delivered', 'accepted'],
232
+ }
233
+
234
+ export const Epic: Noun = {
235
+ singular: 'epic',
236
+ plural: 'epics',
237
+ description: 'A large body of work that can be broken into stories',
238
+ properties: {
239
+ name: { type: 'string', description: 'Epic name' },
240
+ description: { type: 'string', description: 'Epic description' },
241
+ status: { type: 'string', description: 'Epic status', examples: ['draft', 'ready', 'in-progress', 'done', 'cancelled'] },
242
+ priority: { type: 'string', description: 'Epic priority', examples: ['critical', 'high', 'medium', 'low'] },
243
+ theme: { type: 'string', description: 'Epic theme or initiative' },
244
+ businessValue: { type: 'string', description: 'Business value statement' },
245
+ hypothesis: { type: 'string', description: 'Business hypothesis', optional: true },
246
+ successMetrics: { type: 'string[]', description: 'Success metrics' },
247
+ acceptanceCriteria: { type: 'string[]', description: 'Acceptance criteria' },
248
+ startDate: { type: 'date', description: 'Start date' },
249
+ targetDate: { type: 'date', description: 'Target completion date' },
250
+ completedDate: { type: 'date', description: 'Completion date', optional: true },
251
+ estimate: { type: 'number', description: 'Estimated points' },
252
+ completed: { type: 'number', description: 'Completed points' },
253
+ progress: { type: 'number', description: 'Progress percentage' },
254
+ owner: { type: 'string', description: 'Epic owner' },
255
+ labels: { type: 'string[]', description: 'Epic labels' },
256
+ notes: { type: 'string', description: 'Internal notes', optional: true },
257
+ tags: { type: 'string[]', description: 'Epic tags' },
258
+ metadata: { type: 'object', description: 'Additional metadata', optional: true },
259
+ },
260
+ relationships: {
261
+ project: { type: 'project', description: 'Parent project', backref: 'epics', required: true },
262
+ stories: { type: 'story[]', description: 'Epic stories', backref: 'epic' },
263
+ tasks: { type: 'task[]', description: 'Epic tasks', backref: 'epic' },
264
+ initiative: { type: 'initiative', description: 'Parent initiative', backref: 'epics' },
265
+ dependencies: { type: 'epic[]', description: 'Dependent epics', backref: 'dependents' },
266
+ },
267
+ actions: ['create', 'update', 'refine', 'start', 'complete', 'cancel', 'split', 'prioritize'],
268
+ events: ['created', 'updated', 'refined', 'started', 'completed', 'cancelled', 'split', 'prioritized'],
269
+ }
270
+
271
+ export const Story: Noun = {
272
+ singular: 'story',
273
+ plural: 'stories',
274
+ description: 'A user story representing a feature from user perspective',
275
+ properties: {
276
+ name: { type: 'string', description: 'Story name' },
277
+ description: { type: 'string', description: 'Story description' },
278
+ userStory: { type: 'string', description: 'As a... I want... So that...' },
279
+ status: { type: 'string', description: 'Story status', examples: ['draft', 'ready', 'in-progress', 'review', 'done', 'cancelled'] },
280
+ priority: { type: 'string', description: 'Story priority', examples: ['critical', 'high', 'medium', 'low'] },
281
+ storyPoints: { type: 'number', description: 'Story points estimate' },
282
+ businessValue: { type: 'number', description: 'Business value score' },
283
+ acceptanceCriteria: { type: 'string[]', description: 'Acceptance criteria' },
284
+ definition: { type: 'string', description: 'Definition of done criteria' },
285
+ persona: { type: 'string', description: 'Target user persona' },
286
+ assignee: { type: 'string', description: 'Assigned person' },
287
+ reporter: { type: 'string', description: 'Story reporter' },
288
+ labels: { type: 'string[]', description: 'Story labels' },
289
+ components: { type: 'string[]', description: 'Affected components' },
290
+ startDate: { type: 'date', description: 'Start date' },
291
+ dueDate: { type: 'date', description: 'Due date' },
292
+ completedDate: { type: 'date', description: 'Completion date', optional: true },
293
+ progress: { type: 'number', description: 'Progress percentage' },
294
+ notes: { type: 'string', description: 'Internal notes', optional: true },
295
+ tags: { type: 'string[]', description: 'Story tags' },
296
+ metadata: { type: 'object', description: 'Additional metadata', optional: true },
297
+ },
298
+ relationships: {
299
+ epic: { type: 'epic', description: 'Parent epic', backref: 'stories' },
300
+ project: { type: 'project', description: 'Parent project', backref: 'stories' },
301
+ sprint: { type: 'sprint', description: 'Assigned sprint', backref: 'stories' },
302
+ tasks: { type: 'task[]', description: 'Story tasks', backref: 'story' },
303
+ blockedBy: { type: 'story[]', description: 'Blocked by stories', backref: 'blocks' },
304
+ blocks: { type: 'story[]', description: 'Stories this blocks', backref: 'blockedBy' },
305
+ },
306
+ actions: ['create', 'update', 'refine', 'estimate', 'assign', 'start', 'complete', 'reject', 'split'],
307
+ events: ['created', 'updated', 'refined', 'estimated', 'assigned', 'started', 'completed', 'rejected', 'split'],
308
+ }
309
+
310
+ export const Resource: Noun = {
311
+ singular: 'resource',
312
+ plural: 'resources',
313
+ description: 'A project resource (person, equipment, or material)',
314
+ properties: {
315
+ name: { type: 'string', description: 'Resource name' },
316
+ type: { type: 'string', description: 'Type of resource', examples: ['person', 'equipment', 'material', 'facility', 'budget', 'software'] },
317
+ status: { type: 'string', description: 'Resource status', examples: ['available', 'assigned', 'unavailable', 'on-leave', 'overallocated'] },
318
+ role: { type: 'string', description: 'Resource role or function' },
319
+ skills: { type: 'string[]', description: 'Skills or capabilities' },
320
+ capacity: { type: 'number', description: 'Total capacity (hours/units)' },
321
+ allocated: { type: 'number', description: 'Currently allocated' },
322
+ available: { type: 'number', description: 'Available capacity' },
323
+ utilizationTarget: { type: 'number', description: 'Target utilization percentage' },
324
+ utilizationActual: { type: 'number', description: 'Actual utilization percentage' },
325
+ costRate: { type: 'number', description: 'Cost rate per hour/unit' },
326
+ billableRate: { type: 'number', description: 'Billable rate per hour/unit', optional: true },
327
+ currency: { type: 'string', description: 'Rate currency' },
328
+ location: { type: 'string', description: 'Resource location' },
329
+ timezone: { type: 'string', description: 'Time zone' },
330
+ startDate: { type: 'date', description: 'Availability start' },
331
+ endDate: { type: 'date', description: 'Availability end', optional: true },
332
+ manager: { type: 'string', description: 'Resource manager' },
333
+ email: { type: 'string', description: 'Contact email', optional: true },
334
+ notes: { type: 'string', description: 'Internal notes', optional: true },
335
+ tags: { type: 'string[]', description: 'Resource tags' },
336
+ metadata: { type: 'object', description: 'Additional metadata', optional: true },
337
+ },
338
+ relationships: {
339
+ projects: { type: 'project[]', description: 'Assigned projects', backref: 'resources' },
340
+ tasks: { type: 'task[]', description: 'Assigned tasks', backref: 'resource' },
341
+ team: { type: 'team', description: 'Resource team', backref: 'resources' },
342
+ worker: { type: 'worker', description: 'Worker profile', backref: 'resource' },
343
+ },
344
+ actions: ['create', 'update', 'allocate', 'deallocate', 'reassign', 'book', 'release'],
345
+ events: ['created', 'updated', 'allocated', 'deallocated', 'reassigned', 'booked', 'released'],
346
+ }
347
+
348
+ // Export all project entities
349
+ export const ProjectEntities = {
350
+ Project,
351
+ Task,
352
+ Milestone,
353
+ Sprint,
354
+ Deliverable,
355
+ Epic,
356
+ Story,
357
+ Resource,
358
+ }
359
+
360
+ export default ProjectEntities