@contractspec/example.marketplace 1.57.0 → 1.59.0

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 (302) hide show
  1. package/dist/browser/docs/index.js +103 -0
  2. package/dist/browser/docs/marketplace.docblock.js +103 -0
  3. package/dist/browser/entities/index.js +721 -0
  4. package/dist/browser/entities/order.js +167 -0
  5. package/dist/browser/entities/payout.js +142 -0
  6. package/dist/browser/entities/product.js +152 -0
  7. package/dist/browser/entities/review.js +129 -0
  8. package/dist/browser/entities/store.js +97 -0
  9. package/dist/browser/example.js +42 -0
  10. package/dist/browser/handlers/index.js +303 -0
  11. package/dist/browser/handlers/marketplace.handlers.js +303 -0
  12. package/dist/browser/index.js +2016 -0
  13. package/dist/browser/marketplace.capability.js +40 -0
  14. package/dist/browser/marketplace.feature.js +137 -0
  15. package/dist/browser/order/index.js +307 -0
  16. package/dist/browser/order/order.enum.js +17 -0
  17. package/dist/browser/order/order.event.js +131 -0
  18. package/dist/browser/order/order.operations.js +172 -0
  19. package/dist/browser/order/order.presentation.js +153 -0
  20. package/dist/browser/order/order.schema.js +79 -0
  21. package/dist/browser/payout/index.js +152 -0
  22. package/dist/browser/payout/payout.enum.js +12 -0
  23. package/dist/browser/payout/payout.event.js +55 -0
  24. package/dist/browser/payout/payout.operations.js +94 -0
  25. package/dist/browser/payout/payout.presentation.js +111 -0
  26. package/dist/browser/payout/payout.schema.js +61 -0
  27. package/dist/browser/product/index.js +249 -0
  28. package/dist/browser/product/product.enum.js +13 -0
  29. package/dist/browser/product/product.event.js +74 -0
  30. package/dist/browser/product/product.operations.js +171 -0
  31. package/dist/browser/product/product.presentation.js +158 -0
  32. package/dist/browser/product/product.schema.js +84 -0
  33. package/dist/browser/review/index.js +206 -0
  34. package/dist/browser/review/review.enum.js +11 -0
  35. package/dist/browser/review/review.event.js +50 -0
  36. package/dist/browser/review/review.operations.js +152 -0
  37. package/dist/browser/review/review.presentation.js +123 -0
  38. package/dist/browser/review/review.schema.js +74 -0
  39. package/dist/browser/seeders/index.js +12 -0
  40. package/dist/browser/store/index.js +142 -0
  41. package/dist/browser/store/store.enum.js +11 -0
  42. package/dist/browser/store/store.event.js +52 -0
  43. package/dist/browser/store/store.operations.js +88 -0
  44. package/dist/browser/store/store.presentation.js +94 -0
  45. package/dist/browser/store/store.schema.js +43 -0
  46. package/dist/browser/tests/operations.test-spec.js +139 -0
  47. package/dist/browser/ui/MarketplaceDashboard.js +418 -0
  48. package/dist/browser/ui/hooks/index.js +59 -0
  49. package/dist/browser/ui/hooks/useMarketplaceData.js +56 -0
  50. package/dist/browser/ui/index.js +668 -0
  51. package/dist/browser/ui/renderers/index.js +248 -0
  52. package/dist/browser/ui/renderers/marketplace.markdown.js +248 -0
  53. package/dist/docs/index.d.ts +2 -1
  54. package/dist/docs/index.d.ts.map +1 -0
  55. package/dist/docs/index.js +104 -1
  56. package/dist/docs/marketplace.docblock.d.ts +2 -1
  57. package/dist/docs/marketplace.docblock.d.ts.map +1 -0
  58. package/dist/docs/marketplace.docblock.js +46 -57
  59. package/dist/entities/index.d.ts +302 -307
  60. package/dist/entities/index.d.ts.map +1 -1
  61. package/dist/entities/index.js +719 -43
  62. package/dist/entities/order.d.ts +77 -82
  63. package/dist/entities/order.d.ts.map +1 -1
  64. package/dist/entities/order.js +162 -167
  65. package/dist/entities/payout.d.ts +64 -69
  66. package/dist/entities/payout.d.ts.map +1 -1
  67. package/dist/entities/payout.js +137 -156
  68. package/dist/entities/product.d.ts +69 -74
  69. package/dist/entities/product.d.ts.map +1 -1
  70. package/dist/entities/product.js +148 -156
  71. package/dist/entities/review.d.ts +55 -60
  72. package/dist/entities/review.d.ts.map +1 -1
  73. package/dist/entities/review.js +124 -146
  74. package/dist/entities/store.d.ts +40 -45
  75. package/dist/entities/store.d.ts.map +1 -1
  76. package/dist/entities/store.js +94 -106
  77. package/dist/example.d.ts +2 -6
  78. package/dist/example.d.ts.map +1 -1
  79. package/dist/example.js +41 -55
  80. package/dist/handlers/index.d.ts +2 -2
  81. package/dist/handlers/index.d.ts.map +1 -0
  82. package/dist/handlers/index.js +304 -3
  83. package/dist/handlers/marketplace.handlers.d.ts +138 -137
  84. package/dist/handlers/marketplace.handlers.d.ts.map +1 -1
  85. package/dist/handlers/marketplace.handlers.js +284 -309
  86. package/dist/index.d.ts +13 -31
  87. package/dist/index.d.ts.map +1 -0
  88. package/dist/index.js +2017 -32
  89. package/dist/marketplace.capability.d.ts +3 -8
  90. package/dist/marketplace.capability.d.ts.map +1 -1
  91. package/dist/marketplace.capability.js +41 -34
  92. package/dist/marketplace.feature.d.ts +1 -6
  93. package/dist/marketplace.feature.d.ts.map +1 -1
  94. package/dist/marketplace.feature.js +136 -313
  95. package/dist/node/docs/index.js +103 -0
  96. package/dist/node/docs/marketplace.docblock.js +103 -0
  97. package/dist/node/entities/index.js +721 -0
  98. package/dist/node/entities/order.js +167 -0
  99. package/dist/node/entities/payout.js +142 -0
  100. package/dist/node/entities/product.js +152 -0
  101. package/dist/node/entities/review.js +129 -0
  102. package/dist/node/entities/store.js +97 -0
  103. package/dist/node/example.js +42 -0
  104. package/dist/node/handlers/index.js +303 -0
  105. package/dist/node/handlers/marketplace.handlers.js +303 -0
  106. package/dist/node/index.js +2016 -0
  107. package/dist/node/marketplace.capability.js +40 -0
  108. package/dist/node/marketplace.feature.js +137 -0
  109. package/dist/node/order/index.js +307 -0
  110. package/dist/node/order/order.enum.js +17 -0
  111. package/dist/node/order/order.event.js +131 -0
  112. package/dist/node/order/order.operations.js +172 -0
  113. package/dist/node/order/order.presentation.js +153 -0
  114. package/dist/node/order/order.schema.js +79 -0
  115. package/dist/node/payout/index.js +152 -0
  116. package/dist/node/payout/payout.enum.js +12 -0
  117. package/dist/node/payout/payout.event.js +55 -0
  118. package/dist/node/payout/payout.operations.js +94 -0
  119. package/dist/node/payout/payout.presentation.js +111 -0
  120. package/dist/node/payout/payout.schema.js +61 -0
  121. package/dist/node/product/index.js +249 -0
  122. package/dist/node/product/product.enum.js +13 -0
  123. package/dist/node/product/product.event.js +74 -0
  124. package/dist/node/product/product.operations.js +171 -0
  125. package/dist/node/product/product.presentation.js +158 -0
  126. package/dist/node/product/product.schema.js +84 -0
  127. package/dist/node/review/index.js +206 -0
  128. package/dist/node/review/review.enum.js +11 -0
  129. package/dist/node/review/review.event.js +50 -0
  130. package/dist/node/review/review.operations.js +152 -0
  131. package/dist/node/review/review.presentation.js +123 -0
  132. package/dist/node/review/review.schema.js +74 -0
  133. package/dist/node/seeders/index.js +12 -0
  134. package/dist/node/store/index.js +142 -0
  135. package/dist/node/store/store.enum.js +11 -0
  136. package/dist/node/store/store.event.js +52 -0
  137. package/dist/node/store/store.operations.js +88 -0
  138. package/dist/node/store/store.presentation.js +94 -0
  139. package/dist/node/store/store.schema.js +43 -0
  140. package/dist/node/tests/operations.test-spec.js +139 -0
  141. package/dist/node/ui/MarketplaceDashboard.js +418 -0
  142. package/dist/node/ui/hooks/index.js +59 -0
  143. package/dist/node/ui/hooks/useMarketplaceData.js +56 -0
  144. package/dist/node/ui/index.js +668 -0
  145. package/dist/node/ui/renderers/index.js +248 -0
  146. package/dist/node/ui/renderers/marketplace.markdown.js +248 -0
  147. package/dist/order/index.d.ts +8 -5
  148. package/dist/order/index.d.ts.map +1 -0
  149. package/dist/order/index.js +307 -5
  150. package/dist/order/order.enum.d.ts +1 -6
  151. package/dist/order/order.enum.d.ts.map +1 -1
  152. package/dist/order/order.enum.js +16 -20
  153. package/dist/order/order.event.d.ts +133 -139
  154. package/dist/order/order.event.d.ts.map +1 -1
  155. package/dist/order/order.event.js +121 -205
  156. package/dist/order/order.operations.d.ts +291 -297
  157. package/dist/order/order.operations.d.ts.map +1 -1
  158. package/dist/order/order.operations.js +169 -115
  159. package/dist/order/order.presentation.d.ts +3 -8
  160. package/dist/order/order.presentation.d.ts.map +1 -1
  161. package/dist/order/order.presentation.js +149 -81
  162. package/dist/order/order.schema.d.ts +143 -148
  163. package/dist/order/order.schema.d.ts.map +1 -1
  164. package/dist/order/order.schema.js +75 -150
  165. package/dist/payout/index.d.ts +8 -5
  166. package/dist/payout/index.d.ts.map +1 -0
  167. package/dist/payout/index.js +152 -5
  168. package/dist/payout/payout.enum.d.ts +1 -6
  169. package/dist/payout/payout.enum.d.ts.map +1 -1
  170. package/dist/payout/payout.enum.js +11 -15
  171. package/dist/payout/payout.event.d.ts +54 -60
  172. package/dist/payout/payout.event.d.ts.map +1 -1
  173. package/dist/payout/payout.event.js +51 -87
  174. package/dist/payout/payout.operations.d.ts +82 -88
  175. package/dist/payout/payout.operations.d.ts.map +1 -1
  176. package/dist/payout/payout.operations.js +92 -50
  177. package/dist/payout/payout.presentation.d.ts +2 -7
  178. package/dist/payout/payout.presentation.d.ts.map +1 -1
  179. package/dist/payout/payout.presentation.js +108 -56
  180. package/dist/payout/payout.schema.d.ts +139 -144
  181. package/dist/payout/payout.schema.d.ts.map +1 -1
  182. package/dist/payout/payout.schema.js +58 -112
  183. package/dist/product/index.d.ts +8 -5
  184. package/dist/product/index.d.ts.map +1 -0
  185. package/dist/product/index.js +249 -5
  186. package/dist/product/product.enum.d.ts +1 -6
  187. package/dist/product/product.enum.d.ts.map +1 -1
  188. package/dist/product/product.enum.js +12 -16
  189. package/dist/product/product.event.d.ts +63 -69
  190. package/dist/product/product.event.d.ts.map +1 -1
  191. package/dist/product/product.event.js +68 -113
  192. package/dist/product/product.operations.d.ts +225 -231
  193. package/dist/product/product.operations.d.ts.map +1 -1
  194. package/dist/product/product.operations.js +168 -104
  195. package/dist/product/product.presentation.d.ts +3 -8
  196. package/dist/product/product.presentation.d.ts.map +1 -1
  197. package/dist/product/product.presentation.js +154 -81
  198. package/dist/product/product.schema.d.ts +196 -201
  199. package/dist/product/product.schema.d.ts.map +1 -1
  200. package/dist/product/product.schema.js +80 -171
  201. package/dist/review/index.d.ts +8 -5
  202. package/dist/review/index.d.ts.map +1 -0
  203. package/dist/review/index.js +206 -5
  204. package/dist/review/review.enum.d.ts +1 -6
  205. package/dist/review/review.enum.d.ts.map +1 -1
  206. package/dist/review/review.enum.js +10 -14
  207. package/dist/review/review.event.d.ts +46 -52
  208. package/dist/review/review.event.d.ts.map +1 -1
  209. package/dist/review/review.event.js +46 -79
  210. package/dist/review/review.operations.d.ts +190 -196
  211. package/dist/review/review.operations.d.ts.map +1 -1
  212. package/dist/review/review.operations.js +149 -102
  213. package/dist/review/review.presentation.d.ts +2 -7
  214. package/dist/review/review.presentation.d.ts.map +1 -1
  215. package/dist/review/review.presentation.js +120 -56
  216. package/dist/review/review.schema.d.ts +164 -169
  217. package/dist/review/review.schema.d.ts.map +1 -1
  218. package/dist/review/review.schema.js +70 -151
  219. package/dist/seeders/index.d.ts +4 -8
  220. package/dist/seeders/index.d.ts.map +1 -1
  221. package/dist/seeders/index.js +11 -16
  222. package/dist/store/index.d.ts +8 -5
  223. package/dist/store/index.d.ts.map +1 -0
  224. package/dist/store/index.js +142 -5
  225. package/dist/store/store.enum.d.ts +1 -6
  226. package/dist/store/store.enum.d.ts.map +1 -1
  227. package/dist/store/store.enum.js +10 -14
  228. package/dist/store/store.event.d.ts +42 -48
  229. package/dist/store/store.event.d.ts.map +1 -1
  230. package/dist/store/store.event.js +48 -75
  231. package/dist/store/store.operations.d.ts +98 -104
  232. package/dist/store/store.operations.d.ts.map +1 -1
  233. package/dist/store/store.operations.js +86 -58
  234. package/dist/store/store.presentation.d.ts +2 -7
  235. package/dist/store/store.presentation.d.ts.map +1 -1
  236. package/dist/store/store.presentation.js +91 -56
  237. package/dist/store/store.schema.d.ts +70 -75
  238. package/dist/store/store.schema.d.ts.map +1 -1
  239. package/dist/store/store.schema.js +41 -90
  240. package/dist/tests/operations.test-spec.d.ts +5 -10
  241. package/dist/tests/operations.test-spec.d.ts.map +1 -1
  242. package/dist/tests/operations.test-spec.js +134 -146
  243. package/dist/ui/MarketplaceDashboard.d.ts +1 -6
  244. package/dist/ui/MarketplaceDashboard.d.ts.map +1 -1
  245. package/dist/ui/MarketplaceDashboard.js +413 -313
  246. package/dist/ui/hooks/index.d.ts +2 -2
  247. package/dist/ui/hooks/index.d.ts.map +1 -0
  248. package/dist/ui/hooks/index.js +59 -4
  249. package/dist/ui/hooks/useMarketplaceData.d.ts +16 -20
  250. package/dist/ui/hooks/useMarketplaceData.d.ts.map +1 -1
  251. package/dist/ui/hooks/useMarketplaceData.js +53 -60
  252. package/dist/ui/index.d.ts +7 -6
  253. package/dist/ui/index.d.ts.map +1 -0
  254. package/dist/ui/index.js +668 -5
  255. package/dist/ui/renderers/index.d.ts +2 -2
  256. package/dist/ui/renderers/index.d.ts.map +1 -0
  257. package/dist/ui/renderers/index.js +249 -3
  258. package/dist/ui/renderers/marketplace.markdown.d.ts +13 -14
  259. package/dist/ui/renderers/marketplace.markdown.d.ts.map +1 -1
  260. package/dist/ui/renderers/marketplace.markdown.js +241 -236
  261. package/package.json +528 -109
  262. package/dist/docs/marketplace.docblock.js.map +0 -1
  263. package/dist/entities/index.js.map +0 -1
  264. package/dist/entities/order.js.map +0 -1
  265. package/dist/entities/payout.js.map +0 -1
  266. package/dist/entities/product.js.map +0 -1
  267. package/dist/entities/review.js.map +0 -1
  268. package/dist/entities/store.js.map +0 -1
  269. package/dist/example.js.map +0 -1
  270. package/dist/handlers/marketplace.handlers.js.map +0 -1
  271. package/dist/marketplace.capability.js.map +0 -1
  272. package/dist/marketplace.feature.js.map +0 -1
  273. package/dist/order/order.enum.js.map +0 -1
  274. package/dist/order/order.event.js.map +0 -1
  275. package/dist/order/order.operations.js.map +0 -1
  276. package/dist/order/order.presentation.js.map +0 -1
  277. package/dist/order/order.schema.js.map +0 -1
  278. package/dist/payout/payout.enum.js.map +0 -1
  279. package/dist/payout/payout.event.js.map +0 -1
  280. package/dist/payout/payout.operations.js.map +0 -1
  281. package/dist/payout/payout.presentation.js.map +0 -1
  282. package/dist/payout/payout.schema.js.map +0 -1
  283. package/dist/product/product.enum.js.map +0 -1
  284. package/dist/product/product.event.js.map +0 -1
  285. package/dist/product/product.operations.js.map +0 -1
  286. package/dist/product/product.presentation.js.map +0 -1
  287. package/dist/product/product.schema.js.map +0 -1
  288. package/dist/review/review.enum.js.map +0 -1
  289. package/dist/review/review.event.js.map +0 -1
  290. package/dist/review/review.operations.js.map +0 -1
  291. package/dist/review/review.presentation.js.map +0 -1
  292. package/dist/review/review.schema.js.map +0 -1
  293. package/dist/seeders/index.js.map +0 -1
  294. package/dist/store/store.enum.js.map +0 -1
  295. package/dist/store/store.event.js.map +0 -1
  296. package/dist/store/store.operations.js.map +0 -1
  297. package/dist/store/store.presentation.js.map +0 -1
  298. package/dist/store/store.schema.js.map +0 -1
  299. package/dist/tests/operations.test-spec.js.map +0 -1
  300. package/dist/ui/MarketplaceDashboard.js.map +0 -1
  301. package/dist/ui/hooks/useMarketplaceData.js.map +0 -1
  302. package/dist/ui/renderers/marketplace.markdown.js.map +0 -1
@@ -1,329 +1,304 @@
1
+ // @bun
2
+ // src/handlers/marketplace.handlers.ts
1
3
  import { web } from "@contractspec/lib.runtime-sandbox";
2
-
3
- //#region src/handlers/marketplace.handlers.ts
4
- const { generateId } = web;
4
+ var { generateId } = web;
5
5
  function rowToStore(row) {
6
- return {
7
- id: row.id,
8
- projectId: row.projectId,
9
- organizationId: row.organizationId,
10
- name: row.name,
11
- description: row.description ?? void 0,
12
- status: row.status,
13
- rating: row.rating,
14
- reviewCount: row.reviewCount,
15
- createdAt: new Date(row.createdAt),
16
- updatedAt: new Date(row.updatedAt)
17
- };
6
+ return {
7
+ id: row.id,
8
+ projectId: row.projectId,
9
+ organizationId: row.organizationId,
10
+ name: row.name,
11
+ description: row.description ?? undefined,
12
+ status: row.status,
13
+ rating: row.rating,
14
+ reviewCount: row.reviewCount,
15
+ createdAt: new Date(row.createdAt),
16
+ updatedAt: new Date(row.updatedAt)
17
+ };
18
18
  }
19
19
  function rowToProduct(row) {
20
- return {
21
- id: row.id,
22
- storeId: row.storeId,
23
- name: row.name,
24
- description: row.description ?? void 0,
25
- price: row.price,
26
- currency: row.currency,
27
- status: row.status,
28
- stock: row.stock,
29
- category: row.category ?? void 0,
30
- imageUrl: row.imageUrl ?? void 0,
31
- createdAt: new Date(row.createdAt),
32
- updatedAt: new Date(row.updatedAt)
33
- };
20
+ return {
21
+ id: row.id,
22
+ storeId: row.storeId,
23
+ name: row.name,
24
+ description: row.description ?? undefined,
25
+ price: row.price,
26
+ currency: row.currency,
27
+ status: row.status,
28
+ stock: row.stock,
29
+ category: row.category ?? undefined,
30
+ imageUrl: row.imageUrl ?? undefined,
31
+ createdAt: new Date(row.createdAt),
32
+ updatedAt: new Date(row.updatedAt)
33
+ };
34
34
  }
35
35
  function rowToOrder(row) {
36
- return {
37
- id: row.id,
38
- projectId: row.projectId,
39
- storeId: row.storeId,
40
- customerId: row.customerId,
41
- status: row.status,
42
- total: row.total,
43
- currency: row.currency,
44
- shippingAddress: row.shippingAddress ?? void 0,
45
- createdAt: new Date(row.createdAt),
46
- updatedAt: new Date(row.updatedAt)
47
- };
36
+ return {
37
+ id: row.id,
38
+ projectId: row.projectId,
39
+ storeId: row.storeId,
40
+ customerId: row.customerId,
41
+ status: row.status,
42
+ total: row.total,
43
+ currency: row.currency,
44
+ shippingAddress: row.shippingAddress ?? undefined,
45
+ createdAt: new Date(row.createdAt),
46
+ updatedAt: new Date(row.updatedAt)
47
+ };
48
48
  }
49
49
  function rowToOrderItem(row) {
50
- return {
51
- id: row.id,
52
- orderId: row.orderId,
53
- productId: row.productId,
54
- quantity: row.quantity,
55
- price: row.price,
56
- createdAt: new Date(row.createdAt)
57
- };
50
+ return {
51
+ id: row.id,
52
+ orderId: row.orderId,
53
+ productId: row.productId,
54
+ quantity: row.quantity,
55
+ price: row.price,
56
+ createdAt: new Date(row.createdAt)
57
+ };
58
58
  }
59
59
  function rowToPayout(row) {
60
- return {
61
- id: row.id,
62
- storeId: row.storeId,
63
- amount: row.amount,
64
- currency: row.currency,
65
- status: row.status,
66
- processedAt: row.processedAt ? new Date(row.processedAt) : void 0,
67
- createdAt: new Date(row.createdAt)
68
- };
60
+ return {
61
+ id: row.id,
62
+ storeId: row.storeId,
63
+ amount: row.amount,
64
+ currency: row.currency,
65
+ status: row.status,
66
+ processedAt: row.processedAt ? new Date(row.processedAt) : undefined,
67
+ createdAt: new Date(row.createdAt)
68
+ };
69
69
  }
70
70
  function rowToReview(row) {
71
- return {
72
- id: row.id,
73
- productId: row.productId,
74
- customerId: row.customerId,
75
- orderId: row.orderId ?? void 0,
76
- rating: row.rating,
77
- comment: row.comment ?? void 0,
78
- createdAt: new Date(row.createdAt)
79
- };
71
+ return {
72
+ id: row.id,
73
+ productId: row.productId,
74
+ customerId: row.customerId,
75
+ orderId: row.orderId ?? undefined,
76
+ rating: row.rating,
77
+ comment: row.comment ?? undefined,
78
+ createdAt: new Date(row.createdAt)
79
+ };
80
80
  }
81
81
  function createMarketplaceHandlers(db) {
82
- /**
83
- * List stores
84
- */
85
- async function listStores(input) {
86
- const { projectId, status, search, limit = 20, offset = 0 } = input;
87
- let whereClause = "WHERE projectId = ?";
88
- const params = [projectId];
89
- if (status && status !== "all") {
90
- whereClause += " AND status = ?";
91
- params.push(status);
92
- }
93
- if (search) {
94
- whereClause += " AND name LIKE ?";
95
- params.push(`%${search}%`);
96
- }
97
- const total = (await db.query(`SELECT COUNT(*) as count FROM marketplace_store ${whereClause}`, params)).rows[0]?.count ?? 0;
98
- return {
99
- stores: (await db.query(`SELECT * FROM marketplace_store ${whereClause} ORDER BY rating DESC LIMIT ? OFFSET ?`, [
100
- ...params,
101
- limit,
102
- offset
103
- ])).rows.map(rowToStore),
104
- total
105
- };
106
- }
107
- /**
108
- * Create a store
109
- */
110
- async function createStore(input, context) {
111
- const id = generateId("store");
112
- const now = (/* @__PURE__ */ new Date()).toISOString();
113
- await db.execute(`INSERT INTO marketplace_store (id, projectId, organizationId, name, description, status, rating, reviewCount, createdAt, updatedAt)
82
+ async function listStores(input) {
83
+ const { projectId, status, search, limit = 20, offset = 0 } = input;
84
+ let whereClause = "WHERE projectId = ?";
85
+ const params = [projectId];
86
+ if (status && status !== "all") {
87
+ whereClause += " AND status = ?";
88
+ params.push(status);
89
+ }
90
+ if (search) {
91
+ whereClause += " AND name LIKE ?";
92
+ params.push(`%${search}%`);
93
+ }
94
+ const countResult = (await db.query(`SELECT COUNT(*) as count FROM marketplace_store ${whereClause}`, params)).rows;
95
+ const total = countResult[0]?.count ?? 0;
96
+ const rows = (await db.query(`SELECT * FROM marketplace_store ${whereClause} ORDER BY rating DESC LIMIT ? OFFSET ?`, [...params, limit, offset])).rows;
97
+ return {
98
+ stores: rows.map(rowToStore),
99
+ total
100
+ };
101
+ }
102
+ async function createStore(input, context) {
103
+ const id = generateId("store");
104
+ const now = new Date().toISOString();
105
+ await db.execute(`INSERT INTO marketplace_store (id, projectId, organizationId, name, description, status, rating, reviewCount, createdAt, updatedAt)
114
106
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [
115
- id,
116
- context.projectId,
117
- context.organizationId,
118
- input.name,
119
- input.description ?? null,
120
- "PENDING",
121
- 0,
122
- 0,
123
- now,
124
- now
125
- ]);
126
- const rows = (await db.query(`SELECT * FROM marketplace_store WHERE id = ?`, [id])).rows;
127
- return rowToStore(rows[0]);
128
- }
129
- /**
130
- * List products
131
- */
132
- async function listProducts(input) {
133
- const { storeId, status, category, search, limit = 20, offset = 0 } = input;
134
- let whereClause = "WHERE 1=1";
135
- const params = [];
136
- if (storeId) {
137
- whereClause += " AND storeId = ?";
138
- params.push(storeId);
139
- }
140
- if (status && status !== "all") {
141
- whereClause += " AND status = ?";
142
- params.push(status);
143
- }
144
- if (category) {
145
- whereClause += " AND category = ?";
146
- params.push(category);
147
- }
148
- if (search) {
149
- whereClause += " AND name LIKE ?";
150
- params.push(`%${search}%`);
151
- }
152
- const total = (await db.query(`SELECT COUNT(*) as count FROM marketplace_product ${whereClause}`, params)).rows[0]?.count ?? 0;
153
- return {
154
- products: (await db.query(`SELECT * FROM marketplace_product ${whereClause} ORDER BY createdAt DESC LIMIT ? OFFSET ?`, [
155
- ...params,
156
- limit,
157
- offset
158
- ])).rows.map(rowToProduct),
159
- total
160
- };
161
- }
162
- /**
163
- * Add a product
164
- */
165
- async function addProduct(input) {
166
- const id = generateId("prod");
167
- const now = (/* @__PURE__ */ new Date()).toISOString();
168
- await db.execute(`INSERT INTO marketplace_product (id, storeId, name, description, price, currency, status, stock, category, imageUrl, createdAt, updatedAt)
107
+ id,
108
+ context.projectId,
109
+ context.organizationId,
110
+ input.name,
111
+ input.description ?? null,
112
+ "PENDING",
113
+ 0,
114
+ 0,
115
+ now,
116
+ now
117
+ ]);
118
+ const rows = (await db.query(`SELECT * FROM marketplace_store WHERE id = ?`, [id])).rows;
119
+ return rowToStore(rows[0]);
120
+ }
121
+ async function listProducts(input) {
122
+ const { storeId, status, category, search, limit = 20, offset = 0 } = input;
123
+ let whereClause = "WHERE 1=1";
124
+ const params = [];
125
+ if (storeId) {
126
+ whereClause += " AND storeId = ?";
127
+ params.push(storeId);
128
+ }
129
+ if (status && status !== "all") {
130
+ whereClause += " AND status = ?";
131
+ params.push(status);
132
+ }
133
+ if (category) {
134
+ whereClause += " AND category = ?";
135
+ params.push(category);
136
+ }
137
+ if (search) {
138
+ whereClause += " AND name LIKE ?";
139
+ params.push(`%${search}%`);
140
+ }
141
+ const countResult = (await db.query(`SELECT COUNT(*) as count FROM marketplace_product ${whereClause}`, params)).rows;
142
+ const total = countResult[0]?.count ?? 0;
143
+ const rows = (await db.query(`SELECT * FROM marketplace_product ${whereClause} ORDER BY createdAt DESC LIMIT ? OFFSET ?`, [...params, limit, offset])).rows;
144
+ return {
145
+ products: rows.map(rowToProduct),
146
+ total
147
+ };
148
+ }
149
+ async function addProduct(input) {
150
+ const id = generateId("prod");
151
+ const now = new Date().toISOString();
152
+ await db.execute(`INSERT INTO marketplace_product (id, storeId, name, description, price, currency, status, stock, category, imageUrl, createdAt, updatedAt)
169
153
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [
170
- id,
171
- input.storeId,
172
- input.name,
173
- input.description ?? null,
174
- input.price,
175
- input.currency ?? "USD",
176
- "DRAFT",
177
- input.stock ?? 0,
178
- input.category ?? null,
179
- input.imageUrl ?? null,
180
- now,
181
- now
182
- ]);
183
- const rows = (await db.query(`SELECT * FROM marketplace_product WHERE id = ?`, [id])).rows;
184
- return rowToProduct(rows[0]);
185
- }
186
- /**
187
- * List orders
188
- */
189
- async function listOrders(input) {
190
- const { projectId, storeId, customerId, status, limit = 20, offset = 0 } = input;
191
- let whereClause = "WHERE projectId = ?";
192
- const params = [projectId];
193
- if (storeId) {
194
- whereClause += " AND storeId = ?";
195
- params.push(storeId);
196
- }
197
- if (customerId) {
198
- whereClause += " AND customerId = ?";
199
- params.push(customerId);
200
- }
201
- if (status && status !== "all") {
202
- whereClause += " AND status = ?";
203
- params.push(status);
204
- }
205
- const total = (await db.query(`SELECT COUNT(*) as count FROM marketplace_order ${whereClause}`, params)).rows[0]?.count ?? 0;
206
- const totalRevenue = (await db.query(`SELECT COALESCE(SUM(total), 0) as revenue FROM marketplace_order ${whereClause}`, params)).rows[0]?.revenue ?? 0;
207
- return {
208
- orders: (await db.query(`SELECT * FROM marketplace_order ${whereClause} ORDER BY createdAt DESC LIMIT ? OFFSET ?`, [
209
- ...params,
210
- limit,
211
- offset
212
- ])).rows.map(rowToOrder),
213
- total,
214
- totalRevenue
215
- };
216
- }
217
- /**
218
- * Place an order
219
- */
220
- async function placeOrder(input, context) {
221
- const orderId = generateId("order");
222
- const now = (/* @__PURE__ */ new Date()).toISOString();
223
- let total = 0;
224
- const itemsToCreate = [];
225
- for (const item of input.items) {
226
- const products = (await db.query(`SELECT * FROM marketplace_product WHERE id = ?`, [item.productId])).rows;
227
- if (!products[0]) throw new Error(`Product not found: ${item.productId}`);
228
- const itemPrice = products[0].price * item.quantity;
229
- total += itemPrice;
230
- itemsToCreate.push({
231
- productId: item.productId,
232
- quantity: item.quantity,
233
- price: products[0].price
234
- });
235
- }
236
- await db.execute(`INSERT INTO marketplace_order (id, projectId, storeId, customerId, status, total, currency, shippingAddress, createdAt, updatedAt)
154
+ id,
155
+ input.storeId,
156
+ input.name,
157
+ input.description ?? null,
158
+ input.price,
159
+ input.currency ?? "USD",
160
+ "DRAFT",
161
+ input.stock ?? 0,
162
+ input.category ?? null,
163
+ input.imageUrl ?? null,
164
+ now,
165
+ now
166
+ ]);
167
+ const rows = (await db.query(`SELECT * FROM marketplace_product WHERE id = ?`, [id])).rows;
168
+ return rowToProduct(rows[0]);
169
+ }
170
+ async function listOrders(input) {
171
+ const {
172
+ projectId,
173
+ storeId,
174
+ customerId,
175
+ status,
176
+ limit = 20,
177
+ offset = 0
178
+ } = input;
179
+ let whereClause = "WHERE projectId = ?";
180
+ const params = [projectId];
181
+ if (storeId) {
182
+ whereClause += " AND storeId = ?";
183
+ params.push(storeId);
184
+ }
185
+ if (customerId) {
186
+ whereClause += " AND customerId = ?";
187
+ params.push(customerId);
188
+ }
189
+ if (status && status !== "all") {
190
+ whereClause += " AND status = ?";
191
+ params.push(status);
192
+ }
193
+ const countResult = (await db.query(`SELECT COUNT(*) as count FROM marketplace_order ${whereClause}`, params)).rows;
194
+ const total = countResult[0]?.count ?? 0;
195
+ const revenueResult = (await db.query(`SELECT COALESCE(SUM(total), 0) as revenue FROM marketplace_order ${whereClause}`, params)).rows;
196
+ const totalRevenue = revenueResult[0]?.revenue ?? 0;
197
+ const rows = (await db.query(`SELECT * FROM marketplace_order ${whereClause} ORDER BY createdAt DESC LIMIT ? OFFSET ?`, [...params, limit, offset])).rows;
198
+ return {
199
+ orders: rows.map(rowToOrder),
200
+ total,
201
+ totalRevenue
202
+ };
203
+ }
204
+ async function placeOrder(input, context) {
205
+ const orderId = generateId("order");
206
+ const now = new Date().toISOString();
207
+ let total = 0;
208
+ const itemsToCreate = [];
209
+ for (const item of input.items) {
210
+ const products = (await db.query(`SELECT * FROM marketplace_product WHERE id = ?`, [
211
+ item.productId
212
+ ])).rows;
213
+ if (!products[0]) {
214
+ throw new Error(`Product not found: ${item.productId}`);
215
+ }
216
+ const itemPrice = products[0].price * item.quantity;
217
+ total += itemPrice;
218
+ itemsToCreate.push({
219
+ productId: item.productId,
220
+ quantity: item.quantity,
221
+ price: products[0].price
222
+ });
223
+ }
224
+ await db.execute(`INSERT INTO marketplace_order (id, projectId, storeId, customerId, status, total, currency, shippingAddress, createdAt, updatedAt)
237
225
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`, [
238
- orderId,
239
- context.projectId,
240
- input.storeId,
241
- context.customerId,
242
- "PENDING",
243
- total,
244
- "USD",
245
- input.shippingAddress ?? null,
246
- now,
247
- now
248
- ]);
249
- for (const item of itemsToCreate) await db.execute(`INSERT INTO marketplace_order_item (id, orderId, productId, quantity, price, createdAt)
226
+ orderId,
227
+ context.projectId,
228
+ input.storeId,
229
+ context.customerId,
230
+ "PENDING",
231
+ total,
232
+ "USD",
233
+ input.shippingAddress ?? null,
234
+ now,
235
+ now
236
+ ]);
237
+ for (const item of itemsToCreate) {
238
+ await db.execute(`INSERT INTO marketplace_order_item (id, orderId, productId, quantity, price, createdAt)
250
239
  VALUES (?, ?, ?, ?, ?, ?)`, [
251
- generateId("orditem"),
252
- orderId,
253
- item.productId,
254
- item.quantity,
255
- item.price,
256
- now
257
- ]);
258
- const rows = (await db.query(`SELECT * FROM marketplace_order WHERE id = ?`, [orderId])).rows;
259
- return rowToOrder(rows[0]);
260
- }
261
- /**
262
- * Get order items
263
- */
264
- async function getOrderItems(orderId) {
265
- return (await db.query(`SELECT * FROM marketplace_order_item WHERE orderId = ?`, [orderId])).rows.map(rowToOrderItem);
266
- }
267
- /**
268
- * Update order status
269
- */
270
- async function updateOrderStatus(orderId, status) {
271
- const now = (/* @__PURE__ */ new Date()).toISOString();
272
- await db.execute(`UPDATE marketplace_order SET status = ?, updatedAt = ? WHERE id = ?`, [
273
- status,
274
- now,
275
- orderId
276
- ]);
277
- const rows = (await db.query(`SELECT * FROM marketplace_order WHERE id = ?`, [orderId])).rows;
278
- return rowToOrder(rows[0]);
279
- }
280
- /**
281
- * List payouts
282
- */
283
- async function listPayouts(storeId) {
284
- return (await db.query(`SELECT * FROM marketplace_payout WHERE storeId = ? ORDER BY createdAt DESC`, [storeId])).rows.map(rowToPayout);
285
- }
286
- /**
287
- * List reviews for a product
288
- */
289
- async function listReviews(productId) {
290
- return (await db.query(`SELECT * FROM marketplace_review WHERE productId = ? ORDER BY createdAt DESC`, [productId])).rows.map(rowToReview);
291
- }
292
- /**
293
- * Submit a review
294
- */
295
- async function submitReview(input) {
296
- const id = generateId("review");
297
- const now = (/* @__PURE__ */ new Date()).toISOString();
298
- await db.execute(`INSERT INTO marketplace_review (id, productId, customerId, orderId, rating, comment, createdAt)
240
+ generateId("orditem"),
241
+ orderId,
242
+ item.productId,
243
+ item.quantity,
244
+ item.price,
245
+ now
246
+ ]);
247
+ }
248
+ const rows = (await db.query(`SELECT * FROM marketplace_order WHERE id = ?`, [orderId])).rows;
249
+ return rowToOrder(rows[0]);
250
+ }
251
+ async function getOrderItems(orderId) {
252
+ const rows = (await db.query(`SELECT * FROM marketplace_order_item WHERE orderId = ?`, [
253
+ orderId
254
+ ])).rows;
255
+ return rows.map(rowToOrderItem);
256
+ }
257
+ async function updateOrderStatus(orderId, status) {
258
+ const now = new Date().toISOString();
259
+ await db.execute(`UPDATE marketplace_order SET status = ?, updatedAt = ? WHERE id = ?`, [status, now, orderId]);
260
+ const rows = (await db.query(`SELECT * FROM marketplace_order WHERE id = ?`, [orderId])).rows;
261
+ return rowToOrder(rows[0]);
262
+ }
263
+ async function listPayouts(storeId) {
264
+ const rows = (await db.query(`SELECT * FROM marketplace_payout WHERE storeId = ? ORDER BY createdAt DESC`, [storeId])).rows;
265
+ return rows.map(rowToPayout);
266
+ }
267
+ async function listReviews(productId) {
268
+ const rows = (await db.query(`SELECT * FROM marketplace_review WHERE productId = ? ORDER BY createdAt DESC`, [productId])).rows;
269
+ return rows.map(rowToReview);
270
+ }
271
+ async function submitReview(input) {
272
+ const id = generateId("review");
273
+ const now = new Date().toISOString();
274
+ await db.execute(`INSERT INTO marketplace_review (id, productId, customerId, orderId, rating, comment, createdAt)
299
275
  VALUES (?, ?, ?, ?, ?, ?, ?)`, [
300
- id,
301
- input.productId,
302
- input.customerId,
303
- input.orderId ?? null,
304
- input.rating,
305
- input.comment ?? null,
306
- now,
307
- now
308
- ]);
309
- const rows = (await db.query(`SELECT * FROM marketplace_review WHERE id = ?`, [id])).rows;
310
- return rowToReview(rows[0]);
311
- }
312
- return {
313
- listStores,
314
- createStore,
315
- listProducts,
316
- addProduct,
317
- listOrders,
318
- placeOrder,
319
- getOrderItems,
320
- updateOrderStatus,
321
- listPayouts,
322
- listReviews,
323
- submitReview
324
- };
276
+ id,
277
+ input.productId,
278
+ input.customerId,
279
+ input.orderId ?? null,
280
+ input.rating,
281
+ input.comment ?? null,
282
+ now,
283
+ now
284
+ ]);
285
+ const rows = (await db.query(`SELECT * FROM marketplace_review WHERE id = ?`, [id])).rows;
286
+ return rowToReview(rows[0]);
287
+ }
288
+ return {
289
+ listStores,
290
+ createStore,
291
+ listProducts,
292
+ addProduct,
293
+ listOrders,
294
+ placeOrder,
295
+ getOrderItems,
296
+ updateOrderStatus,
297
+ listPayouts,
298
+ listReviews,
299
+ submitReview
300
+ };
325
301
  }
326
-
327
- //#endregion
328
- export { createMarketplaceHandlers };
329
- //# sourceMappingURL=marketplace.handlers.js.map
302
+ export {
303
+ createMarketplaceHandlers
304
+ };