@delmaredigital/payload-puck 0.1.3 → 0.3.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 (565) hide show
  1. package/README.md +293 -1237
  2. package/dist/admin/EditWithPuckButton.d.ts +74 -0
  3. package/dist/admin/EditWithPuckButton.d.ts.map +1 -0
  4. package/dist/admin/EditWithPuckButton.js +114 -0
  5. package/dist/admin/EditWithPuckButton.js.map +1 -0
  6. package/dist/admin/EditWithPuckCell.d.ts +43 -0
  7. package/dist/admin/EditWithPuckCell.d.ts.map +1 -0
  8. package/dist/admin/EditWithPuckCell.js +66 -0
  9. package/dist/admin/EditWithPuckCell.js.map +1 -0
  10. package/dist/admin/PuckEditorView.d.ts +85 -0
  11. package/dist/admin/PuckEditorView.d.ts.map +1 -0
  12. package/dist/admin/PuckEditorView.js +135 -0
  13. package/dist/admin/PuckEditorView.js.map +1 -0
  14. package/dist/admin/client.d.ts +8 -104
  15. package/dist/admin/client.d.ts.map +1 -0
  16. package/dist/admin/client.js +14 -176
  17. package/dist/admin/client.js.map +1 -0
  18. package/dist/admin/generateAdminComponents.d.ts +51 -0
  19. package/dist/admin/generateAdminComponents.d.ts.map +1 -0
  20. package/dist/admin/generateAdminComponents.js +42 -0
  21. package/dist/admin/generateAdminComponents.js.map +1 -0
  22. package/dist/admin/index.d.ts +14 -150
  23. package/dist/admin/index.d.ts.map +1 -0
  24. package/dist/admin/index.js +17 -30
  25. package/dist/admin/index.js.map +1 -0
  26. package/dist/api/createPuckApiRoutes.d.ts +31 -0
  27. package/dist/api/createPuckApiRoutes.d.ts.map +1 -0
  28. package/dist/api/createPuckApiRoutes.js +193 -0
  29. package/dist/api/createPuckApiRoutes.js.map +1 -0
  30. package/dist/api/createPuckApiRoutesVersions.d.ts +28 -0
  31. package/dist/api/createPuckApiRoutesVersions.d.ts.map +1 -0
  32. package/dist/api/createPuckApiRoutesVersions.js +144 -0
  33. package/dist/api/createPuckApiRoutesVersions.js.map +1 -0
  34. package/dist/api/createPuckApiRoutesWithId.d.ts +34 -0
  35. package/dist/api/createPuckApiRoutesWithId.d.ts.map +1 -0
  36. package/dist/api/createPuckApiRoutesWithId.js +251 -0
  37. package/dist/api/createPuckApiRoutesWithId.js.map +1 -0
  38. package/dist/api/index.d.ts +11 -431
  39. package/dist/api/index.d.ts.map +1 -0
  40. package/dist/api/index.js +40 -587
  41. package/dist/api/index.js.map +1 -0
  42. package/dist/api/types.d.ts +302 -0
  43. package/dist/api/types.d.ts.map +1 -0
  44. package/dist/api/types.js +2 -0
  45. package/dist/api/types.js.map +1 -0
  46. package/dist/api/utils/mapRootProps.d.ts +76 -0
  47. package/dist/api/utils/mapRootProps.d.ts.map +1 -0
  48. package/dist/api/utils/mapRootProps.js +169 -0
  49. package/dist/api/utils/mapRootProps.js.map +1 -0
  50. package/dist/collections/Templates.d.ts +9 -0
  51. package/dist/collections/Templates.d.ts.map +1 -0
  52. package/dist/collections/Templates.js +62 -0
  53. package/dist/collections/Templates.js.map +1 -0
  54. package/dist/components/AccordionClient.d.ts +20 -0
  55. package/dist/components/AccordionClient.d.ts.map +1 -0
  56. package/dist/components/AccordionClient.js +67 -0
  57. package/dist/components/AccordionClient.js.map +1 -0
  58. package/dist/components/AnimatedWrapper.d.ts +33 -0
  59. package/dist/components/AnimatedWrapper.d.ts.map +1 -0
  60. package/dist/components/AnimatedWrapper.js +61 -0
  61. package/dist/components/AnimatedWrapper.js.map +1 -0
  62. package/dist/components/exports.d.ts +54 -0
  63. package/dist/components/exports.d.ts.map +1 -0
  64. package/dist/components/exports.js +71 -0
  65. package/dist/components/exports.js.map +1 -0
  66. package/dist/components/index.d.ts +8 -219
  67. package/dist/components/index.d.ts.map +1 -0
  68. package/dist/components/index.js +15 -9155
  69. package/dist/components/index.js.map +1 -0
  70. package/dist/components/interactive/Accordion.d.ts +28 -0
  71. package/dist/components/interactive/Accordion.d.ts.map +1 -0
  72. package/dist/components/interactive/Accordion.js +159 -0
  73. package/dist/components/interactive/Accordion.js.map +1 -0
  74. package/dist/components/interactive/Accordion.server.d.ts +29 -0
  75. package/dist/components/interactive/Accordion.server.d.ts.map +1 -0
  76. package/dist/components/interactive/Accordion.server.js +30 -0
  77. package/dist/components/interactive/Accordion.server.js.map +1 -0
  78. package/dist/components/interactive/Button.d.ts +26 -0
  79. package/dist/components/interactive/Button.d.ts.map +1 -0
  80. package/dist/components/interactive/Button.js +133 -0
  81. package/dist/components/interactive/Button.js.map +1 -0
  82. package/dist/components/interactive/Button.server.d.ts +28 -0
  83. package/dist/components/interactive/Button.server.d.ts.map +1 -0
  84. package/dist/components/interactive/Button.server.js +96 -0
  85. package/dist/components/interactive/Button.server.js.map +1 -0
  86. package/dist/components/interactive/Card.d.ts +27 -0
  87. package/dist/components/interactive/Card.d.ts.map +1 -0
  88. package/dist/components/interactive/Card.js +128 -0
  89. package/dist/components/interactive/Card.js.map +1 -0
  90. package/dist/components/interactive/Card.server.d.ts +29 -0
  91. package/dist/components/interactive/Card.server.d.ts.map +1 -0
  92. package/dist/components/interactive/Card.server.js +77 -0
  93. package/dist/components/interactive/Card.server.js.map +1 -0
  94. package/dist/components/interactive/Divider.d.ts +18 -0
  95. package/dist/components/interactive/Divider.d.ts.map +1 -0
  96. package/dist/components/interactive/Divider.js +68 -0
  97. package/dist/components/interactive/Divider.js.map +1 -0
  98. package/dist/components/interactive/Divider.server.d.ts +20 -0
  99. package/dist/components/interactive/Divider.server.d.ts.map +1 -0
  100. package/dist/components/interactive/Divider.server.js +50 -0
  101. package/dist/components/interactive/Divider.server.js.map +1 -0
  102. package/dist/components/interactive/index.d.ts +10 -0
  103. package/dist/components/interactive/index.d.ts.map +1 -0
  104. package/dist/components/interactive/index.js +10 -0
  105. package/dist/components/interactive/index.js.map +1 -0
  106. package/dist/components/layout/Container.d.ts +29 -0
  107. package/dist/components/layout/Container.d.ts.map +1 -0
  108. package/dist/components/layout/Container.js +166 -0
  109. package/dist/components/layout/Container.js.map +1 -0
  110. package/dist/components/layout/Container.server.d.ts +32 -0
  111. package/dist/components/layout/Container.server.d.ts.map +1 -0
  112. package/dist/components/layout/Container.server.js +105 -0
  113. package/dist/components/layout/Container.server.js.map +1 -0
  114. package/dist/components/layout/Flex.d.ts +36 -0
  115. package/dist/components/layout/Flex.d.ts.map +1 -0
  116. package/dist/components/layout/Flex.js +183 -0
  117. package/dist/components/layout/Flex.js.map +1 -0
  118. package/dist/components/layout/Flex.server.d.ts +36 -0
  119. package/dist/components/layout/Flex.server.d.ts.map +1 -0
  120. package/dist/components/layout/Flex.server.js +97 -0
  121. package/dist/components/layout/Flex.server.js.map +1 -0
  122. package/dist/components/layout/Grid.d.ts +31 -0
  123. package/dist/components/layout/Grid.d.ts.map +1 -0
  124. package/dist/components/layout/Grid.js +164 -0
  125. package/dist/components/layout/Grid.js.map +1 -0
  126. package/dist/components/layout/Grid.server.d.ts +32 -0
  127. package/dist/components/layout/Grid.server.d.ts.map +1 -0
  128. package/dist/components/layout/Grid.server.js +92 -0
  129. package/dist/components/layout/Grid.server.js.map +1 -0
  130. package/dist/components/layout/Section.d.ts +35 -0
  131. package/dist/components/layout/Section.d.ts.map +1 -0
  132. package/dist/components/layout/Section.js +212 -0
  133. package/dist/components/layout/Section.js.map +1 -0
  134. package/dist/components/layout/Section.server.d.ts +35 -0
  135. package/dist/components/layout/Section.server.d.ts.map +1 -0
  136. package/dist/components/layout/Section.server.js +144 -0
  137. package/dist/components/layout/Section.server.js.map +1 -0
  138. package/dist/components/layout/Spacer.d.ts +18 -0
  139. package/dist/components/layout/Spacer.d.ts.map +1 -0
  140. package/dist/components/layout/Spacer.js +99 -0
  141. package/dist/components/layout/Spacer.js.map +1 -0
  142. package/dist/components/layout/Spacer.server.d.ts +21 -0
  143. package/dist/components/layout/Spacer.server.d.ts.map +1 -0
  144. package/dist/components/layout/Spacer.server.js +61 -0
  145. package/dist/components/layout/Spacer.server.js.map +1 -0
  146. package/dist/components/layout/Template.d.ts +35 -0
  147. package/dist/components/layout/Template.d.ts.map +1 -0
  148. package/dist/components/layout/Template.js +124 -0
  149. package/dist/components/layout/Template.js.map +1 -0
  150. package/dist/components/layout/Template.server.d.ts +32 -0
  151. package/dist/components/layout/Template.server.d.ts.map +1 -0
  152. package/dist/components/layout/Template.server.js +75 -0
  153. package/dist/components/layout/Template.server.js.map +1 -0
  154. package/dist/components/layout/index.d.ts +14 -0
  155. package/dist/components/layout/index.d.ts.map +1 -0
  156. package/dist/components/layout/index.js +13 -0
  157. package/dist/components/layout/index.js.map +1 -0
  158. package/dist/components/media/Image.d.ts +30 -0
  159. package/dist/components/media/Image.d.ts.map +1 -0
  160. package/dist/components/media/Image.js +123 -0
  161. package/dist/components/media/Image.js.map +1 -0
  162. package/dist/components/media/Image.server.d.ts +28 -0
  163. package/dist/components/media/Image.server.d.ts.map +1 -0
  164. package/dist/components/media/Image.server.js +76 -0
  165. package/dist/components/media/Image.server.js.map +1 -0
  166. package/dist/components/media/index.d.ts +7 -0
  167. package/dist/components/media/index.d.ts.map +1 -0
  168. package/dist/components/media/index.js +7 -0
  169. package/dist/components/media/index.js.map +1 -0
  170. package/dist/components/typography/Heading.d.ts +21 -0
  171. package/dist/components/typography/Heading.d.ts.map +1 -0
  172. package/dist/components/typography/Heading.js +71 -0
  173. package/dist/components/typography/Heading.js.map +1 -0
  174. package/dist/components/typography/Heading.server.d.ts +21 -0
  175. package/dist/components/typography/Heading.server.d.ts.map +1 -0
  176. package/dist/components/typography/Heading.server.js +49 -0
  177. package/dist/components/typography/Heading.server.js.map +1 -0
  178. package/dist/components/typography/RichText.d.ts +20 -0
  179. package/dist/components/typography/RichText.d.ts.map +1 -0
  180. package/dist/components/typography/RichText.editor.d.ts +11 -0
  181. package/dist/components/typography/RichText.editor.d.ts.map +1 -0
  182. package/dist/components/typography/RichText.editor.js +67 -0
  183. package/dist/components/typography/RichText.editor.js.map +1 -0
  184. package/dist/components/typography/RichText.js +73 -0
  185. package/dist/components/typography/RichText.js.map +1 -0
  186. package/dist/components/typography/RichText.server.d.ts +22 -0
  187. package/dist/components/typography/RichText.server.d.ts.map +1 -0
  188. package/dist/components/typography/RichText.server.js +52 -0
  189. package/dist/components/typography/RichText.server.js.map +1 -0
  190. package/dist/components/typography/Text.d.ts +20 -0
  191. package/dist/components/typography/Text.d.ts.map +1 -0
  192. package/dist/components/typography/Text.js +61 -0
  193. package/dist/components/typography/Text.js.map +1 -0
  194. package/dist/components/typography/Text.server.d.ts +21 -0
  195. package/dist/components/typography/Text.server.d.ts.map +1 -0
  196. package/dist/components/typography/Text.server.js +39 -0
  197. package/dist/components/typography/Text.server.js.map +1 -0
  198. package/dist/components/typography/index.d.ts +10 -0
  199. package/dist/components/typography/index.d.ts.map +1 -0
  200. package/dist/components/typography/index.js +10 -0
  201. package/dist/components/typography/index.js.map +1 -0
  202. package/dist/config/config.editor.d.ts +15 -56
  203. package/dist/config/config.editor.d.ts.map +1 -0
  204. package/dist/config/config.editor.js +125 -9364
  205. package/dist/config/config.editor.js.map +1 -0
  206. package/dist/config/index.d.ts +7 -33
  207. package/dist/config/index.d.ts.map +1 -0
  208. package/dist/config/index.js +110 -2028
  209. package/dist/config/index.js.map +1 -0
  210. package/dist/config/merge.d.ts +23 -0
  211. package/dist/config/merge.d.ts.map +1 -0
  212. package/dist/config/merge.js +80 -0
  213. package/dist/config/merge.js.map +1 -0
  214. package/dist/config/presets.d.ts +342 -0
  215. package/dist/config/presets.d.ts.map +1 -0
  216. package/dist/config/presets.js +247 -0
  217. package/dist/config/presets.js.map +1 -0
  218. package/dist/editor/PuckEditor.client.d.ts +131 -0
  219. package/dist/editor/PuckEditor.client.d.ts.map +1 -0
  220. package/dist/editor/PuckEditor.client.js +42 -0
  221. package/dist/editor/PuckEditor.client.js.map +1 -0
  222. package/dist/editor/PuckEditorCore.client.d.ts +141 -0
  223. package/dist/editor/PuckEditorCore.client.d.ts.map +1 -0
  224. package/dist/editor/PuckEditorCore.client.js +306 -0
  225. package/dist/editor/PuckEditorCore.client.js.map +1 -0
  226. package/dist/editor/components/HeaderActions.d.ts +109 -0
  227. package/dist/editor/components/HeaderActions.d.ts.map +1 -0
  228. package/dist/editor/components/HeaderActions.js +254 -0
  229. package/dist/editor/components/HeaderActions.js.map +1 -0
  230. package/dist/editor/components/IframeWrapper.d.ts +77 -0
  231. package/dist/editor/components/IframeWrapper.d.ts.map +1 -0
  232. package/dist/editor/components/IframeWrapper.js +257 -0
  233. package/dist/editor/components/IframeWrapper.js.map +1 -0
  234. package/dist/editor/components/LoadingState.d.ts +14 -0
  235. package/dist/editor/components/LoadingState.d.ts.map +1 -0
  236. package/dist/editor/components/LoadingState.js +12 -0
  237. package/dist/editor/components/LoadingState.js.map +1 -0
  238. package/dist/editor/components/PreviewModal.d.ts +54 -0
  239. package/dist/editor/components/PreviewModal.d.ts.map +1 -0
  240. package/dist/editor/components/PreviewModal.js +298 -0
  241. package/dist/editor/components/PreviewModal.js.map +1 -0
  242. package/dist/editor/components/VersionHistory.d.ts +44 -0
  243. package/dist/editor/components/VersionHistory.d.ts.map +1 -0
  244. package/dist/editor/components/VersionHistory.js +308 -0
  245. package/dist/editor/components/VersionHistory.js.map +1 -0
  246. package/dist/editor/hooks/useUnsavedChanges.d.ts +27 -0
  247. package/dist/editor/hooks/useUnsavedChanges.d.ts.map +1 -0
  248. package/dist/editor/hooks/useUnsavedChanges.js +55 -0
  249. package/dist/editor/hooks/useUnsavedChanges.js.map +1 -0
  250. package/dist/editor/index.d.ts +16 -756
  251. package/dist/editor/index.d.ts.map +1 -0
  252. package/dist/editor/index.js +49 -4533
  253. package/dist/editor/index.js.map +1 -0
  254. package/dist/editor/plugins/index.d.ts +12 -0
  255. package/dist/editor/plugins/index.d.ts.map +1 -0
  256. package/dist/editor/plugins/index.js +12 -0
  257. package/dist/editor/plugins/index.js.map +1 -0
  258. package/dist/endpoints/index.d.ts +46 -0
  259. package/dist/endpoints/index.d.ts.map +1 -0
  260. package/dist/endpoints/index.js +204 -0
  261. package/dist/endpoints/index.js.map +1 -0
  262. package/dist/exports/client.d.ts +19 -0
  263. package/dist/exports/client.d.ts.map +1 -0
  264. package/dist/exports/client.js +21 -0
  265. package/dist/exports/client.js.map +1 -0
  266. package/dist/exports/rsc.d.ts +19 -0
  267. package/dist/exports/rsc.d.ts.map +1 -0
  268. package/dist/exports/rsc.js +19 -0
  269. package/dist/exports/rsc.js.map +1 -0
  270. package/dist/fields/AlignmentField.d.ts +36 -0
  271. package/dist/fields/AlignmentField.d.ts.map +1 -0
  272. package/dist/fields/AlignmentField.js +120 -0
  273. package/dist/fields/AlignmentField.js.map +1 -0
  274. package/dist/fields/AnimationField.d.ts +44 -0
  275. package/dist/fields/AnimationField.d.ts.map +1 -0
  276. package/dist/fields/AnimationField.js +329 -0
  277. package/dist/fields/AnimationField.js.map +1 -0
  278. package/dist/fields/BackgroundField.d.ts +40 -0
  279. package/dist/fields/BackgroundField.d.ts.map +1 -0
  280. package/dist/fields/BackgroundField.js +413 -0
  281. package/dist/fields/BackgroundField.js.map +1 -0
  282. package/dist/fields/BorderField.d.ts +29 -0
  283. package/dist/fields/BorderField.d.ts.map +1 -0
  284. package/dist/fields/BorderField.js +264 -0
  285. package/dist/fields/BorderField.js.map +1 -0
  286. package/dist/fields/ColorPickerField.d.ts +43 -0
  287. package/dist/fields/ColorPickerField.d.ts.map +1 -0
  288. package/dist/fields/ColorPickerField.js +285 -0
  289. package/dist/fields/ColorPickerField.js.map +1 -0
  290. package/dist/fields/DimensionsField.d.ts +43 -0
  291. package/dist/fields/DimensionsField.d.ts.map +1 -0
  292. package/dist/fields/DimensionsField.js +532 -0
  293. package/dist/fields/DimensionsField.js.map +1 -0
  294. package/dist/fields/FlexAlignmentField.d.ts +61 -0
  295. package/dist/fields/FlexAlignmentField.d.ts.map +1 -0
  296. package/dist/fields/FlexAlignmentField.js +166 -0
  297. package/dist/fields/FlexAlignmentField.js.map +1 -0
  298. package/dist/fields/FolderPickerField.d.ts +17 -0
  299. package/dist/fields/FolderPickerField.d.ts.map +1 -0
  300. package/dist/fields/FolderPickerField.js +282 -0
  301. package/dist/fields/FolderPickerField.js.map +1 -0
  302. package/dist/fields/GradientEditor.d.ts +22 -0
  303. package/dist/fields/GradientEditor.d.ts.map +1 -0
  304. package/dist/fields/GradientEditor.js +322 -0
  305. package/dist/fields/GradientEditor.js.map +1 -0
  306. package/dist/fields/LockedField.d.ts +67 -0
  307. package/dist/fields/LockedField.d.ts.map +1 -0
  308. package/dist/fields/LockedField.js +170 -0
  309. package/dist/fields/LockedField.js.map +1 -0
  310. package/dist/fields/MarginField.d.ts +31 -0
  311. package/dist/fields/MarginField.d.ts.map +1 -0
  312. package/dist/fields/MarginField.js +233 -0
  313. package/dist/fields/MarginField.js.map +1 -0
  314. package/dist/fields/MediaField.d.ts +33 -0
  315. package/dist/fields/MediaField.d.ts.map +1 -0
  316. package/dist/fields/MediaField.js +677 -0
  317. package/dist/fields/MediaField.js.map +1 -0
  318. package/dist/fields/PaddingField.d.ts +29 -0
  319. package/dist/fields/PaddingField.d.ts.map +1 -0
  320. package/dist/fields/PaddingField.js +232 -0
  321. package/dist/fields/PaddingField.js.map +1 -0
  322. package/dist/fields/PageSegmentField.d.ts +17 -0
  323. package/dist/fields/PageSegmentField.d.ts.map +1 -0
  324. package/dist/fields/PageSegmentField.js +92 -0
  325. package/dist/fields/PageSegmentField.js.map +1 -0
  326. package/dist/fields/ResetField.d.ts +27 -0
  327. package/dist/fields/ResetField.d.ts.map +1 -0
  328. package/dist/fields/ResetField.js +122 -0
  329. package/dist/fields/ResetField.js.map +1 -0
  330. package/dist/fields/ResponsiveField.d.ts +38 -0
  331. package/dist/fields/ResponsiveField.d.ts.map +1 -0
  332. package/dist/fields/ResponsiveField.js +275 -0
  333. package/dist/fields/ResponsiveField.js.map +1 -0
  334. package/dist/fields/ResponsiveVisibilityField.d.ts +34 -0
  335. package/dist/fields/ResponsiveVisibilityField.d.ts.map +1 -0
  336. package/dist/fields/ResponsiveVisibilityField.js +145 -0
  337. package/dist/fields/ResponsiveVisibilityField.js.map +1 -0
  338. package/dist/fields/SizeField.d.ts +54 -0
  339. package/dist/fields/SizeField.d.ts.map +1 -0
  340. package/dist/fields/SizeField.js +255 -0
  341. package/dist/fields/SizeField.js.map +1 -0
  342. package/dist/fields/SlugPreviewField.d.ts +16 -0
  343. package/dist/fields/SlugPreviewField.d.ts.map +1 -0
  344. package/dist/fields/SlugPreviewField.js +49 -0
  345. package/dist/fields/SlugPreviewField.js.map +1 -0
  346. package/dist/fields/TemplateField.d.ts +31 -0
  347. package/dist/fields/TemplateField.d.ts.map +1 -0
  348. package/dist/fields/TemplateField.js +428 -0
  349. package/dist/fields/TemplateField.js.map +1 -0
  350. package/dist/fields/TiptapField.d.ts +40 -0
  351. package/dist/fields/TiptapField.d.ts.map +1 -0
  352. package/dist/fields/TiptapField.js +857 -0
  353. package/dist/fields/TiptapField.js.map +1 -0
  354. package/dist/fields/TiptapModal.d.ts +10 -0
  355. package/dist/fields/TiptapModal.d.ts.map +1 -0
  356. package/dist/fields/TiptapModal.js +114 -0
  357. package/dist/fields/TiptapModal.js.map +1 -0
  358. package/dist/fields/TiptapModalField.d.ts +23 -0
  359. package/dist/fields/TiptapModalField.d.ts.map +1 -0
  360. package/dist/fields/TiptapModalField.js +55 -0
  361. package/dist/fields/TiptapModalField.js.map +1 -0
  362. package/dist/fields/TransformField.d.ts +31 -0
  363. package/dist/fields/TransformField.d.ts.map +1 -0
  364. package/dist/fields/TransformField.js +384 -0
  365. package/dist/fields/TransformField.js.map +1 -0
  366. package/dist/fields/VerticalAlignmentField.d.ts +35 -0
  367. package/dist/fields/VerticalAlignmentField.d.ts.map +1 -0
  368. package/dist/fields/VerticalAlignmentField.js +120 -0
  369. package/dist/fields/VerticalAlignmentField.js.map +1 -0
  370. package/dist/fields/WidthField.d.ts +28 -0
  371. package/dist/fields/WidthField.d.ts.map +1 -0
  372. package/dist/fields/WidthField.js +339 -0
  373. package/dist/fields/WidthField.js.map +1 -0
  374. package/dist/fields/index.d.ts +44 -559
  375. package/dist/fields/index.d.ts.map +1 -0
  376. package/dist/fields/index.js +91 -7685
  377. package/dist/fields/index.js.map +1 -0
  378. package/dist/fields/richtext-output.css +219 -0
  379. package/dist/{shared-DeNKN95N.d.mts → fields/shared.d.ts} +114 -133
  380. package/dist/fields/shared.d.ts.map +1 -0
  381. package/dist/fields/shared.js +1542 -0
  382. package/dist/fields/shared.js.map +1 -0
  383. package/dist/fields/{index.css → tiptap-styles.css} +75 -166
  384. package/dist/hooks/index.d.ts +8 -0
  385. package/dist/hooks/index.d.ts.map +1 -0
  386. package/dist/hooks/index.js +8 -0
  387. package/dist/hooks/index.js.map +1 -0
  388. package/dist/hooks/useResponsiveStyles.d.ts +51 -0
  389. package/dist/hooks/useResponsiveStyles.d.ts.map +1 -0
  390. package/dist/hooks/useResponsiveStyles.js +149 -0
  391. package/dist/hooks/useResponsiveStyles.js.map +1 -0
  392. package/dist/hooks/useScrollAnimation.d.ts +56 -0
  393. package/dist/hooks/useScrollAnimation.d.ts.map +1 -0
  394. package/dist/hooks/useScrollAnimation.js +116 -0
  395. package/dist/hooks/useScrollAnimation.js.map +1 -0
  396. package/dist/index.d.ts +66 -6
  397. package/dist/index.d.ts.map +1 -0
  398. package/dist/index.js +67 -568
  399. package/dist/index.js.map +1 -0
  400. package/dist/layouts/LayoutWrapper.d.ts +33 -0
  401. package/dist/layouts/LayoutWrapper.d.ts.map +1 -0
  402. package/dist/layouts/LayoutWrapper.js +112 -0
  403. package/dist/layouts/LayoutWrapper.js.map +1 -0
  404. package/dist/layouts/defaults.d.ts +40 -0
  405. package/dist/layouts/defaults.d.ts.map +1 -0
  406. package/dist/layouts/defaults.js +106 -0
  407. package/dist/layouts/defaults.js.map +1 -0
  408. package/dist/layouts/index.d.ts +27 -94
  409. package/dist/layouts/index.d.ts.map +1 -0
  410. package/dist/layouts/index.js +30 -393
  411. package/dist/layouts/index.js.map +1 -0
  412. package/dist/{types-D7D3rZ1J.d.ts → layouts/types.d.ts} +8 -11
  413. package/dist/layouts/types.d.ts.map +1 -0
  414. package/dist/layouts/types.js +7 -0
  415. package/dist/layouts/types.js.map +1 -0
  416. package/dist/layouts/utils.d.ts +42 -0
  417. package/dist/layouts/utils.d.ts.map +1 -0
  418. package/dist/layouts/utils.js +83 -0
  419. package/dist/layouts/utils.js.map +1 -0
  420. package/dist/plugin/collections/Pages.d.ts +8 -0
  421. package/dist/plugin/collections/Pages.d.ts.map +1 -0
  422. package/dist/plugin/collections/Pages.js +117 -0
  423. package/dist/plugin/collections/Pages.js.map +1 -0
  424. package/dist/plugin/fields/index.d.ts +153 -0
  425. package/dist/plugin/fields/index.d.ts.map +1 -0
  426. package/dist/plugin/fields/index.js +364 -0
  427. package/dist/plugin/fields/index.js.map +1 -0
  428. package/dist/plugin/fields/types.d.ts +108 -0
  429. package/dist/plugin/fields/types.d.ts.map +1 -0
  430. package/dist/plugin/fields/types.js +7 -0
  431. package/dist/plugin/fields/types.js.map +1 -0
  432. package/dist/plugin/index.d.ts +13 -255
  433. package/dist/plugin/index.d.ts.map +1 -0
  434. package/dist/plugin/index.js +276 -553
  435. package/dist/plugin/index.js.map +1 -0
  436. package/dist/render/HybridPageRenderer.d.ts +85 -0
  437. package/dist/render/HybridPageRenderer.d.ts.map +1 -0
  438. package/dist/render/HybridPageRenderer.js +29 -0
  439. package/dist/render/HybridPageRenderer.js.map +1 -0
  440. package/dist/render/PageRenderer.d.ts +51 -0
  441. package/dist/render/PageRenderer.d.ts.map +1 -0
  442. package/dist/render/PageRenderer.js +61 -0
  443. package/dist/render/PageRenderer.js.map +1 -0
  444. package/dist/render/PuckEditor.client.d.ts +66 -0
  445. package/dist/render/PuckEditor.client.d.ts.map +1 -0
  446. package/dist/render/PuckEditor.client.js +66 -0
  447. package/dist/render/PuckEditor.client.js.map +1 -0
  448. package/dist/render/index.d.ts +8 -106
  449. package/dist/render/index.d.ts.map +1 -0
  450. package/dist/render/index.js +10 -2162
  451. package/dist/render/index.js.map +1 -0
  452. package/dist/theme/context.d.ts +59 -0
  453. package/dist/theme/context.d.ts.map +1 -0
  454. package/dist/theme/context.js +73 -0
  455. package/dist/theme/context.js.map +1 -0
  456. package/dist/theme/defaults.d.ts +39 -0
  457. package/dist/theme/defaults.d.ts.map +1 -0
  458. package/dist/theme/defaults.js +72 -0
  459. package/dist/theme/defaults.js.map +1 -0
  460. package/dist/theme/example.d.ts +30 -0
  461. package/dist/theme/example.d.ts.map +1 -0
  462. package/dist/theme/example.js +89 -0
  463. package/dist/theme/example.js.map +1 -0
  464. package/dist/theme/index.d.ts +17 -140
  465. package/dist/theme/index.d.ts.map +1 -0
  466. package/dist/theme/index.js +34 -200
  467. package/dist/theme/index.js.map +1 -0
  468. package/dist/{types-_6MvjyKv.d.ts → theme/types.d.ts} +8 -9
  469. package/dist/theme/types.d.ts.map +1 -0
  470. package/dist/theme/types.js +9 -0
  471. package/dist/theme/types.js.map +1 -0
  472. package/dist/theme/utils.d.ts +30 -0
  473. package/dist/theme/utils.d.ts.map +1 -0
  474. package/dist/theme/utils.js +84 -0
  475. package/dist/theme/utils.js.map +1 -0
  476. package/dist/{index-CQu6SzDg.d.mts → types/index.d.ts} +120 -115
  477. package/dist/types/index.d.ts.map +1 -0
  478. package/dist/types/index.js +2 -0
  479. package/dist/types/index.js.map +1 -0
  480. package/dist/utils/index.d.ts +23 -257
  481. package/dist/utils/index.d.ts.map +1 -0
  482. package/dist/utils/index.js +56 -425
  483. package/dist/utils/index.js.map +1 -0
  484. package/dist/utils/{index.d.mts → migration.d.ts} +16 -112
  485. package/dist/utils/migration.d.ts.map +1 -0
  486. package/dist/utils/migration.js +309 -0
  487. package/dist/utils/migration.js.map +1 -0
  488. package/dist/utils/validation.d.ts +89 -0
  489. package/dist/utils/validation.d.ts.map +1 -0
  490. package/dist/utils/validation.js +247 -0
  491. package/dist/utils/validation.js.map +1 -0
  492. package/dist/views/PuckConfigContext.d.ts +71 -0
  493. package/dist/views/PuckConfigContext.d.ts.map +1 -0
  494. package/dist/views/PuckConfigContext.js +45 -0
  495. package/dist/views/PuckConfigContext.js.map +1 -0
  496. package/dist/views/PuckEditorClient.d.ts +73 -0
  497. package/dist/views/PuckEditorClient.d.ts.map +1 -0
  498. package/dist/views/PuckEditorClient.js +130 -0
  499. package/dist/views/PuckEditorClient.js.map +1 -0
  500. package/dist/views/PuckEditorView.d.ts +19 -0
  501. package/dist/views/PuckEditorView.d.ts.map +1 -0
  502. package/dist/views/PuckEditorView.js +106 -0
  503. package/dist/views/PuckEditorView.js.map +1 -0
  504. package/dist/views/index.d.ts +10 -0
  505. package/dist/views/index.d.ts.map +1 -0
  506. package/dist/views/index.js +10 -0
  507. package/dist/views/index.js.map +1 -0
  508. package/package.json +50 -72
  509. package/dist/AccordionClient.d.mts +0 -24
  510. package/dist/AccordionClient.d.ts +0 -24
  511. package/dist/AccordionClient.js +0 -786
  512. package/dist/AccordionClient.mjs +0 -784
  513. package/dist/AnimatedWrapper.d.mts +0 -30
  514. package/dist/AnimatedWrapper.d.ts +0 -30
  515. package/dist/AnimatedWrapper.js +0 -379
  516. package/dist/AnimatedWrapper.mjs +0 -377
  517. package/dist/admin/client.d.mts +0 -108
  518. package/dist/admin/client.mjs +0 -173
  519. package/dist/admin/index.d.mts +0 -157
  520. package/dist/admin/index.mjs +0 -29
  521. package/dist/api/index.d.mts +0 -460
  522. package/dist/api/index.mjs +0 -578
  523. package/dist/components/index.css +0 -339
  524. package/dist/components/index.d.mts +0 -222
  525. package/dist/components/index.mjs +0 -9109
  526. package/dist/config/config.editor.css +0 -339
  527. package/dist/config/config.editor.d.mts +0 -153
  528. package/dist/config/config.editor.mjs +0 -9347
  529. package/dist/config/index.d.mts +0 -68
  530. package/dist/config/index.mjs +0 -2008
  531. package/dist/editor/index.d.mts +0 -784
  532. package/dist/editor/index.mjs +0 -4500
  533. package/dist/fields/index.d.mts +0 -600
  534. package/dist/fields/index.mjs +0 -7569
  535. package/dist/index-CoUQnyC3.d.ts +0 -327
  536. package/dist/index.d.mts +0 -6
  537. package/dist/index.mjs +0 -555
  538. package/dist/layouts/index.d.mts +0 -96
  539. package/dist/layouts/index.mjs +0 -378
  540. package/dist/plugin/index.d.mts +0 -289
  541. package/dist/plugin/index.mjs +0 -555
  542. package/dist/render/index.d.mts +0 -109
  543. package/dist/render/index.mjs +0 -2140
  544. package/dist/shared-DeNKN95N.d.ts +0 -546
  545. package/dist/theme/index.d.mts +0 -155
  546. package/dist/theme/index.mjs +0 -186
  547. package/dist/types-D7D3rZ1J.d.mts +0 -116
  548. package/dist/types-_6MvjyKv.d.mts +0 -104
  549. package/dist/utils/index.mjs +0 -412
  550. package/dist/utils-DaRs9t0J.d.mts +0 -85
  551. package/dist/utils-gAvt0Vhw.d.ts +0 -85
  552. package/examples/README.md +0 -247
  553. package/examples/api/puck/pages/[id]/route.ts +0 -64
  554. package/examples/api/puck/pages/[id]/versions/route.ts +0 -47
  555. package/examples/api/puck/pages/route.ts +0 -45
  556. package/examples/app/(frontend)/page.tsx +0 -94
  557. package/examples/app/(manage)/layout.tsx +0 -31
  558. package/examples/app/[...slug]/page.tsx +0 -101
  559. package/examples/app/pages/[id]/edit/page.tsx +0 -148
  560. package/examples/components/CustomBanner.tsx +0 -368
  561. package/examples/config/custom-config.ts +0 -223
  562. package/examples/config/payload.config.example.ts +0 -64
  563. package/examples/lib/puck-layouts.ts +0 -258
  564. package/examples/lib/puck-theme.ts +0 -94
  565. package/examples/styles/puck-theme.css +0 -171
@@ -0,0 +1,857 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ /**
4
+ * TiptapField - Rich Text Editor Field for Puck
5
+ *
6
+ * A custom Puck field that provides WYSIWYG rich text editing using Tiptap.
7
+ * Outputs HTML content that can be rendered with dangerouslySetInnerHTML.
8
+ *
9
+ * Features:
10
+ * - Theme-aware "inherit" color option for text that adapts to dark/light mode
11
+ * - Expanded color palette organized by category
12
+ * - Strikethrough and highlight text styling
13
+ * - Font size options (small, normal, large, extra large)
14
+ * - Full toolbar with all formatting options
15
+ * - HTML source view/edit mode
16
+ */
17
+ import { useCallback, memo, useState, useRef, useEffect } from 'react';
18
+ import { useEditor, EditorContent, useEditorState } from '@tiptap/react';
19
+ import StarterKit from '@tiptap/starter-kit';
20
+ import TextAlign from '@tiptap/extension-text-align';
21
+ import { TextStyle } from '@tiptap/extension-text-style';
22
+ import { Color } from '@tiptap/extension-color';
23
+ import Highlight from '@tiptap/extension-highlight';
24
+ import Superscript from '@tiptap/extension-superscript';
25
+ import Subscript from '@tiptap/extension-subscript';
26
+ import { Extension } from '@tiptap/core';
27
+ import { Bold, Italic, Underline, Strikethrough, Highlighter, Link, List, ListOrdered, AlignLeft, AlignCenter, AlignRight, AlignJustify, Heading1, Heading2, Heading3, Heading4, Heading5, Heading6, Quote, Code, RemoveFormatting, Palette, ALargeSmall, ChevronDown, Superscript as SuperscriptIcon, Subscript as SubscriptIcon, Minus, CornerDownLeft, Pilcrow, } from 'lucide-react';
28
+ import { useTheme } from '../theme';
29
+ import './tiptap-styles.css';
30
+ import './richtext-output.css';
31
+ // =============================================================================
32
+ // Injected Editor Styles
33
+ // =============================================================================
34
+ const TIPTAP_EDITOR_STYLES = `
35
+ .tiptap-editor h1 { font-size: 2em !important; font-weight: 700 !important; margin: 1em 0 0.5em 0; }
36
+ .tiptap-editor h2 { font-size: 1.5em !important; font-weight: 700 !important; margin: 1em 0 0.5em 0; }
37
+ .tiptap-editor h3 { font-size: 1.25em !important; font-weight: 600 !important; margin: 1em 0 0.5em 0; }
38
+ .tiptap-editor h4 { font-size: 1.1em !important; font-weight: 600 !important; margin: 1em 0 0.5em 0; }
39
+ .tiptap-editor h5 { font-size: 1em !important; font-weight: 600 !important; margin: 1em 0 0.5em 0; }
40
+ .tiptap-editor h6 { font-size: 0.9em !important; font-weight: 600 !important; margin: 1em 0 0.5em 0; }
41
+ .tiptap-editor h1:first-child, .tiptap-editor h2:first-child, .tiptap-editor h3:first-child,
42
+ .tiptap-editor h4:first-child, .tiptap-editor h5:first-child, .tiptap-editor h6:first-child { margin-top: 0; }
43
+ .tiptap-editor ul, .tiptap-editor ol { padding-left: 1.5em !important; margin: 0 0 1em 0; }
44
+ .tiptap-editor ul { list-style-type: disc !important; }
45
+ .tiptap-editor ol { list-style-type: decimal !important; }
46
+ .tiptap-editor li { margin: 0.25em 0; }
47
+ .tiptap-editor li p { margin: 0; }
48
+ .tiptap-editor blockquote { border-left: 4px solid var(--theme-elevation-200) !important; padding-left: 1em !important; margin: 1em 0 !important; font-style: italic !important; }
49
+ .tiptap-editor p { margin: 0 0 1em 0; }
50
+ .tiptap-editor p:last-child { margin-bottom: 0; }
51
+ @keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
52
+ `;
53
+ // Inject styles once when module loads
54
+ if (typeof document !== 'undefined') {
55
+ const styleId = 'tiptap-editor-injected-styles';
56
+ if (!document.getElementById(styleId)) {
57
+ const style = document.createElement('style');
58
+ style.id = styleId;
59
+ style.textContent = TIPTAP_EDITOR_STYLES;
60
+ document.head.appendChild(style);
61
+ }
62
+ }
63
+ // =============================================================================
64
+ // Styles
65
+ // =============================================================================
66
+ const styles = {
67
+ icon: {
68
+ width: '18px',
69
+ height: '18px',
70
+ },
71
+ iconSmall: {
72
+ width: '12px',
73
+ height: '12px',
74
+ },
75
+ toolbarButton: {
76
+ height: '28px',
77
+ width: '28px',
78
+ padding: 0,
79
+ flexShrink: 0,
80
+ display: 'inline-flex',
81
+ alignItems: 'center',
82
+ justifyContent: 'center',
83
+ borderRadius: '4px',
84
+ transition: 'background-color 0.15s',
85
+ border: 'none',
86
+ cursor: 'pointer',
87
+ backgroundColor: 'transparent',
88
+ },
89
+ toolbarButtonActive: {
90
+ backgroundColor: 'var(--theme-elevation-200)',
91
+ },
92
+ toolbarDivider: {
93
+ width: '1px',
94
+ height: '24px',
95
+ backgroundColor: 'var(--theme-elevation-300)',
96
+ margin: '0 4px',
97
+ flexShrink: 0,
98
+ },
99
+ dropdown: {
100
+ position: 'absolute',
101
+ top: '100%',
102
+ left: 0,
103
+ marginTop: '4px',
104
+ backgroundColor: 'var(--theme-bg)',
105
+ border: '1px solid var(--theme-elevation-200)',
106
+ borderRadius: '6px',
107
+ boxShadow: '0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)',
108
+ zIndex: 50,
109
+ minWidth: '160px',
110
+ },
111
+ dropdownItem: {
112
+ width: '100%',
113
+ padding: '8px 12px',
114
+ textAlign: 'left',
115
+ fontSize: '14px',
116
+ transition: 'background-color 0.15s',
117
+ display: 'flex',
118
+ alignItems: 'center',
119
+ border: 'none',
120
+ backgroundColor: 'transparent',
121
+ cursor: 'pointer',
122
+ },
123
+ dropdownLabel: {
124
+ padding: '4px 12px',
125
+ fontSize: '12px',
126
+ color: 'var(--theme-elevation-500)',
127
+ fontWeight: 500,
128
+ },
129
+ dropdownSeparator: {
130
+ height: '1px',
131
+ backgroundColor: 'var(--theme-elevation-200)',
132
+ margin: '4px 0',
133
+ },
134
+ linkPopover: {
135
+ position: 'absolute',
136
+ top: '100%',
137
+ left: 0,
138
+ marginTop: '4px',
139
+ backgroundColor: 'var(--theme-bg)',
140
+ border: '1px solid var(--theme-elevation-200)',
141
+ borderRadius: '6px',
142
+ boxShadow: '0 10px 15px -3px rgba(0, 0, 0, 0.1)',
143
+ zIndex: 50,
144
+ padding: '12px',
145
+ width: '320px',
146
+ },
147
+ input: {
148
+ width: '100%',
149
+ padding: '8px 12px',
150
+ border: '1px solid var(--theme-elevation-300)',
151
+ borderRadius: '6px',
152
+ fontSize: '14px',
153
+ outline: 'none',
154
+ },
155
+ buttonPrimary: {
156
+ padding: '6px 12px',
157
+ backgroundColor: 'var(--theme-elevation-900)',
158
+ color: 'var(--theme-bg)',
159
+ fontSize: '14px',
160
+ borderRadius: '6px',
161
+ border: 'none',
162
+ cursor: 'pointer',
163
+ },
164
+ buttonSecondary: {
165
+ padding: '6px 12px',
166
+ color: 'var(--theme-elevation-600)',
167
+ fontSize: '14px',
168
+ borderRadius: '6px',
169
+ border: 'none',
170
+ backgroundColor: 'transparent',
171
+ cursor: 'pointer',
172
+ },
173
+ fieldContainer: {
174
+ // puck-field class
175
+ },
176
+ label: {
177
+ display: 'block',
178
+ fontSize: '14px',
179
+ fontWeight: 500,
180
+ color: 'var(--theme-elevation-700)',
181
+ marginBottom: '8px',
182
+ },
183
+ editorWrapper: {
184
+ border: '1px solid var(--theme-elevation-200)',
185
+ borderRadius: '8px',
186
+ backgroundColor: 'var(--theme-bg)',
187
+ overflow: 'hidden',
188
+ },
189
+ toolbar: {
190
+ borderBottom: '1px solid var(--theme-elevation-200)',
191
+ backgroundColor: 'var(--theme-elevation-50)',
192
+ display: 'flex',
193
+ alignItems: 'center',
194
+ flexWrap: 'wrap',
195
+ gap: '4px',
196
+ padding: '8px',
197
+ },
198
+ editorContent: {
199
+ minHeight: '200px',
200
+ backgroundColor: 'var(--theme-bg)',
201
+ },
202
+ sourceTextarea: {
203
+ width: '100%',
204
+ minHeight: '200px',
205
+ padding: '16px',
206
+ fontFamily: 'monospace',
207
+ fontSize: '14px',
208
+ border: 'none',
209
+ resize: 'vertical',
210
+ outline: 'none',
211
+ },
212
+ fontSizeGrid: {
213
+ display: 'grid',
214
+ gridTemplateColumns: 'repeat(3, 1fr)',
215
+ gap: '4px',
216
+ padding: '0 8px 8px',
217
+ },
218
+ fontSizeButton: {
219
+ padding: '6px 8px',
220
+ fontSize: '12px',
221
+ borderRadius: '4px',
222
+ border: '1px solid var(--theme-elevation-200)',
223
+ backgroundColor: 'transparent',
224
+ cursor: 'pointer',
225
+ textAlign: 'center',
226
+ transition: 'background-color 0.15s',
227
+ },
228
+ customSizeInput: {
229
+ width: '64px',
230
+ padding: '4px 8px',
231
+ fontSize: '14px',
232
+ border: '1px solid var(--theme-elevation-200)',
233
+ borderRadius: '4px',
234
+ outline: 'none',
235
+ },
236
+ customSizeSelect: {
237
+ padding: '4px',
238
+ fontSize: '14px',
239
+ border: '1px solid var(--theme-elevation-200)',
240
+ borderRadius: '4px',
241
+ outline: 'none',
242
+ },
243
+ customSizeApply: {
244
+ padding: '4px 8px',
245
+ fontSize: '12px',
246
+ backgroundColor: 'var(--theme-elevation-900)',
247
+ color: 'var(--theme-bg)',
248
+ borderRadius: '4px',
249
+ border: 'none',
250
+ cursor: 'pointer',
251
+ },
252
+ sourceButton: {
253
+ display: 'inline-flex',
254
+ alignItems: 'center',
255
+ borderRadius: '4px',
256
+ transition: 'background-color 0.15s',
257
+ fontSize: '12px',
258
+ height: '28px',
259
+ padding: '0 8px',
260
+ gap: '4px',
261
+ flexShrink: 0,
262
+ border: 'none',
263
+ cursor: 'pointer',
264
+ backgroundColor: 'transparent',
265
+ },
266
+ loadingState: {
267
+ minHeight: '200px',
268
+ padding: '16px',
269
+ color: 'var(--theme-elevation-400)',
270
+ },
271
+ // Color picker styles
272
+ colorPickerContainer: {
273
+ padding: '12px',
274
+ display: 'flex',
275
+ flexDirection: 'column',
276
+ gap: '12px',
277
+ minWidth: '240px',
278
+ },
279
+ colorPickerRow: {
280
+ display: 'flex',
281
+ alignItems: 'center',
282
+ gap: '8px',
283
+ },
284
+ colorPickerInput: {
285
+ width: '36px',
286
+ height: '36px',
287
+ padding: 0,
288
+ border: '1px solid var(--theme-elevation-200)',
289
+ borderRadius: '6px',
290
+ cursor: 'pointer',
291
+ flexShrink: 0,
292
+ },
293
+ colorPickerHexInput: {
294
+ flex: 1,
295
+ height: '36px',
296
+ padding: '0 10px',
297
+ fontSize: '13px',
298
+ fontFamily: 'monospace',
299
+ border: '1px solid var(--theme-elevation-200)',
300
+ borderRadius: '6px',
301
+ backgroundColor: 'var(--theme-input-bg)',
302
+ color: 'var(--theme-elevation-800)',
303
+ outline: 'none',
304
+ },
305
+ colorPickerPreview: {
306
+ width: '36px',
307
+ height: '36px',
308
+ borderRadius: '6px',
309
+ border: '1px solid var(--theme-elevation-200)',
310
+ flexShrink: 0,
311
+ position: 'relative',
312
+ overflow: 'hidden',
313
+ },
314
+ colorPickerCheckerboard: {
315
+ position: 'absolute',
316
+ inset: 0,
317
+ backgroundImage: 'linear-gradient(45deg, #d0d0d0 25%, transparent 25%), linear-gradient(-45deg, #d0d0d0 25%, transparent 25%), linear-gradient(45deg, transparent 75%, #d0d0d0 75%), linear-gradient(-45deg, transparent 75%, #d0d0d0 75%)',
318
+ backgroundSize: '8px 8px',
319
+ backgroundPosition: '0 0, 0 4px, 4px -4px, -4px 0px',
320
+ backgroundColor: '#f0f0f0',
321
+ },
322
+ colorPickerOverlay: {
323
+ position: 'absolute',
324
+ inset: 0,
325
+ },
326
+ colorPickerOpacitySection: {
327
+ display: 'flex',
328
+ flexDirection: 'column',
329
+ gap: '4px',
330
+ },
331
+ colorPickerOpacityHeader: {
332
+ display: 'flex',
333
+ alignItems: 'center',
334
+ justifyContent: 'space-between',
335
+ },
336
+ colorPickerOpacityLabel: {
337
+ fontSize: '11px',
338
+ color: 'var(--theme-elevation-500)',
339
+ },
340
+ colorPickerOpacityValue: {
341
+ fontSize: '11px',
342
+ fontFamily: 'monospace',
343
+ color: 'var(--theme-elevation-500)',
344
+ },
345
+ colorPickerOpacitySlider: {
346
+ position: 'relative',
347
+ height: '10px',
348
+ borderRadius: '5px',
349
+ overflow: 'hidden',
350
+ border: '1px solid var(--theme-elevation-200)',
351
+ },
352
+ colorPickerOpacityInputRange: {
353
+ position: 'absolute',
354
+ inset: 0,
355
+ width: '100%',
356
+ height: '100%',
357
+ opacity: 0,
358
+ cursor: 'pointer',
359
+ margin: 0,
360
+ },
361
+ colorPickerOpacityThumb: {
362
+ position: 'absolute',
363
+ top: 0,
364
+ bottom: 0,
365
+ width: '4px',
366
+ backgroundColor: 'white',
367
+ border: '1px solid var(--theme-elevation-400)',
368
+ borderRadius: '2px',
369
+ boxShadow: '0 1px 2px rgba(0,0,0,0.15)',
370
+ pointerEvents: 'none',
371
+ },
372
+ colorPickerPresetsLabel: {
373
+ fontSize: '11px',
374
+ color: 'var(--theme-elevation-500)',
375
+ marginBottom: '4px',
376
+ },
377
+ colorPickerPresetsGrid: {
378
+ display: 'flex',
379
+ flexWrap: 'wrap',
380
+ gap: '4px',
381
+ },
382
+ colorPickerPresetButton: {
383
+ width: '22px',
384
+ height: '22px',
385
+ padding: 0,
386
+ borderRadius: '4px',
387
+ cursor: 'pointer',
388
+ border: '1px solid var(--theme-elevation-200)',
389
+ outline: 'none',
390
+ transition: 'transform 0.1s',
391
+ },
392
+ colorPickerPresetButtonSelected: {
393
+ width: '22px',
394
+ height: '22px',
395
+ padding: 0,
396
+ borderRadius: '4px',
397
+ cursor: 'pointer',
398
+ border: '2px solid var(--theme-elevation-800)',
399
+ outline: '2px solid var(--theme-elevation-200)',
400
+ outlineOffset: '1px',
401
+ },
402
+ colorPickerThemeButton: {
403
+ display: 'flex',
404
+ alignItems: 'center',
405
+ gap: '8px',
406
+ width: '100%',
407
+ padding: '8px',
408
+ border: '1px solid var(--theme-elevation-200)',
409
+ borderRadius: '6px',
410
+ backgroundColor: 'transparent',
411
+ cursor: 'pointer',
412
+ fontSize: '13px',
413
+ color: 'var(--theme-elevation-700)',
414
+ transition: 'background-color 0.15s',
415
+ },
416
+ colorPickerThemeSwatch: {
417
+ width: '20px',
418
+ height: '20px',
419
+ borderRadius: '4px',
420
+ border: '1px solid var(--theme-elevation-300)',
421
+ flexShrink: 0,
422
+ background: 'linear-gradient(135deg, #fff 50%, #1f2937 50%)',
423
+ },
424
+ };
425
+ const FontSize = Extension.create({
426
+ name: 'fontSize',
427
+ addOptions() {
428
+ return {
429
+ types: ['textStyle'],
430
+ };
431
+ },
432
+ addGlobalAttributes() {
433
+ return [
434
+ {
435
+ types: this.options.types,
436
+ attributes: {
437
+ fontSize: {
438
+ default: null,
439
+ parseHTML: element => element.style.fontSize?.replace(/['"]+/g, ''),
440
+ renderHTML: attributes => {
441
+ if (!attributes.fontSize) {
442
+ return {};
443
+ }
444
+ return {
445
+ style: `font-size: ${attributes.fontSize}`,
446
+ };
447
+ },
448
+ },
449
+ },
450
+ },
451
+ ];
452
+ },
453
+ addCommands() {
454
+ return {
455
+ setFontSize: (fontSize) => ({ chain }) => {
456
+ return chain().setMark('textStyle', { fontSize }).run();
457
+ },
458
+ unsetFontSize: () => ({ chain }) => {
459
+ return chain()
460
+ .setMark('textStyle', { fontSize: null })
461
+ .removeEmptyTextStyle()
462
+ .run();
463
+ },
464
+ };
465
+ },
466
+ });
467
+ // =============================================================================
468
+ // Color Utilities
469
+ // =============================================================================
470
+ /**
471
+ * Validates and normalizes a hex color string
472
+ */
473
+ function normalizeHex(hex) {
474
+ let clean = hex.replace(/^#/, '');
475
+ if (clean.length === 3) {
476
+ clean = clean.split('').map(c => c + c).join('');
477
+ }
478
+ if (!/^[0-9A-Fa-f]{6}$/.test(clean)) {
479
+ return '';
480
+ }
481
+ return `#${clean.toLowerCase()}`;
482
+ }
483
+ /**
484
+ * Converts hex + opacity to rgba CSS string
485
+ */
486
+ function hexToRgba(hex, opacity) {
487
+ const clean = hex.replace(/^#/, '');
488
+ const r = parseInt(clean.substring(0, 2), 16);
489
+ const g = parseInt(clean.substring(2, 4), 16);
490
+ const b = parseInt(clean.substring(4, 6), 16);
491
+ return `rgba(${r}, ${g}, ${b}, ${opacity / 100})`;
492
+ }
493
+ /**
494
+ * Parses a color string (hex or rgba) and returns hex + opacity
495
+ */
496
+ function parseColor(color) {
497
+ if (!color)
498
+ return { hex: '#000000', opacity: 100 };
499
+ // Handle rgba
500
+ const rgbaMatch = color.match(/rgba?\((\d+),\s*(\d+),\s*(\d+)(?:,\s*([\d.]+))?\)/);
501
+ if (rgbaMatch) {
502
+ const r = parseInt(rgbaMatch[1], 10);
503
+ const g = parseInt(rgbaMatch[2], 10);
504
+ const b = parseInt(rgbaMatch[3], 10);
505
+ const a = rgbaMatch[4] ? parseFloat(rgbaMatch[4]) : 1;
506
+ const hex = `#${r.toString(16).padStart(2, '0')}${g.toString(16).padStart(2, '0')}${b.toString(16).padStart(2, '0')}`;
507
+ return { hex, opacity: Math.round(a * 100) };
508
+ }
509
+ // Handle hex
510
+ const normalized = normalizeHex(color);
511
+ if (normalized) {
512
+ return { hex: normalized, opacity: 100 };
513
+ }
514
+ return { hex: '#000000', opacity: 100 };
515
+ }
516
+ // =============================================================================
517
+ // Font Sizes
518
+ // =============================================================================
519
+ const FONT_SIZES = [
520
+ { label: 'XS', value: '0.75rem', px: '12px' },
521
+ { label: 'Small', value: '0.875rem', px: '14px' },
522
+ { label: 'Normal', value: null, px: '16px' },
523
+ { label: 'Medium', value: '1.125rem', px: '18px' },
524
+ { label: 'Large', value: '1.25rem', px: '20px' },
525
+ { label: 'XL', value: '1.5rem', px: '24px' },
526
+ { label: '2XL', value: '1.875rem', px: '30px' },
527
+ { label: '3XL', value: '2.25rem', px: '36px' },
528
+ { label: '4XL', value: '3rem', px: '48px' },
529
+ ];
530
+ const FONT_SIZE_UNITS = ['px', 'rem', 'em'];
531
+ // =============================================================================
532
+ // UI Components
533
+ // =============================================================================
534
+ function ToolbarButton({ onClick, isActive, title, children, }) {
535
+ const [hovered, setHovered] = useState(false);
536
+ return (_jsx("button", { type: "button", onClick: onClick, title: title, onMouseEnter: () => setHovered(true), onMouseLeave: () => setHovered(false), style: {
537
+ ...styles.toolbarButton,
538
+ ...(isActive ? styles.toolbarButtonActive : {}),
539
+ ...(hovered && !isActive ? { backgroundColor: 'var(--theme-elevation-100)' } : {}),
540
+ }, children: children }));
541
+ }
542
+ function ToolbarDropdown({ trigger, children, title, isActive, }) {
543
+ const [isOpen, setIsOpen] = useState(false);
544
+ const [hovered, setHovered] = useState(false);
545
+ const dropdownRef = useRef(null);
546
+ const close = useCallback(() => setIsOpen(false), []);
547
+ useEffect(() => {
548
+ function handleClickOutside(event) {
549
+ const activeElement = document.activeElement;
550
+ if (activeElement?.tagName === 'INPUT' && activeElement.type === 'color') {
551
+ return;
552
+ }
553
+ if (dropdownRef.current && !dropdownRef.current.contains(event.target)) {
554
+ setIsOpen(false);
555
+ }
556
+ }
557
+ document.addEventListener('mousedown', handleClickOutside);
558
+ return () => document.removeEventListener('mousedown', handleClickOutside);
559
+ }, []);
560
+ return (_jsxs("div", { ref: dropdownRef, style: { position: 'relative', flexShrink: 0 }, children: [_jsx("button", { type: "button", onClick: () => setIsOpen(!isOpen), title: title, onMouseEnter: () => setHovered(true), onMouseLeave: () => setHovered(false), style: {
561
+ ...styles.toolbarButton,
562
+ ...(isActive ? styles.toolbarButtonActive : {}),
563
+ ...(hovered && !isActive ? { backgroundColor: 'var(--theme-elevation-100)' } : {}),
564
+ }, children: trigger }), isOpen && (_jsx("div", { style: styles.dropdown, children: typeof children === 'function' ? children(close) : children }))] }));
565
+ }
566
+ function DropdownItem({ onClick, children, }) {
567
+ const [hovered, setHovered] = useState(false);
568
+ return (_jsx("button", { type: "button", onClick: onClick, onMouseEnter: () => setHovered(true), onMouseLeave: () => setHovered(false), style: {
569
+ ...styles.dropdownItem,
570
+ ...(hovered ? { backgroundColor: 'var(--theme-elevation-100)' } : {}),
571
+ }, children: children }));
572
+ }
573
+ function DropdownLabel({ children }) {
574
+ return _jsx("div", { style: styles.dropdownLabel, children: children });
575
+ }
576
+ function DropdownSeparator() {
577
+ return _jsx("div", { style: styles.dropdownSeparator });
578
+ }
579
+ function TiptapColorPicker({ currentColor, onColorChange, onClose, showOpacity = true, mode = 'text', }) {
580
+ const theme = useTheme();
581
+ const presets = theme.colorPresets;
582
+ const parsed = parseColor(currentColor);
583
+ const [hex, setHex] = useState(parsed.hex);
584
+ const [hexInput, setHexInput] = useState(parsed.hex);
585
+ const [opacity, setOpacity] = useState(parsed.opacity);
586
+ const [hoverTheme, setHoverTheme] = useState(false);
587
+ // Apply color to editor (converts to rgba if opacity < 100)
588
+ const applyColor = useCallback((h, o) => {
589
+ if (o < 100) {
590
+ onColorChange(hexToRgba(h, o));
591
+ }
592
+ else {
593
+ onColorChange(h);
594
+ }
595
+ }, [onColorChange]);
596
+ const handleColorInputChange = useCallback((e) => {
597
+ const newHex = e.target.value;
598
+ setHex(newHex);
599
+ setHexInput(newHex);
600
+ applyColor(newHex, opacity);
601
+ }, [opacity, applyColor]);
602
+ const handleHexInputChange = useCallback((e) => {
603
+ const input = e.target.value;
604
+ setHexInput(input);
605
+ const normalized = normalizeHex(input);
606
+ if (normalized) {
607
+ setHex(normalized);
608
+ applyColor(normalized, opacity);
609
+ }
610
+ }, [opacity, applyColor]);
611
+ const handleHexInputBlur = useCallback(() => {
612
+ setHexInput(hex);
613
+ }, [hex]);
614
+ const handleOpacityChange = useCallback((e) => {
615
+ const newOpacity = parseInt(e.target.value, 10);
616
+ setOpacity(newOpacity);
617
+ applyColor(hex, newOpacity);
618
+ }, [hex, applyColor]);
619
+ const handlePresetClick = useCallback((preset) => {
620
+ setHex(preset.hex);
621
+ setHexInput(preset.hex);
622
+ setOpacity(100);
623
+ applyColor(preset.hex, 100);
624
+ onClose();
625
+ }, [applyColor, onClose]);
626
+ const handleClearColor = useCallback(() => {
627
+ onColorChange(null);
628
+ onClose();
629
+ }, [onColorChange, onClose]);
630
+ const previewColor = hexToRgba(hex, opacity);
631
+ return (_jsxs("div", { style: styles.colorPickerContainer, children: [_jsxs("button", { type: "button", onClick: handleClearColor, onMouseEnter: () => setHoverTheme(true), onMouseLeave: () => setHoverTheme(false), style: {
632
+ ...styles.colorPickerThemeButton,
633
+ ...(hoverTheme ? { backgroundColor: 'var(--theme-elevation-50)' } : {}),
634
+ }, children: [_jsx("span", { style: styles.colorPickerThemeSwatch }), mode === 'text' ? 'Theme Color (Auto)' : 'Remove Highlight'] }), _jsxs("div", { style: styles.colorPickerRow, children: [_jsx("input", { type: "color", value: hex, onChange: handleColorInputChange, style: styles.colorPickerInput, title: "Pick a color" }), _jsx("input", { type: "text", value: hexInput, onChange: handleHexInputChange, onBlur: handleHexInputBlur, placeholder: "#000000", style: styles.colorPickerHexInput }), _jsxs("div", { style: styles.colorPickerPreview, title: `${hex} at ${opacity}% opacity`, children: [_jsx("div", { style: styles.colorPickerCheckerboard }), _jsx("div", { style: { ...styles.colorPickerOverlay, backgroundColor: previewColor } })] })] }), showOpacity && (_jsxs("div", { style: styles.colorPickerOpacitySection, children: [_jsxs("div", { style: styles.colorPickerOpacityHeader, children: [_jsx("label", { style: styles.colorPickerOpacityLabel, children: "Opacity" }), _jsxs("span", { style: styles.colorPickerOpacityValue, children: [opacity, "%"] })] }), _jsxs("div", { style: styles.colorPickerOpacitySlider, children: [_jsx("div", { style: styles.colorPickerCheckerboard }), _jsx("div", { style: {
635
+ ...styles.colorPickerOverlay,
636
+ background: `linear-gradient(to right, transparent 0%, ${hex} 100%)`,
637
+ } }), _jsx("input", { type: "range", min: "0", max: "100", value: opacity, onChange: handleOpacityChange, style: styles.colorPickerOpacityInputRange }), _jsx("div", { style: {
638
+ ...styles.colorPickerOpacityThumb,
639
+ left: `calc(${opacity}% - 2px)`,
640
+ } })] })] })), presets.length > 0 && (_jsxs("div", { children: [_jsx("div", { style: styles.colorPickerPresetsLabel, children: "Presets" }), _jsx("div", { style: styles.colorPickerPresetsGrid, children: presets.map((preset) => {
641
+ const isSelected = hex.toLowerCase() === preset.hex.toLowerCase();
642
+ return (_jsx("button", { type: "button", onClick: () => handlePresetClick(preset), style: {
643
+ ...(isSelected ? styles.colorPickerPresetButtonSelected : styles.colorPickerPresetButton),
644
+ backgroundColor: preset.hex,
645
+ }, title: preset.label }, preset.hex));
646
+ }) })] }))] }));
647
+ }
648
+ function LinkPopover({ isOpen, onClose, onSetLink, onRemoveLink, }) {
649
+ const [url, setUrl] = useState('');
650
+ const popoverRef = useRef(null);
651
+ useEffect(() => {
652
+ function handleClickOutside(event) {
653
+ if (popoverRef.current && !popoverRef.current.contains(event.target)) {
654
+ onClose();
655
+ }
656
+ }
657
+ if (isOpen) {
658
+ document.addEventListener('mousedown', handleClickOutside);
659
+ }
660
+ return () => document.removeEventListener('mousedown', handleClickOutside);
661
+ }, [isOpen, onClose]);
662
+ if (!isOpen)
663
+ return null;
664
+ return (_jsx("div", { ref: popoverRef, style: styles.linkPopover, children: _jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: '8px' }, children: [_jsx("label", { style: { fontSize: '14px', fontWeight: 500, color: 'var(--theme-elevation-700)' }, children: "URL" }), _jsx("input", { type: "text", placeholder: "https://example.com", value: url, onChange: (e) => setUrl(e.target.value), onKeyDown: (e) => {
665
+ if (e.key === 'Enter') {
666
+ e.preventDefault();
667
+ if (url) {
668
+ onSetLink(url);
669
+ setUrl('');
670
+ }
671
+ }
672
+ }, style: styles.input }), _jsxs("div", { style: { display: 'flex', gap: '8px' }, children: [_jsx("button", { type: "button", onClick: () => {
673
+ if (url) {
674
+ onSetLink(url);
675
+ setUrl('');
676
+ }
677
+ }, style: styles.buttonPrimary, children: "Add Link" }), _jsx("button", { type: "button", onClick: () => {
678
+ onRemoveLink();
679
+ setUrl('');
680
+ }, style: styles.buttonSecondary, children: "Remove Link" })] })] }) }));
681
+ }
682
+ // =============================================================================
683
+ // Tiptap Extensions Factory
684
+ // =============================================================================
685
+ function createTiptapExtensions() {
686
+ return [
687
+ StarterKit.configure({
688
+ heading: { levels: [1, 2, 3, 4, 5, 6] },
689
+ strike: {},
690
+ horizontalRule: {},
691
+ hardBreak: {},
692
+ link: {
693
+ openOnClick: false,
694
+ HTMLAttributes: {
695
+ style: 'color: var(--theme-elevation-700); text-decoration: underline;',
696
+ },
697
+ },
698
+ underline: {},
699
+ }),
700
+ TextAlign.configure({
701
+ types: ['heading', 'paragraph'],
702
+ alignments: ['left', 'center', 'right', 'justify'],
703
+ }),
704
+ TextStyle,
705
+ Color,
706
+ Highlight.configure({ multicolor: true }),
707
+ FontSize,
708
+ Superscript,
709
+ Subscript,
710
+ ];
711
+ }
712
+ // =============================================================================
713
+ // TiptapField Component
714
+ // =============================================================================
715
+ function TiptapFieldInner({ value, onChange, label, readOnly }) {
716
+ const [isLinkPopoverOpen, setIsLinkPopoverOpen] = useState(false);
717
+ const [showSource, setShowSource] = useState(false);
718
+ const [sourceContent, setSourceContent] = useState(value);
719
+ const onChangeRef = useRef(onChange);
720
+ onChangeRef.current = onChange;
721
+ const handleUpdate = useCallback(({ editor }) => {
722
+ if (editor) {
723
+ const html = editor.getHTML();
724
+ onChangeRef.current(html);
725
+ }
726
+ }, []);
727
+ const editor = useEditor({
728
+ extensions: createTiptapExtensions(),
729
+ content: value,
730
+ editorProps: {
731
+ attributes: {
732
+ class: 'tiptap-editor focus:outline-none min-h-[200px] p-4',
733
+ style: 'min-height: 200px; padding: 16px; outline: none;',
734
+ },
735
+ },
736
+ onUpdate: handleUpdate,
737
+ immediatelyRender: false,
738
+ shouldRerenderOnTransaction: false,
739
+ });
740
+ const formattingState = useEditorState({
741
+ editor,
742
+ selector: ({ editor: e }) => {
743
+ if (!e)
744
+ return null;
745
+ return {
746
+ isBold: e.isActive('bold'),
747
+ isItalic: e.isActive('italic'),
748
+ isUnderline: e.isActive('underline'),
749
+ isStrike: e.isActive('strike'),
750
+ isH1: e.isActive('heading', { level: 1 }),
751
+ isH2: e.isActive('heading', { level: 2 }),
752
+ isH3: e.isActive('heading', { level: 3 }),
753
+ isH4: e.isActive('heading', { level: 4 }),
754
+ isH5: e.isActive('heading', { level: 5 }),
755
+ isH6: e.isActive('heading', { level: 6 }),
756
+ isBulletList: e.isActive('bulletList'),
757
+ isOrderedList: e.isActive('orderedList'),
758
+ isBlockquote: e.isActive('blockquote'),
759
+ isAlignLeft: e.isActive({ textAlign: 'left' }),
760
+ isAlignCenter: e.isActive({ textAlign: 'center' }),
761
+ isAlignRight: e.isActive({ textAlign: 'right' }),
762
+ isAlignJustify: e.isActive({ textAlign: 'justify' }),
763
+ isLink: e.isActive('link'),
764
+ isHighlight: e.isActive('highlight'),
765
+ isSuperscript: e.isActive('superscript'),
766
+ isSubscript: e.isActive('subscript'),
767
+ };
768
+ },
769
+ });
770
+ if (!editor) {
771
+ return (_jsxs("div", { className: "puck-field", children: [label && _jsx("label", { style: styles.label, children: label }), _jsx("div", { style: styles.editorWrapper, children: _jsx("div", { style: styles.loadingState, children: "Loading editor..." }) })] }));
772
+ }
773
+ const setLink = (url) => {
774
+ editor.chain().focus().extendMarkRange('link').setLink({ href: url }).run();
775
+ setIsLinkPopoverOpen(false);
776
+ };
777
+ const removeLink = () => {
778
+ editor.chain().focus().unsetLink().run();
779
+ setIsLinkPopoverOpen(false);
780
+ };
781
+ return (_jsxs("div", { className: "puck-field", children: [label && _jsx("label", { style: styles.label, children: label }), _jsxs("div", { style: styles.editorWrapper, children: [!readOnly && (_jsxs("div", { style: styles.toolbar, children: [_jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleBold().run(), isActive: formattingState?.isBold, title: "Bold", children: _jsx(Bold, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleItalic().run(), isActive: formattingState?.isItalic, title: "Italic", children: _jsx(Italic, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleUnderline().run(), isActive: formattingState?.isUnderline, title: "Underline", children: _jsx(Underline, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleStrike().run(), isActive: formattingState?.isStrike, title: "Strikethrough", children: _jsx(Strikethrough, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleSuperscript().run(), isActive: formattingState?.isSuperscript, title: "Superscript", children: _jsx(SuperscriptIcon, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleSubscript().run(), isActive: formattingState?.isSubscript, title: "Subscript", children: _jsx(SubscriptIcon, { style: styles.icon }) }), _jsx("div", { style: styles.toolbarDivider }), _jsx(ToolbarDropdown, { trigger: _jsxs("span", { style: { display: 'flex', alignItems: 'center', gap: '2px' }, children: [formattingState?.isH1 ? _jsx(Heading1, { style: styles.icon }) :
782
+ formattingState?.isH2 ? _jsx(Heading2, { style: styles.icon }) :
783
+ formattingState?.isH3 ? _jsx(Heading3, { style: styles.icon }) :
784
+ formattingState?.isH4 ? _jsx(Heading4, { style: styles.icon }) :
785
+ formattingState?.isH5 ? _jsx(Heading5, { style: styles.icon }) :
786
+ formattingState?.isH6 ? _jsx(Heading6, { style: styles.icon }) :
787
+ _jsx(Pilcrow, { style: styles.icon }), _jsx(ChevronDown, { style: styles.iconSmall })] }), title: "Text Type", isActive: formattingState?.isH1 || formattingState?.isH2 || formattingState?.isH3 || formattingState?.isH4 || formattingState?.isH5 || formattingState?.isH6, children: (close) => (_jsxs(_Fragment, { children: [_jsxs(DropdownItem, { onClick: () => { editor.chain().focus().setParagraph().run(); close(); }, children: [_jsx(Pilcrow, { style: { ...styles.icon, marginRight: '8px' } }), "Paragraph"] }), _jsx(DropdownSeparator, {}), _jsxs(DropdownItem, { onClick: () => { editor.chain().focus().toggleHeading({ level: 1 }).run(); close(); }, children: [_jsx(Heading1, { style: { ...styles.icon, marginRight: '8px' } }), _jsx("span", { style: { fontWeight: 700, fontSize: '18px' }, children: "Heading 1" })] }), _jsxs(DropdownItem, { onClick: () => { editor.chain().focus().toggleHeading({ level: 2 }).run(); close(); }, children: [_jsx(Heading2, { style: { ...styles.icon, marginRight: '8px' } }), _jsx("span", { style: { fontWeight: 700, fontSize: '16px' }, children: "Heading 2" })] }), _jsxs(DropdownItem, { onClick: () => { editor.chain().focus().toggleHeading({ level: 3 }).run(); close(); }, children: [_jsx(Heading3, { style: { ...styles.icon, marginRight: '8px' } }), _jsx("span", { style: { fontWeight: 600 }, children: "Heading 3" })] }), _jsxs(DropdownItem, { onClick: () => { editor.chain().focus().toggleHeading({ level: 4 }).run(); close(); }, children: [_jsx(Heading4, { style: { ...styles.icon, marginRight: '8px' } }), _jsx("span", { style: { fontWeight: 600, fontSize: '14px' }, children: "Heading 4" })] }), _jsxs(DropdownItem, { onClick: () => { editor.chain().focus().toggleHeading({ level: 5 }).run(); close(); }, children: [_jsx(Heading5, { style: { ...styles.icon, marginRight: '8px' } }), _jsx("span", { style: { fontWeight: 600, fontSize: '12px' }, children: "Heading 5" })] }), _jsxs(DropdownItem, { onClick: () => { editor.chain().focus().toggleHeading({ level: 6 }).run(); close(); }, children: [_jsx(Heading6, { style: { ...styles.icon, marginRight: '8px' } }), _jsx("span", { style: { fontWeight: 600, fontSize: '12px', color: 'var(--theme-elevation-600)' }, children: "Heading 6" })] })] })) }), _jsx("div", { style: styles.toolbarDivider }), _jsx(ToolbarDropdown, { trigger: _jsx(ALargeSmall, { style: styles.icon }), title: "Font Size", children: (close) => (_jsxs(_Fragment, { children: [_jsx(DropdownLabel, { children: "Presets" }), _jsx("div", { style: styles.fontSizeGrid, children: FONT_SIZES.map((size) => (_jsx("button", { type: "button", onClick: () => {
788
+ if (size.value) {
789
+ editor.chain().focus().setFontSize(size.value).run();
790
+ }
791
+ else {
792
+ editor.chain().focus().unsetFontSize().run();
793
+ }
794
+ close();
795
+ }, style: styles.fontSizeButton, title: size.px, children: size.label }, size.label))) }), _jsx(DropdownSeparator, {}), _jsxs("div", { style: { padding: '8px' }, children: [_jsx(DropdownLabel, { children: "Custom Size" }), _jsxs("div", { style: { display: 'flex', alignItems: 'center', gap: '4px', marginTop: '4px' }, children: [_jsx("input", { type: "number", placeholder: "16", min: "8", max: "200", style: styles.customSizeInput, onKeyDown: (e) => {
796
+ if (e.key === 'Enter') {
797
+ const input = e.target;
798
+ const value = input.value;
799
+ const unit = input.nextElementSibling?.value || 'px';
800
+ if (value) {
801
+ editor.chain().focus().setFontSize(`${value}${unit}`).run();
802
+ close();
803
+ }
804
+ }
805
+ } }), _jsx("select", { style: styles.customSizeSelect, defaultValue: "px", children: FONT_SIZE_UNITS.map((unit) => (_jsx("option", { value: unit, children: unit }, unit))) }), _jsx("button", { type: "button", onClick: (e) => {
806
+ const container = e.target.parentElement;
807
+ const input = container?.querySelector('input');
808
+ const select = container?.querySelector('select');
809
+ const value = input?.value;
810
+ const unit = select?.value || 'px';
811
+ if (value) {
812
+ editor.chain().focus().setFontSize(`${value}${unit}`).run();
813
+ close();
814
+ }
815
+ }, style: styles.customSizeApply, children: "Apply" })] })] })] })) }), _jsx("div", { style: styles.toolbarDivider }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleBulletList().run(), isActive: formattingState?.isBulletList, title: "Bullet List", children: _jsx(List, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleOrderedList().run(), isActive: formattingState?.isOrderedList, title: "Numbered List", children: _jsx(ListOrdered, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().toggleBlockquote().run(), isActive: formattingState?.isBlockquote, title: "Blockquote", children: _jsx(Quote, { style: styles.icon }) }), _jsx("div", { style: styles.toolbarDivider }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().setTextAlign('left').run(), isActive: formattingState?.isAlignLeft, title: "Align Left", children: _jsx(AlignLeft, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().setTextAlign('center').run(), isActive: formattingState?.isAlignCenter, title: "Align Center", children: _jsx(AlignCenter, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().setTextAlign('right').run(), isActive: formattingState?.isAlignRight, title: "Align Right", children: _jsx(AlignRight, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().setTextAlign('justify').run(), isActive: formattingState?.isAlignJustify, title: "Justify", children: _jsx(AlignJustify, { style: styles.icon }) }), _jsx("div", { style: styles.toolbarDivider }), _jsxs("div", { style: { position: 'relative', flexShrink: 0 }, children: [_jsx(ToolbarButton, { onClick: () => setIsLinkPopoverOpen(!isLinkPopoverOpen), isActive: formattingState?.isLink, title: "Add Link", children: _jsx(Link, { style: styles.icon }) }), _jsx(LinkPopover, { isOpen: isLinkPopoverOpen, onClose: () => setIsLinkPopoverOpen(false), onSetLink: setLink, onRemoveLink: removeLink })] }), _jsx(ToolbarDropdown, { trigger: _jsx(Palette, { style: styles.icon }), title: "Text Color", children: (close) => (_jsx(TiptapColorPicker, { currentColor: editor.getAttributes('textStyle').color, onColorChange: (color) => {
816
+ if (color) {
817
+ editor.chain().focus().setColor(color).run();
818
+ }
819
+ else {
820
+ editor.chain().focus().unsetColor().run();
821
+ }
822
+ }, onClose: close, showOpacity: true, mode: "text" })) }), _jsx(ToolbarDropdown, { trigger: _jsx(Highlighter, { style: styles.icon }), title: "Highlight", isActive: formattingState?.isHighlight, children: (close) => (_jsx(TiptapColorPicker, { currentColor: editor.getAttributes('highlight').color, onColorChange: (color) => {
823
+ if (color) {
824
+ editor.chain().focus().setHighlight({ color }).run();
825
+ }
826
+ else {
827
+ editor.chain().focus().unsetHighlight().run();
828
+ }
829
+ }, onClose: close, showOpacity: true, mode: "highlight" })) }), _jsx("div", { style: styles.toolbarDivider }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().setHorizontalRule().run(), title: "Horizontal Rule", children: _jsx(Minus, { style: styles.icon }) }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().setHardBreak().run(), title: "Hard Break (Shift+Enter)", children: _jsx(CornerDownLeft, { style: styles.icon }) }), _jsx("div", { style: styles.toolbarDivider }), _jsx(ToolbarButton, { onClick: () => editor.chain().focus().unsetAllMarks().clearNodes().run(), title: "Clear Formatting", children: _jsx(RemoveFormatting, { style: styles.icon }) }), _jsxs("button", { type: "button", onClick: () => {
830
+ if (showSource) {
831
+ editor.commands.setContent(sourceContent);
832
+ onChange(sourceContent);
833
+ }
834
+ else {
835
+ setSourceContent(editor.getHTML());
836
+ }
837
+ setShowSource(!showSource);
838
+ }, title: "View Source", style: {
839
+ ...styles.sourceButton,
840
+ ...(showSource ? styles.toolbarButtonActive : {}),
841
+ }, children: [_jsx(Code, { style: styles.icon }), "Source"] })] })), showSource ? (_jsx("textarea", { value: sourceContent, onChange: (e) => {
842
+ setSourceContent(e.target.value);
843
+ onChange(e.target.value);
844
+ }, style: styles.sourceTextarea, placeholder: "Edit HTML source..." })) : (_jsx("div", { style: styles.editorContent, children: _jsx(EditorContent, { editor: editor }) }))] })] }));
845
+ }
846
+ export const TiptapField = memo(TiptapFieldInner);
847
+ // =============================================================================
848
+ // Field Configuration Factory
849
+ // =============================================================================
850
+ export function createTiptapField(config) {
851
+ return {
852
+ type: 'custom',
853
+ label: config.label,
854
+ render: ({ name, value, onChange, readOnly }) => (_jsx(TiptapField, { value: value || '', onChange: onChange, label: config.label, readOnly: readOnly }, `tiptap-${name}`)),
855
+ };
856
+ }
857
+ //# sourceMappingURL=TiptapField.js.map