@dolusoft/hirebase-mcp 1.1.8

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 (413) hide show
  1. package/README.md +261 -0
  2. package/dist/application/dto/candidate-summary.d.ts +10 -0
  3. package/dist/application/dto/candidate-summary.js +2 -0
  4. package/dist/application/dto/candidate-summary.js.map +1 -0
  5. package/dist/application/dto/extracted-cv.d.ts +46 -0
  6. package/dist/application/dto/extracted-cv.js +2 -0
  7. package/dist/application/dto/extracted-cv.js.map +1 -0
  8. package/dist/application/dto/filter-input.d.ts +7 -0
  9. package/dist/application/dto/filter-input.js +2 -0
  10. package/dist/application/dto/filter-input.js.map +1 -0
  11. package/dist/application/dto/index.d.ts +5 -0
  12. package/dist/application/dto/index.js +2 -0
  13. package/dist/application/dto/index.js.map +1 -0
  14. package/dist/application/dto/search-results.d.ts +13 -0
  15. package/dist/application/dto/search-results.js +2 -0
  16. package/dist/application/dto/search-results.js.map +1 -0
  17. package/dist/application/dto/stats.d.ts +10 -0
  18. package/dist/application/dto/stats.js +2 -0
  19. package/dist/application/dto/stats.js.map +1 -0
  20. package/dist/application/ports/document-parser.d.ts +8 -0
  21. package/dist/application/ports/document-parser.js +2 -0
  22. package/dist/application/ports/document-parser.js.map +1 -0
  23. package/dist/application/ports/embedding-service.d.ts +4 -0
  24. package/dist/application/ports/embedding-service.js +2 -0
  25. package/dist/application/ports/embedding-service.js.map +1 -0
  26. package/dist/application/ports/export-service.d.ts +5 -0
  27. package/dist/application/ports/export-service.js +2 -0
  28. package/dist/application/ports/export-service.js.map +1 -0
  29. package/dist/application/ports/index.d.ts +4 -0
  30. package/dist/application/ports/index.js +2 -0
  31. package/dist/application/ports/index.js.map +1 -0
  32. package/dist/application/ports/structured-extractor.d.ts +4 -0
  33. package/dist/application/ports/structured-extractor.js +2 -0
  34. package/dist/application/ports/structured-extractor.js.map +1 -0
  35. package/dist/application/use-cases/add-cv.d.ts +16 -0
  36. package/dist/application/use-cases/add-cv.js +113 -0
  37. package/dist/application/use-cases/add-cv.js.map +1 -0
  38. package/dist/application/use-cases/add-job-posting.d.ts +17 -0
  39. package/dist/application/use-cases/add-job-posting.js +27 -0
  40. package/dist/application/use-cases/add-job-posting.js.map +1 -0
  41. package/dist/application/use-cases/add-pipeline-note.d.ts +15 -0
  42. package/dist/application/use-cases/add-pipeline-note.js +34 -0
  43. package/dist/application/use-cases/add-pipeline-note.js.map +1 -0
  44. package/dist/application/use-cases/add-to-pipeline.d.ts +18 -0
  45. package/dist/application/use-cases/add-to-pipeline.js +54 -0
  46. package/dist/application/use-cases/add-to-pipeline.js.map +1 -0
  47. package/dist/application/use-cases/bulk-add-cvs.d.ts +14 -0
  48. package/dist/application/use-cases/bulk-add-cvs.js +32 -0
  49. package/dist/application/use-cases/bulk-add-cvs.js.map +1 -0
  50. package/dist/application/use-cases/delete-cv.d.ts +10 -0
  51. package/dist/application/use-cases/delete-cv.js +21 -0
  52. package/dist/application/use-cases/delete-cv.js.map +1 -0
  53. package/dist/application/use-cases/export-results.d.ts +9 -0
  54. package/dist/application/use-cases/export-results.js +21 -0
  55. package/dist/application/use-cases/export-results.js.map +1 -0
  56. package/dist/application/use-cases/filter-candidates.d.ts +9 -0
  57. package/dist/application/use-cases/filter-candidates.js +51 -0
  58. package/dist/application/use-cases/filter-candidates.js.map +1 -0
  59. package/dist/application/use-cases/get-candidate-history.d.ts +25 -0
  60. package/dist/application/use-cases/get-candidate-history.js +36 -0
  61. package/dist/application/use-cases/get-candidate-history.js.map +1 -0
  62. package/dist/application/use-cases/get-cv-chunks.d.ts +15 -0
  63. package/dist/application/use-cases/get-cv-chunks.js +18 -0
  64. package/dist/application/use-cases/get-cv-chunks.js.map +1 -0
  65. package/dist/application/use-cases/get-cv-detail.d.ts +7 -0
  66. package/dist/application/use-cases/get-cv-detail.js +15 -0
  67. package/dist/application/use-cases/get-cv-detail.js.map +1 -0
  68. package/dist/application/use-cases/get-cv-versions.d.ts +9 -0
  69. package/dist/application/use-cases/get-cv-versions.js +18 -0
  70. package/dist/application/use-cases/get-cv-versions.js.map +1 -0
  71. package/dist/application/use-cases/get-pending-actions.d.ts +23 -0
  72. package/dist/application/use-cases/get-pending-actions.js +50 -0
  73. package/dist/application/use-cases/get-pending-actions.js.map +1 -0
  74. package/dist/application/use-cases/get-pipeline.d.ts +27 -0
  75. package/dist/application/use-cases/get-pipeline.js +40 -0
  76. package/dist/application/use-cases/get-pipeline.js.map +1 -0
  77. package/dist/application/use-cases/get-stats.d.ts +13 -0
  78. package/dist/application/use-cases/get-stats.js +50 -0
  79. package/dist/application/use-cases/get-stats.js.map +1 -0
  80. package/dist/application/use-cases/index.d.ts +23 -0
  81. package/dist/application/use-cases/index.js +24 -0
  82. package/dist/application/use-cases/index.js.map +1 -0
  83. package/dist/application/use-cases/list-cvs.d.ts +8 -0
  84. package/dist/application/use-cases/list-cvs.js +20 -0
  85. package/dist/application/use-cases/list-cvs.js.map +1 -0
  86. package/dist/application/use-cases/list-job-postings.d.ts +7 -0
  87. package/dist/application/use-cases/list-job-postings.js +10 -0
  88. package/dist/application/use-cases/list-job-postings.js.map +1 -0
  89. package/dist/application/use-cases/manage-tags.d.ts +7 -0
  90. package/dist/application/use-cases/manage-tags.js +36 -0
  91. package/dist/application/use-cases/manage-tags.js.map +1 -0
  92. package/dist/application/use-cases/match-candidates.d.ts +27 -0
  93. package/dist/application/use-cases/match-candidates.js +92 -0
  94. package/dist/application/use-cases/match-candidates.js.map +1 -0
  95. package/dist/application/use-cases/semantic-search.d.ts +11 -0
  96. package/dist/application/use-cases/semantic-search.js +40 -0
  97. package/dist/application/use-cases/semantic-search.js.map +1 -0
  98. package/dist/application/use-cases/set-pending-action.d.ts +13 -0
  99. package/dist/application/use-cases/set-pending-action.js +24 -0
  100. package/dist/application/use-cases/set-pending-action.js.map +1 -0
  101. package/dist/application/use-cases/update-cv.d.ts +17 -0
  102. package/dist/application/use-cases/update-cv.js +103 -0
  103. package/dist/application/use-cases/update-cv.js.map +1 -0
  104. package/dist/application/use-cases/update-job-posting.d.ts +19 -0
  105. package/dist/application/use-cases/update-job-posting.js +28 -0
  106. package/dist/application/use-cases/update-job-posting.js.map +1 -0
  107. package/dist/application/use-cases/update-pipeline-status.d.ts +14 -0
  108. package/dist/application/use-cases/update-pipeline-status.js +38 -0
  109. package/dist/application/use-cases/update-pipeline-status.js.map +1 -0
  110. package/dist/domain/entities/application-event.d.ts +11 -0
  111. package/dist/domain/entities/application-event.js +2 -0
  112. package/dist/domain/entities/application-event.js.map +1 -0
  113. package/dist/domain/entities/application.d.ts +13 -0
  114. package/dist/domain/entities/application.js +2 -0
  115. package/dist/domain/entities/application.js.map +1 -0
  116. package/dist/domain/entities/candidate.d.ts +26 -0
  117. package/dist/domain/entities/candidate.js +2 -0
  118. package/dist/domain/entities/candidate.js.map +1 -0
  119. package/dist/domain/entities/cv-chunk.d.ts +10 -0
  120. package/dist/domain/entities/cv-chunk.js +2 -0
  121. package/dist/domain/entities/cv-chunk.js.map +1 -0
  122. package/dist/domain/entities/cv-version.d.ts +7 -0
  123. package/dist/domain/entities/cv-version.js +2 -0
  124. package/dist/domain/entities/cv-version.js.map +1 -0
  125. package/dist/domain/entities/index.d.ts +6 -0
  126. package/dist/domain/entities/index.js +2 -0
  127. package/dist/domain/entities/index.js.map +1 -0
  128. package/dist/domain/entities/job-posting.d.ts +14 -0
  129. package/dist/domain/entities/job-posting.js +2 -0
  130. package/dist/domain/entities/job-posting.js.map +1 -0
  131. package/dist/domain/repositories/application-event-repository.d.ts +7 -0
  132. package/dist/domain/repositories/application-event-repository.js +2 -0
  133. package/dist/domain/repositories/application-event-repository.js.map +1 -0
  134. package/dist/domain/repositories/application-repository.d.ts +12 -0
  135. package/dist/domain/repositories/application-repository.js +2 -0
  136. package/dist/domain/repositories/application-repository.js.map +1 -0
  137. package/dist/domain/repositories/candidate-repository.d.ts +12 -0
  138. package/dist/domain/repositories/candidate-repository.js +2 -0
  139. package/dist/domain/repositories/candidate-repository.js.map +1 -0
  140. package/dist/domain/repositories/chunk-repository.d.ts +13 -0
  141. package/dist/domain/repositories/chunk-repository.js +2 -0
  142. package/dist/domain/repositories/chunk-repository.js.map +1 -0
  143. package/dist/domain/repositories/index.d.ts +6 -0
  144. package/dist/domain/repositories/index.js +2 -0
  145. package/dist/domain/repositories/index.js.map +1 -0
  146. package/dist/domain/repositories/job-posting-repository.d.ts +9 -0
  147. package/dist/domain/repositories/job-posting-repository.js +2 -0
  148. package/dist/domain/repositories/job-posting-repository.js.map +1 -0
  149. package/dist/domain/repositories/version-repository.d.ts +6 -0
  150. package/dist/domain/repositories/version-repository.js +2 -0
  151. package/dist/domain/repositories/version-repository.js.map +1 -0
  152. package/dist/domain/value-objects/certification.d.ts +5 -0
  153. package/dist/domain/value-objects/certification.js +2 -0
  154. package/dist/domain/value-objects/certification.js.map +1 -0
  155. package/dist/domain/value-objects/contact-info.d.ts +5 -0
  156. package/dist/domain/value-objects/contact-info.js +2 -0
  157. package/dist/domain/value-objects/contact-info.js.map +1 -0
  158. package/dist/domain/value-objects/education.d.ts +7 -0
  159. package/dist/domain/value-objects/education.js +2 -0
  160. package/dist/domain/value-objects/education.js.map +1 -0
  161. package/dist/domain/value-objects/experience.d.ts +7 -0
  162. package/dist/domain/value-objects/experience.js +2 -0
  163. package/dist/domain/value-objects/experience.js.map +1 -0
  164. package/dist/domain/value-objects/index.d.ts +7 -0
  165. package/dist/domain/value-objects/index.js +2 -0
  166. package/dist/domain/value-objects/index.js.map +1 -0
  167. package/dist/domain/value-objects/language.d.ts +4 -0
  168. package/dist/domain/value-objects/language.js +2 -0
  169. package/dist/domain/value-objects/language.js.map +1 -0
  170. package/dist/domain/value-objects/links.d.ts +6 -0
  171. package/dist/domain/value-objects/links.js +2 -0
  172. package/dist/domain/value-objects/links.js.map +1 -0
  173. package/dist/domain/value-objects/project.d.ts +5 -0
  174. package/dist/domain/value-objects/project.js +2 -0
  175. package/dist/domain/value-objects/project.js.map +1 -0
  176. package/dist/infrastructure/ai/index.d.ts +2 -0
  177. package/dist/infrastructure/ai/index.js +3 -0
  178. package/dist/infrastructure/ai/index.js.map +1 -0
  179. package/dist/infrastructure/ai/openai-embedding-service.d.ts +8 -0
  180. package/dist/infrastructure/ai/openai-embedding-service.js +39 -0
  181. package/dist/infrastructure/ai/openai-embedding-service.js.map +1 -0
  182. package/dist/infrastructure/ai/openai-structured-extractor.d.ts +9 -0
  183. package/dist/infrastructure/ai/openai-structured-extractor.js +163 -0
  184. package/dist/infrastructure/ai/openai-structured-extractor.js.map +1 -0
  185. package/dist/infrastructure/config/app-config.d.ts +9 -0
  186. package/dist/infrastructure/config/app-config.js +15 -0
  187. package/dist/infrastructure/config/app-config.js.map +1 -0
  188. package/dist/infrastructure/export/csv-export-service.d.ts +6 -0
  189. package/dist/infrastructure/export/csv-export-service.js +24 -0
  190. package/dist/infrastructure/export/csv-export-service.js.map +1 -0
  191. package/dist/infrastructure/parsers/docx-parser.d.ts +5 -0
  192. package/dist/infrastructure/parsers/docx-parser.js +17 -0
  193. package/dist/infrastructure/parsers/docx-parser.js.map +1 -0
  194. package/dist/infrastructure/parsers/index.d.ts +3 -0
  195. package/dist/infrastructure/parsers/index.js +4 -0
  196. package/dist/infrastructure/parsers/index.js.map +1 -0
  197. package/dist/infrastructure/parsers/ocr-service.d.ts +8 -0
  198. package/dist/infrastructure/parsers/ocr-service.js +65 -0
  199. package/dist/infrastructure/parsers/ocr-service.js.map +1 -0
  200. package/dist/infrastructure/parsers/pdf-parser.d.ts +5 -0
  201. package/dist/infrastructure/parsers/pdf-parser.js +44 -0
  202. package/dist/infrastructure/parsers/pdf-parser.js.map +1 -0
  203. package/dist/infrastructure/persistence/database.d.ts +20 -0
  204. package/dist/infrastructure/persistence/database.js +156 -0
  205. package/dist/infrastructure/persistence/database.js.map +1 -0
  206. package/dist/infrastructure/persistence/index.d.ts +6 -0
  207. package/dist/infrastructure/persistence/index.js +7 -0
  208. package/dist/infrastructure/persistence/index.js.map +1 -0
  209. package/dist/infrastructure/persistence/lancedb-application-event-repository.d.ts +16 -0
  210. package/dist/infrastructure/persistence/lancedb-application-event-repository.js +85 -0
  211. package/dist/infrastructure/persistence/lancedb-application-event-repository.js.map +1 -0
  212. package/dist/infrastructure/persistence/lancedb-application-repository.d.ts +21 -0
  213. package/dist/infrastructure/persistence/lancedb-application-repository.js +151 -0
  214. package/dist/infrastructure/persistence/lancedb-application-repository.js.map +1 -0
  215. package/dist/infrastructure/persistence/lancedb-candidate-repository.d.ts +21 -0
  216. package/dist/infrastructure/persistence/lancedb-candidate-repository.js +169 -0
  217. package/dist/infrastructure/persistence/lancedb-candidate-repository.js.map +1 -0
  218. package/dist/infrastructure/persistence/lancedb-chunk-repository.d.ts +18 -0
  219. package/dist/infrastructure/persistence/lancedb-chunk-repository.js +105 -0
  220. package/dist/infrastructure/persistence/lancedb-chunk-repository.js.map +1 -0
  221. package/dist/infrastructure/persistence/lancedb-job-posting-repository.d.ts +21 -0
  222. package/dist/infrastructure/persistence/lancedb-job-posting-repository.js +128 -0
  223. package/dist/infrastructure/persistence/lancedb-job-posting-repository.js.map +1 -0
  224. package/dist/infrastructure/persistence/lancedb-version-repository.d.ts +13 -0
  225. package/dist/infrastructure/persistence/lancedb-version-repository.js +62 -0
  226. package/dist/infrastructure/persistence/lancedb-version-repository.js.map +1 -0
  227. package/dist/interface/cli/index.d.ts +2 -0
  228. package/dist/interface/cli/index.js +17 -0
  229. package/dist/interface/cli/index.js.map +1 -0
  230. package/dist/interface/dashboard/call-context.d.ts +4 -0
  231. package/dist/interface/dashboard/call-context.js +26 -0
  232. package/dist/interface/dashboard/call-context.js.map +1 -0
  233. package/dist/interface/dashboard/event-bus.d.ts +7 -0
  234. package/dist/interface/dashboard/event-bus.js +16 -0
  235. package/dist/interface/dashboard/event-bus.js.map +1 -0
  236. package/dist/interface/dashboard/events.d.ts +30 -0
  237. package/dist/interface/dashboard/events.js +2 -0
  238. package/dist/interface/dashboard/events.js.map +1 -0
  239. package/dist/interface/dashboard/html.d.ts +1 -0
  240. package/dist/interface/dashboard/html.js +1007 -0
  241. package/dist/interface/dashboard/html.js.map +1 -0
  242. package/dist/interface/dashboard/public/200.html +1 -0
  243. package/dist/interface/dashboard/public/404.html +1 -0
  244. package/dist/interface/dashboard/public/_fonts/1ZTlEDqU4DtwDJiND8f6qaugUpa0RIDvQl-v7iM6l54-8KeALpAu2nWJknvJhMk31fqE06iajfSeiM57lsZAo5g.woff +0 -0
  245. package/dist/interface/dashboard/public/_fonts/1ZTlEDqU4DtwDJiND8f6qaugUpa0RIDvQl-v7iM6l54-CAyrLGU3kauAbzcFnj2Cv_iAPV8wT2NEvNmrA_77Up0.woff +0 -0
  246. package/dist/interface/dashboard/public/_fonts/1ZTlEDqU4DtwDJiND8f6qaugUpa0RIDvQl-v7iM6l54-Cbq5YGF_nsoQo6qYm9EhA3p-oINRUqlXhACZ2Wh4BBE.woff +0 -0
  247. package/dist/interface/dashboard/public/_fonts/1ZTlEDqU4DtwDJiND8f6qaugUpa0RIDvQl-v7iM6l54-G1pKsfAhfeIECsLbuPUckyz92yuHFKi9rmiwlRl8Tb0.woff +0 -0
  248. package/dist/interface/dashboard/public/_fonts/1ZTlEDqU4DtwDJiND8f6qaugUpa0RIDvQl-v7iM6l54-OnaIl8fChu9Cb4bpYiOA4dK_W7eeMCjXQOWR8tUhXJ0.woff +0 -0
  249. package/dist/interface/dashboard/public/_fonts/1ZTlEDqU4DtwDJiND8f6qaugUpa0RIDvQl-v7iM6l54-kzEiBeXQ06q7fC06p1Y4RaOpLlRWCnHcCcSaqFMJ6fc.woff +0 -0
  250. package/dist/interface/dashboard/public/_fonts/1ZTlEDqU4DtwDJiND8f6qaugUpa0RIDvQl-v7iM6l54-rmd8_oLeTXCNUhiFyy1UYsogNo6QYBr9dQHrhl_hLbs.woff +0 -0
  251. package/dist/interface/dashboard/public/_fonts/1ZTlEDqU4DtwDJiND8f6qaugUpa0RIDvQl-v7iM6l54-wjJHhPsTzX4mZm37l7bbvLDtOEIT1R38DKPlwV_Z34A.woff +0 -0
  252. package/dist/interface/dashboard/public/_fonts/57NSSoFy1VLVs2gqly8Ls9awBnZMFyXGrefpmqvdqmc-zJfbBtpgM4cDmcXBsqZNW79_kFnlpPd62b48glgdydA.woff2 +0 -0
  253. package/dist/interface/dashboard/public/_fonts/8VR2wSMN-3U4NbWAVYXlkRV6hA0jFBXP-0RtL3X7fko-x2gYI4qfmkRdxyQQUPaBZdZdgl1TeVrquF_TxHeM4lM.woff2 +0 -0
  254. package/dist/interface/dashboard/public/_fonts/GsKUclqeNLJ96g5AU593ug6yanivOiwjW_7zESNPChw-jHA4tBeM1bjF7LATGUpfBuSTyomIFrWBTzjF7txVYfg.woff2 +0 -0
  255. package/dist/interface/dashboard/public/_fonts/Ld1FnTo3yTIwDyGfTQ5-Fws9AWsCbKfMvgxduXr7JcY-W25bL8NF1fjpLRSOgJb7RoZPHqGQNwMTM7S9tHVoxx8.woff2 +0 -0
  256. package/dist/interface/dashboard/public/_fonts/NdzqRASp2bovDUhQT1IRE_EMqKJ2KYQdTCfFcBvL8yw-KhwZiS86o3fErOe5GGMExHUemmI_dBfaEFxjISZrBd0.woff2 +0 -0
  257. package/dist/interface/dashboard/public/_fonts/iTkrULNFJJkTvihIg1Vqi5IODRH_9btXCioVF5l98I8-AndUyau2HR2felA_ra8V2mutQgschhasE5FD1dXGJX8.woff2 +0 -0
  258. package/dist/interface/dashboard/public/_nuxt/BtFgTcXQ.js +30 -0
  259. package/dist/interface/dashboard/public/_nuxt/CdJZeyak.js +30 -0
  260. package/dist/interface/dashboard/public/_nuxt/D9vxbU2B.js +1 -0
  261. package/dist/interface/dashboard/public/_nuxt/DHg6ig_T.js +1 -0
  262. package/dist/interface/dashboard/public/_nuxt/DhFk2_Al.js +1 -0
  263. package/dist/interface/dashboard/public/_nuxt/DlAUqK2U.js +1 -0
  264. package/dist/interface/dashboard/public/_nuxt/DtX-aPBA.js +1 -0
  265. package/dist/interface/dashboard/public/_nuxt/DvCMYK3d.js +1 -0
  266. package/dist/interface/dashboard/public/_nuxt/builds/latest.json +1 -0
  267. package/dist/interface/dashboard/public/_nuxt/builds/meta/027020ec-4e7d-4fc7-8447-19800f7d0bac.json +1 -0
  268. package/dist/interface/dashboard/public/_nuxt/builds/meta/18e19101-a96b-41dc-b602-f9a8f013a036.json +1 -0
  269. package/dist/interface/dashboard/public/_nuxt/builds/meta/2fd3d0d3-6004-4659-9055-d27aa6656fd3.json +1 -0
  270. package/dist/interface/dashboard/public/_nuxt/builds/meta/54792d4b-ca55-4b5d-b0dd-1d7dc34de344.json +1 -0
  271. package/dist/interface/dashboard/public/_nuxt/builds/meta/5959a14b-2494-4e0d-be28-fef9adfd889d.json +1 -0
  272. package/dist/interface/dashboard/public/_nuxt/builds/meta/60cda583-d704-4d4e-b37e-7ab337e3b6cc.json +1 -0
  273. package/dist/interface/dashboard/public/_nuxt/builds/meta/64d05a43-99ec-4c22-934e-071b310b968f.json +1 -0
  274. package/dist/interface/dashboard/public/_nuxt/builds/meta/6c1632a5-f0af-41e3-9d88-12294e03a0b9.json +1 -0
  275. package/dist/interface/dashboard/public/_nuxt/builds/meta/6c80982c-5e2c-446c-aaf6-7000a976e493.json +1 -0
  276. package/dist/interface/dashboard/public/_nuxt/builds/meta/79161adb-748c-4d36-a031-a71899a56ecd.json +1 -0
  277. package/dist/interface/dashboard/public/_nuxt/builds/meta/84e5a87d-4ae5-48dd-8d5e-5b1fe89f7243.json +1 -0
  278. package/dist/interface/dashboard/public/_nuxt/builds/meta/86082677-a11d-4acf-ab04-c3c067a71622.json +1 -0
  279. package/dist/interface/dashboard/public/_nuxt/builds/meta/8892e611-c2b4-425b-a6a5-988314d8da4d.json +1 -0
  280. package/dist/interface/dashboard/public/_nuxt/builds/meta/9bfe6b22-73f8-4584-b13d-ed1df5600e12.json +1 -0
  281. package/dist/interface/dashboard/public/_nuxt/builds/meta/a39bf957-ddae-41a6-a183-08292363098b.json +1 -0
  282. package/dist/interface/dashboard/public/_nuxt/builds/meta/b0bf7fc4-02c1-46fd-acca-f4458feed978.json +1 -0
  283. package/dist/interface/dashboard/public/_nuxt/builds/meta/b2847d83-b695-45d4-9dca-d7498158a501.json +1 -0
  284. package/dist/interface/dashboard/public/_nuxt/builds/meta/c8382eda-1354-4f92-b6d0-5b5b9f43354a.json +1 -0
  285. package/dist/interface/dashboard/public/_nuxt/builds/meta/e707aa44-7202-413d-bcd5-1538b5b56570.json +1 -0
  286. package/dist/interface/dashboard/public/_nuxt/builds/meta/ea661002-05ab-4bfb-b02f-c91bb721c5e9.json +1 -0
  287. package/dist/interface/dashboard/public/_nuxt/builds/meta/f2f23a12-a792-480e-922a-ee8b73dc0310.json +1 -0
  288. package/dist/interface/dashboard/public/_nuxt/builds/meta/f6503b83-d731-40f8-9110-c1599663b3ba.json +1 -0
  289. package/dist/interface/dashboard/public/_nuxt/builds/meta/feac6d04-6bc5-4fa4-a241-79e897d7f8c1.json +1 -0
  290. package/dist/interface/dashboard/public/_nuxt/entry.BSUaoqsu.css +1 -0
  291. package/dist/interface/dashboard/public/_nuxt/entry.Bl31cpjT.css +1 -0
  292. package/dist/interface/dashboard/public/_nuxt/error-404.B6WzzNMA.css +1 -0
  293. package/dist/interface/dashboard/public/_nuxt/error-500.CVIcHofV.css +1 -0
  294. package/dist/interface/dashboard/public/_nuxt/index.BH5Gbe6q.css +1 -0
  295. package/dist/interface/dashboard/public/_nuxt/index.TQmbXYdV.css +1 -0
  296. package/dist/interface/dashboard/public/_nuxt/qq1iUjth.js +1 -0
  297. package/dist/interface/dashboard/public/favicon.ico +0 -0
  298. package/dist/interface/dashboard/public/index.html +1 -0
  299. package/dist/interface/dashboard/server.d.ts +11 -0
  300. package/dist/interface/dashboard/server.js +145 -0
  301. package/dist/interface/dashboard/server.js.map +1 -0
  302. package/dist/interface/dashboard/tool-wrapper.d.ts +4 -0
  303. package/dist/interface/dashboard/tool-wrapper.js +96 -0
  304. package/dist/interface/dashboard/tool-wrapper.js.map +1 -0
  305. package/dist/interface/mcp/server.d.ts +2 -0
  306. package/dist/interface/mcp/server.js +109 -0
  307. package/dist/interface/mcp/server.js.map +1 -0
  308. package/dist/interface/mcp/tools/add-cv.d.ts +3 -0
  309. package/dist/interface/mcp/tools/add-cv.js +21 -0
  310. package/dist/interface/mcp/tools/add-cv.js.map +1 -0
  311. package/dist/interface/mcp/tools/add-job-posting.d.ts +3 -0
  312. package/dist/interface/mcp/tools/add-job-posting.js +38 -0
  313. package/dist/interface/mcp/tools/add-job-posting.js.map +1 -0
  314. package/dist/interface/mcp/tools/add-pipeline-note.d.ts +3 -0
  315. package/dist/interface/mcp/tools/add-pipeline-note.js +32 -0
  316. package/dist/interface/mcp/tools/add-pipeline-note.js.map +1 -0
  317. package/dist/interface/mcp/tools/add-to-pipeline.d.ts +3 -0
  318. package/dist/interface/mcp/tools/add-to-pipeline.js +28 -0
  319. package/dist/interface/mcp/tools/add-to-pipeline.js.map +1 -0
  320. package/dist/interface/mcp/tools/bulk-add-cvs.d.ts +3 -0
  321. package/dist/interface/mcp/tools/bulk-add-cvs.js +28 -0
  322. package/dist/interface/mcp/tools/bulk-add-cvs.js.map +1 -0
  323. package/dist/interface/mcp/tools/delete-cv.d.ts +3 -0
  324. package/dist/interface/mcp/tools/delete-cv.js +20 -0
  325. package/dist/interface/mcp/tools/delete-cv.js.map +1 -0
  326. package/dist/interface/mcp/tools/delete-job-posting.d.ts +3 -0
  327. package/dist/interface/mcp/tools/delete-job-posting.js +27 -0
  328. package/dist/interface/mcp/tools/delete-job-posting.js.map +1 -0
  329. package/dist/interface/mcp/tools/export-results.d.ts +3 -0
  330. package/dist/interface/mcp/tools/export-results.js +23 -0
  331. package/dist/interface/mcp/tools/export-results.js.map +1 -0
  332. package/dist/interface/mcp/tools/filter-candidates.d.ts +3 -0
  333. package/dist/interface/mcp/tools/filter-candidates.js +32 -0
  334. package/dist/interface/mcp/tools/filter-candidates.js.map +1 -0
  335. package/dist/interface/mcp/tools/get-candidate-history.d.ts +3 -0
  336. package/dist/interface/mcp/tools/get-candidate-history.js +22 -0
  337. package/dist/interface/mcp/tools/get-candidate-history.js.map +1 -0
  338. package/dist/interface/mcp/tools/get-cv-chunks.d.ts +3 -0
  339. package/dist/interface/mcp/tools/get-cv-chunks.js +26 -0
  340. package/dist/interface/mcp/tools/get-cv-chunks.js.map +1 -0
  341. package/dist/interface/mcp/tools/get-cv-detail.d.ts +3 -0
  342. package/dist/interface/mcp/tools/get-cv-detail.js +23 -0
  343. package/dist/interface/mcp/tools/get-cv-detail.js.map +1 -0
  344. package/dist/interface/mcp/tools/get-cv-versions.d.ts +3 -0
  345. package/dist/interface/mcp/tools/get-cv-versions.js +20 -0
  346. package/dist/interface/mcp/tools/get-cv-versions.js.map +1 -0
  347. package/dist/interface/mcp/tools/get-job-posting.d.ts +3 -0
  348. package/dist/interface/mcp/tools/get-job-posting.js +26 -0
  349. package/dist/interface/mcp/tools/get-job-posting.js.map +1 -0
  350. package/dist/interface/mcp/tools/get-pending-actions.d.ts +3 -0
  351. package/dist/interface/mcp/tools/get-pending-actions.js +19 -0
  352. package/dist/interface/mcp/tools/get-pending-actions.js.map +1 -0
  353. package/dist/interface/mcp/tools/get-pipeline.d.ts +3 -0
  354. package/dist/interface/mcp/tools/get-pipeline.js +22 -0
  355. package/dist/interface/mcp/tools/get-pipeline.js.map +1 -0
  356. package/dist/interface/mcp/tools/get-server-status.d.ts +3 -0
  357. package/dist/interface/mcp/tools/get-server-status.js +38 -0
  358. package/dist/interface/mcp/tools/get-server-status.js.map +1 -0
  359. package/dist/interface/mcp/tools/get-stats.d.ts +3 -0
  360. package/dist/interface/mcp/tools/get-stats.js +19 -0
  361. package/dist/interface/mcp/tools/get-stats.js.map +1 -0
  362. package/dist/interface/mcp/tools/list-cvs.d.ts +3 -0
  363. package/dist/interface/mcp/tools/list-cvs.js +32 -0
  364. package/dist/interface/mcp/tools/list-cvs.js.map +1 -0
  365. package/dist/interface/mcp/tools/list-job-postings.d.ts +3 -0
  366. package/dist/interface/mcp/tools/list-job-postings.js +19 -0
  367. package/dist/interface/mcp/tools/list-job-postings.js.map +1 -0
  368. package/dist/interface/mcp/tools/manage-tags.d.ts +3 -0
  369. package/dist/interface/mcp/tools/manage-tags.js +24 -0
  370. package/dist/interface/mcp/tools/manage-tags.js.map +1 -0
  371. package/dist/interface/mcp/tools/match-candidates.d.ts +3 -0
  372. package/dist/interface/mcp/tools/match-candidates.js +23 -0
  373. package/dist/interface/mcp/tools/match-candidates.js.map +1 -0
  374. package/dist/interface/mcp/tools/reset-database.d.ts +3 -0
  375. package/dist/interface/mcp/tools/reset-database.js +35 -0
  376. package/dist/interface/mcp/tools/reset-database.js.map +1 -0
  377. package/dist/interface/mcp/tools/semantic-search.d.ts +3 -0
  378. package/dist/interface/mcp/tools/semantic-search.js +27 -0
  379. package/dist/interface/mcp/tools/semantic-search.js.map +1 -0
  380. package/dist/interface/mcp/tools/set-pending-action.d.ts +3 -0
  381. package/dist/interface/mcp/tools/set-pending-action.js +36 -0
  382. package/dist/interface/mcp/tools/set-pending-action.js.map +1 -0
  383. package/dist/interface/mcp/tools/update-cv.d.ts +3 -0
  384. package/dist/interface/mcp/tools/update-cv.js +23 -0
  385. package/dist/interface/mcp/tools/update-cv.js.map +1 -0
  386. package/dist/interface/mcp/tools/update-job-posting.d.ts +3 -0
  387. package/dist/interface/mcp/tools/update-job-posting.js +42 -0
  388. package/dist/interface/mcp/tools/update-job-posting.js.map +1 -0
  389. package/dist/interface/mcp/tools/update-pipeline-status.d.ts +3 -0
  390. package/dist/interface/mcp/tools/update-pipeline-status.js +41 -0
  391. package/dist/interface/mcp/tools/update-pipeline-status.js.map +1 -0
  392. package/dist/interface/mcp/types.d.ts +26 -0
  393. package/dist/interface/mcp/types.js +2 -0
  394. package/dist/interface/mcp/types.js.map +1 -0
  395. package/dist/shared/errors/index.d.ts +32 -0
  396. package/dist/shared/errors/index.js +56 -0
  397. package/dist/shared/errors/index.js.map +1 -0
  398. package/dist/shared/types/index.d.ts +19 -0
  399. package/dist/shared/types/index.js +2 -0
  400. package/dist/shared/types/index.js.map +1 -0
  401. package/dist/shared/utils/chunking.d.ts +3 -0
  402. package/dist/shared/utils/chunking.js +89 -0
  403. package/dist/shared/utils/chunking.js.map +1 -0
  404. package/dist/shared/utils/file-storage.d.ts +8 -0
  405. package/dist/shared/utils/file-storage.js +49 -0
  406. package/dist/shared/utils/file-storage.js.map +1 -0
  407. package/dist/shared/utils/index.d.ts +3 -0
  408. package/dist/shared/utils/index.js +4 -0
  409. package/dist/shared/utils/index.js.map +1 -0
  410. package/dist/shared/utils/text.d.ts +5 -0
  411. package/dist/shared/utils/text.js +21 -0
  412. package/dist/shared/utils/text.js.map +1 -0
  413. package/package.json +72 -0
@@ -0,0 +1,27 @@
1
+ import type { IApplicationRepository } from '../../domain/repositories/application-repository.js';
2
+ import type { IApplicationEventRepository } from '../../domain/repositories/application-event-repository.js';
3
+ import type { ICandidateRepository } from '../../domain/repositories/candidate-repository.js';
4
+ import type { IJobPostingRepository } from '../../domain/repositories/job-posting-repository.js';
5
+ import type { Application, ApplicationStatus } from '../../domain/entities/application.js';
6
+ import type { ApplicationEvent } from '../../domain/entities/application-event.js';
7
+ export interface PipelineEntry {
8
+ application: Application;
9
+ candidateName: string;
10
+ eventCount: number;
11
+ lastEvent?: ApplicationEvent;
12
+ }
13
+ export interface PipelineResult {
14
+ jobPostingId: string;
15
+ jobTitle: string;
16
+ entries: PipelineEntry[];
17
+ summary: Record<ApplicationStatus, number>;
18
+ totalApplications: number;
19
+ }
20
+ export declare class GetPipelineUseCase {
21
+ private applicationRepo;
22
+ private eventRepo;
23
+ private candidateRepo;
24
+ private jobPostingRepo;
25
+ constructor(applicationRepo: IApplicationRepository, eventRepo: IApplicationEventRepository, candidateRepo: ICandidateRepository, jobPostingRepo: IJobPostingRepository);
26
+ execute(jobPostingId: string): Promise<PipelineResult>;
27
+ }
@@ -0,0 +1,40 @@
1
+ export class GetPipelineUseCase {
2
+ applicationRepo;
3
+ eventRepo;
4
+ candidateRepo;
5
+ jobPostingRepo;
6
+ constructor(applicationRepo, eventRepo, candidateRepo, jobPostingRepo) {
7
+ this.applicationRepo = applicationRepo;
8
+ this.eventRepo = eventRepo;
9
+ this.candidateRepo = candidateRepo;
10
+ this.jobPostingRepo = jobPostingRepo;
11
+ }
12
+ async execute(jobPostingId) {
13
+ const jobPosting = await this.jobPostingRepo.findById(jobPostingId);
14
+ if (!jobPosting) {
15
+ throw new Error(`Job posting not found: ${jobPostingId}`);
16
+ }
17
+ const applications = await this.applicationRepo.findByJobPostingId(jobPostingId);
18
+ const entries = [];
19
+ const summary = {};
20
+ for (const app of applications) {
21
+ const candidate = await this.candidateRepo.findById(app.candidateId);
22
+ const events = await this.eventRepo.findByApplicationId(app.id);
23
+ entries.push({
24
+ application: app,
25
+ candidateName: candidate?.name ?? 'Unknown',
26
+ eventCount: events.length,
27
+ lastEvent: events.length > 0 ? events[events.length - 1] : undefined,
28
+ });
29
+ summary[app.status] = (summary[app.status] ?? 0) + 1;
30
+ }
31
+ return {
32
+ jobPostingId,
33
+ jobTitle: jobPosting.title,
34
+ entries,
35
+ summary: summary,
36
+ totalApplications: applications.length,
37
+ };
38
+ }
39
+ }
40
+ //# sourceMappingURL=get-pipeline.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-pipeline.js","sourceRoot":"","sources":["../../../src/application/use-cases/get-pipeline.ts"],"names":[],"mappings":"AAsBA,MAAM,OAAO,kBAAkB;IAEnB;IACA;IACA;IACA;IAJV,YACU,eAAuC,EACvC,SAAsC,EACtC,aAAmC,EACnC,cAAqC;QAHrC,oBAAe,GAAf,eAAe,CAAwB;QACvC,cAAS,GAAT,SAAS,CAA6B;QACtC,kBAAa,GAAb,aAAa,CAAsB;QACnC,mBAAc,GAAd,cAAc,CAAuB;IAC5C,CAAC;IAEJ,KAAK,CAAC,OAAO,CAAC,YAAoB;QAChC,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QACpE,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CAAC,0BAA0B,YAAY,EAAE,CAAC,CAAC;QAC5D,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;QAEjF,MAAM,OAAO,GAAoB,EAAE,CAAC;QACpC,MAAM,OAAO,GAA2B,EAAE,CAAC;QAE3C,KAAK,MAAM,GAAG,IAAI,YAAY,EAAE,CAAC;YAC/B,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;YACrE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEhE,OAAO,CAAC,IAAI,CAAC;gBACX,WAAW,EAAE,GAAG;gBAChB,aAAa,EAAE,SAAS,EAAE,IAAI,IAAI,SAAS;gBAC3C,UAAU,EAAE,MAAM,CAAC,MAAM;gBACzB,SAAS,EAAE,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;aACrE,CAAC,CAAC;YAEH,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QACvD,CAAC;QAED,OAAO;YACL,YAAY;YACZ,QAAQ,EAAE,UAAU,CAAC,KAAK;YAC1B,OAAO;YACP,OAAO,EAAE,OAA4C;YACrD,iBAAiB,EAAE,YAAY,CAAC,MAAM;SACvC,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,13 @@
1
+ import type { ICandidateRepository } from '../../domain/repositories/candidate-repository.js';
2
+ import type { IChunkRepository } from '../../domain/repositories/chunk-repository.js';
3
+ import type { IApplicationRepository } from '../../domain/repositories/application-repository.js';
4
+ import type { IApplicationEventRepository } from '../../domain/repositories/application-event-repository.js';
5
+ import type { StatsDto } from '../dto/stats.js';
6
+ export declare class GetStatsUseCase {
7
+ private candidateRepo;
8
+ private chunkRepo;
9
+ private applicationRepo?;
10
+ private applicationEventRepo?;
11
+ constructor(candidateRepo: ICandidateRepository, chunkRepo: IChunkRepository, applicationRepo?: IApplicationRepository | undefined, applicationEventRepo?: IApplicationEventRepository | undefined);
12
+ execute(): Promise<StatsDto>;
13
+ }
@@ -0,0 +1,50 @@
1
+ export class GetStatsUseCase {
2
+ candidateRepo;
3
+ chunkRepo;
4
+ applicationRepo;
5
+ applicationEventRepo;
6
+ constructor(candidateRepo, chunkRepo, applicationRepo, applicationEventRepo) {
7
+ this.candidateRepo = candidateRepo;
8
+ this.chunkRepo = chunkRepo;
9
+ this.applicationRepo = applicationRepo;
10
+ this.applicationEventRepo = applicationEventRepo;
11
+ }
12
+ async execute() {
13
+ const candidates = await this.candidateRepo.findAll();
14
+ const totalChunks = await this.chunkRepo.count();
15
+ const skillCounts = {};
16
+ const locationCounts = {};
17
+ const tagCounts = {};
18
+ let totalYears = 0;
19
+ let candidatesWithYears = 0;
20
+ for (const c of candidates) {
21
+ for (const skill of c.skills) {
22
+ skillCounts[skill] = (skillCounts[skill] ?? 0) + 1;
23
+ }
24
+ const location = c.contact.location;
25
+ if (location) {
26
+ locationCounts[location] = (locationCounts[location] ?? 0) + 1;
27
+ }
28
+ for (const tag of c.tags) {
29
+ tagCounts[tag] = (tagCounts[tag] ?? 0) + 1;
30
+ }
31
+ if (c.experienceYears !== undefined) {
32
+ totalYears += c.experienceYears;
33
+ candidatesWithYears++;
34
+ }
35
+ }
36
+ const totalApplications = this.applicationRepo ? await this.applicationRepo.count() : 0;
37
+ const totalApplicationEvents = this.applicationEventRepo ? await this.applicationEventRepo.count() : 0;
38
+ return {
39
+ totalCandidates: candidates.length,
40
+ totalChunks,
41
+ skillCounts,
42
+ locationCounts,
43
+ avgExperienceYears: candidatesWithYears > 0 ? totalYears / candidatesWithYears : 0,
44
+ tagCounts,
45
+ totalApplications,
46
+ totalApplicationEvents,
47
+ };
48
+ }
49
+ }
50
+ //# sourceMappingURL=get-stats.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-stats.js","sourceRoot":"","sources":["../../../src/application/use-cases/get-stats.ts"],"names":[],"mappings":"AAMA,MAAM,OAAO,eAAe;IAEhB;IACA;IACA;IACA;IAJV,YACU,aAAmC,EACnC,SAA2B,EAC3B,eAAwC,EACxC,oBAAkD;QAHlD,kBAAa,GAAb,aAAa,CAAsB;QACnC,cAAS,GAAT,SAAS,CAAkB;QAC3B,oBAAe,GAAf,eAAe,CAAyB;QACxC,yBAAoB,GAApB,oBAAoB,CAA8B;IACzD,CAAC;IAEJ,KAAK,CAAC,OAAO;QACX,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;QACtD,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QAEjD,MAAM,WAAW,GAA2B,EAAE,CAAC;QAC/C,MAAM,cAAc,GAA2B,EAAE,CAAC;QAClD,MAAM,SAAS,GAA2B,EAAE,CAAC;QAC7C,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,IAAI,mBAAmB,GAAG,CAAC,CAAC;QAE5B,KAAK,MAAM,CAAC,IAAI,UAAU,EAAE,CAAC;YAC3B,KAAK,MAAM,KAAK,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;gBAC7B,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;YACrD,CAAC;YAED,MAAM,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC;YACpC,IAAI,QAAQ,EAAE,CAAC;gBACb,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;YACjE,CAAC;YAED,KAAK,MAAM,GAAG,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;gBACzB,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;YAC7C,CAAC;YAED,IAAI,CAAC,CAAC,eAAe,KAAK,SAAS,EAAE,CAAC;gBACpC,UAAU,IAAI,CAAC,CAAC,eAAe,CAAC;gBAChC,mBAAmB,EAAE,CAAC;YACxB,CAAC;QACH,CAAC;QAED,MAAM,iBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACxF,MAAM,sBAAsB,GAAG,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAEvG,OAAO;YACL,eAAe,EAAE,UAAU,CAAC,MAAM;YAClC,WAAW;YACX,WAAW;YACX,cAAc;YACd,kBAAkB,EAAE,mBAAmB,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,GAAG,mBAAmB,CAAC,CAAC,CAAC,CAAC;YAClF,SAAS;YACT,iBAAiB;YACjB,sBAAsB;SACvB,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,23 @@
1
+ export { AddCvUseCase } from './add-cv.js';
2
+ export { UpdateCvUseCase } from './update-cv.js';
3
+ export { SemanticSearchUseCase } from './semantic-search.js';
4
+ export { FilterCandidatesUseCase } from './filter-candidates.js';
5
+ export { GetCvDetailUseCase } from './get-cv-detail.js';
6
+ export { GetCvChunksUseCase } from './get-cv-chunks.js';
7
+ export { ListCvsUseCase } from './list-cvs.js';
8
+ export { DeleteCvUseCase } from './delete-cv.js';
9
+ export { ManageTagsUseCase } from './manage-tags.js';
10
+ export { GetCvVersionsUseCase } from './get-cv-versions.js';
11
+ export { GetStatsUseCase } from './get-stats.js';
12
+ export { ExportResultsUseCase } from './export-results.js';
13
+ export { AddJobPostingUseCase } from './add-job-posting.js';
14
+ export { UpdateJobPostingUseCase } from './update-job-posting.js';
15
+ export { ListJobPostingsUseCase } from './list-job-postings.js';
16
+ export { MatchCandidatesUseCase } from './match-candidates.js';
17
+ export { AddToPipelineUseCase } from './add-to-pipeline.js';
18
+ export { UpdatePipelineStatusUseCase } from './update-pipeline-status.js';
19
+ export { AddPipelineNoteUseCase } from './add-pipeline-note.js';
20
+ export { SetPendingActionUseCase } from './set-pending-action.js';
21
+ export { GetPipelineUseCase } from './get-pipeline.js';
22
+ export { GetCandidateHistoryUseCase } from './get-candidate-history.js';
23
+ export { GetPendingActionsUseCase } from './get-pending-actions.js';
@@ -0,0 +1,24 @@
1
+ export { AddCvUseCase } from './add-cv.js';
2
+ export { UpdateCvUseCase } from './update-cv.js';
3
+ export { SemanticSearchUseCase } from './semantic-search.js';
4
+ export { FilterCandidatesUseCase } from './filter-candidates.js';
5
+ export { GetCvDetailUseCase } from './get-cv-detail.js';
6
+ export { GetCvChunksUseCase } from './get-cv-chunks.js';
7
+ export { ListCvsUseCase } from './list-cvs.js';
8
+ export { DeleteCvUseCase } from './delete-cv.js';
9
+ export { ManageTagsUseCase } from './manage-tags.js';
10
+ export { GetCvVersionsUseCase } from './get-cv-versions.js';
11
+ export { GetStatsUseCase } from './get-stats.js';
12
+ export { ExportResultsUseCase } from './export-results.js';
13
+ export { AddJobPostingUseCase } from './add-job-posting.js';
14
+ export { UpdateJobPostingUseCase } from './update-job-posting.js';
15
+ export { ListJobPostingsUseCase } from './list-job-postings.js';
16
+ export { MatchCandidatesUseCase } from './match-candidates.js';
17
+ export { AddToPipelineUseCase } from './add-to-pipeline.js';
18
+ export { UpdatePipelineStatusUseCase } from './update-pipeline-status.js';
19
+ export { AddPipelineNoteUseCase } from './add-pipeline-note.js';
20
+ export { SetPendingActionUseCase } from './set-pending-action.js';
21
+ export { GetPipelineUseCase } from './get-pipeline.js';
22
+ export { GetCandidateHistoryUseCase } from './get-candidate-history.js';
23
+ export { GetPendingActionsUseCase } from './get-pending-actions.js';
24
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/application/use-cases/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAE,2BAA2B,EAAE,MAAM,6BAA6B,CAAC;AAC1E,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,0BAA0B,EAAE,MAAM,4BAA4B,CAAC;AACxE,OAAO,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { ICandidateRepository } from '../../domain/repositories/candidate-repository.js';
2
+ import type { CandidateSummaryDto } from '../dto/candidate-summary.js';
3
+ import type { PaginationOptions, SortOptions } from '../../shared/types/index.js';
4
+ export declare class ListCvsUseCase {
5
+ private candidateRepo;
6
+ constructor(candidateRepo: ICandidateRepository);
7
+ execute(pagination?: PaginationOptions, sort?: SortOptions): Promise<CandidateSummaryDto[]>;
8
+ }
@@ -0,0 +1,20 @@
1
+ export class ListCvsUseCase {
2
+ candidateRepo;
3
+ constructor(candidateRepo) {
4
+ this.candidateRepo = candidateRepo;
5
+ }
6
+ async execute(pagination, sort) {
7
+ const candidates = await this.candidateRepo.findAll(pagination, sort);
8
+ return candidates.map((c) => ({
9
+ id: c.id,
10
+ name: c.name,
11
+ email: c.contact.email,
12
+ location: c.contact.location,
13
+ skills: c.skills,
14
+ experienceYears: c.experienceYears,
15
+ tags: c.tags,
16
+ createdAt: c.createdAt,
17
+ }));
18
+ }
19
+ }
20
+ //# sourceMappingURL=list-cvs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-cvs.js","sourceRoot":"","sources":["../../../src/application/use-cases/list-cvs.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,cAAc;IACL;IAApB,YAAoB,aAAmC;QAAnC,kBAAa,GAAb,aAAa,CAAsB;IAAG,CAAC;IAE3D,KAAK,CAAC,OAAO,CAAC,UAA8B,EAAE,IAAkB;QAC9D,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QACtE,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC5B,EAAE,EAAE,CAAC,CAAC,EAAE;YACR,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK;YACtB,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ;YAC5B,MAAM,EAAE,CAAC,CAAC,MAAM;YAChB,eAAe,EAAE,CAAC,CAAC,eAAe;YAClC,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,SAAS,EAAE,CAAC,CAAC,SAAS;SACvB,CAAC,CAAC,CAAC;IACN,CAAC;CACF"}
@@ -0,0 +1,7 @@
1
+ import type { IJobPostingRepository } from '../../domain/repositories/job-posting-repository.js';
2
+ import type { JobPosting } from '../../domain/entities/job-posting.js';
3
+ export declare class ListJobPostingsUseCase {
4
+ private jobPostingRepo;
5
+ constructor(jobPostingRepo: IJobPostingRepository);
6
+ execute(): Promise<JobPosting[]>;
7
+ }
@@ -0,0 +1,10 @@
1
+ export class ListJobPostingsUseCase {
2
+ jobPostingRepo;
3
+ constructor(jobPostingRepo) {
4
+ this.jobPostingRepo = jobPostingRepo;
5
+ }
6
+ async execute() {
7
+ return this.jobPostingRepo.findAll();
8
+ }
9
+ }
10
+ //# sourceMappingURL=list-job-postings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-job-postings.js","sourceRoot":"","sources":["../../../src/application/use-cases/list-job-postings.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,sBAAsB;IACb;IAApB,YAAoB,cAAqC;QAArC,mBAAc,GAAd,cAAc,CAAuB;IAAG,CAAC;IAE7D,KAAK,CAAC,OAAO;QACX,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;IACvC,CAAC;CACF"}
@@ -0,0 +1,7 @@
1
+ import type { ICandidateRepository } from '../../domain/repositories/candidate-repository.js';
2
+ import type { TagAction } from '../../shared/types/index.js';
3
+ export declare class ManageTagsUseCase {
4
+ private candidateRepo;
5
+ constructor(candidateRepo: ICandidateRepository);
6
+ execute(candidateId: string, action: TagAction, tags?: string[]): Promise<string[]>;
7
+ }
@@ -0,0 +1,36 @@
1
+ import { CandidateNotFoundError } from '../../shared/errors/index.js';
2
+ export class ManageTagsUseCase {
3
+ candidateRepo;
4
+ constructor(candidateRepo) {
5
+ this.candidateRepo = candidateRepo;
6
+ }
7
+ async execute(candidateId, action, tags) {
8
+ const candidate = await this.candidateRepo.findById(candidateId);
9
+ if (!candidate) {
10
+ throw new CandidateNotFoundError(candidateId);
11
+ }
12
+ if (action === 'list') {
13
+ return candidate.tags;
14
+ }
15
+ let updatedTags;
16
+ if (action === 'add' && tags) {
17
+ const set = new Set([...candidate.tags, ...tags]);
18
+ updatedTags = [...set];
19
+ }
20
+ else if (action === 'remove' && tags) {
21
+ const removeSet = new Set(tags);
22
+ updatedTags = candidate.tags.filter((t) => !removeSet.has(t));
23
+ }
24
+ else {
25
+ return candidate.tags;
26
+ }
27
+ const updated = {
28
+ ...candidate,
29
+ tags: updatedTags,
30
+ updatedAt: new Date().toISOString(),
31
+ };
32
+ await this.candidateRepo.update(updated);
33
+ return updatedTags;
34
+ }
35
+ }
36
+ //# sourceMappingURL=manage-tags.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"manage-tags.js","sourceRoot":"","sources":["../../../src/application/use-cases/manage-tags.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AAEtE,MAAM,OAAO,iBAAiB;IACR;IAApB,YAAoB,aAAmC;QAAnC,kBAAa,GAAb,aAAa,CAAsB;IAAG,CAAC;IAE3D,KAAK,CAAC,OAAO,CAAC,WAAmB,EAAE,MAAiB,EAAE,IAAe;QACnE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QACjE,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,sBAAsB,CAAC,WAAW,CAAC,CAAC;QAChD,CAAC;QAED,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;YACtB,OAAO,SAAS,CAAC,IAAI,CAAC;QACxB,CAAC;QAED,IAAI,WAAqB,CAAC;QAE1B,IAAI,MAAM,KAAK,KAAK,IAAI,IAAI,EAAE,CAAC;YAC7B,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;YAClD,WAAW,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC;QACzB,CAAC;aAAM,IAAI,MAAM,KAAK,QAAQ,IAAI,IAAI,EAAE,CAAC;YACvC,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC;YAChC,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAChE,CAAC;aAAM,CAAC;YACN,OAAO,SAAS,CAAC,IAAI,CAAC;QACxB,CAAC;QAED,MAAM,OAAO,GAAG;YACd,GAAG,SAAS;YACZ,IAAI,EAAE,WAAW;YACjB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACpC,CAAC;QAEF,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACzC,OAAO,WAAW,CAAC;IACrB,CAAC;CACF"}
@@ -0,0 +1,27 @@
1
+ import type { IJobPostingRepository } from '../../domain/repositories/job-posting-repository.js';
2
+ import type { ICandidateRepository } from '../../domain/repositories/candidate-repository.js';
3
+ import type { IChunkRepository } from '../../domain/repositories/chunk-repository.js';
4
+ import type { IApplicationRepository } from '../../domain/repositories/application-repository.js';
5
+ import type { IEmbeddingService } from '../ports/embedding-service.js';
6
+ import type { ApplicationStatus } from '../../domain/entities/application.js';
7
+ export interface MatchResult {
8
+ candidateId: string;
9
+ candidateName: string;
10
+ compositeScore: number;
11
+ vectorScore: number;
12
+ skillOverlap: number;
13
+ loyaltyFactor: number;
14
+ matchedSkills: string[];
15
+ missingSkills: string[];
16
+ pipelineStatus?: ApplicationStatus;
17
+ }
18
+ export declare class MatchCandidatesUseCase {
19
+ private jobPostingRepo;
20
+ private candidateRepo;
21
+ private chunkRepo;
22
+ private embeddingService;
23
+ private applicationRepo?;
24
+ constructor(jobPostingRepo: IJobPostingRepository, candidateRepo: ICandidateRepository, chunkRepo: IChunkRepository, embeddingService: IEmbeddingService, applicationRepo?: IApplicationRepository | undefined);
25
+ execute(jobPostingId: string, limit?: number): Promise<MatchResult[]>;
26
+ private computeSkillOverlap;
27
+ }
@@ -0,0 +1,92 @@
1
+ const LOYALTY_FACTORS = {
2
+ stable: 1.0,
3
+ moderate: 0.7,
4
+ flight_risk: 0.4,
5
+ };
6
+ export class MatchCandidatesUseCase {
7
+ jobPostingRepo;
8
+ candidateRepo;
9
+ chunkRepo;
10
+ embeddingService;
11
+ applicationRepo;
12
+ constructor(jobPostingRepo, candidateRepo, chunkRepo, embeddingService, applicationRepo) {
13
+ this.jobPostingRepo = jobPostingRepo;
14
+ this.candidateRepo = candidateRepo;
15
+ this.chunkRepo = chunkRepo;
16
+ this.embeddingService = embeddingService;
17
+ this.applicationRepo = applicationRepo;
18
+ }
19
+ async execute(jobPostingId, limit = 10) {
20
+ const jobPosting = await this.jobPostingRepo.findById(jobPostingId);
21
+ if (!jobPosting) {
22
+ throw new Error(`Job posting not found: ${jobPostingId}`);
23
+ }
24
+ // Build search text from job posting (prefer rawText for richer semantic matching)
25
+ const searchText = [jobPosting.rawText, jobPosting.description, jobPosting.requirements].filter(Boolean).join('\n');
26
+ const [queryVector] = await this.embeddingService.embedBatch([searchText]);
27
+ // Search chunks (fetch more than needed to aggregate by candidate)
28
+ const chunkLimit = limit * 5;
29
+ const searchResults = await this.chunkRepo.semanticSearch(queryVector, chunkLimit);
30
+ // Aggregate by candidateId — keep best chunk score per candidate
31
+ const candidateScores = new Map();
32
+ for (const result of searchResults) {
33
+ const cid = result.chunk.candidateId;
34
+ const existing = candidateScores.get(cid);
35
+ if (existing === undefined || result.score > existing) {
36
+ candidateScores.set(cid, result.score);
37
+ }
38
+ }
39
+ // Fetch candidate details and compute composite scores
40
+ const requiredSkillsLower = jobPosting.requiredSkills.map((s) => s.toLowerCase());
41
+ const results = [];
42
+ for (const [candidateId, vectorScore] of candidateScores) {
43
+ const candidate = await this.candidateRepo.findById(candidateId);
44
+ if (!candidate)
45
+ continue;
46
+ const { skillOverlap, matchedSkills, missingSkills } = this.computeSkillOverlap(candidate, requiredSkillsLower, jobPosting.requiredSkills);
47
+ const loyaltyFactor = LOYALTY_FACTORS[candidate.loyaltyScore ?? ''] ?? 0.7;
48
+ const compositeScore = 0.5 * vectorScore + 0.3 * skillOverlap + 0.2 * loyaltyFactor;
49
+ // Check pipeline status
50
+ let pipelineStatus;
51
+ if (this.applicationRepo) {
52
+ const existing = await this.applicationRepo.findByJobAndCandidate(jobPosting.id, candidateId);
53
+ if (existing) {
54
+ pipelineStatus = existing.status;
55
+ }
56
+ }
57
+ results.push({
58
+ candidateId,
59
+ candidateName: candidate.name,
60
+ compositeScore: Math.round(compositeScore * 1000) / 1000,
61
+ vectorScore: Math.round(vectorScore * 1000) / 1000,
62
+ skillOverlap: Math.round(skillOverlap * 1000) / 1000,
63
+ loyaltyFactor,
64
+ matchedSkills,
65
+ missingSkills,
66
+ pipelineStatus,
67
+ });
68
+ }
69
+ // Sort by composite score descending, return top N
70
+ results.sort((a, b) => b.compositeScore - a.compositeScore);
71
+ return results.slice(0, limit);
72
+ }
73
+ computeSkillOverlap(candidate, requiredSkillsLower, requiredSkillsOriginal) {
74
+ if (requiredSkillsLower.length === 0) {
75
+ return { skillOverlap: 1, matchedSkills: [], missingSkills: [] };
76
+ }
77
+ const candidateSkillsLower = candidate.skills.map((s) => s.toLowerCase());
78
+ const matchedSkills = [];
79
+ const missingSkills = [];
80
+ for (let i = 0; i < requiredSkillsLower.length; i++) {
81
+ if (candidateSkillsLower.includes(requiredSkillsLower[i])) {
82
+ matchedSkills.push(requiredSkillsOriginal[i]);
83
+ }
84
+ else {
85
+ missingSkills.push(requiredSkillsOriginal[i]);
86
+ }
87
+ }
88
+ const skillOverlap = matchedSkills.length / requiredSkillsLower.length;
89
+ return { skillOverlap, matchedSkills, missingSkills };
90
+ }
91
+ }
92
+ //# sourceMappingURL=match-candidates.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"match-candidates.js","sourceRoot":"","sources":["../../../src/application/use-cases/match-candidates.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import type { IChunkRepository } from '../../domain/repositories/chunk-repository.js';
2
+ import type { ICandidateRepository } from '../../domain/repositories/candidate-repository.js';
3
+ import type { IEmbeddingService } from '../ports/embedding-service.js';
4
+ import type { SearchInput, SearchResultDto } from '../dto/search-results.js';
5
+ export declare class SemanticSearchUseCase {
6
+ private chunkRepo;
7
+ private embeddingService;
8
+ private candidateRepo;
9
+ constructor(chunkRepo: IChunkRepository, embeddingService: IEmbeddingService, candidateRepo: ICandidateRepository);
10
+ execute(input: SearchInput): Promise<SearchResultDto[]>;
11
+ }
@@ -0,0 +1,40 @@
1
+ import { escapeFilterValue } from '../../shared/utils/text.js';
2
+ export class SemanticSearchUseCase {
3
+ chunkRepo;
4
+ embeddingService;
5
+ candidateRepo;
6
+ constructor(chunkRepo, embeddingService, candidateRepo) {
7
+ this.chunkRepo = chunkRepo;
8
+ this.embeddingService = embeddingService;
9
+ this.candidateRepo = candidateRepo;
10
+ }
11
+ async execute(input) {
12
+ const queryVector = await this.embeddingService.embed(input.query);
13
+ const limit = input.limit ?? 10;
14
+ let filter;
15
+ if (input.sectionType) {
16
+ filter = `section_type = '${escapeFilterValue(input.sectionType)}'`;
17
+ }
18
+ const results = await this.chunkRepo.semanticSearch(queryVector, limit, filter);
19
+ const candidateCache = new Map();
20
+ const dtos = [];
21
+ for (const result of results) {
22
+ let candidateName = candidateCache.get(result.chunk.candidateId);
23
+ if (!candidateName) {
24
+ const candidate = await this.candidateRepo.findById(result.chunk.candidateId);
25
+ candidateName = candidate?.name ?? 'Unknown';
26
+ candidateCache.set(result.chunk.candidateId, candidateName);
27
+ }
28
+ dtos.push({
29
+ candidateId: result.chunk.candidateId,
30
+ candidateName,
31
+ sectionType: result.chunk.sectionType,
32
+ content: result.chunk.content,
33
+ score: result.score,
34
+ metadata: result.chunk.metadata,
35
+ });
36
+ }
37
+ return dtos;
38
+ }
39
+ }
40
+ //# sourceMappingURL=semantic-search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"semantic-search.js","sourceRoot":"","sources":["../../../src/application/use-cases/semantic-search.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAE/D,MAAM,OAAO,qBAAqB;IAEtB;IACA;IACA;IAHV,YACU,SAA2B,EAC3B,gBAAmC,EACnC,aAAmC;QAFnC,cAAS,GAAT,SAAS,CAAkB;QAC3B,qBAAgB,GAAhB,gBAAgB,CAAmB;QACnC,kBAAa,GAAb,aAAa,CAAsB;IAC1C,CAAC;IAEJ,KAAK,CAAC,OAAO,CAAC,KAAkB;QAC9B,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACnE,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC;QAEhC,IAAI,MAA0B,CAAC;QAC/B,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,GAAG,mBAAmB,iBAAiB,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC;QACtE,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,WAAW,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;QAEhF,MAAM,cAAc,GAAG,IAAI,GAAG,EAAkB,CAAC;QAEjD,MAAM,IAAI,GAAsB,EAAE,CAAC;QACnC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,aAAa,GAAG,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YACjE,IAAI,CAAC,aAAa,EAAE,CAAC;gBACnB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;gBAC9E,aAAa,GAAG,SAAS,EAAE,IAAI,IAAI,SAAS,CAAC;gBAC7C,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;YAC9D,CAAC;YAED,IAAI,CAAC,IAAI,CAAC;gBACR,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,WAAW;gBACrC,aAAa;gBACb,WAAW,EAAE,MAAM,CAAC,KAAK,CAAC,WAAW;gBACrC,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO;gBAC7B,KAAK,EAAE,MAAM,CAAC,KAAK;gBACnB,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,QAAQ;aAChC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -0,0 +1,13 @@
1
+ import type { IApplicationRepository } from '../../domain/repositories/application-repository.js';
2
+ import type { Application } from '../../domain/entities/application.js';
3
+ export interface SetPendingActionInput {
4
+ applicationId: string;
5
+ action?: string;
6
+ dueDate?: string;
7
+ owner?: 'us' | 'candidate';
8
+ }
9
+ export declare class SetPendingActionUseCase {
10
+ private applicationRepo;
11
+ constructor(applicationRepo: IApplicationRepository);
12
+ execute(input: SetPendingActionInput): Promise<Application>;
13
+ }
@@ -0,0 +1,24 @@
1
+ export class SetPendingActionUseCase {
2
+ applicationRepo;
3
+ constructor(applicationRepo) {
4
+ this.applicationRepo = applicationRepo;
5
+ }
6
+ async execute(input) {
7
+ const application = await this.applicationRepo.findById(input.applicationId);
8
+ if (!application) {
9
+ throw new Error(`Application not found: ${input.applicationId}`);
10
+ }
11
+ const now = new Date().toISOString();
12
+ // If no action provided, clear pending action
13
+ const updated = {
14
+ ...application,
15
+ pendingAction: input.action,
16
+ pendingActionDue: input.dueDate,
17
+ pendingActionOwner: input.owner,
18
+ updatedAt: now,
19
+ };
20
+ await this.applicationRepo.update(updated);
21
+ return updated;
22
+ }
23
+ }
24
+ //# sourceMappingURL=set-pending-action.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"set-pending-action.js","sourceRoot":"","sources":["../../../src/application/use-cases/set-pending-action.ts"],"names":[],"mappings":"AAUA,MAAM,OAAO,uBAAuB;IACd;IAApB,YAAoB,eAAuC;QAAvC,oBAAe,GAAf,eAAe,CAAwB;IAAG,CAAC;IAE/D,KAAK,CAAC,OAAO,CAAC,KAA4B;QACxC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAC7E,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,0BAA0B,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC;QACnE,CAAC;QAED,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAErC,8CAA8C;QAC9C,MAAM,OAAO,GAAgB;YAC3B,GAAG,WAAW;YACd,aAAa,EAAE,KAAK,CAAC,MAAM;YAC3B,gBAAgB,EAAE,KAAK,CAAC,OAAO;YAC/B,kBAAkB,EAAE,KAAK,CAAC,KAAK;YAC/B,SAAS,EAAE,GAAG;SACf,CAAC;QAEF,MAAM,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAE3C,OAAO,OAAO,CAAC;IACjB,CAAC;CACF"}
@@ -0,0 +1,17 @@
1
+ import type { ICandidateRepository } from '../../domain/repositories/candidate-repository.js';
2
+ import type { IChunkRepository } from '../../domain/repositories/chunk-repository.js';
3
+ import type { IVersionRepository } from '../../domain/repositories/version-repository.js';
4
+ import type { Candidate } from '../../domain/entities/candidate.js';
5
+ import type { IDocumentParser } from '../ports/document-parser.js';
6
+ import type { IEmbeddingService } from '../ports/embedding-service.js';
7
+ import type { IStructuredExtractor } from '../ports/structured-extractor.js';
8
+ export declare class UpdateCvUseCase {
9
+ private candidateRepo;
10
+ private chunkRepo;
11
+ private versionRepo;
12
+ private parsers;
13
+ private embeddingService;
14
+ private extractor;
15
+ constructor(candidateRepo: ICandidateRepository, chunkRepo: IChunkRepository, versionRepo: IVersionRepository, parsers: IDocumentParser[], embeddingService: IEmbeddingService, extractor: IStructuredExtractor);
16
+ execute(candidateId: string, filePath: string): Promise<Candidate>;
17
+ }