@payloadcms/richtext-slate 3.0.0-canary.fb81f02 → 3.0.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 (336) hide show
  1. package/dist/cell/rscEntry.d.ts +8 -0
  2. package/dist/cell/rscEntry.d.ts.map +1 -0
  3. package/dist/cell/rscEntry.js +51 -0
  4. package/dist/cell/rscEntry.js.map +1 -0
  5. package/dist/data/populate.d.ts +3 -2
  6. package/dist/data/populate.d.ts.map +1 -1
  7. package/dist/data/populate.js +2 -1
  8. package/dist/data/populate.js.map +1 -1
  9. package/dist/data/recurseNestedFields.d.ts +3 -2
  10. package/dist/data/recurseNestedFields.d.ts.map +1 -1
  11. package/dist/data/recurseNestedFields.js +10 -1
  12. package/dist/data/recurseNestedFields.js.map +1 -1
  13. package/dist/data/richTextRelationshipPromise.d.ts +5 -4
  14. package/dist/data/richTextRelationshipPromise.d.ts.map +1 -1
  15. package/dist/data/richTextRelationshipPromise.js +8 -2
  16. package/dist/data/richTextRelationshipPromise.js.map +1 -1
  17. package/dist/data/validation.d.ts.map +1 -1
  18. package/dist/data/validation.js +3 -1
  19. package/dist/data/validation.js.map +1 -1
  20. package/dist/exports/client/index.d.ts +49 -0
  21. package/dist/exports/client/index.d.ts.map +1 -0
  22. package/dist/exports/client/index.js +51 -0
  23. package/dist/exports/client/index.js.map +1 -0
  24. package/dist/exports/server/rsc.d.ts +3 -0
  25. package/dist/exports/server/rsc.d.ts.map +1 -0
  26. package/dist/exports/server/rsc.js +4 -0
  27. package/dist/exports/server/rsc.js.map +1 -0
  28. package/dist/field/RichText.d.ts +3 -13
  29. package/dist/field/RichText.d.ts.map +1 -1
  30. package/dist/field/RichText.js +35 -36
  31. package/dist/field/RichText.js.map +1 -1
  32. package/dist/field/buttons.scss +11 -10
  33. package/dist/field/createFeatureMap.d.ts +2 -1
  34. package/dist/field/createFeatureMap.d.ts.map +1 -1
  35. package/dist/field/createFeatureMap.js +15 -4
  36. package/dist/field/createFeatureMap.js.map +1 -1
  37. package/dist/field/elements/Button.js +2 -2
  38. package/dist/field/elements/Button.js.map +1 -1
  39. package/dist/field/elements/EnabledRelationshipsCondition.d.ts.map +1 -1
  40. package/dist/field/elements/EnabledRelationshipsCondition.js +1 -1
  41. package/dist/field/elements/EnabledRelationshipsCondition.js.map +1 -1
  42. package/dist/field/elements/blockquote/Button.d.ts +4 -0
  43. package/dist/field/elements/blockquote/Button.d.ts.map +1 -0
  44. package/dist/field/elements/blockquote/Button.js +11 -0
  45. package/dist/field/elements/blockquote/Button.js.map +1 -0
  46. package/dist/field/elements/blockquote/Element.d.ts +3 -0
  47. package/dist/field/elements/blockquote/Element.d.ts.map +1 -0
  48. package/dist/field/elements/blockquote/{Blockquote.js → Element.js} +2 -2
  49. package/dist/field/elements/blockquote/Element.js.map +1 -0
  50. package/dist/field/elements/blockquote/index.d.ts.map +1 -1
  51. package/dist/field/elements/blockquote/index.js +7 -10
  52. package/dist/field/elements/blockquote/index.js.map +1 -1
  53. package/dist/field/elements/blockquote/index.scss +7 -5
  54. package/dist/field/elements/h1/Button.d.ts +4 -0
  55. package/dist/field/elements/h1/Button.d.ts.map +1 -0
  56. package/dist/field/elements/h1/Button.js +11 -0
  57. package/dist/field/elements/h1/Button.js.map +1 -0
  58. package/dist/field/elements/h1/Heading1.d.ts +1 -1
  59. package/dist/field/elements/h1/Heading1.d.ts.map +1 -1
  60. package/dist/field/elements/h1/Heading1.js +1 -1
  61. package/dist/field/elements/h1/Heading1.js.map +1 -1
  62. package/dist/field/elements/h1/index.d.ts.map +1 -1
  63. package/dist/field/elements/h1/index.js +7 -10
  64. package/dist/field/elements/h1/index.js.map +1 -1
  65. package/dist/field/elements/h2/Button.d.ts +4 -0
  66. package/dist/field/elements/h2/Button.d.ts.map +1 -0
  67. package/dist/field/elements/h2/Button.js +11 -0
  68. package/dist/field/elements/h2/Button.js.map +1 -0
  69. package/dist/field/elements/h2/Heading2.d.ts +1 -1
  70. package/dist/field/elements/h2/Heading2.d.ts.map +1 -1
  71. package/dist/field/elements/h2/Heading2.js +1 -1
  72. package/dist/field/elements/h2/Heading2.js.map +1 -1
  73. package/dist/field/elements/h2/index.d.ts.map +1 -1
  74. package/dist/field/elements/h2/index.js +7 -10
  75. package/dist/field/elements/h2/index.js.map +1 -1
  76. package/dist/field/elements/h3/Button.d.ts +4 -0
  77. package/dist/field/elements/h3/Button.d.ts.map +1 -0
  78. package/dist/field/elements/h3/Button.js +11 -0
  79. package/dist/field/elements/h3/Button.js.map +1 -0
  80. package/dist/field/elements/h3/Heading3.d.ts +1 -1
  81. package/dist/field/elements/h3/Heading3.d.ts.map +1 -1
  82. package/dist/field/elements/h3/Heading3.js +1 -1
  83. package/dist/field/elements/h3/Heading3.js.map +1 -1
  84. package/dist/field/elements/h3/index.d.ts.map +1 -1
  85. package/dist/field/elements/h3/index.js +7 -10
  86. package/dist/field/elements/h3/index.js.map +1 -1
  87. package/dist/field/elements/h4/Button.d.ts +4 -0
  88. package/dist/field/elements/h4/Button.d.ts.map +1 -0
  89. package/dist/field/elements/h4/Button.js +11 -0
  90. package/dist/field/elements/h4/Button.js.map +1 -0
  91. package/dist/field/elements/h4/Heading4.d.ts +1 -1
  92. package/dist/field/elements/h4/Heading4.d.ts.map +1 -1
  93. package/dist/field/elements/h4/Heading4.js +1 -1
  94. package/dist/field/elements/h4/Heading4.js.map +1 -1
  95. package/dist/field/elements/h4/index.d.ts.map +1 -1
  96. package/dist/field/elements/h4/index.js +7 -10
  97. package/dist/field/elements/h4/index.js.map +1 -1
  98. package/dist/field/elements/h5/Button.d.ts +4 -0
  99. package/dist/field/elements/h5/Button.d.ts.map +1 -0
  100. package/dist/field/elements/h5/Button.js +11 -0
  101. package/dist/field/elements/h5/Button.js.map +1 -0
  102. package/dist/field/elements/h5/Heading5.d.ts +1 -1
  103. package/dist/field/elements/h5/Heading5.d.ts.map +1 -1
  104. package/dist/field/elements/h5/Heading5.js +1 -1
  105. package/dist/field/elements/h5/Heading5.js.map +1 -1
  106. package/dist/field/elements/h5/index.d.ts.map +1 -1
  107. package/dist/field/elements/h5/index.js +7 -10
  108. package/dist/field/elements/h5/index.js.map +1 -1
  109. package/dist/field/elements/h6/Button.d.ts +4 -0
  110. package/dist/field/elements/h6/Button.d.ts.map +1 -0
  111. package/dist/field/elements/h6/Button.js +11 -0
  112. package/dist/field/elements/h6/Button.js.map +1 -0
  113. package/dist/field/elements/h6/Heading6.d.ts +1 -1
  114. package/dist/field/elements/h6/Heading6.d.ts.map +1 -1
  115. package/dist/field/elements/h6/Heading6.js +1 -1
  116. package/dist/field/elements/h6/Heading6.js.map +1 -1
  117. package/dist/field/elements/h6/index.d.ts.map +1 -1
  118. package/dist/field/elements/h6/index.js +7 -10
  119. package/dist/field/elements/h6/index.js.map +1 -1
  120. package/dist/field/elements/indent/index.d.ts.map +1 -1
  121. package/dist/field/elements/indent/index.js +2 -4
  122. package/dist/field/elements/indent/index.js.map +1 -1
  123. package/dist/field/elements/isActive.d.ts.map +1 -1
  124. package/dist/field/elements/isActive.js +3 -1
  125. package/dist/field/elements/isActive.js.map +1 -1
  126. package/dist/field/elements/isLastSelectedElementEmpty.d.ts.map +1 -1
  127. package/dist/field/elements/isLastSelectedElementEmpty.js +3 -1
  128. package/dist/field/elements/isLastSelectedElementEmpty.js.map +1 -1
  129. package/dist/field/elements/isListActive.d.ts.map +1 -1
  130. package/dist/field/elements/isListActive.js +6 -2
  131. package/dist/field/elements/isListActive.js.map +1 -1
  132. package/dist/field/elements/li/index.d.ts.map +1 -1
  133. package/dist/field/elements/li/index.js +1 -2
  134. package/dist/field/elements/li/index.js.map +1 -1
  135. package/dist/field/elements/link/Button/index.d.ts +3 -1
  136. package/dist/field/elements/link/Button/index.d.ts.map +1 -1
  137. package/dist/field/elements/link/Button/index.js +21 -17
  138. package/dist/field/elements/link/Button/index.js.map +1 -1
  139. package/dist/field/elements/link/Element/index.d.ts.map +1 -1
  140. package/dist/field/elements/link/Element/index.js +30 -22
  141. package/dist/field/elements/link/Element/index.js.map +1 -1
  142. package/dist/field/elements/link/Element/index.scss +65 -67
  143. package/dist/field/elements/link/LinkDrawer/index.d.ts.map +1 -1
  144. package/dist/field/elements/link/LinkDrawer/index.js +49 -43
  145. package/dist/field/elements/link/LinkDrawer/index.js.map +1 -1
  146. package/dist/field/elements/link/LinkDrawer/index.scss +39 -37
  147. package/dist/field/elements/link/LinkDrawer/types.d.ts +7 -6
  148. package/dist/field/elements/link/LinkDrawer/types.d.ts.map +1 -1
  149. package/dist/field/elements/link/LinkDrawer/types.js.map +1 -1
  150. package/dist/field/elements/link/index.d.ts.map +1 -1
  151. package/dist/field/elements/link/index.js +3 -6
  152. package/dist/field/elements/link/index.js.map +1 -1
  153. package/dist/field/elements/ol/Button.d.ts +4 -0
  154. package/dist/field/elements/ol/Button.d.ts.map +1 -0
  155. package/dist/field/elements/ol/Button.js +11 -0
  156. package/dist/field/elements/ol/Button.js.map +1 -0
  157. package/dist/field/elements/ol/OrderedList.d.ts +1 -1
  158. package/dist/field/elements/ol/OrderedList.d.ts.map +1 -1
  159. package/dist/field/elements/ol/OrderedList.js +1 -1
  160. package/dist/field/elements/ol/OrderedList.js.map +1 -1
  161. package/dist/field/elements/ol/index.d.ts.map +1 -1
  162. package/dist/field/elements/ol/index.js +7 -10
  163. package/dist/field/elements/ol/index.js.map +1 -1
  164. package/dist/field/elements/ol/index.scss +5 -3
  165. package/dist/field/elements/relationship/Button/index.d.ts +1 -1
  166. package/dist/field/elements/relationship/Button/index.d.ts.map +1 -1
  167. package/dist/field/elements/relationship/Button/index.js +3 -3
  168. package/dist/field/elements/relationship/Button/index.js.map +1 -1
  169. package/dist/field/elements/relationship/Button/index.scss +6 -4
  170. package/dist/field/elements/relationship/Element/index.d.ts +1 -7
  171. package/dist/field/elements/relationship/Element/index.d.ts.map +1 -1
  172. package/dist/field/elements/relationship/Element/index.js +7 -7
  173. package/dist/field/elements/relationship/Element/index.js.map +1 -1
  174. package/dist/field/elements/relationship/Element/index.scss +73 -71
  175. package/dist/field/elements/relationship/index.d.ts.map +1 -1
  176. package/dist/field/elements/relationship/index.js +3 -6
  177. package/dist/field/elements/relationship/index.js.map +1 -1
  178. package/dist/field/elements/textAlign/Button.d.ts +2 -0
  179. package/dist/field/elements/textAlign/Button.d.ts.map +1 -0
  180. package/dist/field/elements/textAlign/Button.js +28 -0
  181. package/dist/field/elements/textAlign/Button.js.map +1 -0
  182. package/dist/field/elements/textAlign/index.d.ts.map +1 -1
  183. package/dist/field/elements/textAlign/index.js +2 -28
  184. package/dist/field/elements/textAlign/index.js.map +1 -1
  185. package/dist/field/elements/toggleList.d.ts.map +1 -1
  186. package/dist/field/elements/toggleList.js +6 -2
  187. package/dist/field/elements/toggleList.js.map +1 -1
  188. package/dist/field/elements/ul/Button.d.ts +4 -0
  189. package/dist/field/elements/ul/Button.d.ts.map +1 -0
  190. package/dist/field/elements/ul/Button.js +11 -0
  191. package/dist/field/elements/ul/Button.js.map +1 -0
  192. package/dist/field/elements/ul/UnorderedList.d.ts +1 -1
  193. package/dist/field/elements/ul/UnorderedList.d.ts.map +1 -1
  194. package/dist/field/elements/ul/UnorderedList.js +1 -1
  195. package/dist/field/elements/ul/UnorderedList.js.map +1 -1
  196. package/dist/field/elements/ul/index.d.ts.map +1 -1
  197. package/dist/field/elements/ul/index.js +7 -10
  198. package/dist/field/elements/ul/index.js.map +1 -1
  199. package/dist/field/elements/ul/index.scss +5 -3
  200. package/dist/field/elements/upload/Button/index.d.ts +1 -1
  201. package/dist/field/elements/upload/Button/index.d.ts.map +1 -1
  202. package/dist/field/elements/upload/Button/index.js +1 -1
  203. package/dist/field/elements/upload/Button/index.js.map +1 -1
  204. package/dist/field/elements/upload/Button/index.scss +6 -4
  205. package/dist/field/elements/upload/Element/UploadDrawer/index.d.ts +7 -9
  206. package/dist/field/elements/upload/Element/UploadDrawer/index.d.ts.map +1 -1
  207. package/dist/field/elements/upload/Element/UploadDrawer/index.js +68 -58
  208. package/dist/field/elements/upload/Element/UploadDrawer/index.js.map +1 -1
  209. package/dist/field/elements/upload/Element/index.d.ts +1 -7
  210. package/dist/field/elements/upload/Element/index.d.ts.map +1 -1
  211. package/dist/field/elements/upload/Element/index.js +35 -31
  212. package/dist/field/elements/upload/Element/index.js.map +1 -1
  213. package/dist/field/elements/upload/Element/index.scss +116 -114
  214. package/dist/field/elements/upload/index.d.ts.map +1 -1
  215. package/dist/field/elements/upload/index.js +3 -6
  216. package/dist/field/elements/upload/index.js.map +1 -1
  217. package/dist/field/icons/IndentLeft/index.scss +12 -10
  218. package/dist/field/icons/IndentRight/index.scss +12 -10
  219. package/dist/field/icons/Link/index.scss +8 -6
  220. package/dist/field/icons/Relationship/index.scss +9 -7
  221. package/dist/field/icons/Upload/index.scss +8 -6
  222. package/dist/field/index.d.ts +2 -5
  223. package/dist/field/index.d.ts.map +1 -1
  224. package/dist/field/index.js +15 -11
  225. package/dist/field/index.js.map +1 -1
  226. package/dist/field/index.scss +169 -151
  227. package/dist/field/leaves/bold/Bold/index.d.ts +1 -1
  228. package/dist/field/leaves/bold/Bold/index.d.ts.map +1 -1
  229. package/dist/field/leaves/bold/Bold/index.js +1 -1
  230. package/dist/field/leaves/bold/Bold/index.js.map +1 -1
  231. package/dist/field/leaves/bold/LeafButton.d.ts +2 -0
  232. package/dist/field/leaves/bold/LeafButton.d.ts.map +1 -0
  233. package/dist/field/leaves/bold/LeafButton.js +11 -0
  234. package/dist/field/leaves/bold/LeafButton.js.map +1 -0
  235. package/dist/field/leaves/bold/index.d.ts.map +1 -1
  236. package/dist/field/leaves/bold/index.js +2 -10
  237. package/dist/field/leaves/bold/index.js.map +1 -1
  238. package/dist/field/leaves/code/Code/index.d.ts +1 -1
  239. package/dist/field/leaves/code/Code/index.d.ts.map +1 -1
  240. package/dist/field/leaves/code/Code/index.js +1 -1
  241. package/dist/field/leaves/code/Code/index.js.map +1 -1
  242. package/dist/field/leaves/code/LeafButton.d.ts +2 -0
  243. package/dist/field/leaves/code/LeafButton.d.ts.map +1 -0
  244. package/dist/field/leaves/code/LeafButton.js +11 -0
  245. package/dist/field/leaves/code/LeafButton.js.map +1 -0
  246. package/dist/field/leaves/code/index.d.ts.map +1 -1
  247. package/dist/field/leaves/code/index.js +2 -10
  248. package/dist/field/leaves/code/index.js.map +1 -1
  249. package/dist/field/leaves/italic/Italic/index.d.ts +1 -1
  250. package/dist/field/leaves/italic/Italic/index.d.ts.map +1 -1
  251. package/dist/field/leaves/italic/Italic/index.js +1 -1
  252. package/dist/field/leaves/italic/Italic/index.js.map +1 -1
  253. package/dist/field/leaves/italic/LeafButton.d.ts +2 -0
  254. package/dist/field/leaves/italic/LeafButton.d.ts.map +1 -0
  255. package/dist/field/leaves/italic/LeafButton.js +11 -0
  256. package/dist/field/leaves/italic/LeafButton.js.map +1 -0
  257. package/dist/field/leaves/italic/index.d.ts.map +1 -1
  258. package/dist/field/leaves/italic/index.js +2 -10
  259. package/dist/field/leaves/italic/index.js.map +1 -1
  260. package/dist/field/leaves/strikethrough/LeafButton.d.ts +2 -0
  261. package/dist/field/leaves/strikethrough/LeafButton.d.ts.map +1 -0
  262. package/dist/field/leaves/strikethrough/LeafButton.js +11 -0
  263. package/dist/field/leaves/strikethrough/LeafButton.js.map +1 -0
  264. package/dist/field/leaves/strikethrough/Strikethrough/index.d.ts +1 -1
  265. package/dist/field/leaves/strikethrough/Strikethrough/index.d.ts.map +1 -1
  266. package/dist/field/leaves/strikethrough/Strikethrough/index.js +1 -1
  267. package/dist/field/leaves/strikethrough/Strikethrough/index.js.map +1 -1
  268. package/dist/field/leaves/strikethrough/index.d.ts.map +1 -1
  269. package/dist/field/leaves/strikethrough/index.js +2 -10
  270. package/dist/field/leaves/strikethrough/index.js.map +1 -1
  271. package/dist/field/leaves/underline/LeafButton.d.ts +2 -0
  272. package/dist/field/leaves/underline/LeafButton.d.ts.map +1 -0
  273. package/dist/field/leaves/underline/LeafButton.js +11 -0
  274. package/dist/field/leaves/underline/LeafButton.js.map +1 -0
  275. package/dist/field/leaves/underline/Underline/index.d.ts +1 -1
  276. package/dist/field/leaves/underline/Underline/index.d.ts.map +1 -1
  277. package/dist/field/leaves/underline/Underline/index.js +1 -1
  278. package/dist/field/leaves/underline/Underline/index.js.map +1 -1
  279. package/dist/field/leaves/underline/index.d.ts.map +1 -1
  280. package/dist/field/leaves/underline/index.js +2 -10
  281. package/dist/field/leaves/underline/index.js.map +1 -1
  282. package/dist/field/providers/ElementButtonProvider.d.ts +2 -5
  283. package/dist/field/providers/ElementButtonProvider.d.ts.map +1 -1
  284. package/dist/field/providers/ElementButtonProvider.js.map +1 -1
  285. package/dist/field/providers/ElementProvider.d.ts +3 -6
  286. package/dist/field/providers/ElementProvider.d.ts.map +1 -1
  287. package/dist/field/providers/ElementProvider.js.map +1 -1
  288. package/dist/field/providers/LeafButtonProvider.d.ts +2 -4
  289. package/dist/field/providers/LeafButtonProvider.d.ts.map +1 -1
  290. package/dist/field/providers/LeafButtonProvider.js.map +1 -1
  291. package/dist/field/providers/LeafProvider.d.ts +3 -5
  292. package/dist/field/providers/LeafProvider.d.ts.map +1 -1
  293. package/dist/field/providers/LeafProvider.js.map +1 -1
  294. package/dist/field/rscEntry.d.ts +7 -0
  295. package/dist/field/rscEntry.d.ts.map +1 -0
  296. package/dist/field/rscEntry.js +131 -0
  297. package/dist/field/rscEntry.js.map +1 -0
  298. package/dist/field/types.d.ts +6 -0
  299. package/dist/field/types.d.ts.map +1 -1
  300. package/dist/field/types.js.map +1 -1
  301. package/dist/generateSchemaMap.d.ts.map +1 -1
  302. package/dist/generateSchemaMap.js +30 -5
  303. package/dist/generateSchemaMap.js.map +1 -1
  304. package/dist/index.d.ts +1 -5
  305. package/dist/index.d.ts.map +1 -1
  306. package/dist/index.js +65 -11
  307. package/dist/index.js.map +1 -1
  308. package/dist/scss/app.scss +164 -163
  309. package/dist/scss/colors.scss +256 -254
  310. package/dist/scss/resets.scss +9 -7
  311. package/dist/scss/toastify.scss +42 -41
  312. package/dist/scss/toasts.scss +104 -102
  313. package/dist/scss/type.scss +80 -79
  314. package/dist/types.d.ts +11 -7
  315. package/dist/types.d.ts.map +1 -1
  316. package/dist/types.js.map +1 -1
  317. package/dist/utilities/SlatePropsProvider.d.ts +11 -0
  318. package/dist/utilities/SlatePropsProvider.d.ts.map +1 -0
  319. package/dist/utilities/SlatePropsProvider.js +21 -0
  320. package/dist/utilities/SlatePropsProvider.js.map +1 -0
  321. package/dist/utilities/useSlatePlugin.d.ts.map +1 -1
  322. package/dist/utilities/useSlatePlugin.js +3 -2
  323. package/dist/utilities/useSlatePlugin.js.map +1 -1
  324. package/license.md +22 -0
  325. package/package.json +33 -15
  326. package/dist/cell/index.d.ts +0 -4
  327. package/dist/cell/index.d.ts.map +0 -1
  328. package/dist/cell/index.js +0 -14
  329. package/dist/cell/index.js.map +0 -1
  330. package/dist/field/elements/blockquote/Blockquote.d.ts +0 -3
  331. package/dist/field/elements/blockquote/Blockquote.d.ts.map +0 -1
  332. package/dist/field/elements/blockquote/Blockquote.js.map +0 -1
  333. package/dist/generateComponentMap.d.ts +0 -4
  334. package/dist/generateComponentMap.d.ts.map +0 -1
  335. package/dist/generateComponentMap.js +0 -91
  336. package/dist/generateComponentMap.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/exports/server/rsc.ts"],"sourcesContent":["export { RscEntrySlateCell } from '../../cell/rscEntry.js'\nexport { RscEntrySlateField } from '../../field/rscEntry.js'\n"],"names":["RscEntrySlateCell","RscEntrySlateField"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,yBAAwB;AAC1D,SAASC,kBAAkB,QAAQ,0BAAyB"}
@@ -1,10 +1,9 @@
1
- import type { FormFieldBase, RichTextFieldValidation } from 'payload';
2
1
  import type { BaseEditor } from 'slate';
3
2
  import type { HistoryEditor } from 'slate-history';
4
3
  import type { ReactEditor } from 'slate-react';
5
4
  import React from 'react';
6
- import type { ElementNode, RichTextPlugin, TextNode } from '../types.js';
7
- import type { EnabledFeatures } from './types.js';
5
+ import type { ElementNode, TextNode } from '../types.js';
6
+ import type { LoadedSlateFieldProps } from './types.js';
8
7
  import './index.scss';
9
8
  declare module 'slate' {
10
9
  interface CustomTypes {
@@ -13,14 +12,5 @@ declare module 'slate' {
13
12
  Text: TextNode;
14
13
  }
15
14
  }
16
- export declare const RichText: React.FC<{
17
- elements: EnabledFeatures["elements"];
18
- leaves: EnabledFeatures["leaves"];
19
- name: string;
20
- placeholder?: string;
21
- plugins: RichTextPlugin[];
22
- richTextComponentMap: Map<string, React.ReactNode>;
23
- validate?: RichTextFieldValidation;
24
- width?: string;
25
- } & Omit<FormFieldBase, "validate">>;
15
+ export declare const RichText: React.FC<LoadedSlateFieldProps>;
26
16
  //# sourceMappingURL=RichText.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"RichText.d.ts","sourceRoot":"","sources":["../../src/field/RichText.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAkB,uBAAuB,EAAE,MAAM,SAAS,CAAA;AACrF,OAAO,KAAK,EAAE,UAAU,EAAiB,MAAM,OAAO,CAAA;AACtD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAClD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAc9C,OAAO,KAAkD,MAAM,OAAO,CAAA;AAKtE,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AACxE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAMjD,OAAO,cAAc,CAAA;AAWrB,OAAO,QAAQ,OAAO,CAAC;IACrB,UAAU,WAAW;QACnB,MAAM,EAAE,UAAU,GAAG,aAAa,GAAG,WAAW,CAAA;QAChD,OAAO,EAAE,WAAW,CAAA;QACpB,IAAI,EAAE,QAAQ,CAAA;KACf;CACF;AAuaD,eAAO,MAAM,QAAQ;cAnaP,eAAe,CAAC,UAAU,CAAC;YAC7B,eAAe,CAAC,QAAQ,CAAC;UAC3B,MAAM;kBACE,MAAM;aACX,cAAc,EAAE;0BACH,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC;eACvC,uBAAuB;YAC1B,MAAM;oCA4ZkC,CAAA"}
1
+ {"version":3,"file":"RichText.d.ts","sourceRoot":"","sources":["../../src/field/RichText.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAiB,MAAM,OAAO,CAAA;AACtD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAClD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAM9C,OAAO,KAAkD,MAAM,OAAO,CAAA;AAKtE,OAAO,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AACxD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAA;AAKvD,OAAO,cAAc,CAAA;AAYrB,OAAO,QAAQ,OAAO,CAAC;IACrB,UAAU,WAAW;QACnB,MAAM,EAAE,UAAU,GAAG,aAAa,GAAG,WAAW,CAAA;QAChD,OAAO,EAAE,WAAW,CAAA;QACpB,IAAI,EAAE,QAAQ,CAAA;KACf;CACF;AAsZD,eAAO,MAAM,QAAQ,iCAA+B,CAAA"}
@@ -1,17 +1,18 @@
1
1
  'use client';
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  import { getTranslation } from '@payloadcms/translations';
4
- import { FieldDescription, FieldError, FieldLabel, useEditDepth, useField, useFieldProps, useTranslation, withCondition } from '@payloadcms/ui';
4
+ import { FieldLabel, useEditDepth, useField, useTranslation, withCondition } from '@payloadcms/ui';
5
+ import { mergeFieldStyles } from '@payloadcms/ui/shared';
5
6
  import { isHotkey } from 'is-hotkey';
6
7
  import React, { useCallback, useEffect, useMemo, useRef } from 'react';
7
- import { Node, Element as SlateElement, Text, Transforms, createEditor } from 'slate';
8
+ import { createEditor, Node, Element as SlateElement, Text, Transforms } from 'slate';
8
9
  import { withHistory } from 'slate-history';
9
10
  import { Editable, Slate, withReact } from 'slate-react';
10
11
  import { defaultRichTextValue } from '../data/defaultValue.js';
11
12
  import { richTextValidate } from '../data/validation.js';
12
13
  import { listTypes } from './elements/listTypes.js';
13
- import { hotkeys } from './hotkeys.js';
14
14
  import './index.scss';
15
+ import { hotkeys } from './hotkeys.js';
15
16
  import { toggleLeaf } from './leaves/toggle.js';
16
17
  import { withEnterBreakOut } from './plugins/withEnterBreakOut.js';
17
18
  import { withHTML } from './plugins/withHTML.js';
@@ -21,7 +22,10 @@ import { LeafButtonProvider } from './providers/LeafButtonProvider.js';
21
22
  import { LeafProvider } from './providers/LeafProvider.js';
22
23
  const baseClass = 'rich-text';
23
24
  const RichTextField = (props)=>{
24
- const { name, CustomDescription, CustomError, CustomLabel, className, descriptionProps, elements, errorProps, label, labelProps, leaves, path: pathFromProps, placeholder, plugins, readOnly: readOnlyFromProps, required, style, validate = richTextValidate, width } = props;
25
+ const { elements, field, field: { name, admin: { className, placeholder, readOnly: readOnlyFromAdmin } = {}, label, required }, leaves, path: pathFromProps, plugins, readOnly: readOnlyFromTopLevelProps, schemaPath: schemaPathFromProps, validate = richTextValidate } = props;
26
+ const path = pathFromProps ?? name;
27
+ const schemaPath = schemaPathFromProps ?? name;
28
+ const readOnlyFromProps = readOnlyFromTopLevelProps || readOnlyFromAdmin;
25
29
  const { i18n } = useTranslation();
26
30
  const editorRef = useRef(null);
27
31
  const toolbarRef = useRef(null);
@@ -42,12 +46,11 @@ const RichTextField = (props)=>{
42
46
  required,
43
47
  i18n
44
48
  ]);
45
- const { path: pathFromContext, readOnly: readOnlyFromContext } = useFieldProps();
46
- const { formInitializing, initialValue, path, schemaPath, setValue, showError, value } = useField({
47
- path: pathFromContext ?? pathFromProps ?? name,
49
+ const { customComponents: { Description, Error, Label } = {}, formInitializing, initialValue, setValue, showError, value } = useField({
50
+ path,
48
51
  validate: memoizedValidate
49
52
  });
50
- const disabled = readOnlyFromProps || readOnlyFromContext || formInitializing;
53
+ const disabled = readOnlyFromProps || formInitializing;
51
54
  const editor = useMemo(()=>{
52
55
  let CreatedEditor = withEnterBreakOut(withHistory(withReact(createEditor())));
53
56
  CreatedEditor = withHTML(CreatedEditor);
@@ -71,28 +74,28 @@ const RichTextField = (props)=>{
71
74
  if (element.textAlign) {
72
75
  if (element.type === 'relationship' || element.type === 'upload') {
73
76
  switch(element.textAlign){
74
- case 'left':
77
+ case 'center':
75
78
  attr = {
76
79
  ...attr,
77
80
  style: {
81
+ marginLeft: 'auto',
78
82
  marginRight: 'auto'
79
83
  }
80
84
  };
81
85
  break;
82
- case 'right':
86
+ case 'left':
83
87
  attr = {
84
88
  ...attr,
85
89
  style: {
86
- marginLeft: 'auto'
90
+ marginRight: 'auto'
87
91
  }
88
92
  };
89
93
  break;
90
- case 'center':
94
+ case 'right':
91
95
  attr = {
92
96
  ...attr,
93
97
  style: {
94
- marginLeft: 'auto',
95
- marginRight: 'auto'
98
+ marginLeft: 'auto'
96
99
  }
97
100
  };
98
101
  break;
@@ -107,21 +110,21 @@ const RichTextField = (props)=>{
107
110
  }
108
111
  } else if (element.type === 'li') {
109
112
  switch(element.textAlign){
110
- case 'right':
113
+ case 'center':
111
114
  attr = {
112
115
  ...attr,
113
116
  style: {
114
117
  listStylePosition: 'inside',
115
- textAlign: 'right'
118
+ textAlign: 'center'
116
119
  }
117
120
  };
118
121
  break;
119
- case 'center':
122
+ case 'right':
120
123
  attr = {
121
124
  ...attr,
122
125
  style: {
123
126
  listStylePosition: 'inside',
124
- textAlign: 'center'
127
+ textAlign: 'right'
125
128
  }
126
129
  };
127
130
  break;
@@ -231,7 +234,9 @@ const RichTextField = (props)=>{
231
234
  const isButton = child.tagName === 'BUTTON';
232
235
  const isDisabling = clickState === 'disabled';
233
236
  child.setAttribute('tabIndex', isDisabling ? '-1' : '0');
234
- if (isButton) child.setAttribute('disabled', isDisabling ? 'disabled' : null);
237
+ if (isButton) {
238
+ child.setAttribute('disabled', isDisabling ? 'disabled' : null);
239
+ }
235
240
  });
236
241
  }
237
242
  if (disabled) {
@@ -254,6 +259,9 @@ const RichTextField = (props)=>{
254
259
  // ReactEditor.deselect(editor);
255
260
  // }
256
261
  // }, [path, editor]);
262
+ const styles = useMemo(()=>mergeFieldStyles(field), [
263
+ field
264
+ ]);
257
265
  const classes = [
258
266
  baseClass,
259
267
  'field-type',
@@ -270,28 +278,21 @@ const RichTextField = (props)=>{
270
278
  valueToRender = null;
271
279
  }
272
280
  }
273
- if (!valueToRender) valueToRender = defaultRichTextValue;
281
+ if (!valueToRender) {
282
+ valueToRender = defaultRichTextValue;
283
+ }
274
284
  return /*#__PURE__*/ _jsxs("div", {
275
285
  className: classes,
276
- style: {
277
- ...style,
278
- width
279
- },
286
+ style: styles,
280
287
  children: [
281
- /*#__PURE__*/ _jsx(FieldLabel, {
282
- CustomLabel: CustomLabel,
288
+ Label || /*#__PURE__*/ _jsx(FieldLabel, {
283
289
  label: label,
284
- required: required,
285
- ...labelProps || {}
290
+ required: required
286
291
  }),
287
292
  /*#__PURE__*/ _jsxs("div", {
288
293
  className: `${baseClass}__wrap`,
289
294
  children: [
290
- /*#__PURE__*/ _jsx(FieldError, {
291
- CustomError: CustomError,
292
- path: path,
293
- ...errorProps || {}
294
- }),
295
+ Error,
295
296
  /*#__PURE__*/ _jsx(Slate, {
296
297
  editor: editor,
297
298
  onChange: handleChange,
@@ -410,9 +411,7 @@ const RichTextField = (props)=>{
410
411
  initialValue,
411
412
  path
412
413
  })),
413
- CustomDescription !== undefined ? CustomDescription : /*#__PURE__*/ _jsx(FieldDescription, {
414
- ...descriptionProps || {}
415
- })
414
+ Description
416
415
  ]
417
416
  })
418
417
  ]
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/field/RichText.tsx"],"sourcesContent":["'use client'\n\nimport type { FormFieldBase, PayloadRequest, RichTextFieldValidation } from 'payload'\nimport type { BaseEditor, BaseOperation } from 'slate'\nimport type { HistoryEditor } from 'slate-history'\nimport type { ReactEditor } from 'slate-react'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport {\n FieldDescription,\n FieldError,\n FieldLabel,\n useEditDepth,\n useField,\n useFieldProps,\n useTranslation,\n withCondition,\n} from '@payloadcms/ui'\nimport { isHotkey } from 'is-hotkey'\nimport React, { useCallback, useEffect, useMemo, useRef } from 'react'\nimport { Node, Element as SlateElement, Text, Transforms, createEditor } from 'slate'\nimport { withHistory } from 'slate-history'\nimport { Editable, Slate, withReact } from 'slate-react'\n\nimport type { ElementNode, RichTextPlugin, TextNode } from '../types.js'\nimport type { EnabledFeatures } from './types.js'\n\nimport { defaultRichTextValue } from '../data/defaultValue.js'\nimport { richTextValidate } from '../data/validation.js'\nimport { listTypes } from './elements/listTypes.js'\nimport { hotkeys } from './hotkeys.js'\nimport './index.scss'\nimport { toggleLeaf } from './leaves/toggle.js'\nimport { withEnterBreakOut } from './plugins/withEnterBreakOut.js'\nimport { withHTML } from './plugins/withHTML.js'\nimport { ElementButtonProvider } from './providers/ElementButtonProvider.js'\nimport { ElementProvider } from './providers/ElementProvider.js'\nimport { LeafButtonProvider } from './providers/LeafButtonProvider.js'\nimport { LeafProvider } from './providers/LeafProvider.js'\n\nconst baseClass = 'rich-text'\n\ndeclare module 'slate' {\n interface CustomTypes {\n Editor: BaseEditor & HistoryEditor & ReactEditor\n Element: ElementNode\n Text: TextNode\n }\n}\n\nconst RichTextField: React.FC<\n {\n elements: EnabledFeatures['elements']\n leaves: EnabledFeatures['leaves']\n name: string\n placeholder?: string\n plugins: RichTextPlugin[]\n richTextComponentMap: Map<string, React.ReactNode>\n validate?: RichTextFieldValidation\n width?: string\n } & Omit<FormFieldBase, 'validate'>\n> = (props) => {\n const {\n name,\n CustomDescription,\n CustomError,\n CustomLabel,\n className,\n descriptionProps,\n elements,\n errorProps,\n label,\n labelProps,\n leaves,\n path: pathFromProps,\n placeholder,\n plugins,\n readOnly: readOnlyFromProps,\n required,\n style,\n validate = richTextValidate,\n width,\n } = props\n\n const { i18n } = useTranslation()\n const editorRef = useRef(null)\n const toolbarRef = useRef(null)\n\n const drawerDepth = useEditDepth()\n const drawerIsOpen = drawerDepth > 1\n\n const memoizedValidate = useCallback(\n (value, validationOptions) => {\n if (typeof validate === 'function') {\n return validate(value, {\n ...validationOptions,\n req: {\n t: i18n.t,\n } as PayloadRequest,\n required,\n })\n }\n },\n [validate, required, i18n],\n )\n\n const { path: pathFromContext, readOnly: readOnlyFromContext } = useFieldProps()\n\n const { formInitializing, initialValue, path, schemaPath, setValue, showError, value } = useField(\n {\n path: pathFromContext ?? pathFromProps ?? name,\n validate: memoizedValidate,\n },\n )\n\n const disabled = readOnlyFromProps || readOnlyFromContext || formInitializing\n\n const editor = useMemo(() => {\n let CreatedEditor = withEnterBreakOut(withHistory(withReact(createEditor())))\n\n CreatedEditor = withHTML(CreatedEditor)\n\n if (plugins.length) {\n CreatedEditor = plugins.reduce((editorWithPlugins, plugin) => {\n return plugin(editorWithPlugins)\n }, CreatedEditor)\n }\n\n return CreatedEditor\n }, [plugins])\n\n const renderElement = useCallback(\n ({ attributes, children, element }) => {\n // return <div {...attributes}>{children}</div>\n\n const matchedElement = elements[element.type]\n const Element = matchedElement?.Element\n\n let attr = { ...attributes }\n\n // this converts text alignment to margin when dealing with void elements\n if (element.textAlign) {\n if (element.type === 'relationship' || element.type === 'upload') {\n switch (element.textAlign) {\n case 'left':\n attr = { ...attr, style: { marginRight: 'auto' } }\n break\n case 'right':\n attr = { ...attr, style: { marginLeft: 'auto' } }\n break\n case 'center':\n attr = { ...attr, style: { marginLeft: 'auto', marginRight: 'auto' } }\n break\n default:\n attr = { ...attr, style: { textAlign: element.textAlign } }\n break\n }\n } else if (element.type === 'li') {\n switch (element.textAlign) {\n case 'right':\n attr = { ...attr, style: { listStylePosition: 'inside', textAlign: 'right' } }\n break\n case 'center':\n attr = { ...attr, style: { listStylePosition: 'inside', textAlign: 'center' } }\n break\n case 'left':\n default:\n attr = { ...attr, style: { listStylePosition: 'outside', textAlign: 'left' } }\n break\n }\n } else {\n attr = { ...attr, style: { textAlign: element.textAlign } }\n }\n }\n\n if (Element) {\n const el = (\n <ElementProvider\n attributes={attr}\n childNodes={children}\n editorRef={editorRef}\n element={element}\n fieldProps={props}\n path={path}\n schemaPath={schemaPath}\n >\n {Element}\n </ElementProvider>\n )\n\n return el\n }\n\n return <div {...attr}>{children}</div>\n },\n [elements, path, props, schemaPath],\n )\n\n const renderLeaf = useCallback(\n ({ attributes, children, leaf }) => {\n const matchedLeaves = Object.entries(leaves).filter(([leafName]) => leaf[leafName])\n\n if (matchedLeaves.length > 0) {\n return matchedLeaves.reduce(\n (result, [, leafConfig], i) => {\n if (leafConfig?.Leaf) {\n const Leaf = leafConfig.Leaf\n\n return (\n <LeafProvider\n attributes={attributes}\n editorRef={editorRef}\n fieldProps={props}\n key={i}\n leaf={leaf}\n path={path}\n result={result}\n schemaPath={schemaPath}\n >\n {Leaf}\n </LeafProvider>\n )\n }\n\n return result\n },\n <span {...attributes}>{children}</span>,\n )\n }\n\n return <span {...attributes}>{children}</span>\n },\n [path, props, schemaPath, leaves],\n )\n\n // All slate changes fire the onChange event\n // including selection changes\n // so we will filter the set_selection operations out\n // and only fire setValue when onChange is because of value\n const handleChange = useCallback(\n (val: unknown) => {\n const ops = editor?.operations.filter((o: BaseOperation) => {\n if (o) {\n return o.type !== 'set_selection'\n }\n return false\n })\n\n if (ops && Array.isArray(ops) && ops.length > 0) {\n if (!disabled && val !== defaultRichTextValue && val !== value) {\n setValue(val)\n }\n }\n },\n [editor?.operations, disabled, setValue, value],\n )\n\n useEffect(() => {\n function setClickableState(clickState: 'disabled' | 'enabled') {\n const selectors = 'button, a, [role=\"button\"]'\n const toolbarButtons: (HTMLAnchorElement | HTMLButtonElement)[] =\n toolbarRef.current?.querySelectorAll(selectors)\n\n ;(toolbarButtons || []).forEach((child) => {\n const isButton = child.tagName === 'BUTTON'\n const isDisabling = clickState === 'disabled'\n child.setAttribute('tabIndex', isDisabling ? '-1' : '0')\n if (isButton) child.setAttribute('disabled', isDisabling ? 'disabled' : null)\n })\n }\n\n if (disabled) {\n setClickableState('disabled')\n }\n\n return () => {\n if (disabled) {\n setClickableState('enabled')\n }\n }\n }, [disabled])\n\n // useEffect(() => {\n // // If there is a change to the initial value, we need to reset Slate history\n // // and clear selection because the old selection may no longer be valid\n // // as returned JSON may be modified in hooks and have a different shape\n // if (editor.selection) {\n // console.log('deselecting');\n // ReactEditor.deselect(editor);\n // }\n // }, [path, editor]);\n\n const classes = [\n baseClass,\n 'field-type',\n className,\n showError && 'error',\n disabled && `${baseClass}--read-only`,\n ]\n .filter(Boolean)\n .join(' ')\n\n let valueToRender = value\n\n if (typeof valueToRender === 'string') {\n try {\n const parsedJSON = JSON.parse(valueToRender)\n valueToRender = parsedJSON\n } catch (err) {\n valueToRender = null\n }\n }\n\n if (!valueToRender) valueToRender = defaultRichTextValue\n\n return (\n <div\n className={classes}\n style={{\n ...style,\n width,\n }}\n >\n <FieldLabel\n CustomLabel={CustomLabel}\n label={label}\n required={required}\n {...(labelProps || {})}\n />\n <div className={`${baseClass}__wrap`}>\n <FieldError CustomError={CustomError} path={path} {...(errorProps || {})} />\n <Slate\n editor={editor}\n key={JSON.stringify({ initialValue, path })} // makes sure slate is completely re-rendered when initialValue changes, bypassing the slate-internal value memoization. That way, external changes to the form will update the editor\n onChange={handleChange}\n value={valueToRender as any[]}\n >\n <div className={`${baseClass}__wrapper`}>\n {Object.keys(elements)?.length + Object.keys(leaves)?.length > 0 && (\n <div\n className={[`${baseClass}__toolbar`, drawerIsOpen && `${baseClass}__drawerIsOpen`]\n .filter(Boolean)\n .join(' ')}\n ref={toolbarRef}\n >\n <div className={`${baseClass}__toolbar-wrap`}>\n {Object.values(elements).map((element) => {\n const Button = element?.Button\n\n if (Button) {\n return (\n <ElementButtonProvider\n disabled={disabled}\n fieldProps={props}\n key={element.name}\n path={path}\n schemaPath={schemaPath}\n >\n {Button}\n </ElementButtonProvider>\n )\n }\n\n return null\n })}\n {Object.values(leaves).map((leaf) => {\n const Button = leaf?.Button\n\n if (Button) {\n return (\n <LeafButtonProvider\n fieldProps={props}\n key={leaf.name}\n path={path}\n schemaPath={schemaPath}\n >\n {Button}\n </LeafButtonProvider>\n )\n }\n\n return null\n })}\n </div>\n </div>\n )}\n <div className={`${baseClass}__editor`} ref={editorRef}>\n <Editable\n className={`${baseClass}__input`}\n id={`field-${path.replace(/\\./g, '__')}`}\n onKeyDown={(event) => {\n if (event.key === 'Enter') {\n if (event.shiftKey) {\n event.preventDefault()\n editor.insertText('\\n')\n } else {\n const selectedElement = Node.descendant(\n editor,\n editor.selection.anchor.path.slice(0, -1),\n )\n\n if (SlateElement.isElement(selectedElement)) {\n // Allow hard enter to \"break out\" of certain elements\n if (editor.shouldBreakOutOnEnter(selectedElement)) {\n event.preventDefault()\n const selectedLeaf = Node.descendant(editor, editor.selection.anchor.path)\n\n if (\n Text.isText(selectedLeaf) &&\n String(selectedLeaf.text).length === editor.selection.anchor.offset\n ) {\n Transforms.insertNodes(editor, { children: [{ text: '' }] })\n } else {\n Transforms.splitNodes(editor)\n Transforms.setNodes(editor, {})\n }\n }\n }\n }\n }\n\n if (event.key === 'Backspace') {\n const selectedElement = Node.descendant(\n editor,\n editor.selection.anchor.path.slice(0, -1),\n )\n\n if (SlateElement.isElement(selectedElement) && selectedElement.type === 'li') {\n const selectedLeaf = Node.descendant(editor, editor.selection.anchor.path)\n if (Text.isText(selectedLeaf) && String(selectedLeaf.text).length === 0) {\n event.preventDefault()\n Transforms.unwrapNodes(editor, {\n match: (n) => SlateElement.isElement(n) && listTypes.includes(n.type),\n mode: 'lowest',\n split: true,\n })\n\n Transforms.setNodes(editor, { type: undefined })\n }\n } else if (editor.isVoid(selectedElement)) {\n Transforms.removeNodes(editor)\n }\n }\n\n Object.keys(hotkeys).forEach((hotkey) => {\n if (isHotkey(hotkey, event as any)) {\n event.preventDefault()\n const mark = hotkeys[hotkey]\n toggleLeaf(editor, mark)\n }\n })\n }}\n placeholder={getTranslation(placeholder, i18n)}\n readOnly={disabled}\n renderElement={renderElement}\n renderLeaf={renderLeaf}\n spellCheck\n />\n </div>\n </div>\n </Slate>\n {CustomDescription !== undefined ? (\n CustomDescription\n ) : (\n <FieldDescription {...(descriptionProps || {})} />\n )}\n </div>\n </div>\n )\n}\n\nexport const RichText = withCondition(RichTextField)\n"],"names":["getTranslation","FieldDescription","FieldError","FieldLabel","useEditDepth","useField","useFieldProps","useTranslation","withCondition","isHotkey","React","useCallback","useEffect","useMemo","useRef","Node","Element","SlateElement","Text","Transforms","createEditor","withHistory","Editable","Slate","withReact","defaultRichTextValue","richTextValidate","listTypes","hotkeys","toggleLeaf","withEnterBreakOut","withHTML","ElementButtonProvider","ElementProvider","LeafButtonProvider","LeafProvider","baseClass","RichTextField","props","name","CustomDescription","CustomError","CustomLabel","className","descriptionProps","elements","errorProps","label","labelProps","leaves","path","pathFromProps","placeholder","plugins","readOnly","readOnlyFromProps","required","style","validate","width","i18n","editorRef","toolbarRef","drawerDepth","drawerIsOpen","memoizedValidate","value","validationOptions","req","t","pathFromContext","readOnlyFromContext","formInitializing","initialValue","schemaPath","setValue","showError","disabled","editor","CreatedEditor","length","reduce","editorWithPlugins","plugin","renderElement","attributes","children","element","matchedElement","type","attr","textAlign","marginRight","marginLeft","listStylePosition","el","childNodes","fieldProps","div","renderLeaf","leaf","matchedLeaves","Object","entries","filter","leafName","result","leafConfig","i","Leaf","span","handleChange","val","ops","operations","o","Array","isArray","setClickableState","clickState","selectors","toolbarButtons","current","querySelectorAll","forEach","child","isButton","tagName","isDisabling","setAttribute","classes","Boolean","join","valueToRender","parsedJSON","JSON","parse","err","onChange","keys","ref","values","map","Button","id","replace","onKeyDown","event","key","shiftKey","preventDefault","insertText","selectedElement","descendant","selection","anchor","slice","isElement","shouldBreakOutOnEnter","selectedLeaf","isText","String","text","offset","insertNodes","splitNodes","setNodes","unwrapNodes","match","n","includes","mode","split","undefined","isVoid","removeNodes","hotkey","mark","spellCheck","stringify","RichText"],"mappings":"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"}
1
+ {"version":3,"sources":["../../src/field/RichText.tsx"],"sourcesContent":["'use client'\n\nimport type { PayloadRequest } from 'payload'\nimport type { BaseEditor, BaseOperation } from 'slate'\nimport type { HistoryEditor } from 'slate-history'\nimport type { ReactEditor } from 'slate-react'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport { FieldLabel, useEditDepth, useField, useTranslation, withCondition } from '@payloadcms/ui'\nimport { mergeFieldStyles } from '@payloadcms/ui/shared'\nimport { isHotkey } from 'is-hotkey'\nimport React, { useCallback, useEffect, useMemo, useRef } from 'react'\nimport { createEditor, Node, Element as SlateElement, Text, Transforms } from 'slate'\nimport { withHistory } from 'slate-history'\nimport { Editable, Slate, withReact } from 'slate-react'\n\nimport type { ElementNode, TextNode } from '../types.js'\nimport type { LoadedSlateFieldProps } from './types.js'\n\nimport { defaultRichTextValue } from '../data/defaultValue.js'\nimport { richTextValidate } from '../data/validation.js'\nimport { listTypes } from './elements/listTypes.js'\nimport './index.scss'\nimport { hotkeys } from './hotkeys.js'\nimport { toggleLeaf } from './leaves/toggle.js'\nimport { withEnterBreakOut } from './plugins/withEnterBreakOut.js'\nimport { withHTML } from './plugins/withHTML.js'\nimport { ElementButtonProvider } from './providers/ElementButtonProvider.js'\nimport { ElementProvider } from './providers/ElementProvider.js'\nimport { LeafButtonProvider } from './providers/LeafButtonProvider.js'\nimport { LeafProvider } from './providers/LeafProvider.js'\n\nconst baseClass = 'rich-text'\n\ndeclare module 'slate' {\n interface CustomTypes {\n Editor: BaseEditor & HistoryEditor & ReactEditor\n Element: ElementNode\n Text: TextNode\n }\n}\n\nconst RichTextField: React.FC<LoadedSlateFieldProps> = (props) => {\n const {\n elements,\n field,\n field: {\n name,\n admin: { className, placeholder, readOnly: readOnlyFromAdmin } = {},\n label,\n required,\n },\n leaves,\n path: pathFromProps,\n plugins,\n readOnly: readOnlyFromTopLevelProps,\n schemaPath: schemaPathFromProps,\n validate = richTextValidate,\n } = props\n\n const path = pathFromProps ?? name\n const schemaPath = schemaPathFromProps ?? name\n\n const readOnlyFromProps = readOnlyFromTopLevelProps || readOnlyFromAdmin\n\n const { i18n } = useTranslation()\n const editorRef = useRef(null)\n const toolbarRef = useRef(null)\n\n const drawerDepth = useEditDepth()\n const drawerIsOpen = drawerDepth > 1\n\n const memoizedValidate = useCallback(\n (value, validationOptions) => {\n if (typeof validate === 'function') {\n return validate(value, {\n ...validationOptions,\n req: {\n t: i18n.t,\n } as PayloadRequest,\n required,\n })\n }\n },\n [validate, required, i18n],\n )\n\n const {\n customComponents: { Description, Error, Label } = {},\n formInitializing,\n initialValue,\n setValue,\n showError,\n value,\n } = useField({\n path,\n validate: memoizedValidate,\n })\n\n const disabled = readOnlyFromProps || formInitializing\n\n const editor = useMemo(() => {\n let CreatedEditor = withEnterBreakOut(withHistory(withReact(createEditor())))\n\n CreatedEditor = withHTML(CreatedEditor)\n\n if (plugins.length) {\n CreatedEditor = plugins.reduce((editorWithPlugins, plugin) => {\n return plugin(editorWithPlugins)\n }, CreatedEditor)\n }\n\n return CreatedEditor\n }, [plugins])\n\n const renderElement = useCallback(\n ({ attributes, children, element }) => {\n // return <div {...attributes}>{children}</div>\n\n const matchedElement = elements[element.type]\n const Element = matchedElement?.Element\n\n let attr = { ...attributes }\n\n // this converts text alignment to margin when dealing with void elements\n if (element.textAlign) {\n if (element.type === 'relationship' || element.type === 'upload') {\n switch (element.textAlign) {\n case 'center':\n attr = { ...attr, style: { marginLeft: 'auto', marginRight: 'auto' } }\n break\n case 'left':\n attr = { ...attr, style: { marginRight: 'auto' } }\n break\n case 'right':\n attr = { ...attr, style: { marginLeft: 'auto' } }\n break\n default:\n attr = { ...attr, style: { textAlign: element.textAlign } }\n break\n }\n } else if (element.type === 'li') {\n switch (element.textAlign) {\n case 'center':\n attr = { ...attr, style: { listStylePosition: 'inside', textAlign: 'center' } }\n break\n case 'right':\n attr = { ...attr, style: { listStylePosition: 'inside', textAlign: 'right' } }\n break\n case 'left':\n default:\n attr = { ...attr, style: { listStylePosition: 'outside', textAlign: 'left' } }\n break\n }\n } else {\n attr = { ...attr, style: { textAlign: element.textAlign } }\n }\n }\n\n if (Element) {\n const el = (\n <ElementProvider\n attributes={attr}\n childNodes={children}\n editorRef={editorRef}\n element={element}\n fieldProps={props}\n path={path}\n schemaPath={schemaPath}\n >\n {Element}\n </ElementProvider>\n )\n\n return el\n }\n\n return <div {...attr}>{children}</div>\n },\n [elements, path, props, schemaPath],\n )\n\n const renderLeaf = useCallback(\n ({ attributes, children, leaf }) => {\n const matchedLeaves = Object.entries(leaves).filter(([leafName]) => leaf[leafName])\n\n if (matchedLeaves.length > 0) {\n return matchedLeaves.reduce(\n (result, [, leafConfig], i) => {\n if (leafConfig?.Leaf) {\n const Leaf = leafConfig.Leaf\n\n return (\n <LeafProvider\n attributes={attributes}\n editorRef={editorRef}\n fieldProps={props}\n key={i}\n leaf={leaf}\n path={path}\n result={result}\n schemaPath={schemaPath}\n >\n {Leaf}\n </LeafProvider>\n )\n }\n\n return result\n },\n <span {...attributes}>{children}</span>,\n )\n }\n\n return <span {...attributes}>{children}</span>\n },\n [path, props, schemaPath, leaves],\n )\n\n // All slate changes fire the onChange event\n // including selection changes\n // so we will filter the set_selection operations out\n // and only fire setValue when onChange is because of value\n const handleChange = useCallback(\n (val: unknown) => {\n const ops = editor?.operations.filter((o: BaseOperation) => {\n if (o) {\n return o.type !== 'set_selection'\n }\n return false\n })\n\n if (ops && Array.isArray(ops) && ops.length > 0) {\n if (!disabled && val !== defaultRichTextValue && val !== value) {\n setValue(val)\n }\n }\n },\n [editor?.operations, disabled, setValue, value],\n )\n\n useEffect(() => {\n function setClickableState(clickState: 'disabled' | 'enabled') {\n const selectors = 'button, a, [role=\"button\"]'\n const toolbarButtons: (HTMLAnchorElement | HTMLButtonElement)[] =\n toolbarRef.current?.querySelectorAll(selectors)\n\n ;(toolbarButtons || []).forEach((child) => {\n const isButton = child.tagName === 'BUTTON'\n const isDisabling = clickState === 'disabled'\n child.setAttribute('tabIndex', isDisabling ? '-1' : '0')\n if (isButton) {\n child.setAttribute('disabled', isDisabling ? 'disabled' : null)\n }\n })\n }\n\n if (disabled) {\n setClickableState('disabled')\n }\n\n return () => {\n if (disabled) {\n setClickableState('enabled')\n }\n }\n }, [disabled])\n\n // useEffect(() => {\n // // If there is a change to the initial value, we need to reset Slate history\n // // and clear selection because the old selection may no longer be valid\n // // as returned JSON may be modified in hooks and have a different shape\n // if (editor.selection) {\n // console.log('deselecting');\n // ReactEditor.deselect(editor);\n // }\n // }, [path, editor]);\n\n const styles = useMemo(() => mergeFieldStyles(field), [field])\n\n const classes = [\n baseClass,\n 'field-type',\n className,\n showError && 'error',\n disabled && `${baseClass}--read-only`,\n ]\n .filter(Boolean)\n .join(' ')\n\n let valueToRender = value\n\n if (typeof valueToRender === 'string') {\n try {\n const parsedJSON = JSON.parse(valueToRender)\n valueToRender = parsedJSON\n } catch (err) {\n valueToRender = null\n }\n }\n\n if (!valueToRender) {\n valueToRender = defaultRichTextValue\n }\n\n return (\n <div className={classes} style={styles}>\n {Label || <FieldLabel label={label} required={required} />}\n <div className={`${baseClass}__wrap`}>\n {Error}\n <Slate\n editor={editor}\n key={JSON.stringify({ initialValue, path })} // makes sure slate is completely re-rendered when initialValue changes, bypassing the slate-internal value memoization. That way, external changes to the form will update the editor\n onChange={handleChange}\n value={valueToRender as any[]}\n >\n <div className={`${baseClass}__wrapper`}>\n {Object.keys(elements)?.length + Object.keys(leaves)?.length > 0 && (\n <div\n className={[`${baseClass}__toolbar`, drawerIsOpen && `${baseClass}__drawerIsOpen`]\n .filter(Boolean)\n .join(' ')}\n ref={toolbarRef}\n >\n <div className={`${baseClass}__toolbar-wrap`}>\n {Object.values(elements).map((element) => {\n const Button = element?.Button\n\n if (Button) {\n return (\n <ElementButtonProvider\n disabled={disabled}\n fieldProps={props}\n key={element.name}\n path={path}\n schemaPath={schemaPath}\n >\n {Button}\n </ElementButtonProvider>\n )\n }\n\n return null\n })}\n {Object.values(leaves).map((leaf) => {\n const Button = leaf?.Button\n\n if (Button) {\n return (\n <LeafButtonProvider\n fieldProps={props}\n key={leaf.name}\n path={path}\n schemaPath={schemaPath}\n >\n {Button}\n </LeafButtonProvider>\n )\n }\n\n return null\n })}\n </div>\n </div>\n )}\n <div className={`${baseClass}__editor`} ref={editorRef}>\n <Editable\n className={`${baseClass}__input`}\n id={`field-${path.replace(/\\./g, '__')}`}\n onKeyDown={(event) => {\n if (event.key === 'Enter') {\n if (event.shiftKey) {\n event.preventDefault()\n editor.insertText('\\n')\n } else {\n const selectedElement = Node.descendant(\n editor,\n editor.selection.anchor.path.slice(0, -1),\n )\n\n if (SlateElement.isElement(selectedElement)) {\n // Allow hard enter to \"break out\" of certain elements\n if (editor.shouldBreakOutOnEnter(selectedElement)) {\n event.preventDefault()\n const selectedLeaf = Node.descendant(editor, editor.selection.anchor.path)\n\n if (\n Text.isText(selectedLeaf) &&\n String(selectedLeaf.text).length === editor.selection.anchor.offset\n ) {\n Transforms.insertNodes(editor, { children: [{ text: '' }] })\n } else {\n Transforms.splitNodes(editor)\n Transforms.setNodes(editor, {})\n }\n }\n }\n }\n }\n\n if (event.key === 'Backspace') {\n const selectedElement = Node.descendant(\n editor,\n editor.selection.anchor.path.slice(0, -1),\n )\n\n if (SlateElement.isElement(selectedElement) && selectedElement.type === 'li') {\n const selectedLeaf = Node.descendant(editor, editor.selection.anchor.path)\n if (Text.isText(selectedLeaf) && String(selectedLeaf.text).length === 0) {\n event.preventDefault()\n Transforms.unwrapNodes(editor, {\n match: (n) => SlateElement.isElement(n) && listTypes.includes(n.type),\n mode: 'lowest',\n split: true,\n })\n\n Transforms.setNodes(editor, { type: undefined })\n }\n } else if (editor.isVoid(selectedElement)) {\n Transforms.removeNodes(editor)\n }\n }\n\n Object.keys(hotkeys).forEach((hotkey) => {\n if (isHotkey(hotkey, event as any)) {\n event.preventDefault()\n const mark = hotkeys[hotkey]\n toggleLeaf(editor, mark)\n }\n })\n }}\n placeholder={getTranslation(placeholder, i18n)}\n readOnly={disabled}\n renderElement={renderElement}\n renderLeaf={renderLeaf}\n spellCheck\n />\n </div>\n </div>\n </Slate>\n {Description}\n </div>\n </div>\n )\n}\n\nexport const RichText = withCondition(RichTextField)\n"],"names":["getTranslation","FieldLabel","useEditDepth","useField","useTranslation","withCondition","mergeFieldStyles","isHotkey","React","useCallback","useEffect","useMemo","useRef","createEditor","Node","Element","SlateElement","Text","Transforms","withHistory","Editable","Slate","withReact","defaultRichTextValue","richTextValidate","listTypes","hotkeys","toggleLeaf","withEnterBreakOut","withHTML","ElementButtonProvider","ElementProvider","LeafButtonProvider","LeafProvider","baseClass","RichTextField","props","elements","field","name","admin","className","placeholder","readOnly","readOnlyFromAdmin","label","required","leaves","path","pathFromProps","plugins","readOnlyFromTopLevelProps","schemaPath","schemaPathFromProps","validate","readOnlyFromProps","i18n","editorRef","toolbarRef","drawerDepth","drawerIsOpen","memoizedValidate","value","validationOptions","req","t","customComponents","Description","Error","Label","formInitializing","initialValue","setValue","showError","disabled","editor","CreatedEditor","length","reduce","editorWithPlugins","plugin","renderElement","attributes","children","element","matchedElement","type","attr","textAlign","style","marginLeft","marginRight","listStylePosition","el","childNodes","fieldProps","div","renderLeaf","leaf","matchedLeaves","Object","entries","filter","leafName","result","leafConfig","i","Leaf","span","handleChange","val","ops","operations","o","Array","isArray","setClickableState","clickState","selectors","toolbarButtons","current","querySelectorAll","forEach","child","isButton","tagName","isDisabling","setAttribute","styles","classes","Boolean","join","valueToRender","parsedJSON","JSON","parse","err","onChange","keys","ref","values","map","Button","id","replace","onKeyDown","event","key","shiftKey","preventDefault","insertText","selectedElement","descendant","selection","anchor","slice","isElement","shouldBreakOutOnEnter","selectedLeaf","isText","String","text","offset","insertNodes","splitNodes","setNodes","unwrapNodes","match","n","includes","mode","split","undefined","isVoid","removeNodes","hotkey","mark","spellCheck","stringify","RichText"],"mappings":"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"}
@@ -1,15 +1,16 @@
1
1
  @import '../scss/styles.scss';
2
+ @layer payload-default {
3
+ .rich-text__button {
4
+ position: relative;
5
+ cursor: pointer;
2
6
 
3
- .rich-text__button {
4
- position: relative;
5
- cursor: pointer;
7
+ svg {
8
+ width: base(0.75);
9
+ height: base(0.75);
10
+ }
6
11
 
7
- svg {
8
- width: base(0.75);
9
- height: base(0.75);
10
- }
11
-
12
- &--disabled {
13
- opacity: 0.4;
12
+ &--disabled {
13
+ opacity: 0.4;
14
+ }
14
15
  }
15
16
  }
@@ -1,3 +1,4 @@
1
+ import type { ClientField } from 'payload';
1
2
  import type { EnabledFeatures } from './types.js';
2
- export declare const createFeatureMap: (richTextComponentMap: Map<string, React.ReactNode>) => EnabledFeatures;
3
+ export declare const createFeatureMap: (richTextComponentMap: Map<string, ClientField[] | React.ReactNode>) => EnabledFeatures;
3
4
  //# sourceMappingURL=createFeatureMap.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"createFeatureMap.d.ts","sourceRoot":"","sources":["../../src/field/createFeatureMap.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,eAAO,MAAM,gBAAgB,yBACL,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC,KACjD,eA4CF,CAAA"}
1
+ {"version":3,"file":"createFeatureMap.d.ts","sourceRoot":"","sources":["../../src/field/createFeatureMap.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAE1C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAEjD,eAAO,MAAM,gBAAgB,yBACL,GAAG,CAAC,MAAM,EAAE,WAAW,EAAE,GAAG,KAAK,CAAC,SAAS,CAAC,KACjE,eAuDF,CAAA"}
@@ -5,6 +5,9 @@ export const createFeatureMap = (richTextComponentMap)=>{
5
5
  plugins: []
6
6
  };
7
7
  for (const [key, value] of richTextComponentMap){
8
+ if (Array.isArray(value)) {
9
+ continue; // We only wanna process react nodes here
10
+ }
8
11
  if (key.startsWith('leaf.button') || key.startsWith('leaf.component.')) {
9
12
  const leafName = key.replace('leaf.button.', '').replace('leaf.component.', '');
10
13
  if (!features.leaves[leafName]) {
@@ -14,8 +17,12 @@ export const createFeatureMap = (richTextComponentMap)=>{
14
17
  Leaf: null
15
18
  };
16
19
  }
17
- if (key.startsWith('leaf.button.')) features.leaves[leafName].Button = value;
18
- if (key.startsWith('leaf.component.')) features.leaves[leafName].Leaf = value;
20
+ if (key.startsWith('leaf.button.')) {
21
+ features.leaves[leafName].Button = value;
22
+ }
23
+ if (key.startsWith('leaf.component.')) {
24
+ features.leaves[leafName].Leaf = value;
25
+ }
19
26
  }
20
27
  if (key.startsWith('element.button.') || key.startsWith('element.component.')) {
21
28
  const elementName = key.replace('element.button.', '').replace('element.component.', '');
@@ -26,8 +33,12 @@ export const createFeatureMap = (richTextComponentMap)=>{
26
33
  Element: null
27
34
  };
28
35
  }
29
- if (key.startsWith('element.button.')) features.elements[elementName].Button = value;
30
- if (key.startsWith('element.component.')) features.elements[elementName].Element = value;
36
+ if (key.startsWith('element.button.')) {
37
+ features.elements[elementName].Button = value;
38
+ }
39
+ if (key.startsWith('element.component.')) {
40
+ features.elements[elementName].Element = value;
41
+ }
31
42
  }
32
43
  if (key.startsWith('leaf.plugin.') || key.startsWith('element.plugin.')) {
33
44
  features.plugins.push(value);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/field/createFeatureMap.ts"],"sourcesContent":["import type { EnabledFeatures } from './types.js'\n\nexport const createFeatureMap = (\n richTextComponentMap: Map<string, React.ReactNode>,\n): EnabledFeatures => {\n const features: EnabledFeatures = {\n elements: {},\n leaves: {},\n plugins: [],\n }\n\n for (const [key, value] of richTextComponentMap) {\n if (key.startsWith('leaf.button') || key.startsWith('leaf.component.')) {\n const leafName = key.replace('leaf.button.', '').replace('leaf.component.', '')\n\n if (!features.leaves[leafName]) {\n features.leaves[leafName] = {\n name: leafName,\n Button: null,\n Leaf: null,\n }\n }\n\n if (key.startsWith('leaf.button.')) features.leaves[leafName].Button = value\n if (key.startsWith('leaf.component.')) features.leaves[leafName].Leaf = value\n }\n\n if (key.startsWith('element.button.') || key.startsWith('element.component.')) {\n const elementName = key.replace('element.button.', '').replace('element.component.', '')\n\n if (!features.elements[elementName]) {\n features.elements[elementName] = {\n name: elementName,\n Button: null,\n Element: null,\n }\n }\n\n if (key.startsWith('element.button.')) features.elements[elementName].Button = value\n if (key.startsWith('element.component.')) features.elements[elementName].Element = value\n }\n\n if (key.startsWith('leaf.plugin.') || key.startsWith('element.plugin.')) {\n features.plugins.push(value)\n }\n }\n\n return features\n}\n"],"names":["createFeatureMap","richTextComponentMap","features","elements","leaves","plugins","key","value","startsWith","leafName","replace","name","Button","Leaf","elementName","Element","push"],"mappings":"AAEA,OAAO,MAAMA,mBAAmB,CAC9BC;IAEA,MAAMC,WAA4B;QAChCC,UAAU,CAAC;QACXC,QAAQ,CAAC;QACTC,SAAS,EAAE;IACb;IAEA,KAAK,MAAM,CAACC,KAAKC,MAAM,IAAIN,qBAAsB;QAC/C,IAAIK,IAAIE,UAAU,CAAC,kBAAkBF,IAAIE,UAAU,CAAC,oBAAoB;YACtE,MAAMC,WAAWH,IAAII,OAAO,CAAC,gBAAgB,IAAIA,OAAO,CAAC,mBAAmB;YAE5E,IAAI,CAACR,SAASE,MAAM,CAACK,SAAS,EAAE;gBAC9BP,SAASE,MAAM,CAACK,SAAS,GAAG;oBAC1BE,MAAMF;oBACNG,QAAQ;oBACRC,MAAM;gBACR;YACF;YAEA,IAAIP,IAAIE,UAAU,CAAC,iBAAiBN,SAASE,MAAM,CAACK,SAAS,CAACG,MAAM,GAAGL;YACvE,IAAID,IAAIE,UAAU,CAAC,oBAAoBN,SAASE,MAAM,CAACK,SAAS,CAACI,IAAI,GAAGN;QAC1E;QAEA,IAAID,IAAIE,UAAU,CAAC,sBAAsBF,IAAIE,UAAU,CAAC,uBAAuB;YAC7E,MAAMM,cAAcR,IAAII,OAAO,CAAC,mBAAmB,IAAIA,OAAO,CAAC,sBAAsB;YAErF,IAAI,CAACR,SAASC,QAAQ,CAACW,YAAY,EAAE;gBACnCZ,SAASC,QAAQ,CAACW,YAAY,GAAG;oBAC/BH,MAAMG;oBACNF,QAAQ;oBACRG,SAAS;gBACX;YACF;YAEA,IAAIT,IAAIE,UAAU,CAAC,oBAAoBN,SAASC,QAAQ,CAACW,YAAY,CAACF,MAAM,GAAGL;YAC/E,IAAID,IAAIE,UAAU,CAAC,uBAAuBN,SAASC,QAAQ,CAACW,YAAY,CAACC,OAAO,GAAGR;QACrF;QAEA,IAAID,IAAIE,UAAU,CAAC,mBAAmBF,IAAIE,UAAU,CAAC,oBAAoB;YACvEN,SAASG,OAAO,CAACW,IAAI,CAACT;QACxB;IACF;IAEA,OAAOL;AACT,EAAC"}
1
+ {"version":3,"sources":["../../src/field/createFeatureMap.ts"],"sourcesContent":["import type { ClientField } from 'payload'\n\nimport type { EnabledFeatures } from './types.js'\n\nexport const createFeatureMap = (\n richTextComponentMap: Map<string, ClientField[] | React.ReactNode>,\n): EnabledFeatures => {\n const features: EnabledFeatures = {\n elements: {},\n leaves: {},\n plugins: [],\n }\n\n for (const [key, value] of richTextComponentMap) {\n if (Array.isArray(value)) {\n continue // We only wanna process react nodes here\n }\n if (key.startsWith('leaf.button') || key.startsWith('leaf.component.')) {\n const leafName = key.replace('leaf.button.', '').replace('leaf.component.', '')\n\n if (!features.leaves[leafName]) {\n features.leaves[leafName] = {\n name: leafName,\n Button: null,\n Leaf: null,\n }\n }\n\n if (key.startsWith('leaf.button.')) {\n features.leaves[leafName].Button = value\n }\n if (key.startsWith('leaf.component.')) {\n features.leaves[leafName].Leaf = value\n }\n }\n\n if (key.startsWith('element.button.') || key.startsWith('element.component.')) {\n const elementName = key.replace('element.button.', '').replace('element.component.', '')\n\n if (!features.elements[elementName]) {\n features.elements[elementName] = {\n name: elementName,\n Button: null,\n Element: null,\n }\n }\n\n if (key.startsWith('element.button.')) {\n features.elements[elementName].Button = value\n }\n if (key.startsWith('element.component.')) {\n features.elements[elementName].Element = value\n }\n }\n\n if (key.startsWith('leaf.plugin.') || key.startsWith('element.plugin.')) {\n features.plugins.push(value)\n }\n }\n\n return features\n}\n"],"names":["createFeatureMap","richTextComponentMap","features","elements","leaves","plugins","key","value","Array","isArray","startsWith","leafName","replace","name","Button","Leaf","elementName","Element","push"],"mappings":"AAIA,OAAO,MAAMA,mBAAmB,CAC9BC;IAEA,MAAMC,WAA4B;QAChCC,UAAU,CAAC;QACXC,QAAQ,CAAC;QACTC,SAAS,EAAE;IACb;IAEA,KAAK,MAAM,CAACC,KAAKC,MAAM,IAAIN,qBAAsB;QAC/C,IAAIO,MAAMC,OAAO,CAACF,QAAQ;YACxB,UAAS,yCAAyC;QACpD;QACA,IAAID,IAAII,UAAU,CAAC,kBAAkBJ,IAAII,UAAU,CAAC,oBAAoB;YACtE,MAAMC,WAAWL,IAAIM,OAAO,CAAC,gBAAgB,IAAIA,OAAO,CAAC,mBAAmB;YAE5E,IAAI,CAACV,SAASE,MAAM,CAACO,SAAS,EAAE;gBAC9BT,SAASE,MAAM,CAACO,SAAS,GAAG;oBAC1BE,MAAMF;oBACNG,QAAQ;oBACRC,MAAM;gBACR;YACF;YAEA,IAAIT,IAAII,UAAU,CAAC,iBAAiB;gBAClCR,SAASE,MAAM,CAACO,SAAS,CAACG,MAAM,GAAGP;YACrC;YACA,IAAID,IAAII,UAAU,CAAC,oBAAoB;gBACrCR,SAASE,MAAM,CAACO,SAAS,CAACI,IAAI,GAAGR;YACnC;QACF;QAEA,IAAID,IAAII,UAAU,CAAC,sBAAsBJ,IAAII,UAAU,CAAC,uBAAuB;YAC7E,MAAMM,cAAcV,IAAIM,OAAO,CAAC,mBAAmB,IAAIA,OAAO,CAAC,sBAAsB;YAErF,IAAI,CAACV,SAASC,QAAQ,CAACa,YAAY,EAAE;gBACnCd,SAASC,QAAQ,CAACa,YAAY,GAAG;oBAC/BH,MAAMG;oBACNF,QAAQ;oBACRG,SAAS;gBACX;YACF;YAEA,IAAIX,IAAII,UAAU,CAAC,oBAAoB;gBACrCR,SAASC,QAAQ,CAACa,YAAY,CAACF,MAAM,GAAGP;YAC1C;YACA,IAAID,IAAII,UAAU,CAAC,uBAAuB;gBACxCR,SAASC,QAAQ,CAACa,YAAY,CAACC,OAAO,GAAGV;YAC3C;QACF;QAEA,IAAID,IAAII,UAAU,CAAC,mBAAmBJ,IAAII,UAAU,CAAC,oBAAoB;YACvER,SAASG,OAAO,CAACa,IAAI,CAACX;QACxB;IACF;IAEA,OAAOL;AACT,EAAC"}
@@ -35,8 +35,8 @@ export const ElementButton = (props)=>{
35
35
  isElementActive(editor, format, type) && `${baseClass}__button--active`
36
36
  ].filter(Boolean).join(' '),
37
37
  onClick: onClick || defaultOnClick,
38
- onMouseEnter: ()=>setShowTooltip(true),
39
- onMouseLeave: ()=>setShowTooltip(false),
38
+ onPointerEnter: ()=>setShowTooltip(true),
39
+ onPointerLeave: ()=>setShowTooltip(false),
40
40
  children: [
41
41
  tooltip && /*#__PURE__*/ _jsx(Tooltip, {
42
42
  show: showTooltip,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/field/elements/Button.tsx"],"sourcesContent":["'use client'\nimport type { ElementType } from 'react'\n\nimport { Tooltip } from '@payloadcms/ui'\nimport React, { useCallback, useState } from 'react'\nimport { useSlate } from 'slate-react'\n\nimport type { ButtonProps } from './types.js'\n\nimport '../buttons.scss'\nimport { useElementButton } from '../providers/ElementButtonProvider.js'\nimport { isElementActive } from './isActive.js'\nimport { toggleElement } from './toggle.js'\n\nexport const baseClass = 'rich-text__button'\n\nexport const ElementButton: React.FC<ButtonProps> = (props) => {\n const {\n type = 'type',\n children,\n className,\n disabled: disabledFromProps,\n el = 'button',\n format,\n onClick,\n tooltip,\n } = props\n\n const editor = useSlate()\n const { disabled: disabledFromContext } = useElementButton()\n const [showTooltip, setShowTooltip] = useState(false)\n\n const defaultOnClick = useCallback(\n (event) => {\n event.preventDefault()\n setShowTooltip(false)\n toggleElement(editor, format, type)\n },\n [editor, format, type],\n )\n\n const Tag: ElementType = el\n\n const disabled = disabledFromProps || disabledFromContext\n\n return (\n <Tag\n {...(el === 'button' && { type: 'button', disabled })}\n className={[\n baseClass,\n className,\n isElementActive(editor, format, type) && `${baseClass}__button--active`,\n ]\n .filter(Boolean)\n .join(' ')}\n onClick={onClick || defaultOnClick}\n onMouseEnter={() => setShowTooltip(true)}\n onMouseLeave={() => setShowTooltip(false)}\n >\n {tooltip && <Tooltip show={showTooltip}>{tooltip}</Tooltip>}\n {children}\n </Tag>\n )\n}\n"],"names":["Tooltip","React","useCallback","useState","useSlate","useElementButton","isElementActive","toggleElement","baseClass","ElementButton","props","type","children","className","disabled","disabledFromProps","el","format","onClick","tooltip","editor","disabledFromContext","showTooltip","setShowTooltip","defaultOnClick","event","preventDefault","Tag","filter","Boolean","join","onMouseEnter","onMouseLeave","show"],"mappings":"AAAA;;AAGA,SAASA,OAAO,QAAQ,iBAAgB;AACxC,OAAOC,SAASC,WAAW,EAAEC,QAAQ,QAAQ,QAAO;AACpD,SAASC,QAAQ,QAAQ,cAAa;AAItC,OAAO,kBAAiB;AACxB,SAASC,gBAAgB,QAAQ,wCAAuC;AACxE,SAASC,eAAe,QAAQ,gBAAe;AAC/C,SAASC,aAAa,QAAQ,cAAa;AAE3C,OAAO,MAAMC,YAAY,oBAAmB;AAE5C,OAAO,MAAMC,gBAAuC,CAACC;IACnD,MAAM,EACJC,OAAO,MAAM,EACbC,QAAQ,EACRC,SAAS,EACTC,UAAUC,iBAAiB,EAC3BC,KAAK,QAAQ,EACbC,MAAM,EACNC,OAAO,EACPC,OAAO,EACR,GAAGT;IAEJ,MAAMU,SAAShB;IACf,MAAM,EAAEU,UAAUO,mBAAmB,EAAE,GAAGhB;IAC1C,MAAM,CAACiB,aAAaC,eAAe,GAAGpB,SAAS;IAE/C,MAAMqB,iBAAiBtB,YACrB,CAACuB;QACCA,MAAMC,cAAc;QACpBH,eAAe;QACfhB,cAAca,QAAQH,QAAQN;IAChC,GACA;QAACS;QAAQH;QAAQN;KAAK;IAGxB,MAAMgB,MAAmBX;IAEzB,MAAMF,WAAWC,qBAAqBM;IAEtC,qBACE,MAACM;QACE,GAAIX,OAAO,YAAY;YAAEL,MAAM;YAAUG;QAAS,CAAC;QACpDD,WAAW;YACTL;YACAK;YACAP,gBAAgBc,QAAQH,QAAQN,SAAS,CAAC,EAAEH,UAAU,gBAAgB,CAAC;SACxE,CACEoB,MAAM,CAACC,SACPC,IAAI,CAAC;QACRZ,SAASA,WAAWM;QACpBO,cAAc,IAAMR,eAAe;QACnCS,cAAc,IAAMT,eAAe;;YAElCJ,yBAAW,KAACnB;gBAAQiC,MAAMX;0BAAcH;;YACxCP;;;AAGP,EAAC"}
1
+ {"version":3,"sources":["../../../src/field/elements/Button.tsx"],"sourcesContent":["'use client'\nimport type { ElementType } from 'react'\n\nimport { Tooltip } from '@payloadcms/ui'\nimport React, { useCallback, useState } from 'react'\nimport { useSlate } from 'slate-react'\n\nimport type { ButtonProps } from './types.js'\n\nimport '../buttons.scss'\nimport { useElementButton } from '../providers/ElementButtonProvider.js'\nimport { isElementActive } from './isActive.js'\nimport { toggleElement } from './toggle.js'\n\nexport const baseClass = 'rich-text__button'\n\nexport const ElementButton: React.FC<ButtonProps> = (props) => {\n const {\n type = 'type',\n children,\n className,\n disabled: disabledFromProps,\n el = 'button',\n format,\n onClick,\n tooltip,\n } = props\n\n const editor = useSlate()\n const { disabled: disabledFromContext } = useElementButton()\n const [showTooltip, setShowTooltip] = useState(false)\n\n const defaultOnClick = useCallback(\n (event) => {\n event.preventDefault()\n setShowTooltip(false)\n toggleElement(editor, format, type)\n },\n [editor, format, type],\n )\n\n const Tag: ElementType = el\n\n const disabled = disabledFromProps || disabledFromContext\n\n return (\n <Tag\n {...(el === 'button' && { type: 'button', disabled })}\n className={[\n baseClass,\n className,\n isElementActive(editor, format, type) && `${baseClass}__button--active`,\n ]\n .filter(Boolean)\n .join(' ')}\n onClick={onClick || defaultOnClick}\n onPointerEnter={() => setShowTooltip(true)}\n onPointerLeave={() => setShowTooltip(false)}\n >\n {tooltip && <Tooltip show={showTooltip}>{tooltip}</Tooltip>}\n {children}\n </Tag>\n )\n}\n"],"names":["Tooltip","React","useCallback","useState","useSlate","useElementButton","isElementActive","toggleElement","baseClass","ElementButton","props","type","children","className","disabled","disabledFromProps","el","format","onClick","tooltip","editor","disabledFromContext","showTooltip","setShowTooltip","defaultOnClick","event","preventDefault","Tag","filter","Boolean","join","onPointerEnter","onPointerLeave","show"],"mappings":"AAAA;;AAGA,SAASA,OAAO,QAAQ,iBAAgB;AACxC,OAAOC,SAASC,WAAW,EAAEC,QAAQ,QAAQ,QAAO;AACpD,SAASC,QAAQ,QAAQ,cAAa;AAItC,OAAO,kBAAiB;AACxB,SAASC,gBAAgB,QAAQ,wCAAuC;AACxE,SAASC,eAAe,QAAQ,gBAAe;AAC/C,SAASC,aAAa,QAAQ,cAAa;AAE3C,OAAO,MAAMC,YAAY,oBAAmB;AAE5C,OAAO,MAAMC,gBAAuC,CAACC;IACnD,MAAM,EACJC,OAAO,MAAM,EACbC,QAAQ,EACRC,SAAS,EACTC,UAAUC,iBAAiB,EAC3BC,KAAK,QAAQ,EACbC,MAAM,EACNC,OAAO,EACPC,OAAO,EACR,GAAGT;IAEJ,MAAMU,SAAShB;IACf,MAAM,EAAEU,UAAUO,mBAAmB,EAAE,GAAGhB;IAC1C,MAAM,CAACiB,aAAaC,eAAe,GAAGpB,SAAS;IAE/C,MAAMqB,iBAAiBtB,YACrB,CAACuB;QACCA,MAAMC,cAAc;QACpBH,eAAe;QACfhB,cAAca,QAAQH,QAAQN;IAChC,GACA;QAACS;QAAQH;QAAQN;KAAK;IAGxB,MAAMgB,MAAmBX;IAEzB,MAAMF,WAAWC,qBAAqBM;IAEtC,qBACE,MAACM;QACE,GAAIX,OAAO,YAAY;YAAEL,MAAM;YAAUG;QAAS,CAAC;QACpDD,WAAW;YACTL;YACAK;YACAP,gBAAgBc,QAAQH,QAAQN,SAAS,CAAC,EAAEH,UAAU,gBAAgB,CAAC;SACxE,CACEoB,MAAM,CAACC,SACPC,IAAI,CAAC;QACRZ,SAASA,WAAWM;QACpBO,gBAAgB,IAAMR,eAAe;QACrCS,gBAAgB,IAAMT,eAAe;;YAEpCJ,yBAAW,KAACnB;gBAAQiC,MAAMX;0BAAcH;;YACxCP;;;AAGP,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"EnabledRelationshipsCondition.d.ts","sourceRoot":"","sources":["../../../src/field/elements/EnabledRelationshipsCondition.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AA2B9B,eAAO,MAAM,6BAA6B,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,CAiBvD,CAAA"}
1
+ {"version":3,"file":"EnabledRelationshipsCondition.d.ts","sourceRoot":"","sources":["../../../src/field/elements/EnabledRelationshipsCondition.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AA2B9B,eAAO,MAAM,6BAA6B,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,CAmBvD,CAAA"}
@@ -14,7 +14,7 @@ const filterRichTextCollections = (collections, options)=>{
14
14
  };
15
15
  export const EnabledRelationshipsCondition = (props)=>{
16
16
  const { children, uploads = false, ...rest } = props;
17
- const { collections } = useConfig();
17
+ const { config: { collections } } = useConfig();
18
18
  const { user } = useAuth();
19
19
  const { visibleEntities } = useEntityVisibility();
20
20
  const [enabledCollectionSlugs] = React.useState(()=>filterRichTextCollections(collections, {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/field/elements/EnabledRelationshipsCondition.tsx"],"sourcesContent":["'use client'\n\nimport type { ClientCollectionConfig, ClientUser, VisibleEntities } from 'payload'\n\nimport { useAuth, useConfig, useEntityVisibility } from '@payloadcms/ui'\nimport * as React from 'react'\n\ntype Options = {\n uploads: boolean\n user: ClientUser\n visibleEntities: VisibleEntities\n}\n\ntype FilteredCollectionsT = (\n collections: ClientCollectionConfig[],\n options?: Options,\n) => ClientCollectionConfig[]\n\nconst filterRichTextCollections: FilteredCollectionsT = (collections, options) => {\n return collections.filter(({ slug, admin: { enableRichTextRelationship }, upload }) => {\n if (!options.visibleEntities.collections.includes(slug)) {\n return false\n }\n\n if (options?.uploads) {\n return enableRichTextRelationship && Boolean(upload) === true\n }\n\n return upload ? false : enableRichTextRelationship\n })\n}\n\nexport const EnabledRelationshipsCondition: React.FC<any> = (props) => {\n const { children, uploads = false, ...rest } = props\n const { collections } = useConfig()\n const { user } = useAuth()\n const { visibleEntities } = useEntityVisibility()\n\n const [enabledCollectionSlugs] = React.useState(() =>\n filterRichTextCollections(collections, { uploads, user, visibleEntities }).map(\n ({ slug }) => slug,\n ),\n )\n\n if (!enabledCollectionSlugs.length) {\n return null\n }\n\n return React.cloneElement(children, { ...rest, enabledCollectionSlugs })\n}\n"],"names":["useAuth","useConfig","useEntityVisibility","React","filterRichTextCollections","collections","options","filter","slug","admin","enableRichTextRelationship","upload","visibleEntities","includes","uploads","Boolean","EnabledRelationshipsCondition","props","children","rest","user","enabledCollectionSlugs","useState","map","length","cloneElement"],"mappings":"AAAA;AAIA,SAASA,OAAO,EAAEC,SAAS,EAAEC,mBAAmB,QAAQ,iBAAgB;AACxE,YAAYC,WAAW,QAAO;AAa9B,MAAMC,4BAAkD,CAACC,aAAaC;IACpE,OAAOD,YAAYE,MAAM,CAAC,CAAC,EAAEC,IAAI,EAAEC,OAAO,EAAEC,0BAA0B,EAAE,EAAEC,MAAM,EAAE;QAChF,IAAI,CAACL,QAAQM,eAAe,CAACP,WAAW,CAACQ,QAAQ,CAACL,OAAO;YACvD,OAAO;QACT;QAEA,IAAIF,SAASQ,SAAS;YACpB,OAAOJ,8BAA8BK,QAAQJ,YAAY;QAC3D;QAEA,OAAOA,SAAS,QAAQD;IAC1B;AACF;AAEA,OAAO,MAAMM,gCAA+C,CAACC;IAC3D,MAAM,EAAEC,QAAQ,EAAEJ,UAAU,KAAK,EAAE,GAAGK,MAAM,GAAGF;IAC/C,MAAM,EAAEZ,WAAW,EAAE,GAAGJ;IACxB,MAAM,EAAEmB,IAAI,EAAE,GAAGpB;IACjB,MAAM,EAAEY,eAAe,EAAE,GAAGV;IAE5B,MAAM,CAACmB,uBAAuB,GAAGlB,MAAMmB,QAAQ,CAAC,IAC9ClB,0BAA0BC,aAAa;YAAES;YAASM;YAAMR;QAAgB,GAAGW,GAAG,CAC5E,CAAC,EAAEf,IAAI,EAAE,GAAKA;IAIlB,IAAI,CAACa,uBAAuBG,MAAM,EAAE;QAClC,OAAO;IACT;IAEA,qBAAOrB,MAAMsB,YAAY,CAACP,UAAU;QAAE,GAAGC,IAAI;QAAEE;IAAuB;AACxE,EAAC"}
1
+ {"version":3,"sources":["../../../src/field/elements/EnabledRelationshipsCondition.tsx"],"sourcesContent":["'use client'\n\nimport type { ClientCollectionConfig, ClientUser, VisibleEntities } from 'payload'\n\nimport { useAuth, useConfig, useEntityVisibility } from '@payloadcms/ui'\nimport * as React from 'react'\n\ntype Options = {\n uploads: boolean\n user: ClientUser\n visibleEntities: VisibleEntities\n}\n\ntype FilteredCollectionsT = (\n collections: ClientCollectionConfig[],\n options?: Options,\n) => ClientCollectionConfig[]\n\nconst filterRichTextCollections: FilteredCollectionsT = (collections, options) => {\n return collections.filter(({ slug, admin: { enableRichTextRelationship }, upload }) => {\n if (!options.visibleEntities.collections.includes(slug)) {\n return false\n }\n\n if (options?.uploads) {\n return enableRichTextRelationship && Boolean(upload) === true\n }\n\n return upload ? false : enableRichTextRelationship\n })\n}\n\nexport const EnabledRelationshipsCondition: React.FC<any> = (props) => {\n const { children, uploads = false, ...rest } = props\n const {\n config: { collections },\n } = useConfig()\n const { user } = useAuth()\n const { visibleEntities } = useEntityVisibility()\n\n const [enabledCollectionSlugs] = React.useState(() =>\n filterRichTextCollections(collections, { uploads, user, visibleEntities }).map(\n ({ slug }) => slug,\n ),\n )\n\n if (!enabledCollectionSlugs.length) {\n return null\n }\n\n return React.cloneElement(children, { ...rest, enabledCollectionSlugs })\n}\n"],"names":["useAuth","useConfig","useEntityVisibility","React","filterRichTextCollections","collections","options","filter","slug","admin","enableRichTextRelationship","upload","visibleEntities","includes","uploads","Boolean","EnabledRelationshipsCondition","props","children","rest","config","user","enabledCollectionSlugs","useState","map","length","cloneElement"],"mappings":"AAAA;AAIA,SAASA,OAAO,EAAEC,SAAS,EAAEC,mBAAmB,QAAQ,iBAAgB;AACxE,YAAYC,WAAW,QAAO;AAa9B,MAAMC,4BAAkD,CAACC,aAAaC;IACpE,OAAOD,YAAYE,MAAM,CAAC,CAAC,EAAEC,IAAI,EAAEC,OAAO,EAAEC,0BAA0B,EAAE,EAAEC,MAAM,EAAE;QAChF,IAAI,CAACL,QAAQM,eAAe,CAACP,WAAW,CAACQ,QAAQ,CAACL,OAAO;YACvD,OAAO;QACT;QAEA,IAAIF,SAASQ,SAAS;YACpB,OAAOJ,8BAA8BK,QAAQJ,YAAY;QAC3D;QAEA,OAAOA,SAAS,QAAQD;IAC1B;AACF;AAEA,OAAO,MAAMM,gCAA+C,CAACC;IAC3D,MAAM,EAAEC,QAAQ,EAAEJ,UAAU,KAAK,EAAE,GAAGK,MAAM,GAAGF;IAC/C,MAAM,EACJG,QAAQ,EAAEf,WAAW,EAAE,EACxB,GAAGJ;IACJ,MAAM,EAAEoB,IAAI,EAAE,GAAGrB;IACjB,MAAM,EAAEY,eAAe,EAAE,GAAGV;IAE5B,MAAM,CAACoB,uBAAuB,GAAGnB,MAAMoB,QAAQ,CAAC,IAC9CnB,0BAA0BC,aAAa;YAAES;YAASO;YAAMT;QAAgB,GAAGY,GAAG,CAC5E,CAAC,EAAEhB,IAAI,EAAE,GAAKA;IAIlB,IAAI,CAACc,uBAAuBG,MAAM,EAAE;QAClC,OAAO;IACT;IAEA,qBAAOtB,MAAMuB,YAAY,CAACR,UAAU;QAAE,GAAGC,IAAI;QAAEG;IAAuB;AACxE,EAAC"}
@@ -0,0 +1,4 @@
1
+ export declare const BlockquoteElementButton: ({ format }: {
2
+ format: string;
3
+ }) => import("react/jsx-runtime").JSX.Element;
4
+ //# sourceMappingURL=Button.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../../../src/field/elements/blockquote/Button.tsx"],"names":[],"mappings":"AAMA,eAAO,MAAM,uBAAuB,eAAgB;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,4CAIrE,CAAA"}
@@ -0,0 +1,11 @@
1
+ 'use client';
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import React from 'react';
4
+ import { BlockquoteIcon } from '../../icons/Blockquote/index.js';
5
+ import { ElementButton } from '../Button.js';
6
+ export const BlockquoteElementButton = ({ format })=>/*#__PURE__*/ _jsx(ElementButton, {
7
+ format: format,
8
+ children: /*#__PURE__*/ _jsx(BlockquoteIcon, {})
9
+ });
10
+
11
+ //# sourceMappingURL=Button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/field/elements/blockquote/Button.tsx"],"sourcesContent":["'use client'\nimport React from 'react'\n\nimport { BlockquoteIcon } from '../../icons/Blockquote/index.js'\nimport { ElementButton } from '../Button.js'\n\nexport const BlockquoteElementButton = ({ format }: { format: string }) => (\n <ElementButton format={format}>\n <BlockquoteIcon />\n </ElementButton>\n)\n"],"names":["React","BlockquoteIcon","ElementButton","BlockquoteElementButton","format"],"mappings":"AAAA;;AACA,OAAOA,WAAW,QAAO;AAEzB,SAASC,cAAc,QAAQ,kCAAiC;AAChE,SAASC,aAAa,QAAQ,eAAc;AAE5C,OAAO,MAAMC,0BAA0B,CAAC,EAAEC,MAAM,EAAsB,iBACpE,KAACF;QAAcE,QAAQA;kBACrB,cAAA,KAACH;OAEJ"}
@@ -0,0 +1,3 @@
1
+ import './index.scss';
2
+ export declare const BlockquoteElement: () => import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=Element.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Element.d.ts","sourceRoot":"","sources":["../../../../src/field/elements/blockquote/Element.tsx"],"names":[],"mappings":"AAKA,OAAO,cAAc,CAAA;AAErB,eAAO,MAAM,iBAAiB,+CAQ7B,CAAA"}
@@ -3,7 +3,7 @@ import { jsx as _jsx } from "react/jsx-runtime";
3
3
  import React from 'react';
4
4
  import { useElement } from '../../providers/ElementProvider.js';
5
5
  import './index.scss';
6
- export const Blockquote = ()=>{
6
+ export const BlockquoteElement = ()=>{
7
7
  const { attributes, children } = useElement();
8
8
  return /*#__PURE__*/ _jsx("blockquote", {
9
9
  className: "rich-text-blockquote",
@@ -12,4 +12,4 @@ export const Blockquote = ()=>{
12
12
  });
13
13
  };
14
14
 
15
- //# sourceMappingURL=Blockquote.js.map
15
+ //# sourceMappingURL=Element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/field/elements/blockquote/Element.tsx"],"sourcesContent":["'use client'\n\nimport React from 'react'\n\nimport { useElement } from '../../providers/ElementProvider.js'\nimport './index.scss'\n\nexport const BlockquoteElement = () => {\n const { attributes, children } = useElement()\n\n return (\n <blockquote className=\"rich-text-blockquote\" {...attributes}>\n {children}\n </blockquote>\n )\n}\n"],"names":["React","useElement","BlockquoteElement","attributes","children","blockquote","className"],"mappings":"AAAA;;AAEA,OAAOA,WAAW,QAAO;AAEzB,SAASC,UAAU,QAAQ,qCAAoC;AAC/D,OAAO,eAAc;AAErB,OAAO,MAAMC,oBAAoB;IAC/B,MAAM,EAAEC,UAAU,EAAEC,QAAQ,EAAE,GAAGH;IAEjC,qBACE,KAACI;QAAWC,WAAU;QAAwB,GAAGH,UAAU;kBACxDC;;AAGP,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/elements/blockquote/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA;AAQ9D,eAAO,MAAM,UAAU,EAAE,qBAQxB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/elements/blockquote/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA;AAI9D,eAAO,MAAM,UAAU,EAAE,qBASxB,CAAA"}
@@ -1,16 +1,13 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import React from 'react';
3
- import { BlockquoteIcon } from '../../icons/Blockquote/index.js';
4
- import { ElementButton } from '../Button.js';
5
- import { Blockquote } from './Blockquote.js';
6
1
  const name = 'blockquote';
7
2
  export const blockquote = {
8
3
  name,
9
- Button: ()=>/*#__PURE__*/ _jsx(ElementButton, {
10
- format: name,
11
- children: /*#__PURE__*/ _jsx(BlockquoteIcon, {})
12
- }),
13
- Element: Blockquote
4
+ Button: {
5
+ clientProps: {
6
+ format: name
7
+ },
8
+ path: '@payloadcms/richtext-slate/client#BlockquoteElementButton'
9
+ },
10
+ Element: '@payloadcms/richtext-slate/client#BlockquoteElement'
14
11
  };
15
12
 
16
13
  //# sourceMappingURL=index.js.map