@webstudio-is/react-sdk 0.8.0 → 0.10.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 (612) hide show
  1. package/lib/app/custom-components/image.js +46 -0
  2. package/lib/app/custom-components/index.js +18 -0
  3. package/lib/app/custom-components/link.js +6 -0
  4. package/lib/app/custom-components/rich-text-link.js +6 -0
  5. package/lib/app/custom-components/shared/remix-link.js +29 -0
  6. package/lib/app/handle-request.server.js +19 -0
  7. package/lib/{remix → app}/index.js +1 -0
  8. package/lib/app/params.js +10 -0
  9. package/lib/app/root.js +40 -0
  10. package/lib/cjs/app/custom-components/image.cjs +63 -0
  11. package/lib/cjs/app/custom-components/index.cjs +38 -0
  12. package/lib/cjs/app/custom-components/link.cjs +26 -0
  13. package/lib/cjs/app/custom-components/rich-text-link.cjs +26 -0
  14. package/lib/cjs/app/custom-components/shared/remix-link.cjs +49 -0
  15. package/lib/cjs/app/handle-request.server.cjs +39 -0
  16. package/lib/cjs/app/index.cjs +20 -0
  17. package/lib/cjs/app/params.cjs +30 -0
  18. package/lib/cjs/app/root.cjs +60 -0
  19. package/lib/cjs/components/__generated__/body.props.json +491 -0
  20. package/lib/cjs/components/__generated__/bold.props.json +491 -0
  21. package/lib/cjs/components/__generated__/box.props.json +508 -0
  22. package/lib/cjs/components/__generated__/button.props.json +547 -0
  23. package/lib/cjs/components/__generated__/form.props.json +531 -0
  24. package/lib/cjs/components/__generated__/heading.props.json +497 -0
  25. package/lib/cjs/components/__generated__/image.props.json +560 -0
  26. package/lib/cjs/components/__generated__/input.props.json +657 -0
  27. package/lib/cjs/components/__generated__/italic.props.json +491 -0
  28. package/lib/cjs/components/__generated__/link.props.json +547 -0
  29. package/lib/cjs/components/__generated__/paragraph.props.json +491 -0
  30. package/lib/cjs/components/__generated__/rich-text-link.props.json +547 -0
  31. package/lib/cjs/components/__generated__/span.props.json +491 -0
  32. package/lib/cjs/components/__generated__/subscript.props.json +491 -0
  33. package/lib/cjs/components/__generated__/superscript.props.json +491 -0
  34. package/lib/cjs/components/__generated__/text-block.props.json +491 -0
  35. package/lib/cjs/components/body.cjs +29 -6
  36. package/lib/cjs/components/body.ws.cjs +83 -59
  37. package/lib/cjs/components/bold.cjs +29 -6
  38. package/lib/cjs/components/bold.ws.cjs +35 -11
  39. package/lib/cjs/components/box.cjs +29 -7
  40. package/lib/cjs/components/box.ws.cjs +40 -16
  41. package/lib/cjs/components/button.cjs +33 -8
  42. package/lib/cjs/components/button.ws.cjs +36 -12
  43. package/lib/cjs/components/component-type.cjs +77 -27
  44. package/lib/cjs/components/form.cjs +29 -6
  45. package/lib/cjs/components/form.ws.cjs +45 -21
  46. package/lib/cjs/components/heading.cjs +29 -7
  47. package/lib/cjs/components/heading.ws.cjs +36 -12
  48. package/lib/cjs/components/image.cjs +39 -14
  49. package/lib/cjs/components/image.ws.cjs +45 -24
  50. package/lib/cjs/components/index.cjs +145 -35
  51. package/lib/cjs/components/input.cjs +29 -6
  52. package/lib/cjs/components/input.ws.cjs +35 -11
  53. package/lib/cjs/components/italic.cjs +29 -6
  54. package/lib/cjs/components/italic.ws.cjs +40 -16
  55. package/lib/cjs/components/link.cjs +32 -7
  56. package/lib/cjs/components/link.ws.cjs +46 -22
  57. package/lib/cjs/components/paragraph.cjs +29 -6
  58. package/lib/cjs/components/paragraph.ws.cjs +36 -12
  59. package/lib/cjs/components/rich-text-link.cjs +33 -0
  60. package/lib/cjs/components/rich-text-link.ws.cjs +38 -0
  61. package/lib/cjs/components/span.cjs +29 -6
  62. package/lib/cjs/components/span.ws.cjs +35 -11
  63. package/lib/cjs/components/subscript.cjs +29 -6
  64. package/lib/cjs/components/subscript.ws.cjs +35 -11
  65. package/lib/cjs/components/superscript.cjs +29 -6
  66. package/lib/cjs/components/superscript.ws.cjs +35 -11
  67. package/lib/cjs/components/text-block.cjs +29 -6
  68. package/lib/cjs/components/text-block.ws.cjs +42 -18
  69. package/lib/cjs/css/breakpoints.cjs +27 -7
  70. package/lib/cjs/css/categories.cjs +218 -203
  71. package/lib/cjs/css/get-browser-style.cjs +56 -40
  72. package/lib/cjs/css/index.cjs +18 -17
  73. package/lib/cjs/db/index.cjs +17 -16
  74. package/lib/cjs/db/instance.cjs +37 -17
  75. package/lib/cjs/db/types.cjs +15 -1
  76. package/lib/cjs/index.cjs +30 -34
  77. package/lib/cjs/pubsub/create.cjs +76 -61
  78. package/lib/cjs/pubsub/index.cjs +16 -15
  79. package/lib/cjs/tree/create-elements-tree.cjs +90 -48
  80. package/lib/cjs/tree/index.cjs +18 -17
  81. package/lib/cjs/tree/root.cjs +43 -15
  82. package/lib/cjs/tree/session-storage-polyfill.cjs +60 -37
  83. package/lib/cjs/tree/wrapper-component.cjs +53 -46
  84. package/lib/cjs/user-props/all-user-props.cjs +35 -17
  85. package/lib/cjs/user-props/index.cjs +19 -18
  86. package/lib/cjs/user-props/schema.cjs +52 -31
  87. package/lib/cjs/user-props/types.cjs +15 -1
  88. package/lib/cjs/user-props/use-user-props-asset.cjs +41 -0
  89. package/lib/cjs/user-props/use-user-props.cjs +38 -30
  90. package/lib/components/__generated__/body.props.json +491 -0
  91. package/lib/components/__generated__/bold.props.json +491 -0
  92. package/lib/components/__generated__/box.props.json +508 -0
  93. package/lib/components/__generated__/button.props.json +547 -0
  94. package/lib/components/__generated__/form.props.json +531 -0
  95. package/lib/components/__generated__/heading.props.json +497 -0
  96. package/lib/components/__generated__/image.props.json +560 -0
  97. package/lib/components/__generated__/input.props.json +657 -0
  98. package/lib/components/__generated__/italic.props.json +491 -0
  99. package/lib/components/__generated__/link.props.json +547 -0
  100. package/lib/components/__generated__/paragraph.props.json +491 -0
  101. package/lib/components/__generated__/rich-text-link.props.json +547 -0
  102. package/lib/components/__generated__/span.props.json +491 -0
  103. package/lib/components/__generated__/subscript.props.json +491 -0
  104. package/lib/components/__generated__/superscript.props.json +491 -0
  105. package/lib/components/__generated__/text-block.props.json +491 -0
  106. package/lib/components/body.js +8 -2
  107. package/lib/components/body.ws.js +57 -57
  108. package/lib/components/bold.js +8 -2
  109. package/lib/components/bold.ws.js +9 -9
  110. package/lib/components/box.js +11 -3
  111. package/lib/components/box.ws.js +14 -14
  112. package/lib/components/button.js +11 -3
  113. package/lib/components/button.ws.js +10 -10
  114. package/lib/components/component-type.js +54 -21
  115. package/lib/components/form.js +8 -2
  116. package/lib/components/form.ws.js +19 -19
  117. package/lib/components/heading.js +11 -3
  118. package/lib/components/heading.ws.js +10 -10
  119. package/lib/components/image.js +17 -9
  120. package/lib/components/image.ws.js +19 -22
  121. package/lib/components/index.js +120 -15
  122. package/lib/components/input.js +8 -2
  123. package/lib/components/input.ws.js +9 -9
  124. package/lib/components/italic.js +8 -2
  125. package/lib/components/italic.ws.js +14 -14
  126. package/lib/components/link.js +11 -3
  127. package/lib/components/link.ws.js +20 -20
  128. package/lib/components/paragraph.js +8 -2
  129. package/lib/components/paragraph.ws.js +10 -10
  130. package/lib/components/rich-text-link.js +13 -0
  131. package/lib/components/rich-text-link.ws.js +12 -0
  132. package/lib/components/span.js +8 -2
  133. package/lib/components/span.ws.js +9 -9
  134. package/lib/components/subscript.js +8 -2
  135. package/lib/components/subscript.ws.js +9 -9
  136. package/lib/components/superscript.js +8 -2
  137. package/lib/components/superscript.ws.js +9 -9
  138. package/lib/components/text-block.js +8 -2
  139. package/lib/components/text-block.ws.js +16 -16
  140. package/lib/css/breakpoints.js +8 -5
  141. package/lib/css/categories.js +198 -200
  142. package/lib/css/get-browser-style.js +35 -35
  143. package/lib/db/instance.js +14 -10
  144. package/lib/db/types.js +0 -1
  145. package/lib/index.js +10 -3
  146. package/lib/pubsub/create.js +51 -55
  147. package/lib/tree/create-elements-tree.js +68 -42
  148. package/lib/tree/root.js +21 -9
  149. package/lib/tree/session-storage-polyfill.js +41 -34
  150. package/lib/tree/wrapper-component.js +34 -19
  151. package/lib/user-props/all-user-props.js +15 -13
  152. package/lib/user-props/schema.js +33 -29
  153. package/lib/user-props/types.js +0 -1
  154. package/lib/user-props/use-user-props-asset.js +21 -0
  155. package/lib/user-props/use-user-props.js +19 -27
  156. package/package.json +14 -24
  157. package/src/app/custom-components/image.tsx +62 -0
  158. package/src/app/custom-components/index.ts +17 -0
  159. package/src/app/custom-components/link.tsx +4 -0
  160. package/src/app/custom-components/rich-text-link.tsx +4 -0
  161. package/src/app/custom-components/shared/remix-link.tsx +40 -0
  162. package/src/app/handle-request.server.tsx +21 -0
  163. package/{lib/cjs/remix/index.d.ts → src/app/index.ts} +1 -1
  164. package/src/app/params.ts +13 -0
  165. package/src/app/root.tsx +27 -0
  166. package/src/components/__generated__/body.props.json +491 -0
  167. package/src/components/__generated__/bold.props.json +491 -0
  168. package/src/components/__generated__/box.props.json +508 -0
  169. package/src/components/__generated__/button.props.json +547 -0
  170. package/src/components/__generated__/form.props.json +531 -0
  171. package/src/components/__generated__/heading.props.json +497 -0
  172. package/src/components/__generated__/image.props.json +560 -0
  173. package/src/components/__generated__/input.props.json +657 -0
  174. package/src/components/__generated__/italic.props.json +491 -0
  175. package/src/components/__generated__/link.props.json +547 -0
  176. package/src/components/__generated__/paragraph.props.json +491 -0
  177. package/src/components/__generated__/rich-text-link.props.json +547 -0
  178. package/src/components/__generated__/span.props.json +491 -0
  179. package/src/components/__generated__/subscript.props.json +491 -0
  180. package/src/components/__generated__/superscript.props.json +491 -0
  181. package/src/components/__generated__/text-block.props.json +491 -0
  182. package/src/components/body.stories.tsx +11 -0
  183. package/src/components/body.tsx +10 -0
  184. package/src/components/body.ws.tsx +63 -0
  185. package/src/components/bold.stories.tsx +16 -0
  186. package/src/components/bold.tsx +10 -0
  187. package/src/components/bold.ws.tsx +12 -0
  188. package/src/components/box.stories.tsx +17 -0
  189. package/src/components/box.tsx +31 -0
  190. package/src/components/box.ws.ts +20 -0
  191. package/src/components/button.stories.tsx +17 -0
  192. package/src/components/button.tsx +14 -0
  193. package/src/components/button.ws.tsx +13 -0
  194. package/src/components/component-type.ts +89 -0
  195. package/src/components/form.stories.tsx +14 -0
  196. package/src/components/form.tsx +10 -0
  197. package/src/components/form.ws.tsx +25 -0
  198. package/src/components/heading.stories.tsx +16 -0
  199. package/src/components/heading.tsx +20 -0
  200. package/src/components/heading.ws.tsx +13 -0
  201. package/src/components/image.stories.tsx +15 -0
  202. package/src/components/image.tsx +52 -0
  203. package/src/components/image.ws.tsx +28 -0
  204. package/src/components/index.test.ts +28 -0
  205. package/src/components/index.ts +159 -0
  206. package/src/components/input.stories.tsx +14 -0
  207. package/src/components/input.tsx +11 -0
  208. package/src/components/input.ws.tsx +12 -0
  209. package/src/components/italic.stories.tsx +16 -0
  210. package/src/components/italic.tsx +10 -0
  211. package/src/components/italic.ws.tsx +20 -0
  212. package/src/components/link.stories.tsx +16 -0
  213. package/src/components/link.tsx +9 -0
  214. package/src/components/link.ws.tsx +26 -0
  215. package/src/components/paragraph.stories.tsx +16 -0
  216. package/src/components/paragraph.tsx +10 -0
  217. package/src/components/paragraph.ws.tsx +13 -0
  218. package/src/components/rich-text-link.stories.tsx +16 -0
  219. package/src/components/rich-text-link.tsx +9 -0
  220. package/src/components/rich-text-link.ws.tsx +12 -0
  221. package/src/components/span.stories.tsx +16 -0
  222. package/src/components/span.tsx +10 -0
  223. package/src/components/span.ws.tsx +12 -0
  224. package/src/components/subscript.stories.tsx +16 -0
  225. package/src/components/subscript.tsx +10 -0
  226. package/src/components/subscript.ws.tsx +12 -0
  227. package/src/components/superscript.stories.tsx +16 -0
  228. package/src/components/superscript.tsx +10 -0
  229. package/src/components/superscript.ws.tsx +12 -0
  230. package/src/components/text-block.stories.tsx +16 -0
  231. package/src/components/text-block.tsx +10 -0
  232. package/src/components/text-block.ws.tsx +22 -0
  233. package/src/css/breakpoints.ts +10 -0
  234. package/src/css/categories.ts +254 -0
  235. package/src/css/get-browser-style.ts +50 -0
  236. package/{lib/cjs/css/index.d.ts → src/css/index.ts} +0 -1
  237. package/{lib/cjs/db/index.d.ts → src/db/index.ts} +0 -1
  238. package/src/db/instance.ts +34 -0
  239. package/src/db/types.ts +18 -0
  240. package/src/index.ts +12 -0
  241. package/src/pubsub/create.ts +84 -0
  242. package/src/pubsub/index.ts +1 -0
  243. package/src/tree/create-elements-tree.tsx +102 -0
  244. package/{lib/tree/index.d.ts → src/tree/index.ts} +0 -1
  245. package/src/tree/root.ts +45 -0
  246. package/src/tree/session-storage-polyfill.tsx +50 -0
  247. package/src/tree/wrapper-component.tsx +48 -0
  248. package/src/user-props/all-user-props.ts +22 -0
  249. package/{lib/cjs/user-props/index.d.ts → src/user-props/index.ts} +0 -1
  250. package/src/user-props/schema.ts +35 -0
  251. package/src/user-props/types.ts +14 -0
  252. package/src/user-props/use-user-props-asset.ts +31 -0
  253. package/src/user-props/use-user-props.ts +30 -0
  254. package/lib/arg-types/utils.d.ts +0 -10
  255. package/lib/arg-types/utils.d.ts.map +0 -1
  256. package/lib/arg-types/utils.js +0 -83
  257. package/lib/cjs/arg-types/utils.cjs +0 -88
  258. package/lib/cjs/arg-types/utils.d.ts +0 -10
  259. package/lib/cjs/arg-types/utils.d.ts.map +0 -1
  260. package/lib/cjs/components/body.d.ts +0 -3
  261. package/lib/cjs/components/body.d.ts.map +0 -1
  262. package/lib/cjs/components/body.props.json +0 -491
  263. package/lib/cjs/components/body.stories.cjs +0 -11
  264. package/lib/cjs/components/body.stories.d.ts +0 -7
  265. package/lib/cjs/components/body.stories.d.ts.map +0 -1
  266. package/lib/cjs/components/body.ws.d.ts +0 -5
  267. package/lib/cjs/components/body.ws.d.ts.map +0 -1
  268. package/lib/cjs/components/bold.d.ts +0 -3
  269. package/lib/cjs/components/bold.d.ts.map +0 -1
  270. package/lib/cjs/components/bold.props.json +0 -491
  271. package/lib/cjs/components/bold.stories.cjs +0 -14
  272. package/lib/cjs/components/bold.stories.d.ts +0 -6
  273. package/lib/cjs/components/bold.stories.d.ts.map +0 -1
  274. package/lib/cjs/components/bold.ws.d.ts +0 -5
  275. package/lib/cjs/components/bold.ws.d.ts.map +0 -1
  276. package/lib/cjs/components/box.d.ts +0 -8
  277. package/lib/cjs/components/box.d.ts.map +0 -1
  278. package/lib/cjs/components/box.props.json +0 -508
  279. package/lib/cjs/components/box.stories.cjs +0 -12
  280. package/lib/cjs/components/box.stories.d.ts +0 -10
  281. package/lib/cjs/components/box.stories.d.ts.map +0 -1
  282. package/lib/cjs/components/box.ws.d.ts +0 -5
  283. package/lib/cjs/components/box.ws.d.ts.map +0 -1
  284. package/lib/cjs/components/button.d.ts +0 -3
  285. package/lib/cjs/components/button.d.ts.map +0 -1
  286. package/lib/cjs/components/button.props.json +0 -547
  287. package/lib/cjs/components/button.stories.cjs +0 -14
  288. package/lib/cjs/components/button.stories.d.ts +0 -6
  289. package/lib/cjs/components/button.stories.d.ts.map +0 -1
  290. package/lib/cjs/components/button.ws.d.ts +0 -5
  291. package/lib/cjs/components/button.ws.d.ts.map +0 -1
  292. package/lib/cjs/components/component-type.d.ts +0 -17
  293. package/lib/cjs/components/component-type.d.ts.map +0 -1
  294. package/lib/cjs/components/form.d.ts +0 -3
  295. package/lib/cjs/components/form.d.ts.map +0 -1
  296. package/lib/cjs/components/form.props.json +0 -531
  297. package/lib/cjs/components/form.stories.cjs +0 -12
  298. package/lib/cjs/components/form.stories.d.ts +0 -6
  299. package/lib/cjs/components/form.stories.d.ts.map +0 -1
  300. package/lib/cjs/components/form.ws.d.ts +0 -5
  301. package/lib/cjs/components/form.ws.d.ts.map +0 -1
  302. package/lib/cjs/components/heading.d.ts +0 -8
  303. package/lib/cjs/components/heading.d.ts.map +0 -1
  304. package/lib/cjs/components/heading.props.json +0 -497
  305. package/lib/cjs/components/heading.stories.cjs +0 -14
  306. package/lib/cjs/components/heading.stories.d.ts +0 -10
  307. package/lib/cjs/components/heading.stories.d.ts.map +0 -1
  308. package/lib/cjs/components/heading.ws.d.ts +0 -5
  309. package/lib/cjs/components/heading.ws.d.ts.map +0 -1
  310. package/lib/cjs/components/image.d.ts +0 -3
  311. package/lib/cjs/components/image.d.ts.map +0 -1
  312. package/lib/cjs/components/image.props.json +0 -575
  313. package/lib/cjs/components/image.stories.cjs +0 -12
  314. package/lib/cjs/components/image.stories.d.ts +0 -6
  315. package/lib/cjs/components/image.stories.d.ts.map +0 -1
  316. package/lib/cjs/components/image.ws.d.ts +0 -5
  317. package/lib/cjs/components/image.ws.d.ts.map +0 -1
  318. package/lib/cjs/components/index.d.ts +0 -16
  319. package/lib/cjs/components/index.d.ts.map +0 -1
  320. package/lib/cjs/components/index.test.cjs +0 -33
  321. package/lib/cjs/components/index.test.d.ts +0 -2
  322. package/lib/cjs/components/index.test.d.ts.map +0 -1
  323. package/lib/cjs/components/input.d.ts +0 -3
  324. package/lib/cjs/components/input.d.ts.map +0 -1
  325. package/lib/cjs/components/input.props.json +0 -657
  326. package/lib/cjs/components/input.stories.cjs +0 -12
  327. package/lib/cjs/components/input.stories.d.ts +0 -6
  328. package/lib/cjs/components/input.stories.d.ts.map +0 -1
  329. package/lib/cjs/components/input.ws.d.ts +0 -5
  330. package/lib/cjs/components/input.ws.d.ts.map +0 -1
  331. package/lib/cjs/components/italic.d.ts +0 -3
  332. package/lib/cjs/components/italic.d.ts.map +0 -1
  333. package/lib/cjs/components/italic.props.json +0 -491
  334. package/lib/cjs/components/italic.stories.cjs +0 -14
  335. package/lib/cjs/components/italic.stories.d.ts +0 -6
  336. package/lib/cjs/components/italic.stories.d.ts.map +0 -1
  337. package/lib/cjs/components/italic.ws.d.ts +0 -5
  338. package/lib/cjs/components/italic.ws.d.ts.map +0 -1
  339. package/lib/cjs/components/link.d.ts +0 -8
  340. package/lib/cjs/components/link.d.ts.map +0 -1
  341. package/lib/cjs/components/link.props.json +0 -547
  342. package/lib/cjs/components/link.stories.cjs +0 -14
  343. package/lib/cjs/components/link.stories.d.ts +0 -10
  344. package/lib/cjs/components/link.stories.d.ts.map +0 -1
  345. package/lib/cjs/components/link.ws.d.ts +0 -5
  346. package/lib/cjs/components/link.ws.d.ts.map +0 -1
  347. package/lib/cjs/components/meta.cjs +0 -40
  348. package/lib/cjs/components/meta.d.ts +0 -7479
  349. package/lib/cjs/components/meta.d.ts.map +0 -1
  350. package/lib/cjs/components/paragraph.d.ts +0 -3
  351. package/lib/cjs/components/paragraph.d.ts.map +0 -1
  352. package/lib/cjs/components/paragraph.props.json +0 -491
  353. package/lib/cjs/components/paragraph.stories.cjs +0 -14
  354. package/lib/cjs/components/paragraph.stories.d.ts +0 -6
  355. package/lib/cjs/components/paragraph.stories.d.ts.map +0 -1
  356. package/lib/cjs/components/paragraph.ws.d.ts +0 -5
  357. package/lib/cjs/components/paragraph.ws.d.ts.map +0 -1
  358. package/lib/cjs/components/span.d.ts +0 -3
  359. package/lib/cjs/components/span.d.ts.map +0 -1
  360. package/lib/cjs/components/span.props.json +0 -491
  361. package/lib/cjs/components/span.stories.cjs +0 -14
  362. package/lib/cjs/components/span.stories.d.ts +0 -6
  363. package/lib/cjs/components/span.stories.d.ts.map +0 -1
  364. package/lib/cjs/components/span.ws.d.ts +0 -5
  365. package/lib/cjs/components/span.ws.d.ts.map +0 -1
  366. package/lib/cjs/components/subscript.d.ts +0 -3
  367. package/lib/cjs/components/subscript.d.ts.map +0 -1
  368. package/lib/cjs/components/subscript.props.json +0 -491
  369. package/lib/cjs/components/subscript.stories.cjs +0 -14
  370. package/lib/cjs/components/subscript.stories.d.ts +0 -6
  371. package/lib/cjs/components/subscript.stories.d.ts.map +0 -1
  372. package/lib/cjs/components/subscript.ws.d.ts +0 -5
  373. package/lib/cjs/components/subscript.ws.d.ts.map +0 -1
  374. package/lib/cjs/components/superscript.d.ts +0 -3
  375. package/lib/cjs/components/superscript.d.ts.map +0 -1
  376. package/lib/cjs/components/superscript.props.json +0 -491
  377. package/lib/cjs/components/superscript.stories.cjs +0 -14
  378. package/lib/cjs/components/superscript.stories.d.ts +0 -6
  379. package/lib/cjs/components/superscript.stories.d.ts.map +0 -1
  380. package/lib/cjs/components/superscript.ws.d.ts +0 -5
  381. package/lib/cjs/components/superscript.ws.d.ts.map +0 -1
  382. package/lib/cjs/components/text-block.d.ts +0 -3
  383. package/lib/cjs/components/text-block.d.ts.map +0 -1
  384. package/lib/cjs/components/text-block.props.json +0 -491
  385. package/lib/cjs/components/text-block.stories.cjs +0 -14
  386. package/lib/cjs/components/text-block.stories.d.ts +0 -6
  387. package/lib/cjs/components/text-block.stories.d.ts.map +0 -1
  388. package/lib/cjs/components/text-block.ws.d.ts +0 -5
  389. package/lib/cjs/components/text-block.ws.d.ts.map +0 -1
  390. package/lib/cjs/css/breakpoints.d.ts +0 -4
  391. package/lib/cjs/css/breakpoints.d.ts.map +0 -1
  392. package/lib/cjs/css/categories.d.ts +0 -408
  393. package/lib/cjs/css/categories.d.ts.map +0 -1
  394. package/lib/cjs/css/get-browser-style.d.ts +0 -3
  395. package/lib/cjs/css/get-browser-style.d.ts.map +0 -1
  396. package/lib/cjs/css/index.d.ts.map +0 -1
  397. package/lib/cjs/db/index.d.ts.map +0 -1
  398. package/lib/cjs/db/instance.d.ts +0 -14
  399. package/lib/cjs/db/instance.d.ts.map +0 -1
  400. package/lib/cjs/db/types.d.ts +0 -17
  401. package/lib/cjs/db/types.d.ts.map +0 -1
  402. package/lib/cjs/index.d.ts +0 -9
  403. package/lib/cjs/index.d.ts.map +0 -1
  404. package/lib/cjs/pubsub/create.d.ts +0 -29
  405. package/lib/cjs/pubsub/create.d.ts.map +0 -1
  406. package/lib/cjs/pubsub/index.d.ts +0 -2
  407. package/lib/cjs/pubsub/index.d.ts.map +0 -1
  408. package/lib/cjs/remix/handle-request.server.cjs +0 -15
  409. package/lib/cjs/remix/handle-request.server.d.ts +0 -3
  410. package/lib/cjs/remix/handle-request.server.d.ts.map +0 -1
  411. package/lib/cjs/remix/index.cjs +0 -18
  412. package/lib/cjs/remix/index.d.ts.map +0 -1
  413. package/lib/cjs/remix/root.cjs +0 -13
  414. package/lib/cjs/remix/root.d.ts +0 -8
  415. package/lib/cjs/remix/root.d.ts.map +0 -1
  416. package/lib/cjs/tree/create-elements-tree.d.ts +0 -19
  417. package/lib/cjs/tree/create-elements-tree.d.ts.map +0 -1
  418. package/lib/cjs/tree/index.d.ts +0 -4
  419. package/lib/cjs/tree/index.d.ts.map +0 -1
  420. package/lib/cjs/tree/root.d.ts +0 -18
  421. package/lib/cjs/tree/root.d.ts.map +0 -1
  422. package/lib/cjs/tree/session-storage-polyfill.d.ts +0 -2
  423. package/lib/cjs/tree/session-storage-polyfill.d.ts.map +0 -1
  424. package/lib/cjs/tree/wrapper-component.d.ts +0 -12
  425. package/lib/cjs/tree/wrapper-component.d.ts.map +0 -1
  426. package/lib/cjs/user-props/all-user-props.d.ts +0 -8
  427. package/lib/cjs/user-props/all-user-props.d.ts.map +0 -1
  428. package/lib/cjs/user-props/index.d.ts.map +0 -1
  429. package/lib/cjs/user-props/schema.d.ts +0 -72
  430. package/lib/cjs/user-props/schema.d.ts.map +0 -1
  431. package/lib/cjs/user-props/types.d.ts +0 -13
  432. package/lib/cjs/user-props/types.d.ts.map +0 -1
  433. package/lib/cjs/user-props/use-user-props.d.ts +0 -12
  434. package/lib/cjs/user-props/use-user-props.d.ts.map +0 -1
  435. package/lib/components/body.d.ts +0 -3
  436. package/lib/components/body.d.ts.map +0 -1
  437. package/lib/components/body.props.json +0 -491
  438. package/lib/components/body.stories.d.ts +0 -7
  439. package/lib/components/body.stories.d.ts.map +0 -1
  440. package/lib/components/body.stories.js +0 -7
  441. package/lib/components/body.ws.d.ts +0 -5
  442. package/lib/components/body.ws.d.ts.map +0 -1
  443. package/lib/components/bold.d.ts +0 -3
  444. package/lib/components/bold.d.ts.map +0 -1
  445. package/lib/components/bold.props.json +0 -491
  446. package/lib/components/bold.stories.d.ts +0 -6
  447. package/lib/components/bold.stories.d.ts.map +0 -1
  448. package/lib/components/bold.stories.js +0 -11
  449. package/lib/components/bold.ws.d.ts +0 -5
  450. package/lib/components/bold.ws.d.ts.map +0 -1
  451. package/lib/components/box.d.ts +0 -8
  452. package/lib/components/box.d.ts.map +0 -1
  453. package/lib/components/box.props.json +0 -508
  454. package/lib/components/box.stories.d.ts +0 -10
  455. package/lib/components/box.stories.d.ts.map +0 -1
  456. package/lib/components/box.stories.js +0 -9
  457. package/lib/components/box.ws.d.ts +0 -5
  458. package/lib/components/box.ws.d.ts.map +0 -1
  459. package/lib/components/button.d.ts +0 -3
  460. package/lib/components/button.d.ts.map +0 -1
  461. package/lib/components/button.props.json +0 -547
  462. package/lib/components/button.stories.d.ts +0 -6
  463. package/lib/components/button.stories.d.ts.map +0 -1
  464. package/lib/components/button.stories.js +0 -11
  465. package/lib/components/button.ws.d.ts +0 -5
  466. package/lib/components/button.ws.d.ts.map +0 -1
  467. package/lib/components/component-type.d.ts +0 -17
  468. package/lib/components/component-type.d.ts.map +0 -1
  469. package/lib/components/form.d.ts +0 -3
  470. package/lib/components/form.d.ts.map +0 -1
  471. package/lib/components/form.props.json +0 -531
  472. package/lib/components/form.stories.d.ts +0 -6
  473. package/lib/components/form.stories.d.ts.map +0 -1
  474. package/lib/components/form.stories.js +0 -9
  475. package/lib/components/form.ws.d.ts +0 -5
  476. package/lib/components/form.ws.d.ts.map +0 -1
  477. package/lib/components/heading.d.ts +0 -8
  478. package/lib/components/heading.d.ts.map +0 -1
  479. package/lib/components/heading.props.json +0 -497
  480. package/lib/components/heading.stories.d.ts +0 -10
  481. package/lib/components/heading.stories.d.ts.map +0 -1
  482. package/lib/components/heading.stories.js +0 -11
  483. package/lib/components/heading.ws.d.ts +0 -5
  484. package/lib/components/heading.ws.d.ts.map +0 -1
  485. package/lib/components/image.d.ts +0 -3
  486. package/lib/components/image.d.ts.map +0 -1
  487. package/lib/components/image.props.json +0 -575
  488. package/lib/components/image.stories.d.ts +0 -6
  489. package/lib/components/image.stories.d.ts.map +0 -1
  490. package/lib/components/image.stories.js +0 -9
  491. package/lib/components/image.ws.d.ts +0 -5
  492. package/lib/components/image.ws.d.ts.map +0 -1
  493. package/lib/components/index.d.ts +0 -16
  494. package/lib/components/index.d.ts.map +0 -1
  495. package/lib/components/index.test.d.ts +0 -2
  496. package/lib/components/index.test.d.ts.map +0 -1
  497. package/lib/components/index.test.js +0 -8
  498. package/lib/components/input.d.ts +0 -3
  499. package/lib/components/input.d.ts.map +0 -1
  500. package/lib/components/input.props.json +0 -657
  501. package/lib/components/input.stories.d.ts +0 -6
  502. package/lib/components/input.stories.d.ts.map +0 -1
  503. package/lib/components/input.stories.js +0 -9
  504. package/lib/components/input.ws.d.ts +0 -5
  505. package/lib/components/input.ws.d.ts.map +0 -1
  506. package/lib/components/italic.d.ts +0 -3
  507. package/lib/components/italic.d.ts.map +0 -1
  508. package/lib/components/italic.props.json +0 -491
  509. package/lib/components/italic.stories.d.ts +0 -6
  510. package/lib/components/italic.stories.d.ts.map +0 -1
  511. package/lib/components/italic.stories.js +0 -11
  512. package/lib/components/italic.ws.d.ts +0 -5
  513. package/lib/components/italic.ws.d.ts.map +0 -1
  514. package/lib/components/link.d.ts +0 -8
  515. package/lib/components/link.d.ts.map +0 -1
  516. package/lib/components/link.props.json +0 -547
  517. package/lib/components/link.stories.d.ts +0 -10
  518. package/lib/components/link.stories.d.ts.map +0 -1
  519. package/lib/components/link.stories.js +0 -11
  520. package/lib/components/link.ws.d.ts +0 -5
  521. package/lib/components/link.ws.d.ts.map +0 -1
  522. package/lib/components/meta.d.ts +0 -7479
  523. package/lib/components/meta.d.ts.map +0 -1
  524. package/lib/components/meta.js +0 -34
  525. package/lib/components/paragraph.d.ts +0 -3
  526. package/lib/components/paragraph.d.ts.map +0 -1
  527. package/lib/components/paragraph.props.json +0 -491
  528. package/lib/components/paragraph.stories.d.ts +0 -6
  529. package/lib/components/paragraph.stories.d.ts.map +0 -1
  530. package/lib/components/paragraph.stories.js +0 -11
  531. package/lib/components/paragraph.ws.d.ts +0 -5
  532. package/lib/components/paragraph.ws.d.ts.map +0 -1
  533. package/lib/components/span.d.ts +0 -3
  534. package/lib/components/span.d.ts.map +0 -1
  535. package/lib/components/span.props.json +0 -491
  536. package/lib/components/span.stories.d.ts +0 -6
  537. package/lib/components/span.stories.d.ts.map +0 -1
  538. package/lib/components/span.stories.js +0 -11
  539. package/lib/components/span.ws.d.ts +0 -5
  540. package/lib/components/span.ws.d.ts.map +0 -1
  541. package/lib/components/subscript.d.ts +0 -3
  542. package/lib/components/subscript.d.ts.map +0 -1
  543. package/lib/components/subscript.props.json +0 -491
  544. package/lib/components/subscript.stories.d.ts +0 -6
  545. package/lib/components/subscript.stories.d.ts.map +0 -1
  546. package/lib/components/subscript.stories.js +0 -11
  547. package/lib/components/subscript.ws.d.ts +0 -5
  548. package/lib/components/subscript.ws.d.ts.map +0 -1
  549. package/lib/components/superscript.d.ts +0 -3
  550. package/lib/components/superscript.d.ts.map +0 -1
  551. package/lib/components/superscript.props.json +0 -491
  552. package/lib/components/superscript.stories.d.ts +0 -6
  553. package/lib/components/superscript.stories.d.ts.map +0 -1
  554. package/lib/components/superscript.stories.js +0 -11
  555. package/lib/components/superscript.ws.d.ts +0 -5
  556. package/lib/components/superscript.ws.d.ts.map +0 -1
  557. package/lib/components/text-block.d.ts +0 -3
  558. package/lib/components/text-block.d.ts.map +0 -1
  559. package/lib/components/text-block.props.json +0 -491
  560. package/lib/components/text-block.stories.d.ts +0 -6
  561. package/lib/components/text-block.stories.d.ts.map +0 -1
  562. package/lib/components/text-block.stories.js +0 -11
  563. package/lib/components/text-block.ws.d.ts +0 -5
  564. package/lib/components/text-block.ws.d.ts.map +0 -1
  565. package/lib/css/breakpoints.d.ts +0 -4
  566. package/lib/css/breakpoints.d.ts.map +0 -1
  567. package/lib/css/categories.d.ts +0 -408
  568. package/lib/css/categories.d.ts.map +0 -1
  569. package/lib/css/get-browser-style.d.ts +0 -3
  570. package/lib/css/get-browser-style.d.ts.map +0 -1
  571. package/lib/css/index.d.ts +0 -4
  572. package/lib/css/index.d.ts.map +0 -1
  573. package/lib/db/index.d.ts +0 -3
  574. package/lib/db/index.d.ts.map +0 -1
  575. package/lib/db/instance.d.ts +0 -14
  576. package/lib/db/instance.d.ts.map +0 -1
  577. package/lib/db/types.d.ts +0 -17
  578. package/lib/db/types.d.ts.map +0 -1
  579. package/lib/index.d.ts +0 -9
  580. package/lib/index.d.ts.map +0 -1
  581. package/lib/pubsub/create.d.ts +0 -29
  582. package/lib/pubsub/create.d.ts.map +0 -1
  583. package/lib/pubsub/index.d.ts +0 -2
  584. package/lib/pubsub/index.d.ts.map +0 -1
  585. package/lib/remix/handle-request.server.d.ts +0 -3
  586. package/lib/remix/handle-request.server.d.ts.map +0 -1
  587. package/lib/remix/handle-request.server.js +0 -11
  588. package/lib/remix/index.d.ts +0 -3
  589. package/lib/remix/index.d.ts.map +0 -1
  590. package/lib/remix/root.d.ts +0 -8
  591. package/lib/remix/root.d.ts.map +0 -1
  592. package/lib/remix/root.js +0 -9
  593. package/lib/tree/create-elements-tree.d.ts +0 -19
  594. package/lib/tree/create-elements-tree.d.ts.map +0 -1
  595. package/lib/tree/index.d.ts.map +0 -1
  596. package/lib/tree/root.d.ts +0 -18
  597. package/lib/tree/root.d.ts.map +0 -1
  598. package/lib/tree/session-storage-polyfill.d.ts +0 -2
  599. package/lib/tree/session-storage-polyfill.d.ts.map +0 -1
  600. package/lib/tree/wrapper-component.d.ts +0 -12
  601. package/lib/tree/wrapper-component.d.ts.map +0 -1
  602. package/lib/tsconfig.tsbuildinfo +0 -1
  603. package/lib/user-props/all-user-props.d.ts +0 -8
  604. package/lib/user-props/all-user-props.d.ts.map +0 -1
  605. package/lib/user-props/index.d.ts +0 -5
  606. package/lib/user-props/index.d.ts.map +0 -1
  607. package/lib/user-props/schema.d.ts +0 -72
  608. package/lib/user-props/schema.d.ts.map +0 -1
  609. package/lib/user-props/types.d.ts +0 -13
  610. package/lib/user-props/types.d.ts.map +0 -1
  611. package/lib/user-props/use-user-props.d.ts +0 -12
  612. package/lib/user-props/use-user-props.d.ts.map +0 -1
@@ -0,0 +1,21 @@
1
+ import { useMemo } from "react";
2
+ import { useAllUserProps } from "./all-user-props";
3
+ const useUserPropsAsset = (instanceId, propName) => {
4
+ const [allUserProps] = useAllUserProps();
5
+ const propsData = allUserProps[instanceId];
6
+ const asset = useMemo(() => {
7
+ if (propsData == null)
8
+ return void 0;
9
+ const prop = propsData.props.find((prop2) => prop2.prop === propName);
10
+ if (prop == null)
11
+ return void 0;
12
+ if (prop.type === "asset") {
13
+ return prop.value;
14
+ }
15
+ return void 0;
16
+ }, [propName, propsData]);
17
+ return asset;
18
+ };
19
+ export {
20
+ useUserPropsAsset
21
+ };
@@ -1,29 +1,21 @@
1
- import { useEffect, useMemo, useState } from "react";
1
+ import { useMemo } from "react";
2
2
  import { useAllUserProps } from "./all-user-props";
3
- /**
4
- * User props mapped in prop:value format,
5
- * up to date with props panel.
6
- */
7
- export const useUserProps = (instanceId) => {
8
- const [allUserProps] = useAllUserProps();
9
- const propsData = allUserProps[instanceId];
10
- const initialUserProps = useMemo(() => {
11
- if (propsData === undefined)
12
- return {};
13
- return propsData.props.reduce((props, { prop, value }) => {
14
- props[prop] = value;
15
- return props;
16
- }, {});
17
- }, [propsData]);
18
- const [props, setProps] = useState(initialUserProps);
19
- useEffect(() => {
20
- if (propsData == undefined)
21
- return;
22
- const nextProps = {};
23
- for (const prop of propsData.props) {
24
- nextProps[prop.prop] = prop.value;
25
- }
26
- setProps(nextProps);
27
- }, [propsData]);
28
- return props;
3
+ const useUserProps = (instanceId) => {
4
+ const [allUserProps] = useAllUserProps();
5
+ const propsData = allUserProps[instanceId];
6
+ const props = useMemo(() => {
7
+ if (propsData == null)
8
+ return {};
9
+ const result = {};
10
+ for (const userProp of propsData.props) {
11
+ if (userProp.type !== "asset") {
12
+ result[userProp.prop] = userProp.value;
13
+ }
14
+ }
15
+ return result;
16
+ }, [propsData]);
17
+ return props;
18
+ };
19
+ export {
20
+ useUserProps
29
21
  };
package/package.json CHANGED
@@ -1,21 +1,19 @@
1
1
  {
2
2
  "name": "@webstudio-is/react-sdk",
3
- "version": "0.8.0",
3
+ "version": "0.10.0",
4
4
  "description": "Webstudio JavaScript / TypeScript API",
5
5
  "author": "Webstudio <github@webstudio.is>",
6
6
  "homepage": "https://webstudio.is",
7
7
  "type": "module",
8
8
  "scripts": {
9
- "dev": "tsup --watch",
10
- "build": "yarn build:lib",
11
- "build:args": "tsx ./bin/generate-arg-types.ts './src/components/*.tsx !./src/**/*.stories.tsx !./src/**/*.ws.tsx'",
9
+ "dev": "build-package --watch",
10
+ "build": "build-package",
11
+ "build:args": "generate-arg-types './src/components/*.tsx !./src/**/*.stories.tsx !./src/**/*.ws.tsx' && prettier --write \"**/*.props.json\"",
12
12
  "typecheck": "tsc --noEmit",
13
- "build:cjs": "tsc --module commonjs --outDir lib/cjs && find lib/cjs -name '*.js' | while read NAME; do mv $NAME ${NAME%.js}.cjs; done",
14
- "build:lib": "rm -fr lib tsconfig.tsbuildinfo && tsc && yarn build:cjs",
15
13
  "test": "NODE_OPTIONS=--experimental-vm-modules jest",
16
14
  "lint": "eslint ./src --ext .ts,.tsx --max-warnings 0",
17
15
  "checks": "yarn typecheck && yarn lint && yarn test",
18
- "prepublishOnly": "yarn checks && yarn build:lib",
16
+ "prepublishOnly": "yarn checks && yarn build",
19
17
  "storybook:run": "start-storybook -p 6006",
20
18
  "storybook:build": "build-storybook",
21
19
  "publish-to-npm": "bash ../../bin/publish-to-npm.sh"
@@ -33,18 +31,17 @@
33
31
  "@storybook/manager-webpack4": "^6.5.6",
34
32
  "@storybook/react": "^6.5.6",
35
33
  "@storybook/testing-library": "^0.0.11",
36
- "@types/fs-extra": "^9.0.13",
37
34
  "@types/node": "^17.0.21",
35
+ "@webstudio-is/generate-arg-types": "*",
38
36
  "@webstudio-is/jest-config": "*",
39
- "@webstudio-is/prisma-client": "*",
37
+ "@webstudio-is/scripts": "*",
38
+ "@webstudio-is/design-tokens": "*",
40
39
  "babel-loader": "^8.2.5",
41
40
  "esbuild": "^0.14.25",
42
41
  "esbuild-node-externals": "^1.4.1",
43
42
  "react": "^17.0.2",
44
- "react-docgen-typescript": "^2.2.2",
45
43
  "react-dom": "^17.0.2",
46
44
  "remix-utils": "^4.1.0",
47
- "tsup": "^6.1.3",
48
45
  "tsx": "^3.9.0",
49
46
  "typescript": "4.7.4",
50
47
  "zod": "^3.19.1"
@@ -59,12 +56,12 @@
59
56
  "zod": "^3.19.1"
60
57
  },
61
58
  "dependencies": {
62
- "detect-font": "^0.1.5",
63
59
  "@webstudio-is/asset-uploader": "^*",
64
60
  "@webstudio-is/css-data": "*",
65
- "@webstudio-is/fonts": "*",
66
61
  "@webstudio-is/icons": "*",
67
- "@webstudio-is/jest-config": "*",
62
+ "@webstudio-is/image": "*",
63
+ "@webstudio-is/prisma-client": "*",
64
+ "detect-font": "^0.1.5",
68
65
  "immer": "^9.0.12",
69
66
  "mitt": "^3.0.0",
70
67
  "react-nano-state": "^0.4.0",
@@ -74,20 +71,13 @@
74
71
  "import": "./lib/index.js",
75
72
  "require": "./lib/cjs/index.cjs"
76
73
  },
77
- "types": "lib/index.d.ts",
74
+ "types": "src/index.ts",
78
75
  "files": [
79
76
  "lib/*",
80
- "README.md",
77
+ "src/*",
81
78
  "!*.test.*"
82
79
  ],
83
80
  "license": "MIT",
84
81
  "private": false,
85
- "sideEffects": false,
86
- "tsup": {
87
- "entry": [
88
- "src/index.ts"
89
- ],
90
- "format": "esm",
91
- "outDir": "lib"
92
- }
82
+ "sideEffects": false
93
83
  }
@@ -0,0 +1,62 @@
1
+ import {
2
+ forwardRef,
3
+ useMemo,
4
+ type ComponentProps,
5
+ type ElementRef,
6
+ } from "react";
7
+ import { Image as WebstudioImage, loaders } from "@webstudio-is/image";
8
+ import { Image as SdkImage } from "../../components/image";
9
+ import { useUserPropsAsset } from "../../user-props/use-user-props-asset";
10
+ import { idAttribute } from "../../tree/wrapper-component";
11
+ import { getParams } from "../params";
12
+
13
+ const defaultTag = "img";
14
+
15
+ type Props = ComponentProps<typeof WebstudioImage> & { [idAttribute]: string };
16
+
17
+ export const Image = forwardRef<ElementRef<typeof defaultTag>, Props>(
18
+ (props, ref) => {
19
+ const componentId = props[idAttribute] as string;
20
+
21
+ const asset = useUserPropsAsset(componentId, "src");
22
+ const params = getParams();
23
+
24
+ const loader = useMemo(() => {
25
+ if (asset == null) return null;
26
+ if (asset.location === "REMOTE")
27
+ return loaders.cloudflareImageLoader(params);
28
+ return loaders.localImageLoader();
29
+ }, [asset, params]);
30
+
31
+ let src = props.src;
32
+
33
+ if (asset != null) {
34
+ src = asset.path;
35
+ }
36
+
37
+ if (asset == null || loader == null) {
38
+ return <SdkImage key={src} {...props} src={src} ref={ref} />;
39
+ }
40
+
41
+ return (
42
+ <WebstudioImage
43
+ /**
44
+ * `key` is needed to recreate the image in case of asset change in designer,
45
+ * this gives immediate feedback when an asset is changed.
46
+ * Also, it visually fixes image distortion when another asset has a seriously different aspectRatio
47
+ * (we change aspectRatio CSS prop on asset change)
48
+ *
49
+ * In non-designer mode, key on images are usually also a good idea,
50
+ * prevents showing outdated images on route change.
51
+ **/
52
+ key={src}
53
+ {...props}
54
+ loader={loader}
55
+ src={src}
56
+ ref={ref}
57
+ />
58
+ );
59
+ }
60
+ );
61
+
62
+ Image.displayName = "Image";
@@ -0,0 +1,17 @@
1
+ import { Image } from "./image";
2
+ import { Link } from "./link";
3
+ import { RichTextLink } from "./rich-text-link";
4
+ import { imageProps } from "@webstudio-is/image";
5
+ import type { MetaProps } from "../../components/component-type";
6
+
7
+ export const customComponents = {
8
+ Image,
9
+ Link,
10
+ RichTextLink,
11
+ };
12
+
13
+ export const customComponentsMeta = {
14
+ Image: {
15
+ props: imageProps as MetaProps,
16
+ },
17
+ };
@@ -0,0 +1,4 @@
1
+ import { Link as BaseLink } from "../../components/link";
2
+ import { wrapLinkComponent } from "./shared/remix-link";
3
+
4
+ export const Link = wrapLinkComponent(BaseLink);
@@ -0,0 +1,4 @@
1
+ import { RichTextLink as BaseLink } from "../../components/rich-text-link";
2
+ import { wrapLinkComponent } from "./shared/remix-link";
3
+
4
+ export const RichTextLink = wrapLinkComponent(BaseLink);
@@ -0,0 +1,40 @@
1
+ import { Link } from "@remix-run/react";
2
+ import type {
3
+ ElementRef,
4
+ ComponentProps,
5
+ RefAttributes,
6
+ ForwardRefExoticComponent,
7
+ } from "react";
8
+ import { forwardRef } from "react";
9
+
10
+ const isAbsoluteUrl = (href: string) => {
11
+ try {
12
+ new URL(href);
13
+ return true;
14
+ } catch (e) {
15
+ return false;
16
+ }
17
+ };
18
+
19
+ type Props = Omit<ComponentProps<"a">, "href"> & { href?: string };
20
+
21
+ type Ref = ElementRef<"a">;
22
+
23
+ export const wrapLinkComponent = (
24
+ BaseLink: ForwardRefExoticComponent<Props & RefAttributes<Ref>>
25
+ ) => {
26
+ // We're not actually wrapping BaseLink (no way to wrap with Remix's Link),
27
+ // but this is still useful because we're making sure that props/ref types are compatible
28
+ const Component = forwardRef<Ref, Props>(({ href = "", ...props }, ref) =>
29
+ isAbsoluteUrl(href) ? (
30
+ <a {...props} href={href} ref={ref} />
31
+ ) : (
32
+ <Link {...props} to={href} ref={ref} />
33
+ )
34
+ );
35
+
36
+ // This is the only part that we use from BaseLink at runtime
37
+ Component.displayName = BaseLink.displayName;
38
+
39
+ return Component;
40
+ };
@@ -0,0 +1,21 @@
1
+ import { renderToString } from "react-dom/server";
2
+ import { RemixServer } from "@remix-run/react";
3
+ import type { EntryContext } from "@remix-run/node";
4
+
5
+ export const handleRequest = (
6
+ request: Request,
7
+ responseStatusCode: number,
8
+ responseHeaders: Headers,
9
+ remixContext: EntryContext
10
+ ) => {
11
+ const markup = renderToString(
12
+ <RemixServer context={remixContext} url={request.url} />
13
+ );
14
+
15
+ responseHeaders.set("Content-Type", "text/html");
16
+
17
+ return new Response(`<!DOCTYPE html>${markup}`, {
18
+ status: responseStatusCode,
19
+ headers: responseHeaders,
20
+ });
21
+ };
@@ -1,3 +1,3 @@
1
1
  export * from "./root";
2
2
  export * from "./handle-request.server";
3
- //# sourceMappingURL=index.d.ts.map
3
+ export * from "./params";
@@ -0,0 +1,13 @@
1
+ export type Params = {
2
+ resizeOrigin?: string;
3
+ };
4
+
5
+ let params: Params | null = {};
6
+
7
+ const emptyParams: Params = {};
8
+
9
+ export const getParams = (): Params => params ?? emptyParams;
10
+
11
+ export const setParams = (newParams: Params | null) => {
12
+ params = newParams;
13
+ };
@@ -0,0 +1,27 @@
1
+ import { Links, Meta, Outlet as DefaultOutlet } from "@remix-run/react";
2
+ import { DynamicLinks } from "remix-utils";
3
+
4
+ /**
5
+ * We are using Outlet prop from index layout when user renders site from a subdomain.
6
+ */
7
+ export const Root = ({
8
+ Outlet = DefaultOutlet,
9
+ }: {
10
+ Outlet: typeof DefaultOutlet;
11
+ }) => {
12
+ return (
13
+ <html lang="en">
14
+ <head>
15
+ <meta charSet="utf-8" />
16
+ <meta name="viewport" content="width=device-width,initial-scale=1" />
17
+ <link rel="icon" href="/favicon.ico" type="image/x-icon" />
18
+ <link rel="shortcut icon" href="/favicon.ico" type="image/x-icon" />
19
+ <Meta />
20
+ <DynamicLinks />
21
+ <Links />
22
+ </head>
23
+
24
+ <Outlet />
25
+ </html>
26
+ );
27
+ };