@webstudio-is/react-sdk 0.50.0 → 0.52.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 (364) hide show
  1. package/lib/app/custom-components/image.js +2 -4
  2. package/lib/app/custom-components/shared/remix-link.js +7 -23
  3. package/lib/cjs/app/custom-components/{image.cjs → image.js} +1 -3
  4. package/lib/cjs/app/custom-components/shared/{remix-link.cjs → remix-link.js} +6 -22
  5. package/lib/cjs/components/__generated__/{link.props.cjs → link.props.js} +6 -6
  6. package/lib/cjs/components/{blockquote.cjs → blockquote.js} +2 -1
  7. package/lib/cjs/components/{blockquote.ws.cjs → blockquote.ws.js} +57 -35
  8. package/lib/cjs/components/{body.cjs → body.js} +2 -1
  9. package/lib/cjs/components/{body.ws.cjs → body.ws.js} +30 -46
  10. package/lib/cjs/components/{bold.cjs → bold.js} +2 -1
  11. package/lib/cjs/components/{bold.ws.cjs → bold.ws.js} +6 -1
  12. package/lib/cjs/components/{box.ws.cjs → box.ws.js} +11 -4
  13. package/lib/cjs/components/{button.cjs → button.js} +2 -1
  14. package/lib/cjs/components/{button.ws.cjs → button.ws.js} +6 -1
  15. package/lib/cjs/components/{code.cjs → code.js} +1 -0
  16. package/lib/cjs/components/{code.ws.cjs → code.ws.js} +31 -25
  17. package/lib/cjs/components/{form.cjs → form.js} +2 -1
  18. package/lib/cjs/components/{form.ws.cjs → form.ws.js} +8 -8
  19. package/lib/cjs/components/{heading.ws.cjs → heading.ws.js} +11 -1
  20. package/lib/cjs/components/{image.cjs → image.js} +2 -1
  21. package/lib/cjs/components/{image.ws.cjs → image.ws.js} +15 -11
  22. package/lib/cjs/components/{input.cjs → input.js} +2 -1
  23. package/lib/cjs/components/{input.ws.cjs → input.ws.js} +6 -1
  24. package/lib/cjs/components/{italic.cjs → italic.js} +2 -1
  25. package/lib/cjs/components/{italic.ws.cjs → italic.ws.js} +8 -4
  26. package/lib/cjs/components/{link-block.cjs → link-block.js} +3 -1
  27. package/lib/cjs/components/{link-block.ws.cjs → link-block.ws.js} +13 -9
  28. package/lib/cjs/components/{link.cjs → link.js} +15 -6
  29. package/lib/cjs/components/{link.ws.cjs → link.ws.js} +21 -10
  30. package/lib/cjs/components/{list-item.cjs → list-item.js} +2 -1
  31. package/lib/cjs/components/{list-item.ws.cjs → list-item.ws.js} +6 -1
  32. package/lib/cjs/components/{list.ws.cjs → list.ws.js} +29 -10
  33. package/lib/cjs/components/{paragraph.cjs → paragraph.js} +2 -1
  34. package/lib/cjs/components/{paragraph.ws.cjs → paragraph.ws.js} +6 -1
  35. package/lib/cjs/components/{rich-text-link.ws.cjs → rich-text-link.ws.js} +5 -2
  36. package/lib/cjs/components/{separator.cjs → separator.js} +2 -1
  37. package/lib/cjs/components/{separator.ws.cjs → separator.ws.js} +27 -11
  38. package/lib/cjs/components/{span.cjs → span.js} +2 -1
  39. package/lib/cjs/components/{span.ws.cjs → span.ws.js} +6 -1
  40. package/lib/cjs/components/{subscript.cjs → subscript.js} +2 -1
  41. package/lib/cjs/components/{subscript.ws.cjs → subscript.ws.js} +6 -1
  42. package/lib/cjs/components/{superscript.cjs → superscript.js} +2 -1
  43. package/lib/cjs/components/{superscript.ws.cjs → superscript.ws.js} +6 -1
  44. package/lib/cjs/components/{text-block.cjs → text-block.js} +2 -1
  45. package/lib/cjs/components/{text-block.ws.cjs → text-block.ws.js} +9 -5
  46. package/lib/cjs/{context.cjs → context.js} +2 -1
  47. package/lib/cjs/css/css.js +64 -0
  48. package/lib/cjs/css/global-rules.js +37 -0
  49. package/lib/cjs/css/{index.cjs → index.js} +3 -1
  50. package/lib/cjs/css/normalize-type-check.js +26 -0
  51. package/lib/cjs/css/normalize.js +358 -0
  52. package/lib/cjs/css/presets.js +61 -0
  53. package/lib/cjs/css/style-rules.js +62 -0
  54. package/lib/cjs/package.json +1 -0
  55. package/lib/cjs/{props.cjs → props.js} +43 -2
  56. package/lib/cjs/pubsub/{create.cjs → create.js} +6 -35
  57. package/lib/cjs/pubsub/raf-queue.js +45 -0
  58. package/lib/cjs/tree/{create-elements-tree.cjs → create-elements-tree.js} +8 -1
  59. package/lib/cjs/tree/{root.cjs → root.js} +1 -0
  60. package/lib/cjs/tree/{webstudio-component.cjs → webstudio-component.js} +1 -0
  61. package/lib/components/__generated__/link-block.props.js +5 -5
  62. package/lib/components/__generated__/link.props.js +6 -6
  63. package/lib/components/__generated__/rich-text-link.props.js +5 -5
  64. package/lib/components/blockquote.js +2 -1
  65. package/lib/components/blockquote.ws.js +57 -35
  66. package/lib/components/body.js +2 -1
  67. package/lib/components/body.ws.js +30 -46
  68. package/lib/components/bold.js +2 -1
  69. package/lib/components/bold.ws.js +7 -2
  70. package/lib/components/box.ws.js +22 -4
  71. package/lib/components/button.js +2 -1
  72. package/lib/components/button.ws.js +7 -2
  73. package/lib/components/code.js +1 -0
  74. package/lib/components/code.ws.js +31 -25
  75. package/lib/components/form.js +2 -1
  76. package/lib/components/form.ws.js +8 -8
  77. package/lib/components/heading.ws.js +11 -1
  78. package/lib/components/image.js +2 -1
  79. package/lib/components/image.ws.js +15 -11
  80. package/lib/components/input.js +2 -1
  81. package/lib/components/input.ws.js +7 -2
  82. package/lib/components/italic.js +2 -1
  83. package/lib/components/italic.ws.js +9 -5
  84. package/lib/components/link-block.js +3 -1
  85. package/lib/components/link-block.ws.js +13 -9
  86. package/lib/components/link.js +15 -6
  87. package/lib/components/link.ws.js +22 -11
  88. package/lib/components/list-item.js +2 -1
  89. package/lib/components/list-item.ws.js +6 -1
  90. package/lib/components/list.ws.js +29 -10
  91. package/lib/components/paragraph.js +2 -1
  92. package/lib/components/paragraph.ws.js +6 -1
  93. package/lib/components/rich-text-link.ws.js +6 -3
  94. package/lib/components/separator.js +2 -1
  95. package/lib/components/separator.ws.js +27 -11
  96. package/lib/components/span.js +2 -1
  97. package/lib/components/span.ws.js +7 -2
  98. package/lib/components/subscript.js +2 -1
  99. package/lib/components/subscript.ws.js +6 -1
  100. package/lib/components/superscript.js +2 -1
  101. package/lib/components/superscript.ws.js +6 -1
  102. package/lib/components/text-block.js +2 -1
  103. package/lib/components/text-block.ws.js +10 -6
  104. package/lib/context.js +2 -1
  105. package/lib/css/css.js +44 -0
  106. package/lib/css/get-browser-style.js +3 -1
  107. package/lib/css/global-rules.js +20 -0
  108. package/lib/css/index.js +3 -1
  109. package/lib/css/normalize-type-check.js +3 -0
  110. package/lib/css/normalize.js +338 -0
  111. package/lib/css/presets.js +41 -0
  112. package/lib/css/style-rules.js +42 -0
  113. package/lib/props.js +43 -2
  114. package/lib/pubsub/create.js +6 -25
  115. package/lib/pubsub/raf-queue.js +25 -0
  116. package/lib/tree/create-elements-tree.js +8 -1
  117. package/lib/tree/root.js +1 -0
  118. package/lib/tree/webstudio-component.js +1 -0
  119. package/lib/types/app/custom-components/image.d.ts +6 -0
  120. package/lib/types/app/custom-components/index.d.ts +26 -0
  121. package/lib/types/app/custom-components/link-block.d.ts +6 -0
  122. package/lib/types/app/custom-components/link.d.ts +6 -0
  123. package/lib/types/app/custom-components/rich-text-link.d.ts +6 -0
  124. package/lib/types/app/custom-components/shared/remix-link.d.ts +10 -0
  125. package/lib/types/app/handle-request.server.d.ts +2 -0
  126. package/lib/types/app/index.d.ts +3 -0
  127. package/lib/types/app/params.d.ts +5 -0
  128. package/lib/types/app/root.d.ts +8 -0
  129. package/lib/types/components/__generated__/blockquote.props.d.ts +2 -0
  130. package/lib/types/components/__generated__/body.props.d.ts +2 -0
  131. package/lib/types/components/__generated__/bold.props.d.ts +2 -0
  132. package/lib/types/components/__generated__/box.props.d.ts +2 -0
  133. package/lib/types/components/__generated__/button.props.d.ts +2 -0
  134. package/lib/types/components/__generated__/code.props.d.ts +2 -0
  135. package/lib/types/components/__generated__/form.props.d.ts +2 -0
  136. package/lib/types/components/__generated__/fragment.props.d.ts +2 -0
  137. package/lib/types/components/__generated__/heading.props.d.ts +2 -0
  138. package/lib/types/components/__generated__/image.props.d.ts +2 -0
  139. package/lib/types/components/__generated__/input.props.d.ts +2 -0
  140. package/lib/types/components/__generated__/italic.props.d.ts +2 -0
  141. package/lib/types/components/__generated__/link-block.props.d.ts +2 -0
  142. package/lib/types/components/__generated__/link.props.d.ts +2 -0
  143. package/lib/types/components/__generated__/list-item.props.d.ts +2 -0
  144. package/lib/types/components/__generated__/list.props.d.ts +2 -0
  145. package/lib/types/components/__generated__/paragraph.props.d.ts +2 -0
  146. package/lib/types/components/__generated__/rich-text-link.props.d.ts +2 -0
  147. package/lib/types/components/__generated__/separator.props.d.ts +2 -0
  148. package/lib/types/components/__generated__/slot.props.d.ts +2 -0
  149. package/lib/types/components/__generated__/span.props.d.ts +2 -0
  150. package/lib/types/components/__generated__/subscript.props.d.ts +2 -0
  151. package/lib/types/components/__generated__/superscript.props.d.ts +2 -0
  152. package/lib/types/components/__generated__/text-block.props.d.ts +2 -0
  153. package/lib/types/components/blockquote.d.ts +3 -0
  154. package/lib/types/components/blockquote.stories.d.ts +5 -0
  155. package/lib/types/components/blockquote.ws.d.ts +3 -0
  156. package/lib/types/components/body.d.ts +3 -0
  157. package/lib/types/components/body.stories.d.ts +6 -0
  158. package/lib/types/components/body.ws.d.ts +3 -0
  159. package/lib/types/components/bold.d.ts +3 -0
  160. package/lib/types/components/bold.stories.d.ts +5 -0
  161. package/lib/types/components/bold.ws.d.ts +3 -0
  162. package/lib/types/components/box.d.ts +7 -0
  163. package/lib/types/components/box.stories.d.ts +9 -0
  164. package/lib/types/components/box.ws.d.ts +3 -0
  165. package/lib/types/components/button.d.ts +7 -0
  166. package/lib/types/components/button.stories.d.ts +9 -0
  167. package/lib/types/components/button.ws.d.ts +3 -0
  168. package/lib/types/components/code.d.ts +9 -0
  169. package/lib/types/components/code.stories.d.ts +11 -0
  170. package/lib/types/components/code.ws.d.ts +3 -0
  171. package/lib/types/components/component-meta.d.ts +605 -0
  172. package/lib/types/components/components-utils.d.ts +34 -0
  173. package/lib/types/components/components.d.ts +31 -0
  174. package/lib/types/components/form.d.ts +3 -0
  175. package/lib/types/components/form.stories.d.ts +5 -0
  176. package/lib/types/components/form.ws.d.ts +3 -0
  177. package/lib/types/components/fragment.d.ts +6 -0
  178. package/lib/types/components/fragment.ws.d.ts +3 -0
  179. package/lib/types/components/heading.d.ts +7 -0
  180. package/lib/types/components/heading.stories.d.ts +9 -0
  181. package/lib/types/components/heading.ws.d.ts +3 -0
  182. package/lib/types/components/image.d.ts +3 -0
  183. package/lib/types/components/image.stories.d.ts +5 -0
  184. package/lib/types/components/image.ws.d.ts +3 -0
  185. package/lib/types/components/index.d.ts +17 -0
  186. package/lib/types/components/input.d.ts +3 -0
  187. package/lib/types/components/input.stories.d.ts +5 -0
  188. package/lib/types/components/input.ws.d.ts +3 -0
  189. package/lib/types/components/italic.d.ts +3 -0
  190. package/lib/types/components/italic.stories.d.ts +5 -0
  191. package/lib/types/components/italic.ws.d.ts +3 -0
  192. package/lib/types/components/link-block.d.ts +3 -0
  193. package/lib/types/components/link-block.stories.d.ts +13 -0
  194. package/lib/types/components/link-block.ws.d.ts +3 -0
  195. package/lib/types/components/link.d.ts +9 -0
  196. package/lib/types/components/link.stories.d.ts +13 -0
  197. package/lib/types/components/link.ws.d.ts +3 -0
  198. package/lib/types/components/list-item.d.ts +3 -0
  199. package/lib/types/components/list-item.stories.d.ts +5 -0
  200. package/lib/types/components/list-item.ws.d.ts +3 -0
  201. package/lib/types/components/list.d.ts +9 -0
  202. package/lib/types/components/list.stories.d.ts +9 -0
  203. package/lib/types/components/list.ws.d.ts +3 -0
  204. package/lib/types/components/paragraph.d.ts +3 -0
  205. package/lib/types/components/paragraph.stories.d.ts +5 -0
  206. package/lib/types/components/paragraph.ws.d.ts +3 -0
  207. package/lib/types/components/rich-text-link.d.ts +2 -0
  208. package/lib/types/components/rich-text-link.stories.d.ts +13 -0
  209. package/lib/types/components/rich-text-link.ws.d.ts +3 -0
  210. package/lib/types/components/separator.d.ts +3 -0
  211. package/lib/types/components/separator.stories.d.ts +5 -0
  212. package/lib/types/components/separator.ws.d.ts +3 -0
  213. package/lib/types/components/slot.d.ts +6 -0
  214. package/lib/types/components/slot.stories.d.ts +9 -0
  215. package/lib/types/components/slot.ws.d.ts +3 -0
  216. package/lib/types/components/span.d.ts +3 -0
  217. package/lib/types/components/span.stories.d.ts +5 -0
  218. package/lib/types/components/span.ws.d.ts +3 -0
  219. package/lib/types/components/subscript.d.ts +3 -0
  220. package/lib/types/components/subscript.stories.d.ts +5 -0
  221. package/lib/types/components/subscript.ws.d.ts +3 -0
  222. package/lib/types/components/superscript.d.ts +3 -0
  223. package/lib/types/components/superscript.stories.d.ts +5 -0
  224. package/lib/types/components/superscript.ws.d.ts +3 -0
  225. package/lib/types/components/text-block.d.ts +3 -0
  226. package/lib/types/components/text-block.stories.d.ts +5 -0
  227. package/lib/types/components/text-block.ws.d.ts +3 -0
  228. package/lib/types/context.d.ts +9 -0
  229. package/lib/types/css/css.d.ts +10 -0
  230. package/lib/types/css/get-browser-style.d.ts +2 -0
  231. package/lib/types/css/global-rules.d.ts +44 -0
  232. package/lib/types/css/index.d.ts +4 -0
  233. package/lib/types/css/normalize-type-check.d.ts +1 -0
  234. package/lib/types/css/normalize.d.ts +2429 -0
  235. package/lib/types/css/presets.d.ts +38 -0
  236. package/lib/types/css/style-rules.d.ts +248 -0
  237. package/lib/types/css/style-rules.test.d.ts +1 -0
  238. package/lib/types/index.d.ts +9 -0
  239. package/lib/types/props.d.ts +97 -0
  240. package/lib/types/props.test.d.ts +1 -0
  241. package/lib/types/pubsub/create.d.ts +28 -0
  242. package/lib/types/pubsub/index.d.ts +1 -0
  243. package/lib/types/pubsub/raf-queue.d.ts +1 -0
  244. package/lib/types/tree/create-elements-tree.d.ts +16 -0
  245. package/lib/types/tree/index.d.ts +3 -0
  246. package/lib/types/tree/root.d.ts +25 -0
  247. package/lib/types/tree/session-storage-polyfill.d.ts +2 -0
  248. package/lib/types/tree/webstudio-component.d.ts +15 -0
  249. package/package.json +20 -19
  250. package/src/app/custom-components/image.tsx +4 -7
  251. package/src/app/custom-components/shared/remix-link.tsx +12 -48
  252. package/src/components/__generated__/link-block.props.ts +5 -5
  253. package/src/components/__generated__/link.props.ts +6 -6
  254. package/src/components/__generated__/rich-text-link.props.ts +5 -5
  255. package/src/components/blockquote.tsx +1 -1
  256. package/src/components/blockquote.ws.tsx +63 -36
  257. package/src/components/body.tsx +1 -1
  258. package/src/components/body.ws.tsx +39 -47
  259. package/src/components/bold.tsx +1 -1
  260. package/src/components/bold.ws.tsx +10 -2
  261. package/src/components/box.ws.ts +28 -5
  262. package/src/components/button.tsx +1 -1
  263. package/src/components/button.ws.tsx +10 -2
  264. package/src/components/code.tsx +1 -1
  265. package/src/components/code.ws.tsx +36 -28
  266. package/src/components/component-meta.ts +4 -1
  267. package/src/components/form.tsx +1 -1
  268. package/src/components/form.ws.tsx +11 -9
  269. package/src/components/heading.ws.tsx +16 -0
  270. package/src/components/image.tsx +1 -1
  271. package/src/components/image.ws.tsx +19 -12
  272. package/src/components/input.tsx +1 -1
  273. package/src/components/input.ws.tsx +10 -2
  274. package/src/components/italic.tsx +1 -1
  275. package/src/components/italic.ws.tsx +12 -6
  276. package/src/components/link-block.tsx +1 -0
  277. package/src/components/link-block.ws.tsx +16 -10
  278. package/src/components/link.tsx +14 -6
  279. package/src/components/link.ws.tsx +25 -12
  280. package/src/components/list-item.tsx +1 -1
  281. package/src/components/list-item.ws.tsx +8 -0
  282. package/src/components/list.tsx +2 -0
  283. package/src/components/list.ws.tsx +32 -11
  284. package/src/components/paragraph.tsx +1 -1
  285. package/src/components/paragraph.ws.tsx +8 -0
  286. package/src/components/rich-text-link.ws.tsx +6 -3
  287. package/src/components/separator.tsx +1 -1
  288. package/src/components/separator.ws.tsx +33 -12
  289. package/src/components/span.tsx +1 -1
  290. package/src/components/span.ws.tsx +10 -2
  291. package/src/components/subscript.tsx +1 -1
  292. package/src/components/subscript.ws.tsx +8 -0
  293. package/src/components/superscript.tsx +1 -1
  294. package/src/components/superscript.ws.tsx +8 -0
  295. package/src/components/text-block.tsx +1 -1
  296. package/src/components/text-block.ws.tsx +14 -7
  297. package/src/context.tsx +4 -1
  298. package/src/css/css.ts +57 -0
  299. package/src/css/get-browser-style.ts +6 -1
  300. package/src/css/global-rules.ts +29 -0
  301. package/src/css/index.ts +3 -1
  302. package/src/css/normalize-type-check.ts +13 -0
  303. package/src/css/normalize.ts +519 -0
  304. package/src/css/presets.ts +42 -0
  305. package/src/css/style-rules.test.ts +147 -0
  306. package/src/css/style-rules.ts +66 -0
  307. package/src/props.test.ts +95 -0
  308. package/src/props.ts +59 -5
  309. package/src/pubsub/create.ts +7 -38
  310. package/src/pubsub/raf-queue.ts +31 -0
  311. package/src/tree/create-elements-tree.tsx +7 -2
  312. package/src/tree/root.ts +2 -0
  313. package/src/tree/webstudio-component.tsx +1 -0
  314. package/lib/cjs/css/categories.cjs +0 -250
  315. package/lib/css/categories.js +0 -230
  316. package/src/css/categories.ts +0 -254
  317. package/lib/cjs/app/custom-components/{index.cjs → index.js} +0 -0
  318. package/lib/cjs/app/custom-components/{link-block.cjs → link-block.js} +0 -0
  319. package/lib/cjs/app/custom-components/{link.cjs → link.js} +0 -0
  320. package/lib/cjs/app/custom-components/{rich-text-link.cjs → rich-text-link.js} +0 -0
  321. package/lib/cjs/app/{handle-request.server.cjs → handle-request.server.js} +0 -0
  322. package/lib/cjs/app/{index.cjs → index.js} +0 -0
  323. package/lib/cjs/app/{params.cjs → params.js} +0 -0
  324. package/lib/cjs/app/{root.cjs → root.js} +0 -0
  325. package/lib/cjs/components/__generated__/{blockquote.props.cjs → blockquote.props.js} +0 -0
  326. package/lib/cjs/components/__generated__/{body.props.cjs → body.props.js} +0 -0
  327. package/lib/cjs/components/__generated__/{bold.props.cjs → bold.props.js} +0 -0
  328. package/lib/cjs/components/__generated__/{box.props.cjs → box.props.js} +0 -0
  329. package/lib/cjs/components/__generated__/{button.props.cjs → button.props.js} +0 -0
  330. package/lib/cjs/components/__generated__/{code.props.cjs → code.props.js} +0 -0
  331. package/lib/cjs/components/__generated__/{form.props.cjs → form.props.js} +0 -0
  332. package/lib/cjs/components/__generated__/{fragment.props.cjs → fragment.props.js} +0 -0
  333. package/lib/cjs/components/__generated__/{heading.props.cjs → heading.props.js} +0 -0
  334. package/lib/cjs/components/__generated__/{image.props.cjs → image.props.js} +0 -0
  335. package/lib/cjs/components/__generated__/{input.props.cjs → input.props.js} +0 -0
  336. package/lib/cjs/components/__generated__/{italic.props.cjs → italic.props.js} +0 -0
  337. package/lib/cjs/components/__generated__/{link-block.props.cjs → link-block.props.js} +5 -5
  338. package/lib/cjs/components/__generated__/{list-item.props.cjs → list-item.props.js} +0 -0
  339. package/lib/cjs/components/__generated__/{list.props.cjs → list.props.js} +0 -0
  340. package/lib/cjs/components/__generated__/{paragraph.props.cjs → paragraph.props.js} +0 -0
  341. package/lib/cjs/components/__generated__/{rich-text-link.props.cjs → rich-text-link.props.js} +5 -5
  342. /package/lib/cjs/components/__generated__/{separator.props.cjs → separator.props.js} +0 -0
  343. /package/lib/cjs/components/__generated__/{slot.props.cjs → slot.props.js} +0 -0
  344. /package/lib/cjs/components/__generated__/{span.props.cjs → span.props.js} +0 -0
  345. /package/lib/cjs/components/__generated__/{subscript.props.cjs → subscript.props.js} +0 -0
  346. /package/lib/cjs/components/__generated__/{superscript.props.cjs → superscript.props.js} +0 -0
  347. /package/lib/cjs/components/__generated__/{text-block.props.cjs → text-block.props.js} +0 -0
  348. /package/lib/cjs/components/{box.cjs → box.js} +0 -0
  349. /package/lib/cjs/components/{component-meta.cjs → component-meta.js} +0 -0
  350. /package/lib/cjs/components/{components-utils.cjs → components-utils.js} +0 -0
  351. /package/lib/cjs/components/{components.cjs → components.js} +0 -0
  352. /package/lib/cjs/components/{fragment.cjs → fragment.js} +0 -0
  353. /package/lib/cjs/components/{fragment.ws.cjs → fragment.ws.js} +0 -0
  354. /package/lib/cjs/components/{heading.cjs → heading.js} +0 -0
  355. /package/lib/cjs/components/{index.cjs → index.js} +0 -0
  356. /package/lib/cjs/components/{list.cjs → list.js} +0 -0
  357. /package/lib/cjs/components/{rich-text-link.cjs → rich-text-link.js} +0 -0
  358. /package/lib/cjs/components/{slot.cjs → slot.js} +0 -0
  359. /package/lib/cjs/components/{slot.ws.cjs → slot.ws.js} +0 -0
  360. /package/lib/cjs/css/{get-browser-style.cjs → get-browser-style.js} +0 -0
  361. /package/lib/cjs/{index.cjs → index.js} +0 -0
  362. /package/lib/cjs/pubsub/{index.cjs → index.js} +0 -0
  363. /package/lib/cjs/tree/{index.cjs → index.js} +0 -0
  364. /package/lib/cjs/tree/{session-storage-polyfill.cjs → session-storage-polyfill.js} +0 -0
@@ -1,11 +1,20 @@
1
1
  import { jsx } from "react/jsx-runtime";
2
2
  import { forwardRef } from "react";
3
- const Link = forwardRef(
4
- ({ href = "", ...props }, ref) => {
5
- return /* @__PURE__ */ jsx("a", { ...props, href, ref });
6
- }
7
- );
3
+ import { usePropUrl, getInstanceIdFromComponentProps } from "../props";
4
+ const defaultTag = "a";
5
+ const Link = forwardRef((props, ref) => {
6
+ const href = usePropUrl(getInstanceIdFromComponentProps(props), "href");
7
+ return /* @__PURE__ */ jsx(
8
+ "a",
9
+ {
10
+ ...props,
11
+ href: typeof href === "string" ? href : href?.path,
12
+ ref
13
+ }
14
+ );
15
+ });
8
16
  Link.displayName = "Link";
9
17
  export {
10
- Link
18
+ Link,
19
+ defaultTag
11
20
  };
@@ -1,26 +1,37 @@
1
- import { Link2Icon } from "@webstudio-is/icons";
1
+ import { LinkIcon } from "@webstudio-is/icons";
2
+ import { a } from "../css/normalize";
2
3
  import { props } from "./__generated__/link.props";
3
4
  const presetStyle = {
4
- minHeight: {
5
- type: "unit",
6
- unit: "em",
7
- value: 1
8
- },
9
- display: {
10
- type: "keyword",
11
- value: "inline-block"
5
+ a: {
6
+ ...a,
7
+ minHeight: {
8
+ type: "unit",
9
+ unit: "em",
10
+ value: 1
11
+ },
12
+ display: {
13
+ type: "keyword",
14
+ value: "inline-block"
15
+ }
12
16
  }
13
17
  };
14
18
  const meta = {
15
19
  category: "general",
16
20
  type: "rich-text",
17
21
  label: "Link Text",
18
- Icon: Link2Icon,
22
+ Icon: LinkIcon,
19
23
  presetStyle,
20
24
  children: ["Link text you can edit"]
21
25
  };
22
26
  const propsMeta = {
23
- props,
27
+ props: {
28
+ ...props,
29
+ href: {
30
+ type: "string",
31
+ control: "url",
32
+ required: false
33
+ }
34
+ },
24
35
  initialProps: ["href", "target", "prefetch"]
25
36
  };
26
37
  export {
@@ -10,5 +10,6 @@ const ListItem = forwardRef(
10
10
  );
11
11
  ListItem.displayName = "ListItem";
12
12
  export {
13
- ListItem
13
+ ListItem,
14
+ defaultTag
14
15
  };
@@ -1,11 +1,16 @@
1
1
  import { ListItemIcon } from "@webstudio-is/icons";
2
+ import { li } from "../css/normalize";
2
3
  import { props } from "./__generated__/list-item.props";
4
+ const presetStyle = {
5
+ li
6
+ };
3
7
  const meta = {
4
8
  category: "typography",
5
9
  type: "rich-text",
6
10
  label: "List Item",
7
11
  Icon: ListItemIcon,
8
- children: ["List Item you can edit"]
12
+ children: ["List Item you can edit"],
13
+ presetStyle
9
14
  };
10
15
  const propsMeta = {
11
16
  props
@@ -1,17 +1,36 @@
1
1
  import { ListIcon } from "@webstudio-is/icons";
2
2
  import { props } from "./__generated__/list.props";
3
+ import { ol, ul } from "../css/normalize";
3
4
  const presetStyle = {
4
- marginTop: {
5
- type: "keyword",
6
- value: "0"
5
+ ol: {
6
+ ...ol,
7
+ marginTop: {
8
+ type: "keyword",
9
+ value: "0"
10
+ },
11
+ marginBottom: {
12
+ type: "keyword",
13
+ value: "10px"
14
+ },
15
+ paddingLeft: {
16
+ type: "keyword",
17
+ value: "40px"
18
+ }
7
19
  },
8
- marginBottom: {
9
- type: "keyword",
10
- value: "10px"
11
- },
12
- paddingLeft: {
13
- type: "keyword",
14
- value: "40px"
20
+ ul: {
21
+ ...ul,
22
+ marginTop: {
23
+ type: "keyword",
24
+ value: "0"
25
+ },
26
+ marginBottom: {
27
+ type: "keyword",
28
+ value: "10px"
29
+ },
30
+ paddingLeft: {
31
+ type: "keyword",
32
+ value: "40px"
33
+ }
15
34
  }
16
35
  };
17
36
  const meta = {
@@ -4,5 +4,6 @@ const defaultTag = "p";
4
4
  const Paragraph = forwardRef((props, ref) => /* @__PURE__ */ jsx("p", { ...props, ref }));
5
5
  Paragraph.displayName = "Paragraph";
6
6
  export {
7
- Paragraph
7
+ Paragraph,
8
+ defaultTag
8
9
  };
@@ -1,11 +1,16 @@
1
1
  import { TextAlignLeftIcon } from "@webstudio-is/icons";
2
+ import { p } from "../css/normalize";
2
3
  import { props } from "./__generated__/paragraph.props";
4
+ const presetStyle = {
5
+ p
6
+ };
3
7
  const meta = {
4
8
  category: "typography",
5
9
  type: "rich-text",
6
10
  label: "Paragraph",
7
11
  Icon: TextAlignLeftIcon,
8
- children: ["Pragraph you can edit"]
12
+ children: ["Pragraph you can edit"],
13
+ presetStyle
9
14
  };
10
15
  const propsMeta = {
11
16
  props
@@ -1,5 +1,5 @@
1
1
  import { props } from "./__generated__/rich-text-link.props";
2
- import { meta as linkMeta, propsMeta as propsLinkMeta } from "./link.ws";
2
+ import { meta as linkMeta, propsMeta as linkPropsMeta } from "./link.ws";
3
3
  const { category, ...linkMetaRest } = linkMeta;
4
4
  const meta = {
5
5
  ...linkMetaRest,
@@ -7,8 +7,11 @@ const meta = {
7
7
  children: []
8
8
  };
9
9
  const propsMeta = {
10
- ...propsLinkMeta,
11
- props
10
+ initialProps: linkPropsMeta.initialProps,
11
+ props: {
12
+ ...props,
13
+ href: linkPropsMeta.props.href
14
+ }
12
15
  };
13
16
  export {
14
17
  meta,
@@ -10,5 +10,6 @@ const Separator = forwardRef(
10
10
  );
11
11
  Separator.displayName = "Separator";
12
12
  export {
13
- Separator
13
+ Separator,
14
+ defaultTag
14
15
  };
@@ -1,17 +1,33 @@
1
1
  import { DashIcon } from "@webstudio-is/icons";
2
2
  import { props } from "./__generated__/separator.props";
3
+ import { hr } from "../css/normalize";
3
4
  const presetStyle = {
4
- height: {
5
- type: "keyword",
6
- value: "1px"
7
- },
8
- backgroundColor: {
9
- type: "keyword",
10
- value: "gray"
11
- },
12
- border: {
13
- type: "keyword",
14
- value: "none"
5
+ hr: {
6
+ ...hr,
7
+ height: {
8
+ type: "keyword",
9
+ value: "1px"
10
+ },
11
+ backgroundColor: {
12
+ type: "keyword",
13
+ value: "gray"
14
+ },
15
+ borderTopStyle: {
16
+ type: "keyword",
17
+ value: "none"
18
+ },
19
+ borderRightStyle: {
20
+ type: "keyword",
21
+ value: "none"
22
+ },
23
+ borderLeftStyle: {
24
+ type: "keyword",
25
+ value: "none"
26
+ },
27
+ borderBottomStyle: {
28
+ type: "keyword",
29
+ value: "none"
30
+ }
15
31
  }
16
32
  };
17
33
  const meta = {
@@ -4,5 +4,6 @@ const defaultTag = "span";
4
4
  const Span = forwardRef((props, ref) => /* @__PURE__ */ jsx("span", { ...props, ref }));
5
5
  Span.displayName = "Span";
6
6
  export {
7
- Span
7
+ Span,
8
+ defaultTag
8
9
  };
@@ -1,9 +1,14 @@
1
- import { BrushIcon } from "@webstudio-is/icons";
1
+ import { PaintBrushIcon } from "@webstudio-is/icons";
2
+ import { span } from "../css/normalize";
2
3
  import { props } from "./__generated__/span.props";
4
+ const presetStyle = {
5
+ span
6
+ };
3
7
  const meta = {
4
8
  type: "rich-text-child",
5
9
  label: "Styled Text",
6
- Icon: BrushIcon
10
+ Icon: PaintBrushIcon,
11
+ presetStyle
7
12
  };
8
13
  const propsMeta = {
9
14
  props
@@ -4,5 +4,6 @@ const defaultTag = "sub";
4
4
  const Subscript = forwardRef((props, ref) => /* @__PURE__ */ jsx("sub", { ...props, ref }));
5
5
  Subscript.displayName = "Subscript";
6
6
  export {
7
- Subscript
7
+ Subscript,
8
+ defaultTag
8
9
  };
@@ -1,9 +1,14 @@
1
1
  import { SubscriptIcon } from "@webstudio-is/icons";
2
+ import { sub } from "../css/normalize";
2
3
  import { props } from "./__generated__/subscript.props";
4
+ const presetStyle = {
5
+ sub
6
+ };
3
7
  const meta = {
4
8
  type: "rich-text-child",
5
9
  label: "Subscript Text",
6
- Icon: SubscriptIcon
10
+ Icon: SubscriptIcon,
11
+ presetStyle
7
12
  };
8
13
  const propsMeta = {
9
14
  props
@@ -4,5 +4,6 @@ const defaultTag = "sup";
4
4
  const Superscript = forwardRef((props, ref) => /* @__PURE__ */ jsx("sup", { ...props, ref }));
5
5
  Superscript.displayName = "Bold";
6
6
  export {
7
- Superscript
7
+ Superscript,
8
+ defaultTag
8
9
  };
@@ -1,9 +1,14 @@
1
1
  import { SuperscriptIcon } from "@webstudio-is/icons";
2
+ import { sup } from "../css/normalize";
2
3
  import { props } from "./__generated__/superscript.props";
4
+ const presetStyle = {
5
+ sup
6
+ };
3
7
  const meta = {
4
8
  type: "rich-text-child",
5
9
  label: "Superscript Text",
6
- Icon: SuperscriptIcon
10
+ Icon: SuperscriptIcon,
11
+ presetStyle
7
12
  };
8
13
  const propsMeta = {
9
14
  props
@@ -4,5 +4,6 @@ const defaultTag = "div";
4
4
  const TextBlock = forwardRef((props, ref) => /* @__PURE__ */ jsx("div", { ...props, ref }));
5
5
  TextBlock.displayName = "TextBlock";
6
6
  export {
7
- TextBlock
7
+ TextBlock,
8
+ defaultTag
8
9
  };
@@ -1,17 +1,21 @@
1
- import { TextIcon } from "@webstudio-is/icons";
1
+ import { TextBlockIcon } from "@webstudio-is/icons";
2
2
  import { props } from "./__generated__/text-block.props";
3
+ import { div } from "../css/normalize";
3
4
  const presetStyle = {
4
- minHeight: {
5
- type: "unit",
6
- unit: "em",
7
- value: 1
5
+ div: {
6
+ ...div,
7
+ minHeight: {
8
+ type: "unit",
9
+ unit: "em",
10
+ value: 1
11
+ }
8
12
  }
9
13
  };
10
14
  const meta = {
11
15
  category: "typography",
12
16
  type: "rich-text",
13
17
  label: "Text Block",
14
- Icon: TextIcon,
18
+ Icon: TextBlockIcon,
15
19
  presetStyle,
16
20
  children: ["Block of text you can edit"]
17
21
  };
package/lib/context.js CHANGED
@@ -2,7 +2,8 @@ import { atom } from "nanostores";
2
2
  import { createContext } from "react";
3
3
  const ReactSdkContext = createContext({
4
4
  propsByInstanceIdStore: atom(/* @__PURE__ */ new Map()),
5
- assetsStore: atom(/* @__PURE__ */ new Map())
5
+ assetsStore: atom(/* @__PURE__ */ new Map()),
6
+ pagesStore: atom(/* @__PURE__ */ new Map())
6
7
  });
7
8
  export {
8
9
  ReactSdkContext
package/lib/css/css.js ADDED
@@ -0,0 +1,44 @@
1
+ import { createCssEngine } from "@webstudio-is/css-engine";
2
+ import { getComponentNames } from "../components/components-utils";
3
+ import { getComponentMeta } from "../components";
4
+ import { componentAttribute, idAttribute } from "../tree";
5
+ import { addGlobalRules } from "./global-rules";
6
+ import { getStyleRules } from "./style-rules";
7
+ const generateCssText = (data) => {
8
+ const assets = new Map(
9
+ data.assets.map((asset) => [asset.id, asset])
10
+ );
11
+ const breakpoints = new Map(data.breakpoints);
12
+ const styles = new Map(data.styles);
13
+ const styleSourceSelections = new Map(data.styleSourceSelections);
14
+ const engine = createCssEngine({ name: "ssr" });
15
+ addGlobalRules(engine, { assets });
16
+ for (const breakpoint of breakpoints.values()) {
17
+ engine.addMediaRule(breakpoint.id, breakpoint);
18
+ }
19
+ for (const component of getComponentNames()) {
20
+ const meta = getComponentMeta(component);
21
+ const presetStyle = meta?.presetStyle;
22
+ if (presetStyle !== void 0) {
23
+ for (const [tag, style] of Object.entries(presetStyle)) {
24
+ engine.addStyleRule(
25
+ `${tag}:where([${componentAttribute}=${component}])`,
26
+ {
27
+ style
28
+ }
29
+ );
30
+ }
31
+ }
32
+ }
33
+ const styleRules = getStyleRules(styles, styleSourceSelections);
34
+ for (const { breakpointId, instanceId, style } of styleRules) {
35
+ engine.addStyleRule(`[${idAttribute}="${instanceId}"]`, {
36
+ breakpoint: breakpointId,
37
+ style
38
+ });
39
+ }
40
+ return engine.cssText;
41
+ };
42
+ export {
43
+ generateCssText
44
+ };
@@ -1,5 +1,7 @@
1
1
  import { detectFont } from "detect-font";
2
- import { keywordValues } from "@webstudio-is/css-data";
2
+ import {
3
+ keywordValues
4
+ } from "@webstudio-is/css-data";
3
5
  import { properties, units } from "@webstudio-is/css-data";
4
6
  const unitsList = Object.values(units).flat();
5
7
  const unitRegex = new RegExp(`${unitsList.join("|")}`);
@@ -0,0 +1,20 @@
1
+ import {
2
+ FONT_FORMATS,
3
+ getFontFaces
4
+ } from "@webstudio-is/fonts";
5
+ const addGlobalRules = (engine, { assets }) => {
6
+ engine.addPlaintextRule("html {margin: 0; height: 100%}");
7
+ const fontAssets = [];
8
+ for (const asset of assets.values()) {
9
+ if (asset && FONT_FORMATS.has(asset.format)) {
10
+ fontAssets.push(asset);
11
+ }
12
+ }
13
+ const fontFaces = getFontFaces(fontAssets);
14
+ for (const fontFace of fontFaces) {
15
+ engine.addFontFaceRule(fontFace);
16
+ }
17
+ };
18
+ export {
19
+ addGlobalRules
20
+ };
package/lib/css/index.js CHANGED
@@ -1,2 +1,4 @@
1
1
  export * from "./get-browser-style";
2
- export * from "./categories";
2
+ export * from "./global-rules";
3
+ export * from "./style-rules";
4
+ export * from "./css";
@@ -0,0 +1,3 @@
1
+ import * as normalize from "./normalize";
2
+ const normalizeWithKeyof = { ...normalize };
3
+ normalizeWithKeyof;