@goplusvn/core 0.1.0 → 0.1.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 (591) hide show
  1. package/package.json +31 -175
  2. package/src/assets/erp_wallpaper.png +0 -0
  3. package/src/assets/goeat_logo.png +0 -0
  4. package/src/audit/audit-manager.ts +139 -0
  5. package/src/audit/index.ts +11 -0
  6. package/src/audit/memory-audit-logger.ts +86 -0
  7. package/src/audit/types.ts +50 -0
  8. package/src/auth/auth-service.ts +97 -0
  9. package/src/auth/index.ts +266 -0
  10. package/src/code-generation/index.ts +69 -0
  11. package/src/configs/auth-routes.ts +17 -0
  12. package/src/configs/crud.ts +136 -0
  13. package/src/configs/data/navigations.ts +781 -0
  14. package/src/configs/data/oauth-links.ts +10 -0
  15. package/src/configs/entities/material-categories.config.ts +125 -0
  16. package/src/configs/i18n.ts +12 -0
  17. package/src/configs/index.ts +26 -0
  18. package/src/configs/status.ts +25 -0
  19. package/src/configs/themes.ts +100 -0
  20. package/src/crud/components/crud-bulk-actions.tsx +91 -0
  21. package/src/crud/components/crud-card-view.tsx +241 -0
  22. package/src/crud/components/crud-context.tsx +122 -0
  23. package/src/crud/components/crud-delete-dialog.tsx +145 -0
  24. package/src/crud/components/crud-dialog.tsx +406 -0
  25. package/src/crud/components/crud-empty-state.tsx +104 -0
  26. package/src/crud/components/crud-export-button.tsx +170 -0
  27. package/src/crud/components/crud-field-renderer.tsx +653 -0
  28. package/src/crud/components/crud-filter-chips.tsx +102 -0
  29. package/src/crud/components/crud-filters/checkbox-filter.tsx +97 -0
  30. package/src/crud/components/crud-filters/datetime-filter.tsx +83 -0
  31. package/src/crud/components/crud-filters/filter-builder.tsx +66 -0
  32. package/src/crud/components/crud-filters/index.tsx +76 -0
  33. package/src/crud/components/crud-filters/radio-filter.tsx +86 -0
  34. package/src/crud/components/crud-filters/select-filter.tsx +141 -0
  35. package/src/crud/components/crud-filters/text-filter.tsx +86 -0
  36. package/src/crud/components/crud-form.tsx +642 -0
  37. package/src/crud/components/crud-import-dialog.tsx +440 -0
  38. package/src/crud/components/crud-infinite-scroll.tsx +116 -0
  39. package/src/crud/components/crud-page.tsx +1017 -0
  40. package/src/crud/components/crud-provider.tsx +277 -0
  41. package/src/crud/components/crud-row-actions.tsx +189 -0
  42. package/src/crud/components/crud-search.tsx +82 -0
  43. package/src/crud/components/crud-sheet.tsx +336 -0
  44. package/src/crud/components/crud-table-skeleton.tsx +26 -0
  45. package/src/crud/components/crud-table-toolbar.tsx +91 -0
  46. package/src/crud/components/crud-table.tsx +352 -0
  47. package/src/crud/components/crud-virtual-table.tsx +55 -0
  48. package/src/crud/components/index.tsx +20 -0
  49. package/src/crud/crud-filters/checkbox-filter.tsx +87 -0
  50. package/src/crud/crud-filters/datetime-filter.tsx +82 -0
  51. package/src/crud/crud-filters/filter-builder.tsx +64 -0
  52. package/src/crud/crud-filters/index.tsx +78 -0
  53. package/src/crud/crud-filters/radio-filter.tsx +79 -0
  54. package/src/crud/crud-filters/select-filter.tsx +148 -0
  55. package/src/crud/crud-filters/text-filter.tsx +81 -0
  56. package/src/crud/index.ts +43 -0
  57. package/src/crud/lib/crud-service.test.ts +334 -0
  58. package/src/crud/lib/crud-service.ts +358 -0
  59. package/src/crud/lib/crud-utils.test.ts +354 -0
  60. package/src/crud/lib/crud-utils.ts +299 -0
  61. package/src/crud/lib/crud-validator.ts +247 -0
  62. package/src/crud/lib/data-loader.ts +234 -0
  63. package/src/crud/lib/field-calculator.ts +241 -0
  64. package/src/crud/lib/field-formatter.ts +240 -0
  65. package/src/crud/lib/import-export-service.test.ts +290 -0
  66. package/src/crud/lib/import-export-service.ts +352 -0
  67. package/src/crud/lib/import-server-utils.ts +109 -0
  68. package/src/crud/lib/lazy-loader.ts +241 -0
  69. package/src/crud/lib/parse-filters.ts +85 -0
  70. package/src/crud/lib/permissions.ts +52 -0
  71. package/src/crud/lib/serialize-config.ts +60 -0
  72. package/src/crud/lib/stream-loader.ts +145 -0
  73. package/src/crud/lib/translate-config.ts +335 -0
  74. package/src/crud/lib/types.ts +11 -0
  75. package/src/crud/pages/entity-crud-page.tsx +144 -0
  76. package/src/crud/server.ts +8 -0
  77. package/src/home/constants.tsx +142 -0
  78. package/src/home/feature-showcase.tsx +171 -0
  79. package/src/home/home-page.tsx +191 -0
  80. package/src/home/hooks/index.ts +1 -0
  81. package/src/home/hooks/useWidgetPreferences.ts +167 -0
  82. package/src/home/index.ts +33 -0
  83. package/src/home/quick-access-dialog.tsx +271 -0
  84. package/src/home/quick-access-menu.tsx +267 -0
  85. package/src/home/types.ts +140 -0
  86. package/src/home/welcome-card.tsx +92 -0
  87. package/src/home/widget-container.tsx +258 -0
  88. package/src/home/widgets/base-widget.tsx +200 -0
  89. package/src/home/widgets/customers-widget.tsx +74 -0
  90. package/src/home/widgets/index.ts +6 -0
  91. package/src/home/widgets/orders-widget.tsx +87 -0
  92. package/src/home/widgets/revenue-widget.tsx +71 -0
  93. package/src/home/widgets/stock-widget.tsx +109 -0
  94. package/src/hooks/index.tsx +598 -0
  95. package/src/hooks/use-tenant.test.tsx +30 -0
  96. package/src/hooks/use-tenant.ts +5 -0
  97. package/src/index.ts +17 -0
  98. package/src/infrastructure/__tests__/architecture-verification.spec.ts +103 -0
  99. package/src/infrastructure/api-service.ts +317 -0
  100. package/src/infrastructure/cache/cache-manager.ts +107 -0
  101. package/src/infrastructure/cache/cache.ts +120 -0
  102. package/src/infrastructure/cache/index.ts +8 -0
  103. package/src/infrastructure/cache/types.ts +48 -0
  104. package/src/infrastructure/cron/cron-manager.ts +239 -0
  105. package/src/infrastructure/cron/index.ts +6 -0
  106. package/src/infrastructure/cron/types.ts +41 -0
  107. package/src/infrastructure/event-bus/event-bus.ts +145 -0
  108. package/src/infrastructure/event-bus/index.ts +2 -0
  109. package/src/infrastructure/event-bus/types.ts +22 -0
  110. package/src/infrastructure/index.ts +32 -0
  111. package/src/infrastructure/lock/decorators.ts +67 -0
  112. package/src/infrastructure/lock/index.ts +2 -0
  113. package/src/infrastructure/lock/lock-manager.ts +33 -0
  114. package/src/infrastructure/logger/index.ts +2 -0
  115. package/src/infrastructure/logger/logger.ts +96 -0
  116. package/src/infrastructure/logger/types.ts +25 -0
  117. package/src/layout/index.tsx +185 -0
  118. package/src/navigation/index.ts +91 -0
  119. package/src/notification/index.ts +14 -0
  120. package/src/notification/notification-service.ts +120 -0
  121. package/src/notification/storage/in-memory.ts +56 -0
  122. package/src/notification/storage/index.ts +1 -0
  123. package/src/notification/types.ts +51 -0
  124. package/src/organization/branch-service.ts +299 -0
  125. package/src/organization/branches.config.ts +154 -0
  126. package/src/organization/index.ts +5 -0
  127. package/src/plugin/apps-registry.ts +97 -0
  128. package/src/plugin/index.ts +5 -0
  129. package/src/plugin/types.ts +41 -0
  130. package/src/providers/index.tsx +109 -0
  131. package/src/providers/tenant-provider.tsx +45 -0
  132. package/src/rbac/components/roles/role-card.tsx +158 -0
  133. package/src/rbac/components/roles/role-stats-cards.tsx +29 -0
  134. package/src/rbac/components/roles/role-toolbar.tsx +123 -0
  135. package/src/rbac/hooks/use-role-operations.ts +159 -0
  136. package/src/rbac/hooks/use-roles-data.ts +59 -0
  137. package/src/rbac/index.ts +297 -0
  138. package/src/rbac/lib/permission-helpers.ts +63 -0
  139. package/src/rbac/pages/action-list-page.tsx +25 -0
  140. package/src/rbac/pages/resource-list-page.tsx +25 -0
  141. package/src/rbac/pages/role-list-page.tsx +378 -0
  142. package/src/rbac/permission-service.ts +140 -0
  143. package/src/rbac/permissions.ts +135 -0
  144. package/src/rbac/resource-service.ts +115 -0
  145. package/src/rbac/resource-validator.ts +119 -0
  146. package/src/rbac/role-service.ts +165 -0
  147. package/src/rbac/server.ts +16 -0
  148. package/src/rbac/types.ts +38 -0
  149. package/src/schemas/action.schema.ts +66 -0
  150. package/src/schemas/branch.schema.ts +52 -0
  151. package/src/schemas/coming-soon-schema.ts +9 -0
  152. package/src/schemas/company.schema.ts +44 -0
  153. package/src/schemas/forgot-passward-schema.ts +9 -0
  154. package/src/schemas/index.ts +30 -0
  155. package/src/schemas/material-category.schema.ts +43 -0
  156. package/src/schemas/material-pricing.schema.ts +74 -0
  157. package/src/schemas/material.schema.ts +76 -0
  158. package/src/schemas/materials.ts +52 -0
  159. package/src/schemas/new-passward-schema.ts +15 -0
  160. package/src/schemas/partner-company.schema.ts +149 -0
  161. package/src/schemas/register-schema.ts +36 -0
  162. package/src/schemas/resource.schema.ts +133 -0
  163. package/src/schemas/role.schema.ts +11 -0
  164. package/src/schemas/sign-in-schema.ts +24 -0
  165. package/src/schemas/supplier-pricing.schema.ts +15 -0
  166. package/src/schemas/supplier.schema.ts +120 -0
  167. package/src/schemas/system-category-group.schema.ts +67 -0
  168. package/src/schemas/system-category.schema.ts +77 -0
  169. package/src/schemas/system-config.schema.ts +118 -0
  170. package/src/schemas/uom.schema.ts +75 -0
  171. package/src/schemas/user-supplier.schema.ts +179 -0
  172. package/src/schemas/user.schema.ts +18 -0
  173. package/src/schemas/verify-email-schema.ts +9 -0
  174. package/src/schemas/warehouse.schema.ts +49 -0
  175. package/src/system/components/categories/category-list.tsx +529 -0
  176. package/src/system/components/categories/category-manager.tsx +89 -0
  177. package/src/system/components/categories/group-sidebar.tsx +308 -0
  178. package/src/system/components/settings/setting-dialogs.tsx +197 -0
  179. package/src/system/components/settings/setting-field.tsx +291 -0
  180. package/src/system/components/settings/setting-form-dialog.tsx +308 -0
  181. package/src/system/components/settings/settings-groups.ts +80 -0
  182. package/src/system/components/settings/settings-search.tsx +71 -0
  183. package/src/system/components/settings/settings-section.tsx +74 -0
  184. package/src/system/components/settings/settings-sidebar.tsx +81 -0
  185. package/src/system/constants.ts +3 -0
  186. package/src/system/index.ts +150 -0
  187. package/src/system/job-manager.ts +176 -0
  188. package/src/system/pages/components/categories/category-list.tsx +537 -0
  189. package/src/system/pages/components/categories/category-manager.tsx +90 -0
  190. package/src/system/pages/components/categories/group-sidebar.tsx +311 -0
  191. package/src/system/pages/components/settings/sales-rules-settings.tsx +222 -0
  192. package/src/system/pages/components/settings/setting-dialogs.tsx +197 -0
  193. package/src/system/pages/components/settings/setting-field.tsx +292 -0
  194. package/src/system/pages/components/settings/setting-form-dialog.tsx +308 -0
  195. package/src/system/pages/components/settings/settings-groups.ts +87 -0
  196. package/src/system/pages/components/settings/settings-page.tsx +372 -0
  197. package/src/system/pages/components/settings/settings-search.tsx +71 -0
  198. package/src/system/pages/components/settings/settings-section.tsx +74 -0
  199. package/src/system/pages/components/settings/settings-sidebar.tsx +81 -0
  200. package/src/system/pages/components/settings/system-settings.tsx +244 -0
  201. package/src/system/pages/system-category-page.tsx +15 -0
  202. package/src/system/pages/system-settings-page.tsx +380 -0
  203. package/src/system/schemas/system-category-group.schema.ts +46 -0
  204. package/src/system/schemas/system-category.schema.ts +56 -0
  205. package/src/system/services/settings-service.ts +127 -0
  206. package/src/system/services/system-category-service.ts +63 -0
  207. package/src/system/types.ts +45 -0
  208. package/src/types/index.ts +703 -0
  209. package/src/ui/auth/auth-layout.tsx +135 -0
  210. package/src/ui/auth/forgot-password-form.tsx +98 -0
  211. package/src/ui/auth/index.tsx +7 -0
  212. package/src/ui/auth/new-password-form.tsx +107 -0
  213. package/src/ui/auth/oauth-links.tsx +30 -0
  214. package/src/ui/auth/register-form.tsx +202 -0
  215. package/src/ui/auth/sign-in-form.tsx +238 -0
  216. package/src/ui/auth/verify-email-form.tsx +104 -0
  217. package/src/ui/crud/index.tsx +10 -0
  218. package/src/ui/data-display/accordion.tsx +65 -0
  219. package/src/ui/data-display/aspect-ratio.tsx +11 -0
  220. package/src/ui/data-display/avatar.tsx +163 -0
  221. package/src/ui/data-display/bento-grid.tsx +77 -0
  222. package/src/ui/data-display/carousel.tsx +249 -0
  223. package/src/ui/data-display/chart.tsx +363 -0
  224. package/src/ui/data-display/code-block-highlight.tsx +54 -0
  225. package/src/ui/data-display/collapsible.tsx +42 -0
  226. package/src/ui/data-display/compact-stat-bar.tsx +149 -0
  227. package/src/ui/data-display/data-table/data-table-context.tsx +255 -0
  228. package/src/ui/data-display/data-table/data-table-empty-state.tsx +133 -0
  229. package/src/ui/data-display/data-table/data-table-skeleton.tsx +145 -0
  230. package/src/ui/data-display/data-table/data-table-toolbar.tsx +353 -0
  231. package/src/ui/data-display/data-table/data-table.tsx +597 -0
  232. package/src/ui/data-display/data-table/index.ts +44 -0
  233. package/src/ui/data-display/data-table-column-header.tsx +75 -0
  234. package/src/ui/data-display/data-table-pagination.tsx +130 -0
  235. package/src/ui/data-display/data-table-view-options.tsx +59 -0
  236. package/src/ui/data-display/formatted-number-input.tsx +210 -0
  237. package/src/ui/data-display/highlight.tsx +20 -0
  238. package/src/ui/data-display/hover-card.tsx +48 -0
  239. package/src/ui/data-display/index.tsx +50 -0
  240. package/src/ui/data-display/iphone-15-pro.tsx +114 -0
  241. package/src/ui/data-display/kanban/index.ts +4 -0
  242. package/src/ui/data-display/kanban/kanban-board.tsx +192 -0
  243. package/src/ui/data-display/kanban/kanban-column.tsx +74 -0
  244. package/src/ui/data-display/kanban/kanban-item.tsx +50 -0
  245. package/src/ui/data-display/kanban/kanban-types.ts +21 -0
  246. package/src/ui/data-display/kpi-card.tsx +68 -0
  247. package/src/ui/data-display/media-grid.tsx +110 -0
  248. package/src/ui/data-display/safari.tsx +175 -0
  249. package/src/ui/data-display/show-more-text.tsx +55 -0
  250. package/src/ui/data-display/tabs.tsx +68 -0
  251. package/src/ui/data-display/timeline.tsx +256 -0
  252. package/src/ui/feedback/alert.tsx +60 -0
  253. package/src/ui/feedback/context-menu.tsx +245 -0
  254. package/src/ui/feedback/drawer.tsx +132 -0
  255. package/src/ui/feedback/error-dialog.tsx +273 -0
  256. package/src/ui/feedback/index.tsx +183 -0
  257. package/src/ui/feedback/progress.tsx +32 -0
  258. package/src/ui/feedback/sheet.tsx +148 -0
  259. package/src/ui/feedback/sonner.tsx +36 -0
  260. package/src/ui/forms/command.tsx +157 -0
  261. package/src/ui/forms/date-picker.tsx +73 -0
  262. package/src/ui/forms/date-range-picker.tsx +76 -0
  263. package/src/ui/forms/date-time-picker.tsx +109 -0
  264. package/src/ui/forms/editor/editor-menu-bar.tsx +394 -0
  265. package/src/ui/forms/editor/index.tsx +130 -0
  266. package/src/ui/forms/editor/multi-select-example.tsx +1234 -0
  267. package/src/ui/forms/emoji-picker.tsx +109 -0
  268. package/src/ui/forms/file-dropzone.tsx +169 -0
  269. package/src/ui/forms/file-thumbnail.tsx +29 -0
  270. package/src/ui/forms/index.tsx +201 -0
  271. package/src/ui/forms/input-file.tsx +99 -0
  272. package/src/ui/forms/input-group.tsx +46 -0
  273. package/src/ui/forms/input-otp.tsx +81 -0
  274. package/src/ui/forms/input-phone.tsx +172 -0
  275. package/src/ui/forms/input-spin.tsx +116 -0
  276. package/src/ui/forms/input-tags.tsx +219 -0
  277. package/src/ui/forms/input-time.tsx +42 -0
  278. package/src/ui/forms/multi-select.tsx +629 -0
  279. package/src/ui/forms/multiple-date-picker.tsx +74 -0
  280. package/src/ui/forms/radio-group.tsx +42 -0
  281. package/src/ui/forms/rating.tsx +158 -0
  282. package/src/ui/forms/time-picker.tsx +57 -0
  283. package/src/ui/index.tsx +17 -0
  284. package/src/ui/layout/animated-list.tsx +77 -0
  285. package/src/ui/layout/animated-sidebar.tsx +294 -0
  286. package/src/ui/layout/command-menu.tsx +355 -0
  287. package/src/ui/layout/customizer.tsx +324 -0
  288. package/src/ui/layout/footer.tsx +43 -0
  289. package/src/ui/layout/full-screen-toggle.tsx +52 -0
  290. package/src/ui/layout/header-breadcrumb.tsx +77 -0
  291. package/src/ui/layout/horizontal-layout-header.tsx +83 -0
  292. package/src/ui/layout/horizontal-layout.tsx +50 -0
  293. package/src/ui/layout/index.tsx +25 -0
  294. package/src/ui/layout/language-dropdown.tsx +103 -0
  295. package/src/ui/layout/logo.tsx +63 -0
  296. package/src/ui/layout/main-layout.tsx +57 -0
  297. package/src/ui/layout/mode-dropdown.tsx +58 -0
  298. package/src/ui/layout/notification-dropdown.tsx +127 -0
  299. package/src/ui/layout/page-tabs.tsx +306 -0
  300. package/src/ui/layout/route-cache.tsx +214 -0
  301. package/src/ui/layout/sidebar-group-icon-menu.tsx +195 -0
  302. package/src/ui/layout/sidebar.tsx +279 -0
  303. package/src/ui/layout/tab-content-cache.tsx +201 -0
  304. package/src/ui/layout/tab-navigation-provider.tsx +536 -0
  305. package/src/ui/layout/toggle-mobile-sidebar.tsx +33 -0
  306. package/src/ui/layout/top-bar-header-menubar.tsx +412 -0
  307. package/src/ui/layout/user-dropdown.tsx +188 -0
  308. package/src/ui/layout/vertical-layout-header.tsx +65 -0
  309. package/src/ui/layout/vertical-layout.tsx +47 -0
  310. package/src/ui/management/audit-log-page.tsx +209 -0
  311. package/src/ui/management/cache-management.tsx +349 -0
  312. package/src/ui/management/index.ts +3 -0
  313. package/src/ui/management/job-management.tsx +308 -0
  314. package/src/ui/pages/not-found.tsx +30 -0
  315. package/src/ui/primitives/badge.tsx +66 -0
  316. package/src/ui/primitives/breadcrumb.tsx +103 -0
  317. package/src/ui/primitives/button.tsx +129 -0
  318. package/src/ui/primitives/calendar.tsx +74 -0
  319. package/src/ui/primitives/card.tsx +86 -0
  320. package/src/ui/primitives/checkbox.tsx +31 -0
  321. package/src/ui/primitives/client.ts +30 -0
  322. package/src/ui/primitives/combobox.tsx +290 -0
  323. package/src/ui/primitives/dialog.tsx +121 -0
  324. package/src/ui/primitives/dropdown-menu.tsx +239 -0
  325. package/src/ui/primitives/dynamic-icon.tsx +24 -0
  326. package/src/ui/primitives/index.tsx +134 -0
  327. package/src/ui/primitives/input-number.tsx +131 -0
  328. package/src/ui/primitives/input.tsx +22 -0
  329. package/src/ui/primitives/keyboard.tsx +23 -0
  330. package/src/ui/primitives/label.tsx +24 -0
  331. package/src/ui/primitives/menubar.tsx +262 -0
  332. package/src/ui/primitives/navigation-menu.tsx +157 -0
  333. package/src/ui/primitives/pagination.tsx +118 -0
  334. package/src/ui/primitives/popover.tsx +56 -0
  335. package/src/ui/primitives/prefetch-link.tsx +60 -0
  336. package/src/ui/primitives/resizable.tsx +59 -0
  337. package/src/ui/primitives/scroll-area.tsx +63 -0
  338. package/src/ui/primitives/select.tsx +172 -0
  339. package/src/ui/primitives/separator.tsx +51 -0
  340. package/src/ui/primitives/sidebar.tsx +844 -0
  341. package/src/ui/primitives/slider.tsx +27 -0
  342. package/src/ui/primitives/status-badge.tsx +47 -0
  343. package/src/ui/primitives/sticky-layout.tsx +50 -0
  344. package/src/ui/primitives/switch.tsx +29 -0
  345. package/src/ui/primitives/table.tsx +116 -0
  346. package/src/ui/primitives/tabs.tsx +55 -0
  347. package/src/ui/primitives/toggle-group.tsx +70 -0
  348. package/src/ui/primitives/toggle.tsx +47 -0
  349. package/src/ui/primitives/tooltip.tsx +59 -0
  350. package/src/user/components/dangerous-zone.tsx +34 -0
  351. package/src/user/components/delete-account-form.tsx +40 -0
  352. package/src/user/components/index.ts +4 -0
  353. package/src/user/components/profile-info-form.tsx +390 -0
  354. package/src/user/components/profile-info.tsx +32 -0
  355. package/src/user/components/unified-profile-dialog.tsx +1019 -0
  356. package/src/user/components/user-stats.tsx +27 -0
  357. package/src/user/components/user-toolbar.tsx +137 -0
  358. package/src/user/components/users-card-view.tsx +253 -0
  359. package/src/user/index.ts +11 -0
  360. package/src/user/pages/user-list-page.tsx +234 -0
  361. package/src/user/pages/users-client-page.tsx +385 -0
  362. package/src/user/profile-page.tsx +19 -0
  363. package/src/user/schemas.ts +68 -0
  364. package/src/user/types.ts +34 -0
  365. package/src/user/user-service.ts +538 -0
  366. package/src/utils/index.ts +906 -0
  367. package/src/workflow/activity-timeline.tsx +412 -0
  368. package/src/workflow/approval-workflow.tsx +31 -0
  369. package/src/workflow/index.ts +2 -0
  370. package/dist/audit/index.d.mts +0 -115
  371. package/dist/audit/index.d.ts +0 -115
  372. package/dist/audit/index.js +0 -204
  373. package/dist/audit/index.js.map +0 -1
  374. package/dist/audit/index.mjs +0 -200
  375. package/dist/audit/index.mjs.map +0 -1
  376. package/dist/auth/index.d.mts +0 -86
  377. package/dist/auth/index.d.ts +0 -86
  378. package/dist/auth/index.js +0 -210
  379. package/dist/auth/index.js.map +0 -1
  380. package/dist/auth/index.mjs +0 -198
  381. package/dist/auth/index.mjs.map +0 -1
  382. package/dist/button-1dWvP9Ib.d.mts +0 -30
  383. package/dist/button-1dWvP9Ib.d.ts +0 -30
  384. package/dist/calendar-2QzdEo1z.d.mts +0 -20
  385. package/dist/calendar-2QzdEo1z.d.ts +0 -20
  386. package/dist/code-generation/index.d.mts +0 -30
  387. package/dist/code-generation/index.d.ts +0 -30
  388. package/dist/code-generation/index.js +0 -31
  389. package/dist/code-generation/index.js.map +0 -1
  390. package/dist/code-generation/index.mjs +0 -28
  391. package/dist/code-generation/index.mjs.map +0 -1
  392. package/dist/configs/index.d.mts +0 -175
  393. package/dist/configs/index.d.ts +0 -175
  394. package/dist/configs/index.js +0 -254
  395. package/dist/configs/index.js.map +0 -1
  396. package/dist/configs/index.mjs +0 -233
  397. package/dist/configs/index.mjs.map +0 -1
  398. package/dist/crud/index.d.mts +0 -646
  399. package/dist/crud/index.d.ts +0 -646
  400. package/dist/crud/index.js +0 -11772
  401. package/dist/crud/index.js.map +0 -1
  402. package/dist/crud/index.mjs +0 -11665
  403. package/dist/crud/index.mjs.map +0 -1
  404. package/dist/crud/server.d.mts +0 -20
  405. package/dist/crud/server.d.ts +0 -20
  406. package/dist/crud/server.js +0 -123
  407. package/dist/crud/server.js.map +0 -1
  408. package/dist/crud/server.mjs +0 -120
  409. package/dist/crud/server.mjs.map +0 -1
  410. package/dist/data-table-skeleton-12NA8Mjx.d.mts +0 -39
  411. package/dist/data-table-skeleton-12NA8Mjx.d.ts +0 -39
  412. package/dist/dialog-bKfjZMTd.d.mts +0 -22
  413. package/dist/dialog-bKfjZMTd.d.ts +0 -22
  414. package/dist/dynamic-icon-DrGIiu2N.d.mts +0 -10
  415. package/dist/dynamic-icon-DrGIiu2N.d.ts +0 -10
  416. package/dist/home/index.d.mts +0 -269
  417. package/dist/home/index.d.ts +0 -269
  418. package/dist/home/index.js +0 -1678
  419. package/dist/home/index.js.map +0 -1
  420. package/dist/home/index.mjs +0 -1635
  421. package/dist/home/index.mjs.map +0 -1
  422. package/dist/hooks/index.d.mts +0 -7
  423. package/dist/hooks/index.d.ts +0 -7
  424. package/dist/hooks/index.js +0 -8316
  425. package/dist/hooks/index.js.map +0 -1
  426. package/dist/hooks/index.mjs +0 -8255
  427. package/dist/hooks/index.mjs.map +0 -1
  428. package/dist/index-50hpiPrV.d.ts +0 -116
  429. package/dist/index-B9zQVEVi.d.mts +0 -116
  430. package/dist/index.d.mts +0 -5
  431. package/dist/index.d.ts +0 -5
  432. package/dist/index.js +0 -123
  433. package/dist/index.js.map +0 -1
  434. package/dist/index.mjs +0 -118
  435. package/dist/index.mjs.map +0 -1
  436. package/dist/infrastructure/index.d.mts +0 -423
  437. package/dist/infrastructure/index.d.ts +0 -423
  438. package/dist/infrastructure/index.js +0 -633
  439. package/dist/infrastructure/index.js.map +0 -1
  440. package/dist/infrastructure/index.mjs +0 -619
  441. package/dist/infrastructure/index.mjs.map +0 -1
  442. package/dist/label-DWTEkNPo.d.ts +0 -226
  443. package/dist/label-LPpdcoBx.d.mts +0 -226
  444. package/dist/layout/index.d.mts +0 -48
  445. package/dist/layout/index.d.ts +0 -48
  446. package/dist/layout/index.js +0 -117
  447. package/dist/layout/index.js.map +0 -1
  448. package/dist/layout/index.mjs +0 -90
  449. package/dist/layout/index.mjs.map +0 -1
  450. package/dist/navigation/index.d.mts +0 -16
  451. package/dist/navigation/index.d.ts +0 -16
  452. package/dist/navigation/index.js +0 -53
  453. package/dist/navigation/index.js.map +0 -1
  454. package/dist/navigation/index.mjs +0 -50
  455. package/dist/navigation/index.mjs.map +0 -1
  456. package/dist/notification/index.d.mts +0 -105
  457. package/dist/notification/index.d.ts +0 -105
  458. package/dist/notification/index.js +0 -278
  459. package/dist/notification/index.js.map +0 -1
  460. package/dist/notification/index.mjs +0 -274
  461. package/dist/notification/index.mjs.map +0 -1
  462. package/dist/organization/index.d.mts +0 -99
  463. package/dist/organization/index.d.ts +0 -99
  464. package/dist/organization/index.js +0 -360
  465. package/dist/organization/index.js.map +0 -1
  466. package/dist/organization/index.mjs +0 -352
  467. package/dist/organization/index.mjs.map +0 -1
  468. package/dist/plugin/index.d.mts +0 -83
  469. package/dist/plugin/index.d.ts +0 -83
  470. package/dist/plugin/index.js +0 -86
  471. package/dist/plugin/index.js.map +0 -1
  472. package/dist/plugin/index.mjs +0 -84
  473. package/dist/plugin/index.mjs.map +0 -1
  474. package/dist/providers/index.d.mts +0 -25
  475. package/dist/providers/index.d.ts +0 -25
  476. package/dist/providers/index.js +0 -84
  477. package/dist/providers/index.js.map +0 -1
  478. package/dist/providers/index.mjs +0 -77
  479. package/dist/providers/index.mjs.map +0 -1
  480. package/dist/rbac/index.d.mts +0 -226
  481. package/dist/rbac/index.d.ts +0 -226
  482. package/dist/rbac/index.js +0 -4784
  483. package/dist/rbac/index.js.map +0 -1
  484. package/dist/rbac/index.mjs +0 -4722
  485. package/dist/rbac/index.mjs.map +0 -1
  486. package/dist/rbac/permissions.d.mts +0 -26
  487. package/dist/rbac/permissions.d.ts +0 -26
  488. package/dist/rbac/permissions.js +0 -94
  489. package/dist/rbac/permissions.js.map +0 -1
  490. package/dist/rbac/permissions.mjs +0 -90
  491. package/dist/rbac/permissions.mjs.map +0 -1
  492. package/dist/rbac/server.d.mts +0 -1
  493. package/dist/rbac/server.d.ts +0 -1
  494. package/dist/rbac/server.js +0 -128
  495. package/dist/rbac/server.js.map +0 -1
  496. package/dist/rbac/server.mjs +0 -124
  497. package/dist/rbac/server.mjs.map +0 -1
  498. package/dist/schemas/index.d.mts +0 -1257
  499. package/dist/schemas/index.d.ts +0 -1257
  500. package/dist/schemas/index.js +0 -572
  501. package/dist/schemas/index.js.map +0 -1
  502. package/dist/schemas/index.mjs +0 -523
  503. package/dist/schemas/index.mjs.map +0 -1
  504. package/dist/server-QuYCTa89.d.mts +0 -83
  505. package/dist/server-QuYCTa89.d.ts +0 -83
  506. package/dist/sonner-C74GlRDQ.d.mts +0 -71
  507. package/dist/sonner-C74GlRDQ.d.ts +0 -71
  508. package/dist/status-BOXZgIqX.d.mts +0 -12
  509. package/dist/status-BOXZgIqX.d.ts +0 -12
  510. package/dist/system/index.d.mts +0 -77
  511. package/dist/system/index.d.ts +0 -77
  512. package/dist/system/index.js +0 -102
  513. package/dist/system/index.js.map +0 -1
  514. package/dist/system/index.mjs +0 -100
  515. package/dist/system/index.mjs.map +0 -1
  516. package/dist/tabs-C6FfBwPY.d.mts +0 -18
  517. package/dist/tabs-C6FfBwPY.d.ts +0 -18
  518. package/dist/tenant-provider-B8eC_Wpb.d.mts +0 -27
  519. package/dist/tenant-provider-B8eC_Wpb.d.ts +0 -27
  520. package/dist/types/index.d.mts +0 -469
  521. package/dist/types/index.d.ts +0 -469
  522. package/dist/types/index.js +0 -25
  523. package/dist/types/index.js.map +0 -1
  524. package/dist/types/index.mjs +0 -21
  525. package/dist/types/index.mjs.map +0 -1
  526. package/dist/ui/auth.d.mts +0 -39
  527. package/dist/ui/auth.d.ts +0 -39
  528. package/dist/ui/auth.js +0 -4941
  529. package/dist/ui/auth.js.map +0 -1
  530. package/dist/ui/auth.mjs +0 -4896
  531. package/dist/ui/auth.mjs.map +0 -1
  532. package/dist/ui/crud.d.mts +0 -2
  533. package/dist/ui/crud.d.ts +0 -2
  534. package/dist/ui/crud.js +0 -4
  535. package/dist/ui/crud.js.map +0 -1
  536. package/dist/ui/crud.mjs +0 -3
  537. package/dist/ui/crud.mjs.map +0 -1
  538. package/dist/ui/data-display.d.mts +0 -596
  539. package/dist/ui/data-display.d.ts +0 -596
  540. package/dist/ui/data-display.js +0 -5307
  541. package/dist/ui/data-display.js.map +0 -1
  542. package/dist/ui/data-display.mjs +0 -5212
  543. package/dist/ui/data-display.mjs.map +0 -1
  544. package/dist/ui/feedback.d.mts +0 -55
  545. package/dist/ui/feedback.d.ts +0 -55
  546. package/dist/ui/feedback.js +0 -2608
  547. package/dist/ui/feedback.js.map +0 -1
  548. package/dist/ui/feedback.mjs +0 -2526
  549. package/dist/ui/feedback.mjs.map +0 -1
  550. package/dist/ui/forms.d.mts +0 -309
  551. package/dist/ui/forms.d.ts +0 -309
  552. package/dist/ui/forms.js +0 -4656
  553. package/dist/ui/forms.js.map +0 -1
  554. package/dist/ui/forms.mjs +0 -4571
  555. package/dist/ui/forms.mjs.map +0 -1
  556. package/dist/ui/index.d.mts +0 -331
  557. package/dist/ui/index.d.ts +0 -331
  558. package/dist/ui/index.js +0 -16953
  559. package/dist/ui/index.js.map +0 -1
  560. package/dist/ui/index.mjs +0 -16598
  561. package/dist/ui/index.mjs.map +0 -1
  562. package/dist/ui/primitives/client.d.mts +0 -61
  563. package/dist/ui/primitives/client.d.ts +0 -61
  564. package/dist/ui/primitives/client.js +0 -3408
  565. package/dist/ui/primitives/client.js.map +0 -1
  566. package/dist/ui/primitives/client.mjs +0 -3256
  567. package/dist/ui/primitives/client.mjs.map +0 -1
  568. package/dist/ui/primitives.d.mts +0 -113
  569. package/dist/ui/primitives.d.ts +0 -113
  570. package/dist/ui/primitives.js +0 -3356
  571. package/dist/ui/primitives.js.map +0 -1
  572. package/dist/ui/primitives.mjs +0 -3227
  573. package/dist/ui/primitives.mjs.map +0 -1
  574. package/dist/user/index.d.mts +0 -228
  575. package/dist/user/index.d.ts +0 -228
  576. package/dist/user/index.js +0 -4306
  577. package/dist/user/index.js.map +0 -1
  578. package/dist/user/index.mjs +0 -4260
  579. package/dist/user/index.mjs.map +0 -1
  580. package/dist/utils/index.d.mts +0 -205
  581. package/dist/utils/index.d.ts +0 -205
  582. package/dist/utils/index.js +0 -574
  583. package/dist/utils/index.js.map +0 -1
  584. package/dist/utils/index.mjs +0 -514
  585. package/dist/utils/index.mjs.map +0 -1
  586. package/dist/workflow/index.d.mts +0 -40
  587. package/dist/workflow/index.d.ts +0 -40
  588. package/dist/workflow/index.js +0 -3710
  589. package/dist/workflow/index.js.map +0 -1
  590. package/dist/workflow/index.mjs +0 -3677
  591. package/dist/workflow/index.mjs.map +0 -1
@@ -1,210 +0,0 @@
1
- 'use strict';
2
-
3
- // src/auth/auth-service.ts
4
- async function verifyPassword(password, hash) {
5
- try {
6
- const bcrypt = await import('bcryptjs');
7
- return bcrypt.compareSync(password, hash);
8
- } catch (error) {
9
- console.error("Error verifying password", error);
10
- return false;
11
- }
12
- }
13
- async function authenticateUser(db, email, password) {
14
- try {
15
- const user = await db.user.findUnique({
16
- where: { email: email.toLowerCase().trim() },
17
- select: {
18
- id: true,
19
- email: true,
20
- name: true,
21
- avatar: true,
22
- password: true,
23
- isActive: true
24
- }
25
- });
26
- if (!user) {
27
- throw new Error("Invalid email or password");
28
- }
29
- if (!user.isActive) {
30
- throw new Error("ACCOUNT_SUSPENDED");
31
- }
32
- if (!user.password) {
33
- throw new Error("Invalid email or password");
34
- }
35
- const isPasswordValid = await verifyPassword(password, user.password);
36
- if (!isPasswordValid) {
37
- throw new Error("Invalid email or password");
38
- }
39
- await db.user.update({
40
- where: { id: user.id },
41
- data: { lastLoginAt: /* @__PURE__ */ new Date() }
42
- });
43
- return {
44
- id: user.id,
45
- name: user.name || "",
46
- email: user.email,
47
- avatar: user.avatar || null,
48
- status: "ONLINE"
49
- };
50
- } catch (error) {
51
- if (error instanceof Error) {
52
- throw error;
53
- }
54
- throw new Error("Error signing in");
55
- }
56
- }
57
-
58
- // src/auth/index.ts
59
- var ADMIN_ROLE_CODE = "admin";
60
- var BYPASS_AUTH = process.env.BYPASS_AUTH === "true" || process.env.BYPASS_AUTH === "1";
61
- var ACTION_CODES = {
62
- create: "create",
63
- view: "view",
64
- update: "update",
65
- delete: "delete",
66
- export: "export",
67
- import: "import",
68
- approve: "approve",
69
- reject: "reject"
70
- };
71
- function getActionCode(action) {
72
- return ACTION_CODES[action] || action;
73
- }
74
- function getUserPermissions(session) {
75
- if (!session?.user) return [];
76
- const user = session.user;
77
- if (!user.permissions) {
78
- return [];
79
- }
80
- return user.permissions;
81
- }
82
- function getCrudPermissionsFromSession(session, entity) {
83
- if (BYPASS_AUTH) {
84
- return {
85
- create: true,
86
- view: true,
87
- update: true,
88
- delete: true,
89
- export: true,
90
- import: true,
91
- approve: true,
92
- reject: true
93
- };
94
- }
95
- if (!session?.user) {
96
- return {
97
- create: false,
98
- view: false,
99
- update: false,
100
- delete: false,
101
- export: false,
102
- import: false,
103
- approve: false,
104
- reject: false
105
- };
106
- }
107
- const user = session.user;
108
- if (!user.id) {
109
- return {
110
- create: false,
111
- view: false,
112
- update: false,
113
- delete: false,
114
- export: false,
115
- import: false,
116
- approve: false,
117
- reject: false
118
- };
119
- }
120
- const isAdmin2 = user.roles?.includes(ADMIN_ROLE_CODE) || user.roles?.includes("SUPER_ADMIN");
121
- if (isAdmin2) {
122
- return {
123
- create: true,
124
- view: true,
125
- update: true,
126
- delete: true,
127
- export: true,
128
- import: true,
129
- approve: true,
130
- reject: true
131
- };
132
- }
133
- const permissions = user.permissions || [];
134
- const permissionKeys = new Set(
135
- permissions.map((p) => `${p.resourceCode}:${p.actionCode}`)
136
- );
137
- const hasPermission2 = (action) => {
138
- const key = `${entity}:${action}`;
139
- return permissionKeys.has(key);
140
- };
141
- return {
142
- create: hasPermission2(getActionCode("create")),
143
- view: hasPermission2(getActionCode("view")),
144
- update: hasPermission2(getActionCode("update")),
145
- delete: hasPermission2(getActionCode("delete")),
146
- export: hasPermission2(getActionCode("export")),
147
- import: hasPermission2(getActionCode("import")),
148
- approve: hasPermission2(getActionCode("approve")),
149
- reject: hasPermission2(getActionCode("reject"))
150
- };
151
- }
152
- function checkPermission(session, resourceCode, actionCode) {
153
- if (BYPASS_AUTH) {
154
- return true;
155
- }
156
- if (!session?.user) return false;
157
- const user = session.user;
158
- if (!user.permissions || user.permissions.length === 0) {
159
- return false;
160
- }
161
- if (user.roles?.includes(ADMIN_ROLE_CODE) || user.roles?.includes("SUPER_ADMIN")) {
162
- return true;
163
- }
164
- return user.permissions.some(
165
- (p) => p.resourceCode === resourceCode && p.actionCode === actionCode
166
- );
167
- }
168
- function hasPermission(session, resourceCode, actionCode) {
169
- return checkPermission(session, resourceCode, actionCode);
170
- }
171
- function requirePermission(session, resourceCode, actionCode) {
172
- if (!checkPermission(session, resourceCode, actionCode)) {
173
- throw new Error(
174
- `Unauthorized: User does not have permission ${actionCode} on ${resourceCode}`
175
- );
176
- }
177
- }
178
- function hasRole(session, roleCode) {
179
- if (!session?.user) return false;
180
- const user = session.user;
181
- if (!user.roles) {
182
- return false;
183
- }
184
- return user.roles.includes(roleCode);
185
- }
186
- function hasAnyRole(session, roleCodes) {
187
- if (!session?.user) return false;
188
- const user = session.user;
189
- if (!user.roles) {
190
- return false;
191
- }
192
- return roleCodes.some((role) => user.roles.includes(role));
193
- }
194
- function isAdmin(session) {
195
- return hasRole(session, ADMIN_ROLE_CODE);
196
- }
197
-
198
- exports.authenticateUser = authenticateUser;
199
- exports.checkPermission = checkPermission;
200
- exports.getActionCode = getActionCode;
201
- exports.getCrudPermissionsFromSession = getCrudPermissionsFromSession;
202
- exports.getUserPermissions = getUserPermissions;
203
- exports.hasAnyRole = hasAnyRole;
204
- exports.hasPermission = hasPermission;
205
- exports.hasRole = hasRole;
206
- exports.isAdmin = isAdmin;
207
- exports.requirePermission = requirePermission;
208
- exports.verifyPassword = verifyPassword;
209
- //# sourceMappingURL=index.js.map
210
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/auth/auth-service.ts","../../src/auth/index.ts"],"names":["isAdmin","hasPermission"],"mappings":"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","file":"index.js","sourcesContent":["// Define the shape of the Prisma Client required by this service\nexport interface AuthPrismaClient {\n user: any;\n}\n\n// Dynamic import bcryptjs to avoid Edge Runtime issues\nexport async function verifyPassword(\n password: string,\n hash: string,\n): Promise<boolean> {\n try {\n const bcrypt = await import(\"bcryptjs\");\n return bcrypt.compareSync(password, hash);\n } catch (error) {\n console.error(\"Error verifying password\", error);\n return false;\n }\n}\n\nexport interface AuthenticatedUser {\n id: string;\n email: string | null;\n name: string;\n avatar: string | null;\n status: string;\n}\n\nexport interface AuthError {\n message: string;\n email?: string;\n}\n\n/**\n * Authenticate user with email and password\n * Returns user data if successful, throws error if failed\n */\nexport async function authenticateUser(\n db: AuthPrismaClient,\n email: string,\n password: string,\n): Promise<AuthenticatedUser> {\n try {\n // Query user from database by email\n const user = await db.user.findUnique({\n where: { email: email.toLowerCase().trim() },\n select: {\n id: true,\n email: true,\n name: true,\n avatar: true,\n password: true,\n isActive: true,\n },\n });\n\n // Check if user exists\n if (!user) {\n throw new Error(\"Invalid email or password\");\n }\n\n // Check if user account is suspended/inactive\n if (!user.isActive) {\n throw new Error(\"ACCOUNT_SUSPENDED\");\n }\n\n // Verify password\n if (!user.password) {\n throw new Error(\"Invalid email or password\");\n }\n\n const isPasswordValid = await verifyPassword(password, user.password);\n if (!isPasswordValid) {\n throw new Error(\"Invalid email or password\");\n }\n\n // Update last login time\n await db.user.update({\n where: { id: user.id },\n data: { lastLoginAt: new Date() },\n });\n\n // Return user data (without password)\n return {\n id: user.id,\n name: user.name || \"\",\n email: user.email,\n avatar: user.avatar || null,\n status: \"ONLINE\",\n };\n } catch (error) {\n // Re-throw error with proper message\n if (error instanceof Error) {\n throw error;\n }\n throw new Error(\"Error signing in\");\n }\n}\n","// @goerp/core/auth\n// Authentication and RBAC utilities for GoERP\n\nimport type { Session } from \"next-auth\";\n\nexport * from \"./auth-service\";\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport interface Permission {\n resourceCode: string;\n actionCode: string;\n}\n\nexport interface ExtendedUser {\n id: string;\n name?: string | null;\n email?: string | null;\n image?: string | null;\n roles?: string[];\n permissions?: Permission[];\n}\n\nexport interface UserSession {\n user: ExtendedUser;\n}\n\nexport interface CrudPermissionResult {\n create: boolean;\n view: boolean;\n update: boolean;\n delete: boolean;\n export: boolean;\n import: boolean;\n approve: boolean;\n reject: boolean;\n}\n\n// ============================================================================\n// Constants\n// ============================================================================\n\nconst ADMIN_ROLE_CODE = \"admin\";\nconst BYPASS_AUTH =\n process.env.BYPASS_AUTH === \"true\" || process.env.BYPASS_AUTH === \"1\";\n\n// Action code mapping\nconst ACTION_CODES: Record<string, string> = {\n create: \"create\",\n view: \"view\",\n update: \"update\",\n delete: \"delete\",\n export: \"export\",\n import: \"import\",\n approve: \"approve\",\n reject: \"reject\",\n};\n\n/**\n * Get action code from action name\n */\nexport function getActionCode(action: string): string {\n return ACTION_CODES[action] || action;\n}\n\n// ============================================================================\n// Permission Functions\n// ============================================================================\n\n/**\n * Get all permissions from session\n */\nexport function getUserPermissions(session: Session | null): Permission[] {\n if (!session?.user) return [];\n const user = session.user as ExtendedUser;\n\n if (!user.permissions) {\n return [];\n }\n return user.permissions;\n}\n\n/**\n * Get CRUD permissions from session for a specific entity\n */\nexport function getCrudPermissionsFromSession(\n session: Session | null,\n entity: string,\n): CrudPermissionResult {\n // TEMPORARY: Return all permissions as true if bypass is enabled\n if (BYPASS_AUTH) {\n return {\n create: true,\n view: true,\n update: true,\n delete: true,\n export: true,\n import: true,\n approve: true,\n reject: true,\n };\n }\n\n if (!session?.user) {\n return {\n create: false,\n view: false,\n update: false,\n delete: false,\n export: false,\n import: false,\n approve: false,\n reject: false,\n };\n }\n\n const user = session.user as ExtendedUser;\n\n if (!user.id) {\n return {\n create: false,\n view: false,\n update: false,\n delete: false,\n export: false,\n import: false,\n approve: false,\n reject: false,\n };\n }\n\n // Check admin role first (fastest check)\n const isAdmin =\n user.roles?.includes(ADMIN_ROLE_CODE) ||\n user.roles?.includes(\"SUPER_ADMIN\");\n if (isAdmin) {\n return {\n create: true,\n view: true,\n update: true,\n delete: true,\n export: true,\n import: true,\n approve: true,\n reject: true,\n };\n }\n\n // Pre-compute permission keys for fast lookup\n const permissions = user.permissions || [];\n const permissionKeys = new Set(\n permissions.map((p) => `${p.resourceCode}:${p.actionCode}`),\n );\n\n const hasPermission = (action: string) => {\n const key = `${entity}:${action}`;\n return permissionKeys.has(key);\n };\n\n return {\n create: hasPermission(getActionCode(\"create\")),\n view: hasPermission(getActionCode(\"view\")),\n update: hasPermission(getActionCode(\"update\")),\n delete: hasPermission(getActionCode(\"delete\")),\n export: hasPermission(getActionCode(\"export\")),\n import: hasPermission(getActionCode(\"import\")),\n approve: hasPermission(getActionCode(\"approve\")),\n reject: hasPermission(getActionCode(\"reject\")),\n };\n}\n\n/**\n * Check if user has a specific permission\n */\nexport function checkPermission(\n session: Session | null,\n resourceCode: string,\n actionCode: string,\n): boolean {\n if (BYPASS_AUTH) {\n return true;\n }\n\n if (!session?.user) return false;\n const user = session.user as ExtendedUser;\n\n if (!user.permissions || user.permissions.length === 0) {\n return false;\n }\n\n // Admin role bypass\n if (\n user.roles?.includes(ADMIN_ROLE_CODE) ||\n user.roles?.includes(\"SUPER_ADMIN\")\n ) {\n return true;\n }\n\n return user.permissions.some(\n (p) => p.resourceCode === resourceCode && p.actionCode === actionCode,\n );\n}\n\n/**\n * Alias for checkPermission\n */\nexport function hasPermission(\n session: Session | null,\n resourceCode: string,\n actionCode: string,\n): boolean {\n return checkPermission(session, resourceCode, actionCode);\n}\n\n/**\n * Require permission - throw error if not authorized\n */\nexport function requirePermission(\n session: Session | null,\n resourceCode: string,\n actionCode: string,\n): void {\n if (!checkPermission(session, resourceCode, actionCode)) {\n throw new Error(\n `Unauthorized: User does not have permission ${actionCode} on ${resourceCode}`,\n );\n }\n}\n\n/**\n * Check if user has a specific role\n */\nexport function hasRole(session: Session | null, roleCode: string): boolean {\n if (!session?.user) return false;\n const user = session.user as ExtendedUser;\n\n if (!user.roles) {\n return false;\n }\n return user.roles.includes(roleCode);\n}\n\n/**\n * Check if user has any of the specified roles\n */\nexport function hasAnyRole(\n session: Session | null,\n roleCodes: string[],\n): boolean {\n if (!session?.user) return false;\n const user = session.user as ExtendedUser;\n\n if (!user.roles) {\n return false;\n }\n return roleCodes.some((role) => user.roles!.includes(role));\n}\n\n/**\n * Check if user is admin\n */\nexport function isAdmin(session: Session | null): boolean {\n return hasRole(session, ADMIN_ROLE_CODE);\n}\n"]}
@@ -1,198 +0,0 @@
1
- // src/auth/auth-service.ts
2
- async function verifyPassword(password, hash) {
3
- try {
4
- const bcrypt = await import('bcryptjs');
5
- return bcrypt.compareSync(password, hash);
6
- } catch (error) {
7
- console.error("Error verifying password", error);
8
- return false;
9
- }
10
- }
11
- async function authenticateUser(db, email, password) {
12
- try {
13
- const user = await db.user.findUnique({
14
- where: { email: email.toLowerCase().trim() },
15
- select: {
16
- id: true,
17
- email: true,
18
- name: true,
19
- avatar: true,
20
- password: true,
21
- isActive: true
22
- }
23
- });
24
- if (!user) {
25
- throw new Error("Invalid email or password");
26
- }
27
- if (!user.isActive) {
28
- throw new Error("ACCOUNT_SUSPENDED");
29
- }
30
- if (!user.password) {
31
- throw new Error("Invalid email or password");
32
- }
33
- const isPasswordValid = await verifyPassword(password, user.password);
34
- if (!isPasswordValid) {
35
- throw new Error("Invalid email or password");
36
- }
37
- await db.user.update({
38
- where: { id: user.id },
39
- data: { lastLoginAt: /* @__PURE__ */ new Date() }
40
- });
41
- return {
42
- id: user.id,
43
- name: user.name || "",
44
- email: user.email,
45
- avatar: user.avatar || null,
46
- status: "ONLINE"
47
- };
48
- } catch (error) {
49
- if (error instanceof Error) {
50
- throw error;
51
- }
52
- throw new Error("Error signing in");
53
- }
54
- }
55
-
56
- // src/auth/index.ts
57
- var ADMIN_ROLE_CODE = "admin";
58
- var BYPASS_AUTH = process.env.BYPASS_AUTH === "true" || process.env.BYPASS_AUTH === "1";
59
- var ACTION_CODES = {
60
- create: "create",
61
- view: "view",
62
- update: "update",
63
- delete: "delete",
64
- export: "export",
65
- import: "import",
66
- approve: "approve",
67
- reject: "reject"
68
- };
69
- function getActionCode(action) {
70
- return ACTION_CODES[action] || action;
71
- }
72
- function getUserPermissions(session) {
73
- if (!session?.user) return [];
74
- const user = session.user;
75
- if (!user.permissions) {
76
- return [];
77
- }
78
- return user.permissions;
79
- }
80
- function getCrudPermissionsFromSession(session, entity) {
81
- if (BYPASS_AUTH) {
82
- return {
83
- create: true,
84
- view: true,
85
- update: true,
86
- delete: true,
87
- export: true,
88
- import: true,
89
- approve: true,
90
- reject: true
91
- };
92
- }
93
- if (!session?.user) {
94
- return {
95
- create: false,
96
- view: false,
97
- update: false,
98
- delete: false,
99
- export: false,
100
- import: false,
101
- approve: false,
102
- reject: false
103
- };
104
- }
105
- const user = session.user;
106
- if (!user.id) {
107
- return {
108
- create: false,
109
- view: false,
110
- update: false,
111
- delete: false,
112
- export: false,
113
- import: false,
114
- approve: false,
115
- reject: false
116
- };
117
- }
118
- const isAdmin2 = user.roles?.includes(ADMIN_ROLE_CODE) || user.roles?.includes("SUPER_ADMIN");
119
- if (isAdmin2) {
120
- return {
121
- create: true,
122
- view: true,
123
- update: true,
124
- delete: true,
125
- export: true,
126
- import: true,
127
- approve: true,
128
- reject: true
129
- };
130
- }
131
- const permissions = user.permissions || [];
132
- const permissionKeys = new Set(
133
- permissions.map((p) => `${p.resourceCode}:${p.actionCode}`)
134
- );
135
- const hasPermission2 = (action) => {
136
- const key = `${entity}:${action}`;
137
- return permissionKeys.has(key);
138
- };
139
- return {
140
- create: hasPermission2(getActionCode("create")),
141
- view: hasPermission2(getActionCode("view")),
142
- update: hasPermission2(getActionCode("update")),
143
- delete: hasPermission2(getActionCode("delete")),
144
- export: hasPermission2(getActionCode("export")),
145
- import: hasPermission2(getActionCode("import")),
146
- approve: hasPermission2(getActionCode("approve")),
147
- reject: hasPermission2(getActionCode("reject"))
148
- };
149
- }
150
- function checkPermission(session, resourceCode, actionCode) {
151
- if (BYPASS_AUTH) {
152
- return true;
153
- }
154
- if (!session?.user) return false;
155
- const user = session.user;
156
- if (!user.permissions || user.permissions.length === 0) {
157
- return false;
158
- }
159
- if (user.roles?.includes(ADMIN_ROLE_CODE) || user.roles?.includes("SUPER_ADMIN")) {
160
- return true;
161
- }
162
- return user.permissions.some(
163
- (p) => p.resourceCode === resourceCode && p.actionCode === actionCode
164
- );
165
- }
166
- function hasPermission(session, resourceCode, actionCode) {
167
- return checkPermission(session, resourceCode, actionCode);
168
- }
169
- function requirePermission(session, resourceCode, actionCode) {
170
- if (!checkPermission(session, resourceCode, actionCode)) {
171
- throw new Error(
172
- `Unauthorized: User does not have permission ${actionCode} on ${resourceCode}`
173
- );
174
- }
175
- }
176
- function hasRole(session, roleCode) {
177
- if (!session?.user) return false;
178
- const user = session.user;
179
- if (!user.roles) {
180
- return false;
181
- }
182
- return user.roles.includes(roleCode);
183
- }
184
- function hasAnyRole(session, roleCodes) {
185
- if (!session?.user) return false;
186
- const user = session.user;
187
- if (!user.roles) {
188
- return false;
189
- }
190
- return roleCodes.some((role) => user.roles.includes(role));
191
- }
192
- function isAdmin(session) {
193
- return hasRole(session, ADMIN_ROLE_CODE);
194
- }
195
-
196
- export { authenticateUser, checkPermission, getActionCode, getCrudPermissionsFromSession, getUserPermissions, hasAnyRole, hasPermission, hasRole, isAdmin, requirePermission, verifyPassword };
197
- //# sourceMappingURL=index.mjs.map
198
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/auth/auth-service.ts","../../src/auth/index.ts"],"names":["isAdmin","hasPermission"],"mappings":"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","file":"index.mjs","sourcesContent":["// Define the shape of the Prisma Client required by this service\nexport interface AuthPrismaClient {\n user: any;\n}\n\n// Dynamic import bcryptjs to avoid Edge Runtime issues\nexport async function verifyPassword(\n password: string,\n hash: string,\n): Promise<boolean> {\n try {\n const bcrypt = await import(\"bcryptjs\");\n return bcrypt.compareSync(password, hash);\n } catch (error) {\n console.error(\"Error verifying password\", error);\n return false;\n }\n}\n\nexport interface AuthenticatedUser {\n id: string;\n email: string | null;\n name: string;\n avatar: string | null;\n status: string;\n}\n\nexport interface AuthError {\n message: string;\n email?: string;\n}\n\n/**\n * Authenticate user with email and password\n * Returns user data if successful, throws error if failed\n */\nexport async function authenticateUser(\n db: AuthPrismaClient,\n email: string,\n password: string,\n): Promise<AuthenticatedUser> {\n try {\n // Query user from database by email\n const user = await db.user.findUnique({\n where: { email: email.toLowerCase().trim() },\n select: {\n id: true,\n email: true,\n name: true,\n avatar: true,\n password: true,\n isActive: true,\n },\n });\n\n // Check if user exists\n if (!user) {\n throw new Error(\"Invalid email or password\");\n }\n\n // Check if user account is suspended/inactive\n if (!user.isActive) {\n throw new Error(\"ACCOUNT_SUSPENDED\");\n }\n\n // Verify password\n if (!user.password) {\n throw new Error(\"Invalid email or password\");\n }\n\n const isPasswordValid = await verifyPassword(password, user.password);\n if (!isPasswordValid) {\n throw new Error(\"Invalid email or password\");\n }\n\n // Update last login time\n await db.user.update({\n where: { id: user.id },\n data: { lastLoginAt: new Date() },\n });\n\n // Return user data (without password)\n return {\n id: user.id,\n name: user.name || \"\",\n email: user.email,\n avatar: user.avatar || null,\n status: \"ONLINE\",\n };\n } catch (error) {\n // Re-throw error with proper message\n if (error instanceof Error) {\n throw error;\n }\n throw new Error(\"Error signing in\");\n }\n}\n","// @goerp/core/auth\n// Authentication and RBAC utilities for GoERP\n\nimport type { Session } from \"next-auth\";\n\nexport * from \"./auth-service\";\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport interface Permission {\n resourceCode: string;\n actionCode: string;\n}\n\nexport interface ExtendedUser {\n id: string;\n name?: string | null;\n email?: string | null;\n image?: string | null;\n roles?: string[];\n permissions?: Permission[];\n}\n\nexport interface UserSession {\n user: ExtendedUser;\n}\n\nexport interface CrudPermissionResult {\n create: boolean;\n view: boolean;\n update: boolean;\n delete: boolean;\n export: boolean;\n import: boolean;\n approve: boolean;\n reject: boolean;\n}\n\n// ============================================================================\n// Constants\n// ============================================================================\n\nconst ADMIN_ROLE_CODE = \"admin\";\nconst BYPASS_AUTH =\n process.env.BYPASS_AUTH === \"true\" || process.env.BYPASS_AUTH === \"1\";\n\n// Action code mapping\nconst ACTION_CODES: Record<string, string> = {\n create: \"create\",\n view: \"view\",\n update: \"update\",\n delete: \"delete\",\n export: \"export\",\n import: \"import\",\n approve: \"approve\",\n reject: \"reject\",\n};\n\n/**\n * Get action code from action name\n */\nexport function getActionCode(action: string): string {\n return ACTION_CODES[action] || action;\n}\n\n// ============================================================================\n// Permission Functions\n// ============================================================================\n\n/**\n * Get all permissions from session\n */\nexport function getUserPermissions(session: Session | null): Permission[] {\n if (!session?.user) return [];\n const user = session.user as ExtendedUser;\n\n if (!user.permissions) {\n return [];\n }\n return user.permissions;\n}\n\n/**\n * Get CRUD permissions from session for a specific entity\n */\nexport function getCrudPermissionsFromSession(\n session: Session | null,\n entity: string,\n): CrudPermissionResult {\n // TEMPORARY: Return all permissions as true if bypass is enabled\n if (BYPASS_AUTH) {\n return {\n create: true,\n view: true,\n update: true,\n delete: true,\n export: true,\n import: true,\n approve: true,\n reject: true,\n };\n }\n\n if (!session?.user) {\n return {\n create: false,\n view: false,\n update: false,\n delete: false,\n export: false,\n import: false,\n approve: false,\n reject: false,\n };\n }\n\n const user = session.user as ExtendedUser;\n\n if (!user.id) {\n return {\n create: false,\n view: false,\n update: false,\n delete: false,\n export: false,\n import: false,\n approve: false,\n reject: false,\n };\n }\n\n // Check admin role first (fastest check)\n const isAdmin =\n user.roles?.includes(ADMIN_ROLE_CODE) ||\n user.roles?.includes(\"SUPER_ADMIN\");\n if (isAdmin) {\n return {\n create: true,\n view: true,\n update: true,\n delete: true,\n export: true,\n import: true,\n approve: true,\n reject: true,\n };\n }\n\n // Pre-compute permission keys for fast lookup\n const permissions = user.permissions || [];\n const permissionKeys = new Set(\n permissions.map((p) => `${p.resourceCode}:${p.actionCode}`),\n );\n\n const hasPermission = (action: string) => {\n const key = `${entity}:${action}`;\n return permissionKeys.has(key);\n };\n\n return {\n create: hasPermission(getActionCode(\"create\")),\n view: hasPermission(getActionCode(\"view\")),\n update: hasPermission(getActionCode(\"update\")),\n delete: hasPermission(getActionCode(\"delete\")),\n export: hasPermission(getActionCode(\"export\")),\n import: hasPermission(getActionCode(\"import\")),\n approve: hasPermission(getActionCode(\"approve\")),\n reject: hasPermission(getActionCode(\"reject\")),\n };\n}\n\n/**\n * Check if user has a specific permission\n */\nexport function checkPermission(\n session: Session | null,\n resourceCode: string,\n actionCode: string,\n): boolean {\n if (BYPASS_AUTH) {\n return true;\n }\n\n if (!session?.user) return false;\n const user = session.user as ExtendedUser;\n\n if (!user.permissions || user.permissions.length === 0) {\n return false;\n }\n\n // Admin role bypass\n if (\n user.roles?.includes(ADMIN_ROLE_CODE) ||\n user.roles?.includes(\"SUPER_ADMIN\")\n ) {\n return true;\n }\n\n return user.permissions.some(\n (p) => p.resourceCode === resourceCode && p.actionCode === actionCode,\n );\n}\n\n/**\n * Alias for checkPermission\n */\nexport function hasPermission(\n session: Session | null,\n resourceCode: string,\n actionCode: string,\n): boolean {\n return checkPermission(session, resourceCode, actionCode);\n}\n\n/**\n * Require permission - throw error if not authorized\n */\nexport function requirePermission(\n session: Session | null,\n resourceCode: string,\n actionCode: string,\n): void {\n if (!checkPermission(session, resourceCode, actionCode)) {\n throw new Error(\n `Unauthorized: User does not have permission ${actionCode} on ${resourceCode}`,\n );\n }\n}\n\n/**\n * Check if user has a specific role\n */\nexport function hasRole(session: Session | null, roleCode: string): boolean {\n if (!session?.user) return false;\n const user = session.user as ExtendedUser;\n\n if (!user.roles) {\n return false;\n }\n return user.roles.includes(roleCode);\n}\n\n/**\n * Check if user has any of the specified roles\n */\nexport function hasAnyRole(\n session: Session | null,\n roleCodes: string[],\n): boolean {\n if (!session?.user) return false;\n const user = session.user as ExtendedUser;\n\n if (!user.roles) {\n return false;\n }\n return roleCodes.some((role) => user.roles!.includes(role));\n}\n\n/**\n * Check if user is admin\n */\nexport function isAdmin(session: Session | null): boolean {\n return hasRole(session, ADMIN_ROLE_CODE);\n}\n"]}
@@ -1,30 +0,0 @@
1
- import * as class_variance_authority_types from 'class-variance-authority/types';
2
- import * as React from 'react';
3
- import { VariantProps } from 'class-variance-authority';
4
-
5
- /**
6
- * Button Variants — Enhanced with Plane-inspired semantic tokens
7
- *
8
- * New variants:
9
- * - accent: Brand CTA button (indigo)
10
- * - danger: Destructive action (red, solid)
11
- * - danger-outline: Destructive action (red, outlined)
12
- * - success: Positive action (green)
13
- *
14
- * New sizes:
15
- * - xs: Ultra-compact for ERP table actions
16
- * - compact: Compact for toolbars
17
- */
18
- declare const buttonVariants: (props?: ({
19
- variant?: "default" | "destructive" | "outline" | "secondary" | "ghost" | "link" | "success" | "accent" | "danger" | "danger-outline" | "tertiary" | null | undefined;
20
- size?: "icon" | "compact" | "default" | "sm" | "lg" | "xs" | "icon-sm" | "icon-xs" | null | undefined;
21
- } & class_variance_authority_types.ClassProp) | undefined) => string;
22
- interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement>, VariantProps<typeof buttonVariants> {
23
- asChild?: boolean;
24
- loading?: boolean;
25
- prependIcon?: React.ReactElement;
26
- appendIcon?: React.ReactElement;
27
- }
28
- declare const Button: React.ForwardRefExoticComponent<ButtonProps & React.RefAttributes<HTMLButtonElement>>;
29
-
30
- export { Button as B, type ButtonProps as a, buttonVariants as b };
@@ -1,30 +0,0 @@
1
- import * as class_variance_authority_types from 'class-variance-authority/types';
2
- import * as React from 'react';
3
- import { VariantProps } from 'class-variance-authority';
4
-
5
- /**
6
- * Button Variants — Enhanced with Plane-inspired semantic tokens
7
- *
8
- * New variants:
9
- * - accent: Brand CTA button (indigo)
10
- * - danger: Destructive action (red, solid)
11
- * - danger-outline: Destructive action (red, outlined)
12
- * - success: Positive action (green)
13
- *
14
- * New sizes:
15
- * - xs: Ultra-compact for ERP table actions
16
- * - compact: Compact for toolbars
17
- */
18
- declare const buttonVariants: (props?: ({
19
- variant?: "default" | "destructive" | "outline" | "secondary" | "ghost" | "link" | "success" | "accent" | "danger" | "danger-outline" | "tertiary" | null | undefined;
20
- size?: "icon" | "compact" | "default" | "sm" | "lg" | "xs" | "icon-sm" | "icon-xs" | null | undefined;
21
- } & class_variance_authority_types.ClassProp) | undefined) => string;
22
- interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement>, VariantProps<typeof buttonVariants> {
23
- asChild?: boolean;
24
- loading?: boolean;
25
- prependIcon?: React.ReactElement;
26
- appendIcon?: React.ReactElement;
27
- }
28
- declare const Button: React.ForwardRefExoticComponent<ButtonProps & React.RefAttributes<HTMLButtonElement>>;
29
-
30
- export { Button as B, type ButtonProps as a, buttonVariants as b };
@@ -1,20 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import * as React from 'react';
3
- import { ComponentProps } from 'react';
4
- import * as PopoverPrimitive from '@radix-ui/react-popover';
5
- import { DayPicker } from 'react-day-picker';
6
-
7
- declare function Popover({ ...props }: ComponentProps<typeof PopoverPrimitive.Root>): react_jsx_runtime.JSX.Element;
8
- declare function PopoverTrigger({ className, ...props }: ComponentProps<typeof PopoverPrimitive.Trigger>): react_jsx_runtime.JSX.Element;
9
- declare function PopoverAnchor({ ...props }: ComponentProps<typeof PopoverPrimitive.Anchor>): react_jsx_runtime.JSX.Element;
10
- declare function PopoverContent({ className, align, sideOffset, container, ...props }: ComponentProps<typeof PopoverPrimitive.Content> & {
11
- container?: HTMLElement;
12
- }): react_jsx_runtime.JSX.Element;
13
-
14
- type CalendarProps = React.ComponentProps<typeof DayPicker>;
15
- declare function Calendar({ className, classNames, showOutsideDays, ...props }: CalendarProps): react_jsx_runtime.JSX.Element;
16
- declare namespace Calendar {
17
- var displayName: string;
18
- }
19
-
20
- export { Calendar as C, Popover as P, type CalendarProps as a, PopoverAnchor as b, PopoverContent as c, PopoverTrigger as d };
@@ -1,20 +0,0 @@
1
- import * as react_jsx_runtime from 'react/jsx-runtime';
2
- import * as React from 'react';
3
- import { ComponentProps } from 'react';
4
- import * as PopoverPrimitive from '@radix-ui/react-popover';
5
- import { DayPicker } from 'react-day-picker';
6
-
7
- declare function Popover({ ...props }: ComponentProps<typeof PopoverPrimitive.Root>): react_jsx_runtime.JSX.Element;
8
- declare function PopoverTrigger({ className, ...props }: ComponentProps<typeof PopoverPrimitive.Trigger>): react_jsx_runtime.JSX.Element;
9
- declare function PopoverAnchor({ ...props }: ComponentProps<typeof PopoverPrimitive.Anchor>): react_jsx_runtime.JSX.Element;
10
- declare function PopoverContent({ className, align, sideOffset, container, ...props }: ComponentProps<typeof PopoverPrimitive.Content> & {
11
- container?: HTMLElement;
12
- }): react_jsx_runtime.JSX.Element;
13
-
14
- type CalendarProps = React.ComponentProps<typeof DayPicker>;
15
- declare function Calendar({ className, classNames, showOutsideDays, ...props }: CalendarProps): react_jsx_runtime.JSX.Element;
16
- declare namespace Calendar {
17
- var displayName: string;
18
- }
19
-
20
- export { Calendar as C, Popover as P, type CalendarProps as a, PopoverAnchor as b, PopoverContent as c, PopoverTrigger as d };
@@ -1,30 +0,0 @@
1
- interface CodeGenerationRule {
2
- id: string;
3
- entityType: string;
4
- ruleName: string;
5
- prefix: string;
6
- pattern: string;
7
- sequenceLength: number;
8
- resetDaily: boolean;
9
- resetMonthly: boolean;
10
- resetYearly: boolean;
11
- isActive: boolean;
12
- createdAt: Date;
13
- updatedAt: Date;
14
- }
15
- interface CodeGenerationContext {
16
- userId: string;
17
- date?: Date;
18
- }
19
- /**
20
- * Parse pattern string and replace placeholders
21
- * Example: "{PREFIX}-{SEQ:3}" -> "WA-001"
22
- */
23
- declare function parsePattern(pattern: string, placeholders: Record<string, string>): string;
24
- /**
25
- * Build search pattern based on rule configuration
26
- * Used to query DB for latest code
27
- */
28
- declare function buildSearchPattern(rule: Partial<CodeGenerationRule>, date: Date): string;
29
-
30
- export { type CodeGenerationContext, type CodeGenerationRule, buildSearchPattern, parsePattern };
@@ -1,30 +0,0 @@
1
- interface CodeGenerationRule {
2
- id: string;
3
- entityType: string;
4
- ruleName: string;
5
- prefix: string;
6
- pattern: string;
7
- sequenceLength: number;
8
- resetDaily: boolean;
9
- resetMonthly: boolean;
10
- resetYearly: boolean;
11
- isActive: boolean;
12
- createdAt: Date;
13
- updatedAt: Date;
14
- }
15
- interface CodeGenerationContext {
16
- userId: string;
17
- date?: Date;
18
- }
19
- /**
20
- * Parse pattern string and replace placeholders
21
- * Example: "{PREFIX}-{SEQ:3}" -> "WA-001"
22
- */
23
- declare function parsePattern(pattern: string, placeholders: Record<string, string>): string;
24
- /**
25
- * Build search pattern based on rule configuration
26
- * Used to query DB for latest code
27
- */
28
- declare function buildSearchPattern(rule: Partial<CodeGenerationRule>, date: Date): string;
29
-
30
- export { type CodeGenerationContext, type CodeGenerationRule, buildSearchPattern, parsePattern };
@@ -1,31 +0,0 @@
1
- 'use strict';
2
-
3
- // src/code-generation/index.ts
4
- function parsePattern(pattern, placeholders) {
5
- let result = pattern;
6
- for (const [key, value] of Object.entries(placeholders)) {
7
- const regex = new RegExp(`\\{${key}(?::\\d+)?\\}`, "g");
8
- result = result.replace(regex, value);
9
- }
10
- return result;
11
- }
12
- function buildSearchPattern(rule, date) {
13
- const { prefix, resetDaily, resetMonthly, resetYearly } = rule;
14
- let searchPattern = `${prefix}-`;
15
- if (resetDaily) {
16
- const dateStr = `${date.getFullYear()}${(date.getMonth() + 1).toString().padStart(2, "0")}${date.getDate().toString().padStart(2, "0")}`;
17
- searchPattern += `${dateStr}-`;
18
- } else if (resetMonthly) {
19
- const monthStr = `${date.getFullYear()}${(date.getMonth() + 1).toString().padStart(2, "0")}`;
20
- searchPattern += `${monthStr}-`;
21
- } else if (resetYearly) {
22
- const yearStr = date.getFullYear().toString();
23
- searchPattern += `${yearStr}-`;
24
- }
25
- return searchPattern;
26
- }
27
-
28
- exports.buildSearchPattern = buildSearchPattern;
29
- exports.parsePattern = parsePattern;
30
- //# sourceMappingURL=index.js.map
31
- //# sourceMappingURL=index.js.map