@contractspec/example.marketplace 1.56.1 → 1.58.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 +40 -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 -138
  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 -7
  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 -15
  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 +529 -110
  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
@@ -0,0 +1,418 @@
1
+ // src/ui/hooks/useMarketplaceData.ts
2
+ import { useCallback, useEffect, useState } from "react";
3
+ import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
4
+ "use client";
5
+ function useMarketplaceData(projectId = "local-project") {
6
+ const { handlers } = useTemplateRuntime();
7
+ const marketplace = handlers.marketplace;
8
+ const [stores, setStores] = useState([]);
9
+ const [products, setProducts] = useState([]);
10
+ const [orders, setOrders] = useState([]);
11
+ const [loading, setLoading] = useState(true);
12
+ const [error, setError] = useState(null);
13
+ const [totalRevenue, setTotalRevenue] = useState(0);
14
+ const fetchData = useCallback(async () => {
15
+ try {
16
+ setLoading(true);
17
+ setError(null);
18
+ const [storeResult, productResult, orderResult] = await Promise.all([
19
+ marketplace.listStores({ projectId, limit: 100 }),
20
+ marketplace.listProducts({ limit: 100 }),
21
+ marketplace.listOrders({ projectId, limit: 100 })
22
+ ]);
23
+ setStores(storeResult.stores);
24
+ setProducts(productResult.products);
25
+ setOrders(orderResult.orders);
26
+ setTotalRevenue(orderResult.totalRevenue);
27
+ } catch (err) {
28
+ setError(err instanceof Error ? err : new Error("Failed to load marketplace"));
29
+ } finally {
30
+ setLoading(false);
31
+ }
32
+ }, [marketplace, projectId]);
33
+ useEffect(() => {
34
+ fetchData();
35
+ }, [fetchData]);
36
+ const stats = {
37
+ totalStores: stores.length,
38
+ activeStores: stores.filter((s) => s.status === "ACTIVE").length,
39
+ totalProducts: products.length,
40
+ totalOrders: orders.length,
41
+ totalRevenue,
42
+ pendingOrders: orders.filter((o) => o.status === "PENDING").length
43
+ };
44
+ return {
45
+ stores,
46
+ products,
47
+ orders,
48
+ loading,
49
+ error,
50
+ stats,
51
+ refetch: fetchData
52
+ };
53
+ }
54
+
55
+ // src/ui/MarketplaceDashboard.tsx
56
+ import { useState as useState2 } from "react";
57
+ import {
58
+ Button,
59
+ ErrorState,
60
+ LoaderBlock,
61
+ StatCard,
62
+ StatCardGroup
63
+ } from "@contractspec/lib.design-system";
64
+ import { jsxDEV } from "react/jsx-dev-runtime";
65
+ "use client";
66
+ var STATUS_COLORS = {
67
+ ACTIVE: "bg-green-100 text-green-700 dark:bg-green-900/30 dark:text-green-400",
68
+ PENDING: "bg-yellow-100 text-yellow-700 dark:bg-yellow-900/30 dark:text-yellow-400",
69
+ SUSPENDED: "bg-red-100 text-red-700 dark:bg-red-900/30 dark:text-red-400",
70
+ DRAFT: "bg-gray-100 text-gray-700 dark:bg-gray-900/30 dark:text-gray-400",
71
+ OUT_OF_STOCK: "bg-orange-100 text-orange-700 dark:bg-orange-900/30 dark:text-orange-400",
72
+ ARCHIVED: "bg-gray-100 text-gray-700 dark:bg-gray-900/30 dark:text-gray-400",
73
+ CONFIRMED: "bg-blue-100 text-blue-700 dark:bg-blue-900/30 dark:text-blue-400",
74
+ PROCESSING: "bg-indigo-100 text-indigo-700 dark:bg-indigo-900/30 dark:text-indigo-400",
75
+ SHIPPED: "bg-purple-100 text-purple-700 dark:bg-purple-900/30 dark:text-purple-400",
76
+ DELIVERED: "bg-green-100 text-green-700 dark:bg-green-900/30 dark:text-green-400",
77
+ CANCELLED: "bg-red-100 text-red-700 dark:bg-red-900/30 dark:text-red-400"
78
+ };
79
+ function formatCurrency(value, currency = "USD") {
80
+ return new Intl.NumberFormat("en-US", {
81
+ style: "currency",
82
+ currency,
83
+ minimumFractionDigits: 0,
84
+ maximumFractionDigits: 2
85
+ }).format(value);
86
+ }
87
+ function MarketplaceDashboard() {
88
+ const [activeTab, setActiveTab] = useState2("stores");
89
+ const { stores, products, orders, loading, error, stats, refetch } = useMarketplaceData();
90
+ const tabs = [
91
+ { id: "stores", label: "Stores", icon: "\uD83C\uDFEA" },
92
+ { id: "products", label: "Products", icon: "\uD83D\uDCE6" },
93
+ { id: "orders", label: "Orders", icon: "\uD83D\uDED2" }
94
+ ];
95
+ if (loading) {
96
+ return /* @__PURE__ */ jsxDEV(LoaderBlock, {
97
+ label: "Loading Marketplace..."
98
+ }, undefined, false, undefined, this);
99
+ }
100
+ if (error) {
101
+ return /* @__PURE__ */ jsxDEV(ErrorState, {
102
+ title: "Failed to load Marketplace",
103
+ description: error.message,
104
+ onRetry: refetch,
105
+ retryLabel: "Retry"
106
+ }, undefined, false, undefined, this);
107
+ }
108
+ return /* @__PURE__ */ jsxDEV("div", {
109
+ className: "space-y-6",
110
+ children: [
111
+ /* @__PURE__ */ jsxDEV("div", {
112
+ className: "flex items-center justify-between",
113
+ children: [
114
+ /* @__PURE__ */ jsxDEV("h2", {
115
+ className: "text-2xl font-bold",
116
+ children: "Marketplace"
117
+ }, undefined, false, undefined, this),
118
+ /* @__PURE__ */ jsxDEV(Button, {
119
+ onClick: () => alert("Create store modal"),
120
+ children: [
121
+ /* @__PURE__ */ jsxDEV("span", {
122
+ className: "mr-2",
123
+ children: "+"
124
+ }, undefined, false, undefined, this),
125
+ " New Store"
126
+ ]
127
+ }, undefined, true, undefined, this)
128
+ ]
129
+ }, undefined, true, undefined, this),
130
+ /* @__PURE__ */ jsxDEV(StatCardGroup, {
131
+ children: [
132
+ /* @__PURE__ */ jsxDEV(StatCard, {
133
+ label: "Stores",
134
+ value: stats.totalStores,
135
+ hint: `${stats.activeStores} active`
136
+ }, undefined, false, undefined, this),
137
+ /* @__PURE__ */ jsxDEV(StatCard, {
138
+ label: "Products",
139
+ value: stats.totalProducts,
140
+ hint: "listed"
141
+ }, undefined, false, undefined, this),
142
+ /* @__PURE__ */ jsxDEV(StatCard, {
143
+ label: "Orders",
144
+ value: stats.totalOrders,
145
+ hint: `${stats.pendingOrders} pending`
146
+ }, undefined, false, undefined, this),
147
+ /* @__PURE__ */ jsxDEV(StatCard, {
148
+ label: "Revenue",
149
+ value: formatCurrency(stats.totalRevenue),
150
+ hint: "total"
151
+ }, undefined, false, undefined, this)
152
+ ]
153
+ }, undefined, true, undefined, this),
154
+ /* @__PURE__ */ jsxDEV("nav", {
155
+ className: "bg-muted flex gap-1 rounded-lg p-1",
156
+ role: "tablist",
157
+ children: tabs.map((tab) => /* @__PURE__ */ jsxDEV(Button, {
158
+ type: "button",
159
+ role: "tab",
160
+ "aria-selected": activeTab === tab.id,
161
+ onClick: () => setActiveTab(tab.id),
162
+ className: `flex flex-1 items-center justify-center gap-2 rounded-md px-4 py-2 text-sm font-medium transition-colors ${activeTab === tab.id ? "bg-background text-foreground shadow-sm" : "text-muted-foreground hover:text-foreground"}`,
163
+ children: [
164
+ /* @__PURE__ */ jsxDEV("span", {
165
+ children: tab.icon
166
+ }, undefined, false, undefined, this),
167
+ tab.label
168
+ ]
169
+ }, tab.id, true, undefined, this))
170
+ }, undefined, false, undefined, this),
171
+ /* @__PURE__ */ jsxDEV("div", {
172
+ className: "min-h-[400px]",
173
+ role: "tabpanel",
174
+ children: [
175
+ activeTab === "stores" && /* @__PURE__ */ jsxDEV("div", {
176
+ className: "border-border rounded-lg border",
177
+ children: /* @__PURE__ */ jsxDEV("table", {
178
+ className: "w-full",
179
+ children: [
180
+ /* @__PURE__ */ jsxDEV("thead", {
181
+ className: "border-border bg-muted/30 border-b",
182
+ children: /* @__PURE__ */ jsxDEV("tr", {
183
+ children: [
184
+ /* @__PURE__ */ jsxDEV("th", {
185
+ className: "px-4 py-3 text-left text-sm font-medium",
186
+ children: "Store"
187
+ }, undefined, false, undefined, this),
188
+ /* @__PURE__ */ jsxDEV("th", {
189
+ className: "px-4 py-3 text-left text-sm font-medium",
190
+ children: "Status"
191
+ }, undefined, false, undefined, this),
192
+ /* @__PURE__ */ jsxDEV("th", {
193
+ className: "px-4 py-3 text-left text-sm font-medium",
194
+ children: "Rating"
195
+ }, undefined, false, undefined, this),
196
+ /* @__PURE__ */ jsxDEV("th", {
197
+ className: "px-4 py-3 text-left text-sm font-medium",
198
+ children: "Reviews"
199
+ }, undefined, false, undefined, this)
200
+ ]
201
+ }, undefined, true, undefined, this)
202
+ }, undefined, false, undefined, this),
203
+ /* @__PURE__ */ jsxDEV("tbody", {
204
+ className: "divide-border divide-y",
205
+ children: [
206
+ stores.map((store) => /* @__PURE__ */ jsxDEV("tr", {
207
+ className: "hover:bg-muted/50",
208
+ children: [
209
+ /* @__PURE__ */ jsxDEV("td", {
210
+ className: "px-4 py-3",
211
+ children: [
212
+ /* @__PURE__ */ jsxDEV("div", {
213
+ className: "font-medium",
214
+ children: store.name
215
+ }, undefined, false, undefined, this),
216
+ /* @__PURE__ */ jsxDEV("div", {
217
+ className: "text-muted-foreground text-sm",
218
+ children: store.description
219
+ }, undefined, false, undefined, this)
220
+ ]
221
+ }, undefined, true, undefined, this),
222
+ /* @__PURE__ */ jsxDEV("td", {
223
+ className: "px-4 py-3",
224
+ children: /* @__PURE__ */ jsxDEV("span", {
225
+ className: `inline-flex rounded-full px-2 py-0.5 text-xs font-medium ${STATUS_COLORS[store.status] ?? ""}`,
226
+ children: store.status
227
+ }, undefined, false, undefined, this)
228
+ }, undefined, false, undefined, this),
229
+ /* @__PURE__ */ jsxDEV("td", {
230
+ className: "px-4 py-3",
231
+ children: /* @__PURE__ */ jsxDEV("span", {
232
+ className: "flex items-center gap-1",
233
+ children: [
234
+ "⭐ ",
235
+ store.rating.toFixed(1)
236
+ ]
237
+ }, undefined, true, undefined, this)
238
+ }, undefined, false, undefined, this),
239
+ /* @__PURE__ */ jsxDEV("td", {
240
+ className: "text-muted-foreground px-4 py-3 text-sm",
241
+ children: [
242
+ store.reviewCount,
243
+ " reviews"
244
+ ]
245
+ }, undefined, true, undefined, this)
246
+ ]
247
+ }, store.id, true, undefined, this)),
248
+ stores.length === 0 && /* @__PURE__ */ jsxDEV("tr", {
249
+ children: /* @__PURE__ */ jsxDEV("td", {
250
+ colSpan: 4,
251
+ className: "text-muted-foreground px-4 py-8 text-center",
252
+ children: "No stores found"
253
+ }, undefined, false, undefined, this)
254
+ }, undefined, false, undefined, this)
255
+ ]
256
+ }, undefined, true, undefined, this)
257
+ ]
258
+ }, undefined, true, undefined, this)
259
+ }, undefined, false, undefined, this),
260
+ activeTab === "products" && /* @__PURE__ */ jsxDEV("div", {
261
+ className: "border-border rounded-lg border",
262
+ children: /* @__PURE__ */ jsxDEV("table", {
263
+ className: "w-full",
264
+ children: [
265
+ /* @__PURE__ */ jsxDEV("thead", {
266
+ className: "border-border bg-muted/30 border-b",
267
+ children: /* @__PURE__ */ jsxDEV("tr", {
268
+ children: [
269
+ /* @__PURE__ */ jsxDEV("th", {
270
+ className: "px-4 py-3 text-left text-sm font-medium",
271
+ children: "Product"
272
+ }, undefined, false, undefined, this),
273
+ /* @__PURE__ */ jsxDEV("th", {
274
+ className: "px-4 py-3 text-left text-sm font-medium",
275
+ children: "Price"
276
+ }, undefined, false, undefined, this),
277
+ /* @__PURE__ */ jsxDEV("th", {
278
+ className: "px-4 py-3 text-left text-sm font-medium",
279
+ children: "Stock"
280
+ }, undefined, false, undefined, this),
281
+ /* @__PURE__ */ jsxDEV("th", {
282
+ className: "px-4 py-3 text-left text-sm font-medium",
283
+ children: "Status"
284
+ }, undefined, false, undefined, this)
285
+ ]
286
+ }, undefined, true, undefined, this)
287
+ }, undefined, false, undefined, this),
288
+ /* @__PURE__ */ jsxDEV("tbody", {
289
+ className: "divide-border divide-y",
290
+ children: [
291
+ products.map((product) => /* @__PURE__ */ jsxDEV("tr", {
292
+ className: "hover:bg-muted/50",
293
+ children: [
294
+ /* @__PURE__ */ jsxDEV("td", {
295
+ className: "px-4 py-3",
296
+ children: [
297
+ /* @__PURE__ */ jsxDEV("div", {
298
+ className: "font-medium",
299
+ children: product.name
300
+ }, undefined, false, undefined, this),
301
+ /* @__PURE__ */ jsxDEV("div", {
302
+ className: "text-muted-foreground text-sm",
303
+ children: product.category
304
+ }, undefined, false, undefined, this)
305
+ ]
306
+ }, undefined, true, undefined, this),
307
+ /* @__PURE__ */ jsxDEV("td", {
308
+ className: "px-4 py-3 font-mono",
309
+ children: formatCurrency(product.price, product.currency)
310
+ }, undefined, false, undefined, this),
311
+ /* @__PURE__ */ jsxDEV("td", {
312
+ className: "px-4 py-3",
313
+ children: product.stock
314
+ }, undefined, false, undefined, this),
315
+ /* @__PURE__ */ jsxDEV("td", {
316
+ className: "px-4 py-3",
317
+ children: /* @__PURE__ */ jsxDEV("span", {
318
+ className: `inline-flex rounded-full px-2 py-0.5 text-xs font-medium ${STATUS_COLORS[product.status] ?? ""}`,
319
+ children: product.status
320
+ }, undefined, false, undefined, this)
321
+ }, undefined, false, undefined, this)
322
+ ]
323
+ }, product.id, true, undefined, this)),
324
+ products.length === 0 && /* @__PURE__ */ jsxDEV("tr", {
325
+ children: /* @__PURE__ */ jsxDEV("td", {
326
+ colSpan: 4,
327
+ className: "text-muted-foreground px-4 py-8 text-center",
328
+ children: "No products found"
329
+ }, undefined, false, undefined, this)
330
+ }, undefined, false, undefined, this)
331
+ ]
332
+ }, undefined, true, undefined, this)
333
+ ]
334
+ }, undefined, true, undefined, this)
335
+ }, undefined, false, undefined, this),
336
+ activeTab === "orders" && /* @__PURE__ */ jsxDEV("div", {
337
+ className: "border-border rounded-lg border",
338
+ children: /* @__PURE__ */ jsxDEV("table", {
339
+ className: "w-full",
340
+ children: [
341
+ /* @__PURE__ */ jsxDEV("thead", {
342
+ className: "border-border bg-muted/30 border-b",
343
+ children: /* @__PURE__ */ jsxDEV("tr", {
344
+ children: [
345
+ /* @__PURE__ */ jsxDEV("th", {
346
+ className: "px-4 py-3 text-left text-sm font-medium",
347
+ children: "Order ID"
348
+ }, undefined, false, undefined, this),
349
+ /* @__PURE__ */ jsxDEV("th", {
350
+ className: "px-4 py-3 text-left text-sm font-medium",
351
+ children: "Customer"
352
+ }, undefined, false, undefined, this),
353
+ /* @__PURE__ */ jsxDEV("th", {
354
+ className: "px-4 py-3 text-left text-sm font-medium",
355
+ children: "Total"
356
+ }, undefined, false, undefined, this),
357
+ /* @__PURE__ */ jsxDEV("th", {
358
+ className: "px-4 py-3 text-left text-sm font-medium",
359
+ children: "Status"
360
+ }, undefined, false, undefined, this),
361
+ /* @__PURE__ */ jsxDEV("th", {
362
+ className: "px-4 py-3 text-left text-sm font-medium",
363
+ children: "Date"
364
+ }, undefined, false, undefined, this)
365
+ ]
366
+ }, undefined, true, undefined, this)
367
+ }, undefined, false, undefined, this),
368
+ /* @__PURE__ */ jsxDEV("tbody", {
369
+ className: "divide-border divide-y",
370
+ children: [
371
+ orders.map((order) => /* @__PURE__ */ jsxDEV("tr", {
372
+ className: "hover:bg-muted/50",
373
+ children: [
374
+ /* @__PURE__ */ jsxDEV("td", {
375
+ className: "px-4 py-3 font-mono text-sm",
376
+ children: order.id
377
+ }, undefined, false, undefined, this),
378
+ /* @__PURE__ */ jsxDEV("td", {
379
+ className: "px-4 py-3 text-sm",
380
+ children: order.customerId
381
+ }, undefined, false, undefined, this),
382
+ /* @__PURE__ */ jsxDEV("td", {
383
+ className: "px-4 py-3 font-mono",
384
+ children: formatCurrency(order.total, order.currency)
385
+ }, undefined, false, undefined, this),
386
+ /* @__PURE__ */ jsxDEV("td", {
387
+ className: "px-4 py-3",
388
+ children: /* @__PURE__ */ jsxDEV("span", {
389
+ className: `inline-flex rounded-full px-2 py-0.5 text-xs font-medium ${STATUS_COLORS[order.status] ?? ""}`,
390
+ children: order.status
391
+ }, undefined, false, undefined, this)
392
+ }, undefined, false, undefined, this),
393
+ /* @__PURE__ */ jsxDEV("td", {
394
+ className: "text-muted-foreground px-4 py-3 text-sm",
395
+ children: order.createdAt.toLocaleDateString()
396
+ }, undefined, false, undefined, this)
397
+ ]
398
+ }, order.id, true, undefined, this)),
399
+ orders.length === 0 && /* @__PURE__ */ jsxDEV("tr", {
400
+ children: /* @__PURE__ */ jsxDEV("td", {
401
+ colSpan: 5,
402
+ className: "text-muted-foreground px-4 py-8 text-center",
403
+ children: "No orders found"
404
+ }, undefined, false, undefined, this)
405
+ }, undefined, false, undefined, this)
406
+ ]
407
+ }, undefined, true, undefined, this)
408
+ ]
409
+ }, undefined, true, undefined, this)
410
+ }, undefined, false, undefined, this)
411
+ ]
412
+ }, undefined, true, undefined, this)
413
+ ]
414
+ }, undefined, true, undefined, this);
415
+ }
416
+ export {
417
+ MarketplaceDashboard
418
+ };
@@ -0,0 +1,59 @@
1
+ // src/ui/hooks/useMarketplaceData.ts
2
+ import { useCallback, useEffect, useState } from "react";
3
+ import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
4
+ "use client";
5
+ function useMarketplaceData(projectId = "local-project") {
6
+ const { handlers } = useTemplateRuntime();
7
+ const marketplace = handlers.marketplace;
8
+ const [stores, setStores] = useState([]);
9
+ const [products, setProducts] = useState([]);
10
+ const [orders, setOrders] = useState([]);
11
+ const [loading, setLoading] = useState(true);
12
+ const [error, setError] = useState(null);
13
+ const [totalRevenue, setTotalRevenue] = useState(0);
14
+ const fetchData = useCallback(async () => {
15
+ try {
16
+ setLoading(true);
17
+ setError(null);
18
+ const [storeResult, productResult, orderResult] = await Promise.all([
19
+ marketplace.listStores({ projectId, limit: 100 }),
20
+ marketplace.listProducts({ limit: 100 }),
21
+ marketplace.listOrders({ projectId, limit: 100 })
22
+ ]);
23
+ setStores(storeResult.stores);
24
+ setProducts(productResult.products);
25
+ setOrders(orderResult.orders);
26
+ setTotalRevenue(orderResult.totalRevenue);
27
+ } catch (err) {
28
+ setError(err instanceof Error ? err : new Error("Failed to load marketplace"));
29
+ } finally {
30
+ setLoading(false);
31
+ }
32
+ }, [marketplace, projectId]);
33
+ useEffect(() => {
34
+ fetchData();
35
+ }, [fetchData]);
36
+ const stats = {
37
+ totalStores: stores.length,
38
+ activeStores: stores.filter((s) => s.status === "ACTIVE").length,
39
+ totalProducts: products.length,
40
+ totalOrders: orders.length,
41
+ totalRevenue,
42
+ pendingOrders: orders.filter((o) => o.status === "PENDING").length
43
+ };
44
+ return {
45
+ stores,
46
+ products,
47
+ orders,
48
+ loading,
49
+ error,
50
+ stats,
51
+ refetch: fetchData
52
+ };
53
+ }
54
+
55
+ // src/ui/hooks/index.ts
56
+ "use client";
57
+ export {
58
+ useMarketplaceData
59
+ };
@@ -0,0 +1,56 @@
1
+ // src/ui/hooks/useMarketplaceData.ts
2
+ import { useCallback, useEffect, useState } from "react";
3
+ import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
4
+ "use client";
5
+ function useMarketplaceData(projectId = "local-project") {
6
+ const { handlers } = useTemplateRuntime();
7
+ const marketplace = handlers.marketplace;
8
+ const [stores, setStores] = useState([]);
9
+ const [products, setProducts] = useState([]);
10
+ const [orders, setOrders] = useState([]);
11
+ const [loading, setLoading] = useState(true);
12
+ const [error, setError] = useState(null);
13
+ const [totalRevenue, setTotalRevenue] = useState(0);
14
+ const fetchData = useCallback(async () => {
15
+ try {
16
+ setLoading(true);
17
+ setError(null);
18
+ const [storeResult, productResult, orderResult] = await Promise.all([
19
+ marketplace.listStores({ projectId, limit: 100 }),
20
+ marketplace.listProducts({ limit: 100 }),
21
+ marketplace.listOrders({ projectId, limit: 100 })
22
+ ]);
23
+ setStores(storeResult.stores);
24
+ setProducts(productResult.products);
25
+ setOrders(orderResult.orders);
26
+ setTotalRevenue(orderResult.totalRevenue);
27
+ } catch (err) {
28
+ setError(err instanceof Error ? err : new Error("Failed to load marketplace"));
29
+ } finally {
30
+ setLoading(false);
31
+ }
32
+ }, [marketplace, projectId]);
33
+ useEffect(() => {
34
+ fetchData();
35
+ }, [fetchData]);
36
+ const stats = {
37
+ totalStores: stores.length,
38
+ activeStores: stores.filter((s) => s.status === "ACTIVE").length,
39
+ totalProducts: products.length,
40
+ totalOrders: orders.length,
41
+ totalRevenue,
42
+ pendingOrders: orders.filter((o) => o.status === "PENDING").length
43
+ };
44
+ return {
45
+ stores,
46
+ products,
47
+ orders,
48
+ loading,
49
+ error,
50
+ stats,
51
+ refetch: fetchData
52
+ };
53
+ }
54
+ export {
55
+ useMarketplaceData
56
+ };