@upstart.gg/sdk 0.0.129 → 0.0.131

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 (529) hide show
  1. package/dist/shared/ai/schemas.d.ts +13 -0
  2. package/dist/shared/ai/schemas.d.ts.map +1 -0
  3. package/dist/shared/ai/schemas.js +3 -0
  4. package/dist/shared/ai/types.d.ts +164 -0
  5. package/dist/shared/ai/types.d.ts.map +1 -0
  6. package/dist/shared/{chunk-EJGNYD4V.js → ai/types.js} +0 -1
  7. package/dist/shared/ajv.d.ts +2 -1
  8. package/dist/shared/ajv.d.ts.map +1 -1
  9. package/dist/shared/ajv.js +1 -1
  10. package/dist/shared/attributes.d.ts +300 -12
  11. package/dist/shared/attributes.d.ts.map +1 -1
  12. package/dist/shared/attributes.js +1 -1
  13. package/dist/shared/brick-manifest.d.ts +3 -1
  14. package/dist/shared/brick-manifest.d.ts.map +1 -1
  15. package/dist/shared/brick-manifest.js +1 -1
  16. package/dist/shared/bricks/manifests/accordion.manifest.d.ts +4 -3
  17. package/dist/shared/bricks/manifests/accordion.manifest.d.ts.map +1 -1
  18. package/dist/shared/bricks/manifests/accordion.manifest.js +1 -1
  19. package/dist/shared/bricks/manifests/all-manifests.d.ts +4 -1
  20. package/dist/shared/bricks/manifests/all-manifests.d.ts.map +1 -1
  21. package/dist/shared/bricks/manifests/all-manifests.js +1 -1
  22. package/dist/shared/bricks/manifests/box.manifest.d.ts +6 -4
  23. package/dist/shared/bricks/manifests/box.manifest.d.ts.map +1 -1
  24. package/dist/shared/bricks/manifests/box.manifest.js +1 -1
  25. package/dist/shared/bricks/manifests/button.manifest.d.ts +4 -3
  26. package/dist/shared/bricks/manifests/button.manifest.d.ts.map +1 -1
  27. package/dist/shared/bricks/manifests/button.manifest.js +1 -1
  28. package/dist/shared/bricks/manifests/card.manifest.d.ts +6 -5
  29. package/dist/shared/bricks/manifests/card.manifest.d.ts.map +1 -1
  30. package/dist/shared/bricks/manifests/card.manifest.js +1 -1
  31. package/dist/shared/bricks/manifests/carousel.manifest.d.ts +6 -5
  32. package/dist/shared/bricks/manifests/carousel.manifest.d.ts.map +1 -1
  33. package/dist/shared/bricks/manifests/carousel.manifest.js +1 -1
  34. package/dist/shared/bricks/manifests/footer.manifest.d.ts +40 -5
  35. package/dist/shared/bricks/manifests/footer.manifest.d.ts.map +1 -1
  36. package/dist/shared/bricks/manifests/footer.manifest.js +1 -1
  37. package/dist/shared/bricks/manifests/form.manifest.d.ts +6 -5
  38. package/dist/shared/bricks/manifests/form.manifest.d.ts.map +1 -1
  39. package/dist/shared/bricks/manifests/form.manifest.js +1 -1
  40. package/dist/shared/bricks/manifests/hero.manifest.d.ts +4 -3
  41. package/dist/shared/bricks/manifests/hero.manifest.d.ts.map +1 -1
  42. package/dist/shared/bricks/manifests/hero.manifest.js +1 -1
  43. package/dist/shared/bricks/manifests/html.manifest.d.ts +3 -2
  44. package/dist/shared/bricks/manifests/html.manifest.d.ts.map +1 -1
  45. package/dist/shared/bricks/manifests/html.manifest.js +1 -1
  46. package/dist/shared/bricks/manifests/icon.manifest.d.ts +3 -2
  47. package/dist/shared/bricks/manifests/icon.manifest.d.ts.map +1 -1
  48. package/dist/shared/bricks/manifests/icon.manifest.js +1 -1
  49. package/dist/shared/bricks/manifests/image.manifest.d.ts +10 -6
  50. package/dist/shared/bricks/manifests/image.manifest.d.ts.map +1 -1
  51. package/dist/shared/bricks/manifests/image.manifest.js +1 -1
  52. package/dist/shared/bricks/manifests/images-gallery.manifest.d.ts +7 -6
  53. package/dist/shared/bricks/manifests/images-gallery.manifest.d.ts.map +1 -1
  54. package/dist/shared/bricks/manifests/images-gallery.manifest.js +1 -1
  55. package/dist/shared/bricks/manifests/map.manifest.d.ts +5 -4
  56. package/dist/shared/bricks/manifests/map.manifest.d.ts.map +1 -1
  57. package/dist/shared/bricks/manifests/map.manifest.js +1 -1
  58. package/dist/shared/bricks/manifests/navbar.manifest.d.ts +42 -8
  59. package/dist/shared/bricks/manifests/navbar.manifest.d.ts.map +1 -1
  60. package/dist/shared/bricks/manifests/navbar.manifest.js +1 -1
  61. package/dist/shared/bricks/manifests/sidebar.manifest.d.ts +4 -3
  62. package/dist/shared/bricks/manifests/sidebar.manifest.d.ts.map +1 -1
  63. package/dist/shared/bricks/manifests/sidebar.manifest.js +1 -1
  64. package/dist/shared/bricks/manifests/social-links.manifest.d.ts +5 -4
  65. package/dist/shared/bricks/manifests/social-links.manifest.d.ts.map +1 -1
  66. package/dist/shared/bricks/manifests/social-links.manifest.js +1 -1
  67. package/dist/shared/bricks/manifests/spacer.manifest.d.ts +3 -2
  68. package/dist/shared/bricks/manifests/spacer.manifest.d.ts.map +1 -1
  69. package/dist/shared/bricks/manifests/spacer.manifest.js +1 -1
  70. package/dist/shared/bricks/manifests/testimonials.manifest.d.ts +6 -5
  71. package/dist/shared/bricks/manifests/testimonials.manifest.d.ts.map +1 -1
  72. package/dist/shared/bricks/manifests/testimonials.manifest.js +1 -1
  73. package/dist/shared/bricks/manifests/text.manifest.d.ts +4 -3
  74. package/dist/shared/bricks/manifests/text.manifest.d.ts.map +1 -1
  75. package/dist/shared/bricks/manifests/text.manifest.js +1 -1
  76. package/dist/shared/bricks/manifests/video.manifest.d.ts +4 -3
  77. package/dist/shared/bricks/manifests/video.manifest.d.ts.map +1 -1
  78. package/dist/shared/bricks/manifests/video.manifest.js +1 -1
  79. package/dist/shared/bricks/props/align.d.ts.map +1 -1
  80. package/dist/shared/bricks/props/align.js +1 -1
  81. package/dist/shared/bricks/props/background.d.ts +6 -9
  82. package/dist/shared/bricks/props/background.d.ts.map +1 -1
  83. package/dist/shared/bricks/props/background.js +1 -1
  84. package/dist/shared/bricks/props/border.d.ts.map +1 -1
  85. package/dist/shared/bricks/props/border.js +1 -1
  86. package/dist/shared/bricks/props/color-preset.d.ts +3 -4
  87. package/dist/shared/bricks/props/color-preset.d.ts.map +1 -1
  88. package/dist/shared/bricks/props/color-preset.js +1 -1
  89. package/dist/shared/bricks/props/color.js +1 -1
  90. package/dist/shared/bricks/props/common.d.ts +6 -6
  91. package/dist/shared/bricks/props/common.d.ts.map +1 -1
  92. package/dist/shared/bricks/props/common.js +1 -1
  93. package/dist/shared/bricks/props/css-length.d.ts.map +1 -1
  94. package/dist/shared/bricks/props/css-length.js +1 -1
  95. package/dist/shared/bricks/props/datasource.d.ts +1 -1
  96. package/dist/shared/bricks/props/datasource.js +1 -1
  97. package/dist/shared/bricks/props/date.d.ts.map +1 -1
  98. package/dist/shared/bricks/props/date.js +1 -1
  99. package/dist/shared/bricks/props/direction.d.ts.map +1 -1
  100. package/dist/shared/bricks/props/direction.js +1 -1
  101. package/dist/shared/bricks/props/dynamic.d.ts.map +1 -1
  102. package/dist/shared/bricks/props/dynamic.js +1 -1
  103. package/dist/shared/bricks/props/effects.d.ts +0 -1
  104. package/dist/shared/bricks/props/effects.d.ts.map +1 -1
  105. package/dist/shared/bricks/props/effects.js +1 -1
  106. package/dist/shared/bricks/props/file.d.ts.map +1 -1
  107. package/dist/shared/bricks/props/file.js +1 -1
  108. package/dist/shared/bricks/props/geolocation.js +1 -1
  109. package/dist/shared/bricks/props/helpers.d.ts +2 -2
  110. package/dist/shared/bricks/props/helpers.js +1 -1
  111. package/dist/shared/bricks/props/image.d.ts +4 -4
  112. package/dist/shared/bricks/props/image.d.ts.map +1 -1
  113. package/dist/shared/bricks/props/image.js +1 -1
  114. package/dist/shared/bricks/props/position.d.ts +0 -2
  115. package/dist/shared/bricks/props/position.d.ts.map +1 -1
  116. package/dist/shared/bricks/props/position.js +1 -1
  117. package/dist/shared/bricks/props/string.js +1 -1
  118. package/dist/shared/bricks/props/tags.d.ts.map +1 -1
  119. package/dist/shared/bricks/props/tags.js +1 -1
  120. package/dist/shared/bricks/props/text.js +1 -1
  121. package/dist/shared/bricks/props/types.d.ts +1 -2
  122. package/dist/shared/bricks/props/types.d.ts.map +1 -1
  123. package/dist/shared/bricks.d.ts +189 -18
  124. package/dist/shared/bricks.d.ts.map +1 -1
  125. package/dist/shared/bricks.js +1 -1
  126. package/dist/shared/chunk-2CYAFF56.js +3 -0
  127. package/dist/shared/chunk-2NLDX5FG.js +3 -0
  128. package/dist/shared/chunk-3FPFR5RA.js +3 -0
  129. package/dist/shared/chunk-3P36LG6T.js +3 -0
  130. package/dist/shared/chunk-3QOAHMV4.js +5 -0
  131. package/dist/shared/chunk-4GIZ6WSG.js +3 -0
  132. package/dist/shared/chunk-5WY7LYXK.js +3 -0
  133. package/dist/shared/chunk-5X5SX5N7.js +4 -0
  134. package/dist/shared/chunk-6L3Z5SZQ.js +3 -0
  135. package/dist/shared/{chunk-UU2MSQXY.js → chunk-6PGAWO4H.js} +1 -1
  136. package/dist/shared/chunk-6R76KIHZ.js +3 -0
  137. package/dist/shared/chunk-7UBMXMNJ.js +3 -0
  138. package/dist/shared/chunk-AB3IMRXZ.js +3 -0
  139. package/dist/shared/chunk-AMQAGDFH.js +3 -0
  140. package/dist/shared/chunk-ARMM6B47.js +3 -0
  141. package/dist/shared/chunk-ARYG4XMX.js +3 -0
  142. package/dist/shared/chunk-AZHH3XJJ.js +3 -0
  143. package/dist/shared/chunk-COT2ROEH.js +34 -0
  144. package/dist/shared/chunk-DHSWVVMI.js +3 -0
  145. package/dist/shared/chunk-DKNOZLA6.js +3 -0
  146. package/dist/shared/chunk-EVDZ2KND.js +6 -0
  147. package/dist/shared/chunk-F4JNKU7J.js +3 -0
  148. package/dist/shared/chunk-GC5OWY2Z.js +3 -0
  149. package/dist/shared/chunk-GXNHF6J5.js +3 -0
  150. package/dist/shared/chunk-HP7CZB2F.js +3 -0
  151. package/dist/shared/chunk-HSRXUIVM.js +3 -0
  152. package/dist/shared/chunk-ILIWVWHC.js +8 -0
  153. package/dist/shared/chunk-JRCVYDCD.js +3 -0
  154. package/dist/shared/chunk-L2HOZVBC.js +3 -0
  155. package/dist/shared/chunk-LEWKHCRI.js +3 -0
  156. package/dist/shared/chunk-LT4CW2F7.js +3 -0
  157. package/dist/shared/chunk-MVCVVKBY.js +3 -0
  158. package/dist/shared/chunk-NKIEDT7V.js +3 -0
  159. package/dist/shared/chunk-NQKXDMQ5.js +3 -0
  160. package/dist/shared/chunk-NXIF3UMD.js +3 -0
  161. package/dist/shared/chunk-PW5HRVMD.js +3 -0
  162. package/dist/shared/chunk-PZYX3ACO.js +3 -0
  163. package/dist/shared/chunk-QDJQAZIA.js +8 -0
  164. package/dist/shared/chunk-QGFQA7OZ.js +4 -0
  165. package/dist/shared/chunk-RJZZWCBD.js +3 -0
  166. package/dist/shared/chunk-SAJY7H6N.js +3 -0
  167. package/dist/shared/chunk-SFDRAHYP.js +3 -0
  168. package/dist/shared/chunk-STDCM2KD.js +3 -0
  169. package/dist/shared/chunk-TCTVRT4O.js +3 -0
  170. package/dist/shared/chunk-TH5SONR6.js +3 -0
  171. package/dist/shared/chunk-UCR2UZOY.js +3 -0
  172. package/dist/shared/chunk-UDQWYGSO.js +3 -0
  173. package/dist/shared/{chunk-LSPN22SI.js → chunk-URRCKLAS.js} +3 -3
  174. package/dist/shared/{chunk-OIOYMECS.js → chunk-US53TNMK.js} +1 -1
  175. package/dist/shared/chunk-VDX2J22H.js +3 -0
  176. package/dist/shared/chunk-VE3S4LGT.js +3 -0
  177. package/dist/shared/chunk-VK26ZZFR.js +3 -0
  178. package/dist/shared/chunk-VLXZMESE.js +3 -0
  179. package/dist/shared/chunk-WAML3IGZ.js +3 -0
  180. package/dist/shared/chunk-WXKRIUTA.js +3 -0
  181. package/dist/shared/chunk-X62OEAE6.js +3 -0
  182. package/dist/shared/chunk-XED6ARVN.js +3 -0
  183. package/dist/shared/chunk-Y3X4F4YJ.js +3 -0
  184. package/dist/shared/chunk-Z4YKRLOX.js +3 -0
  185. package/dist/shared/context.d.ts +6 -15
  186. package/dist/shared/context.d.ts.map +1 -1
  187. package/dist/shared/datarecords/external/airtable/handler.d.ts +24 -7
  188. package/dist/shared/datarecords/external/airtable/handler.d.ts.map +1 -1
  189. package/dist/shared/datarecords/external/airtable/handler.js +3 -0
  190. package/dist/shared/datarecords/external/airtable/oauth/config.js +3 -0
  191. package/dist/shared/datarecords/external/airtable/types.d.ts +40 -0
  192. package/dist/shared/datarecords/external/airtable/types.d.ts.map +1 -0
  193. package/dist/shared/datarecords/external/airtable/types.js +3 -0
  194. package/dist/shared/datarecords/external/generic-webhook/handler.js +3 -0
  195. package/dist/shared/datarecords/external/generic-webhook/options.js +3 -0
  196. package/dist/shared/datarecords/external/google/sheets/client.d.ts +14 -0
  197. package/dist/shared/datarecords/external/google/sheets/client.d.ts.map +1 -0
  198. package/dist/shared/datarecords/external/google/sheets/client.js +3 -0
  199. package/dist/shared/datarecords/external/google/sheets/handler.d.ts +27 -5
  200. package/dist/shared/datarecords/external/google/sheets/handler.d.ts.map +1 -1
  201. package/dist/shared/datarecords/external/google/sheets/handler.js +7 -0
  202. package/dist/shared/datarecords/external/google/sheets/{options.d.ts → types.d.ts} +1 -1
  203. package/dist/shared/datarecords/external/google/sheets/types.d.ts.map +1 -0
  204. package/dist/shared/datarecords/external/google/sheets/types.js +3 -0
  205. package/dist/shared/datarecords/external/notion/handler.d.ts +31 -0
  206. package/dist/shared/datarecords/external/notion/handler.d.ts.map +1 -0
  207. package/dist/shared/datarecords/external/notion/handler.js +3 -0
  208. package/dist/shared/datarecords/external/notion/oauth/config.js +3 -0
  209. package/dist/shared/datarecords/external/notion/{options.d.ts → types.d.ts} +11 -1
  210. package/dist/shared/datarecords/external/notion/types.d.ts.map +1 -0
  211. package/dist/shared/datarecords/external/notion/types.js +3 -0
  212. package/dist/shared/datarecords/types.d.ts +17 -18
  213. package/dist/shared/datarecords/types.d.ts.map +1 -1
  214. package/dist/shared/datarecords/types.js +1 -1
  215. package/dist/shared/datarecords.d.ts +2 -2
  216. package/dist/shared/datarecords.d.ts.map +1 -1
  217. package/dist/shared/datarecords.js +1 -1
  218. package/dist/shared/datasources/external/facebook/posts/fetcher.js +3 -0
  219. package/dist/shared/datasources/external/facebook/posts/schema.js +3 -0
  220. package/dist/shared/datasources/external/http-json/fetcher.js +3 -0
  221. package/dist/shared/datasources/external/http-json/options.js +3 -0
  222. package/dist/shared/datasources/external/http-json/schema.js +3 -0
  223. package/dist/shared/datasources/external/instagram/feed/fetcher.js +3 -0
  224. package/dist/shared/datasources/external/instagram/feed/schema.js +3 -0
  225. package/dist/shared/datasources/external/mastodon/account/fetcher.js +3 -0
  226. package/dist/shared/datasources/external/mastodon/account/schema.js +3 -0
  227. package/dist/shared/datasources/external/mastodon/options.js +3 -0
  228. package/dist/shared/datasources/external/mastodon/status/fetcher.js +3 -0
  229. package/dist/shared/datasources/external/mastodon/status/sample.array.js +3 -0
  230. package/dist/shared/datasources/external/mastodon/status/sample.single.js +3 -0
  231. package/dist/shared/datasources/external/mastodon/status/schema.d.ts.map +1 -1
  232. package/dist/shared/datasources/external/mastodon/status/schema.js +3 -0
  233. package/dist/shared/datasources/external/meta/options.js +3 -0
  234. package/dist/shared/datasources/external/rss/fetcher.js +3 -0
  235. package/dist/shared/datasources/external/rss/options.js +3 -0
  236. package/dist/shared/datasources/external/rss/schema.js +3 -0
  237. package/dist/shared/datasources/external/threads/media/fetcher.js +3 -0
  238. package/dist/shared/datasources/external/threads/media/schema.js +3 -0
  239. package/dist/shared/datasources/external/tiktok/video/fetcher.js +3 -0
  240. package/dist/shared/datasources/external/tiktok/video/options.js +3 -0
  241. package/dist/shared/datasources/external/tiktok/video/schema.js +3 -0
  242. package/dist/shared/datasources/external/youtube/list/fetcher.js +3 -0
  243. package/dist/shared/datasources/external/youtube/list/options.js +3 -0
  244. package/dist/shared/datasources/external/youtube/list/schema.js +3 -0
  245. package/dist/shared/datasources/fetcher.js +2 -0
  246. package/dist/shared/datasources/internal/blog/schema.js +3 -0
  247. package/dist/shared/datasources/internal/changelog/schema.js +3 -0
  248. package/dist/shared/datasources/internal/contact-info/schema.js +3 -0
  249. package/dist/shared/datasources/internal/cv/schema.js +3 -0
  250. package/dist/shared/datasources/internal/faq/schema.js +3 -0
  251. package/dist/shared/datasources/internal/job-board/schema.js +3 -0
  252. package/dist/shared/datasources/internal/links/schema.js +3 -0
  253. package/dist/shared/datasources/internal/recipes/schema.js +3 -0
  254. package/dist/shared/datasources/internal/restaurant/schema.js +3 -0
  255. package/dist/shared/datasources/samples.js +3 -0
  256. package/dist/shared/datasources/schemas.d.ts +0 -49
  257. package/dist/shared/datasources/schemas.d.ts.map +1 -1
  258. package/dist/shared/datasources/schemas.js +1 -1
  259. package/dist/shared/datasources/types.d.ts +53 -130
  260. package/dist/shared/datasources/types.d.ts.map +1 -1
  261. package/dist/shared/datasources/types.js +1 -1
  262. package/dist/shared/datasources/utils.js +3 -0
  263. package/dist/shared/datasources.d.ts +7 -4
  264. package/dist/shared/datasources.d.ts.map +1 -1
  265. package/dist/shared/datasources.js +1 -1
  266. package/dist/shared/errors.js +1 -1
  267. package/dist/shared/images.d.ts +1 -12
  268. package/dist/shared/images.d.ts.map +1 -1
  269. package/dist/shared/images.js +1 -1
  270. package/dist/shared/index.js +3 -0
  271. package/dist/shared/manifest.js +3 -0
  272. package/dist/shared/page.d.ts +155 -50
  273. package/dist/shared/page.d.ts.map +1 -1
  274. package/dist/shared/page.js +1 -1
  275. package/dist/shared/site.d.ts +322 -113
  276. package/dist/shared/site.d.ts.map +1 -1
  277. package/dist/shared/site.js +1 -1
  278. package/dist/shared/sitemap.d.ts +313 -13
  279. package/dist/shared/sitemap.d.ts.map +1 -1
  280. package/dist/shared/sitemap.js +1 -1
  281. package/dist/shared/social-icons.js +3 -0
  282. package/dist/shared/theme.d.ts +41 -4
  283. package/dist/shared/theme.d.ts.map +1 -1
  284. package/dist/shared/theme.js +1 -1
  285. package/dist/shared/utils/invariant.js +1 -1
  286. package/dist/shared/utils/llm.d.ts +19 -0
  287. package/dist/shared/utils/llm.d.ts.map +1 -0
  288. package/dist/shared/utils/llm.js +3 -0
  289. package/dist/shared/utils/schema.d.ts +6 -1
  290. package/dist/shared/utils/schema.d.ts.map +1 -1
  291. package/dist/shared/utils/schema.js +1 -1
  292. package/dist/shared/utils/tests/schema.test.d.ts +2 -0
  293. package/dist/shared/utils/tests/schema.test.d.ts.map +1 -0
  294. package/dist/shared/utils/typed-ref.d.ts +1 -6
  295. package/dist/shared/utils/typed-ref.d.ts.map +1 -1
  296. package/dist/shared/utils/typed-ref.js +1 -1
  297. package/package.json +19 -19
  298. package/src/shared/ai/schemas.ts +33 -0
  299. package/src/shared/ai/types.ts +151 -0
  300. package/src/shared/ajv.ts +123 -0
  301. package/src/shared/analytics/init.ts +14 -0
  302. package/src/shared/analytics/track.ts +21 -0
  303. package/src/shared/analytics/types.ts +13 -0
  304. package/src/shared/attributes.ts +396 -0
  305. package/src/shared/brick-manifest.ts +119 -0
  306. package/src/shared/bricks/manifests/accordion.manifest.ts +482 -0
  307. package/src/shared/bricks/manifests/all-manifests.ts +121 -0
  308. package/src/shared/bricks/manifests/box.manifest.ts +551 -0
  309. package/src/shared/bricks/manifests/button.manifest.ts +208 -0
  310. package/src/shared/bricks/manifests/card.manifest.ts +320 -0
  311. package/src/shared/bricks/manifests/carousel.manifest.ts +708 -0
  312. package/src/shared/bricks/manifests/footer.manifest.ts +509 -0
  313. package/src/shared/bricks/manifests/form.manifest.ts +226 -0
  314. package/src/shared/bricks/manifests/hero.manifest.ts +365 -0
  315. package/src/shared/bricks/manifests/html.manifest.ts +127 -0
  316. package/src/shared/bricks/manifests/icon.manifest.ts +164 -0
  317. package/src/shared/bricks/manifests/image.manifest.ts +378 -0
  318. package/src/shared/bricks/manifests/images-gallery.manifest.ts +822 -0
  319. package/src/shared/bricks/manifests/map.manifest.ts +215 -0
  320. package/src/shared/bricks/manifests/navbar.manifest.ts +361 -0
  321. package/src/shared/bricks/manifests/sidebar.manifest.ts +88 -0
  322. package/src/shared/bricks/manifests/social-links.manifest.ts +497 -0
  323. package/src/shared/bricks/manifests/spacer.manifest.ts +54 -0
  324. package/src/shared/bricks/manifests/testimonials.manifest.ts +480 -0
  325. package/src/shared/bricks/manifests/tests/header.manifest.test.ts +10 -0
  326. package/src/shared/bricks/manifests/text.manifest.ts +245 -0
  327. package/src/shared/bricks/manifests/video.manifest.ts +115 -0
  328. package/src/shared/bricks/props/align.ts +63 -0
  329. package/src/shared/bricks/props/background.ts +79 -0
  330. package/src/shared/bricks/props/boolean.ts +7 -0
  331. package/src/shared/bricks/props/border.ts +86 -0
  332. package/src/shared/bricks/props/color-preset.ts +390 -0
  333. package/src/shared/bricks/props/color.ts +40 -0
  334. package/src/shared/bricks/props/common.ts +64 -0
  335. package/src/shared/bricks/props/css-length.ts +32 -0
  336. package/src/shared/bricks/props/datarecord.ts +11 -0
  337. package/src/shared/bricks/props/datasource.ts +82 -0
  338. package/src/shared/bricks/props/date.ts +21 -0
  339. package/src/shared/bricks/props/direction.ts +21 -0
  340. package/src/shared/bricks/props/dynamic.ts +112 -0
  341. package/src/shared/bricks/props/effects.ts +71 -0
  342. package/src/shared/bricks/props/enum.ts +38 -0
  343. package/src/shared/bricks/props/file.ts +10 -0
  344. package/src/shared/bricks/props/geolocation.ts +36 -0
  345. package/src/shared/bricks/props/helpers.ts +73 -0
  346. package/src/shared/bricks/props/image.ts +96 -0
  347. package/src/shared/bricks/props/number.ts +8 -0
  348. package/src/shared/bricks/props/position.ts +11 -0
  349. package/src/shared/bricks/props/string.ts +72 -0
  350. package/src/shared/bricks/props/tags.ts +26 -0
  351. package/src/shared/bricks/props/tests/background.test.ts +90 -0
  352. package/src/shared/bricks/props/tests/border.test.ts +12 -0
  353. package/src/shared/bricks/props/tests/effects.test.ts +37 -0
  354. package/src/shared/bricks/props/tests/helpers.test.ts +98 -0
  355. package/src/shared/bricks/props/tests/image.test.ts +71 -0
  356. package/src/shared/bricks/props/tests/string.test.ts +80 -0
  357. package/src/shared/bricks/props/text.ts +107 -0
  358. package/src/shared/bricks/props/types.ts +72 -0
  359. package/src/shared/bricks.ts +1237 -0
  360. package/src/shared/context.ts +32 -0
  361. package/src/shared/datarecords/external/airtable/handler.ts +501 -0
  362. package/src/shared/datarecords/external/airtable/oauth/config.ts +11 -0
  363. package/src/shared/datarecords/external/airtable/types.ts +63 -0
  364. package/src/shared/datarecords/external/generic-webhook/handler.ts +10 -0
  365. package/src/shared/datarecords/external/generic-webhook/options.ts +13 -0
  366. package/src/shared/datarecords/external/google/oauth/config.ts +30 -0
  367. package/src/shared/datarecords/external/google/sheets/client.ts +112 -0
  368. package/src/shared/datarecords/external/google/sheets/handler.ts +253 -0
  369. package/src/shared/datarecords/external/google/sheets/types.ts +10 -0
  370. package/src/shared/datarecords/external/notion/handler.ts +469 -0
  371. package/src/shared/datarecords/external/notion/oauth/config.ts +7 -0
  372. package/src/shared/datarecords/external/notion/types.ts +28 -0
  373. package/src/shared/datarecords/types.ts +165 -0
  374. package/src/shared/datarecords.ts +5 -0
  375. package/src/shared/datasources/README.md +3 -0
  376. package/src/shared/datasources/external/facebook/posts/fetcher.ts +52 -0
  377. package/src/shared/datasources/external/facebook/posts/sample.ts +35 -0
  378. package/src/shared/datasources/external/facebook/posts/schema.ts +33 -0
  379. package/src/shared/datasources/external/facebook/posts/tests/fetcher.test.ts +73 -0
  380. package/src/shared/datasources/external/http-json/fetcher.ts +31 -0
  381. package/src/shared/datasources/external/http-json/options.ts +8 -0
  382. package/src/shared/datasources/external/http-json/schema.ts +6 -0
  383. package/src/shared/datasources/external/http-json/tests/fetcher.test.ts +70 -0
  384. package/src/shared/datasources/external/instagram/feed/fetcher.ts +33 -0
  385. package/src/shared/datasources/external/instagram/feed/sample.ts +22 -0
  386. package/src/shared/datasources/external/instagram/feed/schema.ts +23 -0
  387. package/src/shared/datasources/external/instagram/feed/tests/fetcher.test.ts +64 -0
  388. package/src/shared/datasources/external/mastodon/account/fetcher.ts +24 -0
  389. package/src/shared/datasources/external/mastodon/account/sample.ts +33 -0
  390. package/src/shared/datasources/external/mastodon/account/schema.ts +45 -0
  391. package/src/shared/datasources/external/mastodon/account/tests/fetcher.test.ts +47 -0
  392. package/src/shared/datasources/external/mastodon/options.ts +6 -0
  393. package/src/shared/datasources/external/mastodon/status/fetcher.ts +35 -0
  394. package/src/shared/datasources/external/mastodon/status/sample.array.ts +59 -0
  395. package/src/shared/datasources/external/mastodon/status/sample.single.ts +55 -0
  396. package/src/shared/datasources/external/mastodon/status/schema.ts +125 -0
  397. package/src/shared/datasources/external/mastodon/status/tests/fetcher.test.ts +74 -0
  398. package/src/shared/datasources/external/meta/oauth/config.ts +16 -0
  399. package/src/shared/datasources/external/meta/options.ts +7 -0
  400. package/src/shared/datasources/external/rss/fetcher.ts +31 -0
  401. package/src/shared/datasources/external/rss/options.ts +7 -0
  402. package/src/shared/datasources/external/rss/sample.ts +22 -0
  403. package/src/shared/datasources/external/rss/schema.ts +42 -0
  404. package/src/shared/datasources/external/threads/media/fetcher.ts +53 -0
  405. package/src/shared/datasources/external/threads/media/sample.ts +44 -0
  406. package/src/shared/datasources/external/threads/media/schema.ts +37 -0
  407. package/src/shared/datasources/external/tiktok/oauth/config.ts +17 -0
  408. package/src/shared/datasources/external/tiktok/video/fetcher.ts +39 -0
  409. package/src/shared/datasources/external/tiktok/video/options.ts +8 -0
  410. package/src/shared/datasources/external/tiktok/video/sample.ts +26 -0
  411. package/src/shared/datasources/external/tiktok/video/schema.ts +27 -0
  412. package/src/shared/datasources/external/youtube/list/fetcher.ts +37 -0
  413. package/src/shared/datasources/external/youtube/list/options.ts +11 -0
  414. package/src/shared/datasources/external/youtube/list/sample.ts +33 -0
  415. package/src/shared/datasources/external/youtube/list/schema.ts +38 -0
  416. package/src/shared/datasources/external/youtube/oauth/config.ts +15 -0
  417. package/src/shared/datasources/fetcher.ts +16 -0
  418. package/src/shared/datasources/internal/blog/schema.ts +69 -0
  419. package/src/shared/datasources/internal/changelog/schema.ts +48 -0
  420. package/src/shared/datasources/internal/contact-info/schema.ts +20 -0
  421. package/src/shared/datasources/internal/cv/schema.ts +217 -0
  422. package/src/shared/datasources/internal/faq/schema.ts +27 -0
  423. package/src/shared/datasources/internal/job-board/schema.ts +228 -0
  424. package/src/shared/datasources/internal/links/schema.ts +15 -0
  425. package/src/shared/datasources/internal/recipes/schema.ts +42 -0
  426. package/src/shared/datasources/internal/restaurant/schema.ts +225 -0
  427. package/src/shared/datasources/samples.ts +26 -0
  428. package/src/shared/datasources/schemas.ts +48 -0
  429. package/src/shared/datasources/types.ts +490 -0
  430. package/src/shared/datasources/utils.ts +17 -0
  431. package/src/shared/datasources.ts +57 -0
  432. package/src/shared/env.ts +23 -0
  433. package/src/shared/errors.ts +1 -0
  434. package/src/shared/images.ts +44 -0
  435. package/src/shared/index.ts +3 -0
  436. package/src/shared/layout-constants.ts +19 -0
  437. package/src/shared/manifest.ts +50 -0
  438. package/src/shared/oauth.ts +16 -0
  439. package/src/shared/page.ts +36 -0
  440. package/src/shared/prompt.ts +9 -0
  441. package/src/shared/responsive.ts +5 -0
  442. package/src/shared/site.ts +59 -0
  443. package/src/shared/sitemap.ts +98 -0
  444. package/src/shared/social-icons.ts +307 -0
  445. package/src/shared/tests/attributes.test.ts +31 -0
  446. package/src/shared/theme.ts +244 -0
  447. package/src/shared/themes/README.md +34 -0
  448. package/src/shared/themes/color-system.ts +146 -0
  449. package/src/shared/themes/tests/color-system.test.ts +170 -0
  450. package/src/shared/utils/canvas-data-uri.ts +2 -0
  451. package/src/shared/utils/invariant.ts +25 -0
  452. package/src/shared/utils/json-date.ts +8 -0
  453. package/src/shared/utils/llm.ts +282 -0
  454. package/src/shared/utils/merge.ts +12 -0
  455. package/src/shared/utils/object-hash.ts +7 -0
  456. package/src/shared/utils/schema.ts +359 -0
  457. package/src/shared/utils/string-enum.ts +12 -0
  458. package/src/shared/utils/tests/schema.test.ts +724 -0
  459. package/src/shared/utils/try-catch.ts +12 -0
  460. package/src/shared/utils/typed-ref.ts +53 -0
  461. package/dist/shared/bricks/props/container.d.ts +0 -11
  462. package/dist/shared/bricks/props/container.d.ts.map +0 -1
  463. package/dist/shared/bricks/props/container.js +0 -3
  464. package/dist/shared/bricks/props/gap.d.ts +0 -9
  465. package/dist/shared/bricks/props/gap.d.ts.map +0 -1
  466. package/dist/shared/bricks/props/gap.js +0 -3
  467. package/dist/shared/bricks/props/padding.d.ts +0 -5
  468. package/dist/shared/bricks/props/padding.d.ts.map +0 -1
  469. package/dist/shared/bricks/props/padding.js +0 -3
  470. package/dist/shared/bricks/props/tests/padding.d.ts +0 -2
  471. package/dist/shared/bricks/props/tests/padding.d.ts.map +0 -1
  472. package/dist/shared/chunk-2IYSJYNE.js +0 -3
  473. package/dist/shared/chunk-3EM3B4DX.js +0 -3
  474. package/dist/shared/chunk-4TH3C76A.js +0 -3
  475. package/dist/shared/chunk-5N6MBJJ4.js +0 -3
  476. package/dist/shared/chunk-6FITVVZX.js +0 -3
  477. package/dist/shared/chunk-6K3KZDFC.js +0 -3
  478. package/dist/shared/chunk-6WCGUAQN.js +0 -3
  479. package/dist/shared/chunk-7DMUDZ4H.js +0 -3
  480. package/dist/shared/chunk-ACVLF55Q.js +0 -3
  481. package/dist/shared/chunk-AQPN5SE2.js +0 -3
  482. package/dist/shared/chunk-BZGNY7LB.js +0 -3
  483. package/dist/shared/chunk-C2S243PB.js +0 -8
  484. package/dist/shared/chunk-C3VGP4CA.js +0 -3
  485. package/dist/shared/chunk-CT3EI7YN.js +0 -3
  486. package/dist/shared/chunk-DQXDGV67.js +0 -3
  487. package/dist/shared/chunk-E22E4XWE.js +0 -3
  488. package/dist/shared/chunk-ETYYRWLK.js +0 -3
  489. package/dist/shared/chunk-EYPREFMH.js +0 -3
  490. package/dist/shared/chunk-FKNNTHWX.js +0 -5
  491. package/dist/shared/chunk-HHO3ONTQ.js +0 -3
  492. package/dist/shared/chunk-I46VBMLF.js +0 -3
  493. package/dist/shared/chunk-IIFTGWFZ.js +0 -3
  494. package/dist/shared/chunk-JS4K5JRM.js +0 -5
  495. package/dist/shared/chunk-KHFNN4P3.js +0 -3
  496. package/dist/shared/chunk-LFQZRGHS.js +0 -3
  497. package/dist/shared/chunk-LGP6GWIY.js +0 -3
  498. package/dist/shared/chunk-NLEWXPVM.js +0 -3
  499. package/dist/shared/chunk-NNI225RG.js +0 -3
  500. package/dist/shared/chunk-QISTDGPP.js +0 -3
  501. package/dist/shared/chunk-QSZWDE3D.js +0 -3
  502. package/dist/shared/chunk-RGLVKILY.js +0 -3
  503. package/dist/shared/chunk-SLRU4CT6.js +0 -4
  504. package/dist/shared/chunk-T3LIA4YB.js +0 -3
  505. package/dist/shared/chunk-T4LMBG2G.js +0 -3
  506. package/dist/shared/chunk-TATG6SFZ.js +0 -3
  507. package/dist/shared/chunk-TF3JVVRU.js +0 -3
  508. package/dist/shared/chunk-TTTXV7TJ.js +0 -6
  509. package/dist/shared/chunk-TWBY2GOR.js +0 -3
  510. package/dist/shared/chunk-UHF6IEKV.js +0 -3
  511. package/dist/shared/chunk-UMHXXXVP.js +0 -3
  512. package/dist/shared/chunk-VGRYSAXA.js +0 -3
  513. package/dist/shared/chunk-VPFCY4DH.js +0 -3
  514. package/dist/shared/chunk-VTBI7WX3.js +0 -3
  515. package/dist/shared/chunk-VZPXXFVX.js +0 -3
  516. package/dist/shared/chunk-WU6Q4WYD.js +0 -3
  517. package/dist/shared/chunk-X43MB5WD.js +0 -3
  518. package/dist/shared/chunk-YBGPPF7T.js +0 -3
  519. package/dist/shared/chunk-ZQGNYK5I.js +0 -8
  520. package/dist/shared/chunk-ZTDUXSWH.js +0 -3
  521. package/dist/shared/datarecords/external/airtable/elements.d.ts +0 -21
  522. package/dist/shared/datarecords/external/airtable/elements.d.ts.map +0 -1
  523. package/dist/shared/datarecords/external/airtable/options.d.ts +0 -10
  524. package/dist/shared/datarecords/external/airtable/options.d.ts.map +0 -1
  525. package/dist/shared/datarecords/external/google/sheets/options.d.ts.map +0 -1
  526. package/dist/shared/datarecords/external/notion/options.d.ts.map +0 -1
  527. package/dist/shared/utils/schema-resolver.d.ts +0 -3
  528. package/dist/shared/utils/schema-resolver.d.ts.map +0 -1
  529. package/dist/shared/utils/schema-resolver.js +0 -3
@@ -0,0 +1,724 @@
1
+ import { describe, expect, test, beforeEach, vi } from "vitest";
2
+ import { Type } from "@sinclair/typebox";
3
+ import { resolveSchema } from "../schema";
4
+ import { toLLMSchema } from "../llm";
5
+ import { ajv } from "../../ajv";
6
+ import { sitemapSchema } from "~/shared/sitemap";
7
+
8
+ describe("resolveSchema tests suite", () => {
9
+ beforeEach(() => {
10
+ // Clear any test schemas before each test
11
+ ajv.removeSchema("test:simple");
12
+ ajv.removeSchema("test:user");
13
+ ajv.removeSchema("test:address");
14
+ ajv.removeSchema("test:circular1");
15
+ ajv.removeSchema("test:circular2");
16
+ ajv.removeSchema("test:string");
17
+ ajv.removeSchema("test:number");
18
+ ajv.removeSchema("test:boolean");
19
+ ajv.removeSchema("test:base");
20
+ ajv.removeSchema("test:extended");
21
+ });
22
+
23
+ test("should return primitive types unchanged", () => {
24
+ expect(resolveSchema(null as any)).toBe(null);
25
+ expect(resolveSchema(undefined as any)).toBe(undefined);
26
+ expect(resolveSchema("string" as any)).toBe("string");
27
+ expect(resolveSchema(42 as any)).toBe(42);
28
+ expect(resolveSchema(true as any)).toBe(true);
29
+ });
30
+
31
+ test("should return schema without references unchanged", () => {
32
+ const schema = Type.Object({
33
+ name: Type.String(),
34
+ age: Type.Number(),
35
+ });
36
+
37
+ const result = resolveSchema(schema);
38
+ expect(JSON.stringify(result)).toEqual(JSON.stringify(schema));
39
+ });
40
+
41
+ test("should resolve simple $ref", () => {
42
+ const userSchema = Type.Object({
43
+ name: Type.String(),
44
+ email: Type.String({ format: "email" }),
45
+ });
46
+
47
+ ajv.addSchema(userSchema, "test:user");
48
+
49
+ const schemaWithRef = Type.Ref("test:user");
50
+
51
+ const result = resolveSchema(schemaWithRef);
52
+ expect(result.type).toEqual(userSchema.type);
53
+ });
54
+
55
+ // test("should throw error for non-existent $ref", () => {
56
+ // const schemaWithRef = Type.Ref("test:nonexistent");
57
+
58
+ // expect(() => resolveSchema(schemaWithRef)).toThrow("Schema not found for reference: test:nonexistent");
59
+ // });
60
+
61
+ test("should resolve nested object properties", () => {
62
+ const addressSchema = Type.Object({
63
+ street: Type.String(),
64
+ city: Type.String(),
65
+ });
66
+
67
+ ajv.addSchema(addressSchema, "test:address");
68
+
69
+ const schema = Type.Object({
70
+ name: Type.String(),
71
+ address: Type.Ref("test:address"),
72
+ });
73
+
74
+ const result = resolveSchema(schema);
75
+ expect(result.properties.name.type).toEqual("string");
76
+ expect(result.properties.address.type).toEqual(addressSchema.type);
77
+ });
78
+
79
+ test("should resolve array items", () => {
80
+ const itemSchema = Type.Object({
81
+ id: Type.Number(),
82
+ });
83
+
84
+ ajv.addSchema(itemSchema, "test:simple");
85
+
86
+ const schema = Type.Array(Type.Ref("test:simple"));
87
+
88
+ const result = resolveSchema(schema);
89
+ expect(result.items.type).toEqual(itemSchema.type);
90
+ });
91
+
92
+ test("should resolve array items as array", () => {
93
+ const stringSchema = Type.String();
94
+ const numberSchema = Type.Number();
95
+
96
+ ajv.addSchema(stringSchema, "test:string");
97
+ ajv.addSchema(numberSchema, "test:number");
98
+
99
+ const schema = Type.Tuple([Type.Ref("test:string"), Type.Ref("test:number")]);
100
+
101
+ const result = resolveSchema(schema);
102
+ expect(result.items).toHaveLength(2);
103
+ });
104
+
105
+ test("should resolve anyOf schemas", () => {
106
+ const stringSchema = Type.String();
107
+ const numberSchema = Type.Number();
108
+
109
+ ajv.addSchema(stringSchema, "test:string");
110
+ ajv.addSchema(numberSchema, "test:number");
111
+
112
+ const schema = Type.Union([Type.Ref("test:string"), Type.Ref("test:number")]);
113
+
114
+ const result = resolveSchema(schema);
115
+ expect(result.anyOf[0].type).toEqual(stringSchema.type);
116
+ expect(result.anyOf[1].type).toEqual(numberSchema.type);
117
+ });
118
+
119
+ test("should resolve oneOf schemas", () => {
120
+ const stringSchema = Type.String();
121
+ const numberSchema = Type.Number();
122
+
123
+ ajv.addSchema(stringSchema, "test:string");
124
+ ajv.addSchema(numberSchema, "test:number");
125
+
126
+ const schema = {
127
+ oneOf: [Type.Ref("test:string"), Type.Ref("test:number")],
128
+ } as any;
129
+
130
+ const result = resolveSchema(schema);
131
+ expect(result.oneOf[0].type).toEqual(stringSchema.type);
132
+ expect(result.oneOf[1].type).toEqual(numberSchema.type);
133
+ });
134
+
135
+ test("should resolve allOf schemas", () => {
136
+ const baseSchema = Type.Object({
137
+ id: Type.Number(),
138
+ });
139
+
140
+ const extendedSchema = Type.Object({
141
+ name: Type.String(),
142
+ });
143
+
144
+ ajv.addSchema(baseSchema, "test:base");
145
+ ajv.addSchema(extendedSchema, "test:extended");
146
+
147
+ const schema = Type.Intersect([Type.Ref("test:base"), Type.Ref("test:extended")]);
148
+
149
+ const result = resolveSchema(schema);
150
+
151
+ expect(result.allOf[0].type).toEqual(baseSchema.type);
152
+ expect(result.allOf[1].type).toEqual(extendedSchema.type);
153
+ });
154
+
155
+ test("should resolve not schemas", () => {
156
+ const stringSchema = Type.String();
157
+
158
+ ajv.addSchema(stringSchema, "test:string");
159
+
160
+ const schema = Type.Not(Type.Ref("test:string"));
161
+
162
+ const result = resolveSchema(schema);
163
+ expect(result.not.type).toEqual(stringSchema.type);
164
+ });
165
+
166
+ test("should resolve conditional schemas (if/then/else)", () => {
167
+ const stringSchema = Type.String();
168
+ const numberSchema = Type.Number();
169
+ const booleanSchema = Type.Boolean();
170
+
171
+ ajv.addSchema(stringSchema, "test:string");
172
+ ajv.addSchema(numberSchema, "test:number");
173
+ ajv.addSchema(booleanSchema, "test:boolean");
174
+
175
+ const schema = {
176
+ if: Type.Ref("test:string"),
177
+ // biome-ignore lint/suspicious/noThenProperty: Required for JSON schema conditional validation
178
+ then: Type.Ref("test:number"),
179
+ else: Type.Ref("test:boolean"),
180
+ } as any;
181
+
182
+ const result = resolveSchema(schema);
183
+ expect(result.if.type).toEqual(stringSchema.type);
184
+ expect(result.then.type).toEqual(numberSchema.type);
185
+ expect(result.else.type).toEqual(booleanSchema.type);
186
+ });
187
+
188
+ test("should handle deeply nested schema structures", () => {
189
+ const nestedSchema = Type.Object({
190
+ level1: Type.Object({
191
+ level2: Type.Array(Type.Union([Type.String(), Type.Number()])),
192
+ }),
193
+ });
194
+
195
+ const result = resolveSchema(nestedSchema);
196
+ expect(result).toEqual(nestedSchema);
197
+ });
198
+
199
+ test("should handle empty objects and arrays", () => {
200
+ const schema = Type.Object({});
201
+
202
+ const result = resolveSchema(schema);
203
+ expect(result).toEqual(schema);
204
+ });
205
+
206
+ test("should handle schema with no properties", () => {
207
+ const schema = Type.Object({});
208
+
209
+ const result = resolveSchema(schema);
210
+ expect(result).toEqual(schema);
211
+ });
212
+
213
+ test("should handle complex nested refs", () => {
214
+ const addressSchema = Type.Object({
215
+ street: Type.String(),
216
+ city: Type.String(),
217
+ country: Type.String(),
218
+ });
219
+
220
+ const personSchema = Type.Object({
221
+ name: Type.String(),
222
+ address: Type.Ref("test:address"),
223
+ friends: Type.Array(Type.Ref("test:user")),
224
+ });
225
+
226
+ ajv.addSchema(personSchema, "test:user");
227
+ ajv.addSchema(addressSchema, "test:address");
228
+
229
+ const schema = Type.Object({
230
+ users: Type.Array(Type.Ref("test:user")),
231
+ });
232
+
233
+ const result = resolveSchema(schema);
234
+
235
+ expect(result.type).toBe("object");
236
+ expect(result.properties.users.type).toBe("array");
237
+ expect(result.properties.users.items.type).toBe("object");
238
+ expect(result.properties.users.items.properties.name.type).toBe("string");
239
+ expect(result.properties.users.items.properties.address.type).toBe("object");
240
+ expect(result.properties.users.items.properties.address.properties.street.type).toBe("string");
241
+ });
242
+
243
+ test("should handle refs in conditionals properly", () => {
244
+ const stringSchema = Type.String();
245
+ const numberSchema = Type.Number({ minimum: 0 });
246
+
247
+ ajv.addSchema(stringSchema, "test:string");
248
+ ajv.addSchema(numberSchema, "test:number");
249
+
250
+ const schema = Type.Object({
251
+ type: Type.String({ enum: ["string", "number"] }),
252
+ value: {
253
+ if: Type.Object({ type: Type.Const("string") }),
254
+ // biome-ignore lint/suspicious/noThenProperty: Required for JSON schema conditional validation
255
+ then: Type.Ref("test:string"),
256
+ else: Type.Ref("test:number"),
257
+ } as any,
258
+ });
259
+
260
+ const result = resolveSchema(schema);
261
+
262
+ expect(result.properties.value.then.type).toEqual(stringSchema.type);
263
+ expect(result.properties.value.else.type).toEqual(numberSchema.type);
264
+ expect(result.properties.value.else.minimum).toBe(0);
265
+ });
266
+ });
267
+
268
+ describe("toLLMSchema tests suite", () => {
269
+ test("should remove metadata properties", () => {
270
+ const schema = {
271
+ type: "object",
272
+ properties: {
273
+ name: Type.String(),
274
+ age: Type.Number(),
275
+ },
276
+ metadata: {
277
+ description: "User schema",
278
+ source: "api",
279
+ },
280
+ } as any;
281
+
282
+ const result = toLLMSchema(schema);
283
+
284
+ expect(result.type).toBe("object");
285
+ expect(result.properties).toBeDefined();
286
+ expect(result.metadata).toBeUndefined();
287
+ });
288
+
289
+ test("should remove ui: properties", () => {
290
+ const schema = {
291
+ type: "object",
292
+ properties: {
293
+ name: {
294
+ type: "string",
295
+ "ui:widget": "text",
296
+ "ui:placeholder": "Enter name",
297
+ "ui:help": "Your full name",
298
+ },
299
+ age: Type.Number(),
300
+ },
301
+ "ui:order": ["name", "age"],
302
+ "ui:title": "User Form",
303
+ } as any;
304
+
305
+ const result = toLLMSchema(schema);
306
+
307
+ expect(result.type).toBe("object");
308
+ expect(result.properties.name.type).toBe("string");
309
+ expect(result.properties.name["ui:widget"]).toBeUndefined();
310
+ expect(result.properties.name["ui:placeholder"]).toBeUndefined();
311
+ expect(result.properties.name["ui:help"]).toBeUndefined();
312
+ expect(result["ui:order"]).toBeUndefined();
313
+ expect(result["ui:title"]).toBeUndefined();
314
+ });
315
+
316
+ test("should preserve standard JSON schema properties", () => {
317
+ const schema = Type.Object(
318
+ {
319
+ name: Type.String({
320
+ minLength: 1,
321
+ maxLength: 50,
322
+ description: "User's name",
323
+ }),
324
+ age: Type.Number({
325
+ minimum: 0,
326
+ maximum: 120,
327
+ }),
328
+ email: Type.String({
329
+ format: "email",
330
+ }),
331
+ },
332
+ {
333
+ examples: [
334
+ { name: "John Doe", age: 30, email: "john.doe@example.com" },
335
+ {
336
+ name: "Jane Smith",
337
+ age: 25,
338
+ email: "jane.smith@example.com",
339
+ },
340
+ ],
341
+ },
342
+ );
343
+
344
+ const result = toLLMSchema(schema);
345
+
346
+ expect(result.type).toBe("object");
347
+ expect(result.properties.name.type).toBe("string");
348
+ expect(result.properties.name.minLength).toBe(1);
349
+ expect(result.properties.name.maxLength).toBe(50);
350
+ expect(result.properties.name.description).toBe("User's name");
351
+ expect(result.properties.age.minimum).toBe(0);
352
+ expect(result.properties.age.maximum).toBe(120);
353
+ expect(result.properties.email.format).toBe("email");
354
+ expect(result.examples).toBeDefined();
355
+ });
356
+
357
+ test("should handle nested objects recursively", () => {
358
+ const schema = {
359
+ type: "object",
360
+ properties: {
361
+ user: {
362
+ type: "object",
363
+ properties: {
364
+ name: {
365
+ type: "string",
366
+ "ui:widget": "text",
367
+ },
368
+ profile: {
369
+ type: "object",
370
+ properties: {
371
+ bio: {
372
+ type: "string",
373
+ "ui:widget": "textarea",
374
+ },
375
+ },
376
+ "ui:collapsible": true,
377
+ },
378
+ },
379
+ metadata: {
380
+ version: "1.0",
381
+ },
382
+ },
383
+ },
384
+ "ui:layout": "vertical",
385
+ } as any;
386
+
387
+ const result = toLLMSchema(schema);
388
+
389
+ expect(result.type).toBe("object");
390
+ expect(result["ui:layout"]).toBeUndefined();
391
+ expect(result.properties.user.type).toBe("object");
392
+ expect(result.properties.user.metadata).toBeUndefined();
393
+ expect(result.properties.user.properties.name.type).toBe("string");
394
+ expect(result.properties.user.properties.name["ui:widget"]).toBeUndefined();
395
+ expect(result.properties.user.properties.profile.type).toBe("object");
396
+ expect(result.properties.user.properties.profile["ui:collapsible"]).toBeUndefined();
397
+ expect(result.properties.user.properties.profile.properties.bio.type).toBe("string");
398
+ expect(result.properties.user.properties.profile.properties.bio["ui:widget"]).toBeUndefined();
399
+ });
400
+
401
+ test("should handle arrays with schema items", () => {
402
+ const schema = {
403
+ type: "array",
404
+ items: {
405
+ type: "object",
406
+ properties: {
407
+ name: {
408
+ type: "string",
409
+ "ui:widget": "text",
410
+ },
411
+ },
412
+ metadata: {
413
+ itemType: "user",
414
+ },
415
+ },
416
+ "ui:addable": true,
417
+ } as any;
418
+
419
+ const result = toLLMSchema(schema);
420
+
421
+ expect(result.type).toBe("array");
422
+ expect(result["ui:addable"]).toBeUndefined();
423
+ expect(result.items.type).toBe("object");
424
+ expect(result.items.metadata).toBeUndefined();
425
+ expect(result.items.properties.name.type).toBe("string");
426
+ expect(result.items.properties.name["ui:widget"]).toBeUndefined();
427
+ });
428
+
429
+ test("should handle anyOf/oneOf/allOf schemas", () => {
430
+ const schema = {
431
+ anyOf: [
432
+ {
433
+ type: "string",
434
+ "ui:widget": "text",
435
+ },
436
+ {
437
+ type: "number",
438
+ "ui:widget": "number",
439
+ },
440
+ ],
441
+ oneOf: [
442
+ {
443
+ type: "object",
444
+ properties: {
445
+ name: {
446
+ type: "string",
447
+ "ui:placeholder": "Name",
448
+ },
449
+ },
450
+ metadata: {
451
+ variant: "name",
452
+ },
453
+ },
454
+ ],
455
+ "ui:discriminator": "type",
456
+ } as any;
457
+
458
+ const result = toLLMSchema(schema);
459
+
460
+ expect(result["ui:discriminator"]).toBeUndefined();
461
+ expect(result.anyOf[0].type).toBe("string");
462
+ expect(result.anyOf[0]["ui:widget"]).toBeUndefined();
463
+ expect(result.anyOf[1].type).toBe("number");
464
+ expect(result.anyOf[1]["ui:widget"]).toBeUndefined();
465
+ expect(result.oneOf[0].type).toBe("object");
466
+ expect(result.oneOf[0].metadata).toBeUndefined();
467
+ expect(result.oneOf[0].properties.name.type).toBe("string");
468
+ expect(result.oneOf[0].properties.name["ui:placeholder"]).toBeUndefined();
469
+ });
470
+
471
+ test("should handle conditional schemas (if/then/else)", () => {
472
+ const schema = {
473
+ if: {
474
+ properties: {
475
+ type: { const: "user" },
476
+ },
477
+ "ui:condition": "showUserFields",
478
+ },
479
+ // biome-ignore lint/suspicious/noThenProperty: Required for JSON schema conditional validation
480
+ then: {
481
+ properties: {
482
+ name: {
483
+ type: "string",
484
+ "ui:required": true,
485
+ },
486
+ },
487
+ metadata: {
488
+ context: "user",
489
+ },
490
+ },
491
+ else: {
492
+ properties: {
493
+ id: {
494
+ type: "number",
495
+ "ui:readonly": true,
496
+ },
497
+ },
498
+ },
499
+ } as any;
500
+
501
+ const result = toLLMSchema(schema);
502
+
503
+ expect(result.if.properties.type.const).toBe("user");
504
+ expect(result.if["ui:condition"]).toBeUndefined();
505
+ expect(result.then.properties.name.type).toBe("string");
506
+ expect(result.then.properties.name["ui:required"]).toBeUndefined();
507
+ expect(result.then.metadata).toBeUndefined();
508
+ expect(result.else.properties.id.type).toBe("number");
509
+ expect(result.else.properties.id["ui:readonly"]).toBeUndefined();
510
+ });
511
+
512
+ test("should handle definitions and $defs", () => {
513
+ const schema = {
514
+ type: "object",
515
+ properties: {
516
+ user: { $ref: "#/definitions/User" },
517
+ },
518
+ definitions: {
519
+ User: {
520
+ type: "object",
521
+ properties: {
522
+ name: {
523
+ type: "string",
524
+ "ui:widget": "text",
525
+ },
526
+ },
527
+ metadata: {
528
+ table: "users",
529
+ },
530
+ },
531
+ },
532
+ $defs: {
533
+ Address: {
534
+ type: "object",
535
+ properties: {
536
+ street: {
537
+ type: "string",
538
+ "ui:autocomplete": "street-address",
539
+ },
540
+ },
541
+ "ui:fieldset": "address",
542
+ },
543
+ },
544
+ } as any;
545
+
546
+ const result = toLLMSchema(schema);
547
+
548
+ expect(result.type).toBe("object");
549
+ expect(result.properties.user.$ref).toBe("#/definitions/User");
550
+ expect(result.definitions.User.type).toBe("object");
551
+ expect(result.definitions.User.metadata).toBeUndefined();
552
+ expect(result.definitions.User.properties.name.type).toBe("string");
553
+ expect(result.definitions.User.properties.name["ui:widget"]).toBeUndefined();
554
+ expect(result.$defs.Address.type).toBe("object");
555
+ expect(result.$defs.Address["ui:fieldset"]).toBeUndefined();
556
+ expect(result.$defs.Address.properties.street.type).toBe("string");
557
+ expect(result.$defs.Address.properties.street["ui:autocomplete"]).toBeUndefined();
558
+ });
559
+
560
+ test("should handle primitive schemas without changes", () => {
561
+ const stringSchema = Type.String();
562
+ const numberSchema = Type.Number();
563
+ const booleanSchema = Type.Boolean();
564
+
565
+ expect(toLLMSchema(stringSchema).type).toEqual(stringSchema.type);
566
+ expect(toLLMSchema(numberSchema).type).toEqual(numberSchema.type);
567
+ expect(toLLMSchema(booleanSchema).type).toEqual(booleanSchema.type);
568
+ });
569
+
570
+ test("should handle empty object schema", () => {
571
+ const schema = Type.Object({});
572
+ const result = toLLMSchema(schema);
573
+ expect(result.type).toEqual(schema.type);
574
+ });
575
+
576
+ test("should handle patternProperties", () => {
577
+ const schema = {
578
+ type: "object",
579
+ patternProperties: {
580
+ "^ui_": {
581
+ type: "string",
582
+ "ui:widget": "text",
583
+ },
584
+ "^data_": {
585
+ type: "object",
586
+ properties: {
587
+ value: {
588
+ type: "string",
589
+ "ui:placeholder": "Enter value",
590
+ },
591
+ },
592
+ metadata: {
593
+ source: "user",
594
+ },
595
+ },
596
+ },
597
+ "ui:pattern": "flexible",
598
+ } as any;
599
+
600
+ const result = toLLMSchema(schema);
601
+
602
+ expect(result.type).toBe("object");
603
+ expect(result["ui:pattern"]).toBeUndefined();
604
+ expect(result.patternProperties["^ui_"].type).toBe("string");
605
+ expect(result.patternProperties["^ui_"]["ui:widget"]).toBeUndefined();
606
+ expect(result.patternProperties["^data_"].type).toBe("object");
607
+ expect(result.patternProperties["^data_"].metadata).toBeUndefined();
608
+ expect(result.patternProperties["^data_"].properties.value.type).toBe("string");
609
+ expect(result.patternProperties["^data_"].properties.value["ui:placeholder"]).toBeUndefined();
610
+ });
611
+
612
+ test("should remove properties with ai:hidden set to true", () => {
613
+ const schema = {
614
+ type: "object",
615
+ properties: {
616
+ name: {
617
+ type: "string",
618
+ description: "User's name",
619
+ },
620
+ secretField: {
621
+ type: "string",
622
+ "ai:hidden": true,
623
+ description: "This should be hidden from AI",
624
+ },
625
+ age: {
626
+ type: "number",
627
+ "ai:hidden": false, // Explicitly false, should be kept
628
+ },
629
+ profile: {
630
+ type: "object",
631
+ properties: {
632
+ bio: {
633
+ type: "string",
634
+ description: "User bio",
635
+ },
636
+ internalId: {
637
+ type: "string",
638
+ "ai:hidden": true,
639
+ description: "Internal ID, hidden from AI",
640
+ },
641
+ },
642
+ },
643
+ visibleField: {
644
+ type: "string",
645
+ // No ai:hidden property, should be kept
646
+ },
647
+ },
648
+ } as any;
649
+
650
+ const result = toLLMSchema(schema);
651
+
652
+ expect(result.type).toBe("object");
653
+ expect(result.properties.name).toBeDefined();
654
+ expect(result.properties.name.type).toBe("string");
655
+ expect(result.properties.secretField).toBeUndefined(); // Should be removed
656
+ expect(result.properties.age).toBeDefined(); // Should be kept (ai:hidden = false)
657
+ expect(result.properties.age.type).toBe("number");
658
+ expect(result.properties.visibleField).toBeDefined(); // Should be kept (no ai:hidden)
659
+ expect(result.properties.profile).toBeDefined();
660
+ expect(result.properties.profile.properties.bio).toBeDefined();
661
+ expect(result.properties.profile.properties.internalId).toBeUndefined(); // Should be removed
662
+ });
663
+
664
+ test("should handle ai:hidden in nested schemas", () => {
665
+ const schema = {
666
+ definitions: {
667
+ User: {
668
+ type: "object",
669
+ properties: {
670
+ name: {
671
+ type: "string",
672
+ },
673
+ password: {
674
+ type: "string",
675
+ "ai:hidden": true,
676
+ },
677
+ },
678
+ },
679
+ },
680
+ $defs: {
681
+ Settings: {
682
+ type: "object",
683
+ properties: {
684
+ theme: {
685
+ type: "string",
686
+ },
687
+ apiKey: {
688
+ type: "string",
689
+ "ai:hidden": true,
690
+ },
691
+ },
692
+ },
693
+ },
694
+ patternProperties: {
695
+ "^config_": {
696
+ type: "object",
697
+ properties: {
698
+ value: {
699
+ type: "string",
700
+ },
701
+ secret: {
702
+ type: "string",
703
+ "ai:hidden": true,
704
+ },
705
+ },
706
+ },
707
+ },
708
+ } as any;
709
+
710
+ const result = toLLMSchema(schema);
711
+
712
+ expect(result.definitions.User.properties.name).toBeDefined();
713
+ expect(result.definitions.User.properties.password).toBeUndefined();
714
+ expect(result.$defs.Settings.properties.theme).toBeDefined();
715
+ expect(result.$defs.Settings.properties.apiKey).toBeUndefined();
716
+ expect(result.patternProperties["^config_"].properties.value).toBeDefined();
717
+ expect(result.patternProperties["^config_"].properties.secret).toBeUndefined();
718
+ });
719
+
720
+ test("test with existing Upstart schema", () => {
721
+ const transformed = toLLMSchema(sitemapSchema);
722
+ expect(transformed.items.properties.id.type).toEqual(sitemapSchema.items.properties.id.type);
723
+ });
724
+ });