@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
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/field/elements/h6/index.tsx"],"sourcesContent":["import React from 'react'\n\nimport type { RichTextCustomElement } from '../../../types.js'\n\nimport { H6Icon } from '../../icons/headings/H6/index.js'\nimport { ElementButton } from '../Button.js'\nimport { Heading6 } from './Heading6.js'\n\nconst name = 'h6'\n\nexport const h6: RichTextCustomElement = {\n name,\n Button: () => (\n <ElementButton format={name}>\n <H6Icon />\n </ElementButton>\n ),\n Element: Heading6,\n}\n"],"names":["React","H6Icon","ElementButton","Heading6","name","h6","Button","format","Element"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAIzB,SAASC,MAAM,QAAQ,mCAAkC;AACzD,SAASC,aAAa,QAAQ,eAAc;AAC5C,SAASC,QAAQ,QAAQ,gBAAe;AAExC,MAAMC,OAAO;AAEb,OAAO,MAAMC,KAA4B;IACvCD;IACAE,QAAQ,kBACN,KAACJ;YAAcK,QAAQH;sBACrB,cAAA,KAACH;;IAGLO,SAASL;AACX,EAAC"}
1
+ {"version":3,"sources":["../../../../src/field/elements/h6/index.tsx"],"sourcesContent":["import type { RichTextCustomElement } from '../../../types.js'\n\nconst name = 'h6'\n\nexport const h6: RichTextCustomElement = {\n name,\n Button: {\n clientProps: {\n format: name,\n },\n path: '@payloadcms/richtext-slate/client#H6ElementButton',\n },\n Element: '@payloadcms/richtext-slate/client#Heading6Element',\n}\n"],"names":["name","h6","Button","clientProps","format","path","Element"],"mappings":"AAEA,MAAMA,OAAO;AAEb,OAAO,MAAMC,KAA4B;IACvCD;IACAE,QAAQ;QACNC,aAAa;YACXC,QAAQJ;QACV;QACAK,MAAM;IACR;IACAC,SAAS;AACX,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/elements/indent/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA;AAM9D,eAAO,MAAM,MAAM,EAAE,qBAIpB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/elements/indent/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA;AAI9D,eAAO,MAAM,MAAM,EAAE,qBAIpB,CAAA"}
@@ -1,10 +1,8 @@
1
- import { IndentButton } from './Button.js';
2
- import { IndentElement } from './Element.js';
3
1
  import { indentType } from './shared.js';
4
2
  export const indent = {
5
3
  name: indentType,
6
- Button: IndentButton,
7
- Element: IndentElement
4
+ Button: '@payloadcms/richtext-slate/client#IndentButton',
5
+ Element: '@payloadcms/richtext-slate/client#IndentElement'
8
6
  };
9
7
 
10
8
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/field/elements/indent/index.ts"],"sourcesContent":["import type { RichTextCustomElement } from '../../../types.js'\n\nimport { IndentButton } from './Button.js'\nimport { IndentElement } from './Element.js'\nimport { indentType } from './shared.js'\n\nexport const indent: RichTextCustomElement = {\n name: indentType,\n Button: IndentButton,\n Element: IndentElement,\n}\n"],"names":["IndentButton","IndentElement","indentType","indent","name","Button","Element"],"mappings":"AAEA,SAASA,YAAY,QAAQ,cAAa;AAC1C,SAASC,aAAa,QAAQ,eAAc;AAC5C,SAASC,UAAU,QAAQ,cAAa;AAExC,OAAO,MAAMC,SAAgC;IAC3CC,MAAMF;IACNG,QAAQL;IACRM,SAASL;AACX,EAAC"}
1
+ {"version":3,"sources":["../../../../src/field/elements/indent/index.ts"],"sourcesContent":["import type { RichTextCustomElement } from '../../../types.js'\n\nimport { indentType } from './shared.js'\n\nexport const indent: RichTextCustomElement = {\n name: indentType,\n Button: '@payloadcms/richtext-slate/client#IndentButton',\n Element: '@payloadcms/richtext-slate/client#IndentElement',\n}\n"],"names":["indentType","indent","name","Button","Element"],"mappings":"AAEA,SAASA,UAAU,QAAQ,cAAa;AAExC,OAAO,MAAMC,SAAgC;IAC3CC,MAAMF;IACNG,QAAQ;IACRC,SAAS;AACX,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"isActive.d.ts","sourceRoot":"","sources":["../../../src/field/elements/isActive.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAW,MAAM,OAAO,CAAA;AAEvC,eAAO,MAAM,eAAe,WAAY,MAAM,UAAU,MAAM,yBAAuB,OAWpF,CAAA"}
1
+ {"version":3,"file":"isActive.d.ts","sourceRoot":"","sources":["../../../src/field/elements/isActive.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAW,MAAM,OAAO,CAAA;AAEvC,eAAO,MAAM,eAAe,WAAY,MAAM,UAAU,MAAM,yBAAuB,OAapF,CAAA"}
@@ -1,6 +1,8 @@
1
1
  import { Editor, Element } from 'slate';
2
2
  export const isElementActive = (editor, format, blockType = 'type')=>{
3
- if (!editor.selection) return false;
3
+ if (!editor.selection) {
4
+ return false;
5
+ }
4
6
  const [match] = Array.from(Editor.nodes(editor, {
5
7
  at: Editor.unhangRange(editor, editor.selection),
6
8
  match: (n)=>!Editor.isEditor(n) && Element.isElement(n) && n[blockType] === format
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/field/elements/isActive.tsx"],"sourcesContent":["import { Editor, Element } from 'slate'\n\nexport const isElementActive = (editor: Editor, format: string, blockType = 'type'): boolean => {\n if (!editor.selection) return false\n\n const [match] = Array.from(\n Editor.nodes(editor, {\n at: Editor.unhangRange(editor, editor.selection),\n match: (n) => !Editor.isEditor(n) && Element.isElement(n) && n[blockType] === format,\n }),\n )\n\n return !!match\n}\n"],"names":["Editor","Element","isElementActive","editor","format","blockType","selection","match","Array","from","nodes","at","unhangRange","n","isEditor","isElement"],"mappings":"AAAA,SAASA,MAAM,EAAEC,OAAO,QAAQ,QAAO;AAEvC,OAAO,MAAMC,kBAAkB,CAACC,QAAgBC,QAAgBC,YAAY,MAAM;IAChF,IAAI,CAACF,OAAOG,SAAS,EAAE,OAAO;IAE9B,MAAM,CAACC,MAAM,GAAGC,MAAMC,IAAI,CACxBT,OAAOU,KAAK,CAACP,QAAQ;QACnBQ,IAAIX,OAAOY,WAAW,CAACT,QAAQA,OAAOG,SAAS;QAC/CC,OAAO,CAACM,IAAM,CAACb,OAAOc,QAAQ,CAACD,MAAMZ,QAAQc,SAAS,CAACF,MAAMA,CAAC,CAACR,UAAU,KAAKD;IAChF;IAGF,OAAO,CAAC,CAACG;AACX,EAAC"}
1
+ {"version":3,"sources":["../../../src/field/elements/isActive.tsx"],"sourcesContent":["import { Editor, Element } from 'slate'\n\nexport const isElementActive = (editor: Editor, format: string, blockType = 'type'): boolean => {\n if (!editor.selection) {\n return false\n }\n\n const [match] = Array.from(\n Editor.nodes(editor, {\n at: Editor.unhangRange(editor, editor.selection),\n match: (n) => !Editor.isEditor(n) && Element.isElement(n) && n[blockType] === format,\n }),\n )\n\n return !!match\n}\n"],"names":["Editor","Element","isElementActive","editor","format","blockType","selection","match","Array","from","nodes","at","unhangRange","n","isEditor","isElement"],"mappings":"AAAA,SAASA,MAAM,EAAEC,OAAO,QAAQ,QAAO;AAEvC,OAAO,MAAMC,kBAAkB,CAACC,QAAgBC,QAAgBC,YAAY,MAAM;IAChF,IAAI,CAACF,OAAOG,SAAS,EAAE;QACrB,OAAO;IACT;IAEA,MAAM,CAACC,MAAM,GAAGC,MAAMC,IAAI,CACxBT,OAAOU,KAAK,CAACP,QAAQ;QACnBQ,IAAIX,OAAOY,WAAW,CAACT,QAAQA,OAAOG,SAAS;QAC/CC,OAAO,CAACM,IAAM,CAACb,OAAOc,QAAQ,CAACD,MAAMZ,QAAQc,SAAS,CAACF,MAAMA,CAAC,CAACR,UAAU,KAAKD;IAChF;IAGF,OAAO,CAAC,CAACG;AACX,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"isLastSelectedElementEmpty.d.ts","sourceRoot":"","sources":["../../../src/field/elements/isLastSelectedElementEmpty.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAW,MAAM,OAAO,CAAA;AAIvC,eAAO,MAAM,0BAA0B,WAAY,MAAM,KAAG,OAmB3D,CAAA"}
1
+ {"version":3,"file":"isLastSelectedElementEmpty.d.ts","sourceRoot":"","sources":["../../../src/field/elements/isLastSelectedElementEmpty.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAW,MAAM,OAAO,CAAA;AAIvC,eAAO,MAAM,0BAA0B,WAAY,MAAM,KAAG,OAqB3D,CAAA"}
@@ -1,7 +1,9 @@
1
1
  import { Editor, Element } from 'slate';
2
2
  import { nodeIsTextNode } from '../../types.js';
3
3
  export const isLastSelectedElementEmpty = (editor)=>{
4
- if (!editor.selection) return false;
4
+ if (!editor.selection) {
5
+ return false;
6
+ }
5
7
  const currentlySelectedNodes = Array.from(Editor.nodes(editor, {
6
8
  at: Editor.unhangRange(editor, editor.selection),
7
9
  match: (n)=>!Editor.isEditor(n) && Element.isElement(n) && (!n.type || n.type === 'p')
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/field/elements/isLastSelectedElementEmpty.ts"],"sourcesContent":["import { Editor, Element } from 'slate'\n\nimport { nodeIsTextNode } from '../../types.js'\n\nexport const isLastSelectedElementEmpty = (editor: Editor): boolean => {\n if (!editor.selection) return false\n\n const currentlySelectedNodes = Array.from(\n Editor.nodes(editor, {\n at: Editor.unhangRange(editor, editor.selection),\n match: (n) => !Editor.isEditor(n) && Element.isElement(n) && (!n.type || n.type === 'p'),\n }),\n )\n\n const lastSelectedNode = currentlySelectedNodes?.[currentlySelectedNodes?.length - 1]\n\n return (\n lastSelectedNode &&\n Element.isElement(lastSelectedNode[0]) &&\n (!lastSelectedNode[0].type || lastSelectedNode[0].type === 'p') &&\n nodeIsTextNode(lastSelectedNode[0].children?.[0]) &&\n lastSelectedNode[0].children?.[0].text === ''\n )\n}\n"],"names":["Editor","Element","nodeIsTextNode","isLastSelectedElementEmpty","editor","selection","currentlySelectedNodes","Array","from","nodes","at","unhangRange","match","n","isEditor","isElement","type","lastSelectedNode","length","children","text"],"mappings":"AAAA,SAASA,MAAM,EAAEC,OAAO,QAAQ,QAAO;AAEvC,SAASC,cAAc,QAAQ,iBAAgB;AAE/C,OAAO,MAAMC,6BAA6B,CAACC;IACzC,IAAI,CAACA,OAAOC,SAAS,EAAE,OAAO;IAE9B,MAAMC,yBAAyBC,MAAMC,IAAI,CACvCR,OAAOS,KAAK,CAACL,QAAQ;QACnBM,IAAIV,OAAOW,WAAW,CAACP,QAAQA,OAAOC,SAAS;QAC/CO,OAAO,CAACC,IAAM,CAACb,OAAOc,QAAQ,CAACD,MAAMZ,QAAQc,SAAS,CAACF,MAAO,CAAA,CAACA,EAAEG,IAAI,IAAIH,EAAEG,IAAI,KAAK,GAAE;IACxF;IAGF,MAAMC,mBAAmBX,wBAAwB,CAACA,wBAAwBY,SAAS,EAAE;IAErF,OACED,oBACAhB,QAAQc,SAAS,CAACE,gBAAgB,CAAC,EAAE,KACpC,CAAA,CAACA,gBAAgB,CAAC,EAAE,CAACD,IAAI,IAAIC,gBAAgB,CAAC,EAAE,CAACD,IAAI,KAAK,GAAE,KAC7Dd,eAAee,gBAAgB,CAAC,EAAE,CAACE,QAAQ,EAAE,CAAC,EAAE,KAChDF,gBAAgB,CAAC,EAAE,CAACE,QAAQ,EAAE,CAAC,EAAE,CAACC,SAAS;AAE/C,EAAC"}
1
+ {"version":3,"sources":["../../../src/field/elements/isLastSelectedElementEmpty.ts"],"sourcesContent":["import { Editor, Element } from 'slate'\n\nimport { nodeIsTextNode } from '../../types.js'\n\nexport const isLastSelectedElementEmpty = (editor: Editor): boolean => {\n if (!editor.selection) {\n return false\n }\n\n const currentlySelectedNodes = Array.from(\n Editor.nodes(editor, {\n at: Editor.unhangRange(editor, editor.selection),\n match: (n) => !Editor.isEditor(n) && Element.isElement(n) && (!n.type || n.type === 'p'),\n }),\n )\n\n const lastSelectedNode = currentlySelectedNodes?.[currentlySelectedNodes?.length - 1]\n\n return (\n lastSelectedNode &&\n Element.isElement(lastSelectedNode[0]) &&\n (!lastSelectedNode[0].type || lastSelectedNode[0].type === 'p') &&\n nodeIsTextNode(lastSelectedNode[0].children?.[0]) &&\n lastSelectedNode[0].children?.[0].text === ''\n )\n}\n"],"names":["Editor","Element","nodeIsTextNode","isLastSelectedElementEmpty","editor","selection","currentlySelectedNodes","Array","from","nodes","at","unhangRange","match","n","isEditor","isElement","type","lastSelectedNode","length","children","text"],"mappings":"AAAA,SAASA,MAAM,EAAEC,OAAO,QAAQ,QAAO;AAEvC,SAASC,cAAc,QAAQ,iBAAgB;AAE/C,OAAO,MAAMC,6BAA6B,CAACC;IACzC,IAAI,CAACA,OAAOC,SAAS,EAAE;QACrB,OAAO;IACT;IAEA,MAAMC,yBAAyBC,MAAMC,IAAI,CACvCR,OAAOS,KAAK,CAACL,QAAQ;QACnBM,IAAIV,OAAOW,WAAW,CAACP,QAAQA,OAAOC,SAAS;QAC/CO,OAAO,CAACC,IAAM,CAACb,OAAOc,QAAQ,CAACD,MAAMZ,QAAQc,SAAS,CAACF,MAAO,CAAA,CAACA,EAAEG,IAAI,IAAIH,EAAEG,IAAI,KAAK,GAAE;IACxF;IAGF,MAAMC,mBAAmBX,wBAAwB,CAACA,wBAAwBY,SAAS,EAAE;IAErF,OACED,oBACAhB,QAAQc,SAAS,CAACE,gBAAgB,CAAC,EAAE,KACpC,CAAA,CAACA,gBAAgB,CAAC,EAAE,CAACD,IAAI,IAAIC,gBAAgB,CAAC,EAAE,CAACD,IAAI,KAAK,GAAE,KAC7Dd,eAAee,gBAAgB,CAAC,EAAE,CAACE,QAAQ,EAAE,CAAC,EAAE,KAChDF,gBAAgB,CAAC,EAAE,CAACE,QAAQ,EAAE,CAAC,EAAE,CAACC,SAAS;AAE/C,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"isListActive.d.ts","sourceRoot":"","sources":["../../../src/field/elements/isListActive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAW,MAAM,OAAO,CAAA;AAIvC,eAAO,MAAM,YAAY,WAAY,MAAM,UAAU,MAAM,KAAG,OAsB7D,CAAA"}
1
+ {"version":3,"file":"isListActive.d.ts","sourceRoot":"","sources":["../../../src/field/elements/isListActive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAW,MAAM,OAAO,CAAA;AAIvC,eAAO,MAAM,YAAY,WAAY,MAAM,UAAU,MAAM,KAAG,OA0B7D,CAAA"}
@@ -1,9 +1,13 @@
1
1
  import { Editor, Element } from 'slate';
2
2
  import { getCommonBlock } from './getCommonBlock.js';
3
3
  export const isListActive = (editor, format)=>{
4
- if (!editor.selection) return false;
4
+ if (!editor.selection) {
5
+ return false;
6
+ }
5
7
  const [topmostSelectedNode, topmostSelectedNodePath] = getCommonBlock(editor);
6
- if (Editor.isEditor(topmostSelectedNode)) return false;
8
+ if (Editor.isEditor(topmostSelectedNode)) {
9
+ return false;
10
+ }
7
11
  const [match] = Array.from(Editor.nodes(editor, {
8
12
  at: topmostSelectedNodePath,
9
13
  match: (node, path)=>{
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/field/elements/isListActive.ts"],"sourcesContent":["import { Editor, Element } from 'slate'\n\nimport { getCommonBlock } from './getCommonBlock.js'\n\nexport const isListActive = (editor: Editor, format: string): boolean => {\n if (!editor.selection) return false\n const [topmostSelectedNode, topmostSelectedNodePath] = getCommonBlock(editor)\n\n if (Editor.isEditor(topmostSelectedNode)) return false\n\n const [match] = Array.from(\n Editor.nodes(editor, {\n at: topmostSelectedNodePath,\n match: (node, path) => {\n return (\n !Editor.isEditor(node) &&\n Element.isElement(node) &&\n node.type === format &&\n path.length >= topmostSelectedNodePath.length - 2\n )\n },\n mode: 'lowest',\n }),\n )\n\n return !!match\n}\n"],"names":["Editor","Element","getCommonBlock","isListActive","editor","format","selection","topmostSelectedNode","topmostSelectedNodePath","isEditor","match","Array","from","nodes","at","node","path","isElement","type","length","mode"],"mappings":"AAAA,SAASA,MAAM,EAAEC,OAAO,QAAQ,QAAO;AAEvC,SAASC,cAAc,QAAQ,sBAAqB;AAEpD,OAAO,MAAMC,eAAe,CAACC,QAAgBC;IAC3C,IAAI,CAACD,OAAOE,SAAS,EAAE,OAAO;IAC9B,MAAM,CAACC,qBAAqBC,wBAAwB,GAAGN,eAAeE;IAEtE,IAAIJ,OAAOS,QAAQ,CAACF,sBAAsB,OAAO;IAEjD,MAAM,CAACG,MAAM,GAAGC,MAAMC,IAAI,CACxBZ,OAAOa,KAAK,CAACT,QAAQ;QACnBU,IAAIN;QACJE,OAAO,CAACK,MAAMC;YACZ,OACE,CAAChB,OAAOS,QAAQ,CAACM,SACjBd,QAAQgB,SAAS,CAACF,SAClBA,KAAKG,IAAI,KAAKb,UACdW,KAAKG,MAAM,IAAIX,wBAAwBW,MAAM,GAAG;QAEpD;QACAC,MAAM;IACR;IAGF,OAAO,CAAC,CAACV;AACX,EAAC"}
1
+ {"version":3,"sources":["../../../src/field/elements/isListActive.ts"],"sourcesContent":["import { Editor, Element } from 'slate'\n\nimport { getCommonBlock } from './getCommonBlock.js'\n\nexport const isListActive = (editor: Editor, format: string): boolean => {\n if (!editor.selection) {\n return false\n }\n const [topmostSelectedNode, topmostSelectedNodePath] = getCommonBlock(editor)\n\n if (Editor.isEditor(topmostSelectedNode)) {\n return false\n }\n\n const [match] = Array.from(\n Editor.nodes(editor, {\n at: topmostSelectedNodePath,\n match: (node, path) => {\n return (\n !Editor.isEditor(node) &&\n Element.isElement(node) &&\n node.type === format &&\n path.length >= topmostSelectedNodePath.length - 2\n )\n },\n mode: 'lowest',\n }),\n )\n\n return !!match\n}\n"],"names":["Editor","Element","getCommonBlock","isListActive","editor","format","selection","topmostSelectedNode","topmostSelectedNodePath","isEditor","match","Array","from","nodes","at","node","path","isElement","type","length","mode"],"mappings":"AAAA,SAASA,MAAM,EAAEC,OAAO,QAAQ,QAAO;AAEvC,SAASC,cAAc,QAAQ,sBAAqB;AAEpD,OAAO,MAAMC,eAAe,CAACC,QAAgBC;IAC3C,IAAI,CAACD,OAAOE,SAAS,EAAE;QACrB,OAAO;IACT;IACA,MAAM,CAACC,qBAAqBC,wBAAwB,GAAGN,eAAeE;IAEtE,IAAIJ,OAAOS,QAAQ,CAACF,sBAAsB;QACxC,OAAO;IACT;IAEA,MAAM,CAACG,MAAM,GAAGC,MAAMC,IAAI,CACxBZ,OAAOa,KAAK,CAACT,QAAQ;QACnBU,IAAIN;QACJE,OAAO,CAACK,MAAMC;YACZ,OACE,CAAChB,OAAOS,QAAQ,CAACM,SACjBd,QAAQgB,SAAS,CAACF,SAClBA,KAAKG,IAAI,KAAKb,UACdW,KAAKG,MAAM,IAAIX,wBAAwBW,MAAM,GAAG;QAEpD;QACAC,MAAM;IACR;IAGF,OAAO,CAAC,CAACV;AACX,EAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/elements/li/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA;AAI9D,eAAO,MAAM,EAAE,EAAE,qBAGhB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/elements/li/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAA;AAE9D,eAAO,MAAM,EAAE,EAAE,qBAGhB,CAAA"}
@@ -1,7 +1,6 @@
1
- import { ListItemElement } from './ListItem.js';
2
1
  export const li = {
3
2
  name: 'li',
4
- Element: ListItemElement
3
+ Element: '@payloadcms/richtext-slate/client#ListItemElement'
5
4
  };
6
5
 
7
6
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/field/elements/li/index.tsx"],"sourcesContent":["import type { RichTextCustomElement } from '../../../types.js'\n\nimport { ListItemElement } from './ListItem.js'\n\nexport const li: RichTextCustomElement = {\n name: 'li',\n Element: ListItemElement,\n}\n"],"names":["ListItemElement","li","name","Element"],"mappings":"AAEA,SAASA,eAAe,QAAQ,gBAAe;AAE/C,OAAO,MAAMC,KAA4B;IACvCC,MAAM;IACNC,SAASH;AACX,EAAC"}
1
+ {"version":3,"sources":["../../../../src/field/elements/li/index.tsx"],"sourcesContent":["import type { RichTextCustomElement } from '../../../types.js'\n\nexport const li: RichTextCustomElement = {\n name: 'li',\n Element: '@payloadcms/richtext-slate/client#ListItemElement',\n}\n"],"names":["li","name","Element"],"mappings":"AAEA,OAAO,MAAMA,KAA4B;IACvCC,MAAM;IACNC,SAAS;AACX,EAAC"}
@@ -1,3 +1,5 @@
1
1
  import React from 'react';
2
- export declare const LinkButton: React.FC;
2
+ export declare const LinkButton: React.FC<{
3
+ schemaPath: string;
4
+ }>;
3
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/field/elements/link/Button/index.tsx"],"names":[],"mappings":"AAOA,OAAO,KAA6B,MAAM,OAAO,CAAA;AAkDjD,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EA8D9B,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/field/elements/link/Button/index.tsx"],"names":[],"mappings":"AAYA,OAAO,KAA6B,MAAM,OAAO,CAAA;AAkDjD,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC;IAChC,UAAU,EAAE,MAAM,CAAA;CACnB,CAqEA,CAAA"}
@@ -1,7 +1,6 @@
1
1
  'use client';
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
- import { useConfig, useDrawerSlug, useFieldProps, useModal, useTranslation } from '@payloadcms/ui';
4
- import { getFormState } from '@payloadcms/ui/shared';
3
+ import { useDocumentInfo, useDrawerSlug, useModal, useServerFunctions, useTranslation } from '@payloadcms/ui';
5
4
  import { reduceFieldsToValues } from 'payload/shared';
6
5
  import React, { Fragment, useState } from 'react';
7
6
  import { Editor, Range, Transforms } from 'slate';
@@ -60,17 +59,17 @@ import { unwrapLink } from '../utilities.js';
60
59
  }
61
60
  ReactEditor.focus(editor);
62
61
  };
63
- export const LinkButton = ()=>{
62
+ export const LinkButton = ({ schemaPath })=>{
64
63
  const { fieldProps } = useElementButton();
65
64
  const [initialState, setInitialState] = useState({});
66
65
  const { t } = useTranslation();
67
66
  const editor = useSlate();
68
- const config = useConfig();
67
+ const { getFormState } = useServerFunctions();
68
+ const { collectionSlug, docPermissions, getDocPreferences, globalSlug } = useDocumentInfo();
69
69
  const { closeModal, openModal } = useModal();
70
70
  const drawerSlug = useDrawerSlug('rich-text-link');
71
- const { schemaPath } = useFieldProps();
72
- const { richTextComponentMap } = fieldProps;
73
- const fieldMap = richTextComponentMap.get(linkFieldsSchemaPath);
71
+ const { componentMap } = fieldProps;
72
+ const fields = componentMap[linkFieldsSchemaPath];
74
73
  return /*#__PURE__*/ _jsxs(Fragment, {
75
74
  children: [
76
75
  /*#__PURE__*/ _jsx(ElementButton, {
@@ -86,14 +85,18 @@ export const LinkButton = ()=>{
86
85
  const data = {
87
86
  text: editor.selection ? Editor.string(editor, editor.selection) : ''
88
87
  };
89
- const state = await getFormState({
90
- apiRoute: config.routes.api,
91
- body: {
92
- data,
93
- operation: 'update',
94
- schemaPath: `${schemaPath}.${linkFieldsSchemaPath}`
95
- },
96
- serverURL: config.serverURL
88
+ const { state } = await getFormState({
89
+ collectionSlug,
90
+ data,
91
+ docPermissions,
92
+ docPreferences: await getDocPreferences(),
93
+ globalSlug,
94
+ operation: 'update',
95
+ renderAllFields: true,
96
+ schemaPath: [
97
+ ...schemaPath.split('.'),
98
+ ...linkFieldsSchemaPath.split('.')
99
+ ].join('.')
97
100
  });
98
101
  setInitialState(state);
99
102
  }
@@ -104,7 +107,7 @@ export const LinkButton = ()=>{
104
107
  }),
105
108
  /*#__PURE__*/ _jsx(LinkDrawer, {
106
109
  drawerSlug: drawerSlug,
107
- fieldMap: Array.isArray(fieldMap) ? fieldMap : [],
110
+ fields: Array.isArray(fields) ? fields : [],
108
111
  handleClose: ()=>{
109
112
  closeModal(drawerSlug);
110
113
  },
@@ -112,7 +115,8 @@ export const LinkButton = ()=>{
112
115
  insertLink(editor, fields);
113
116
  closeModal(drawerSlug);
114
117
  },
115
- initialState: initialState
118
+ initialState: initialState,
119
+ schemaPath: schemaPath
116
120
  })
117
121
  ]
118
122
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/field/elements/link/Button/index.tsx"],"sourcesContent":["'use client'\n\nimport type { FormState } from 'payload'\n\nimport { useConfig, useDrawerSlug, useFieldProps, useModal, useTranslation } from '@payloadcms/ui'\nimport { getFormState } from '@payloadcms/ui/shared'\nimport { reduceFieldsToValues } from 'payload/shared'\nimport React, { Fragment, useState } from 'react'\nimport { Editor, Range, Transforms } from 'slate'\nimport { ReactEditor, useSlate } from 'slate-react'\n\nimport { LinkIcon } from '../../../icons/Link/index.js'\nimport { useElementButton } from '../../../providers/ElementButtonProvider.js'\nimport { ElementButton } from '../../Button.js'\nimport { isElementActive } from '../../isActive.js'\nimport { LinkDrawer } from '../LinkDrawer/index.js'\nimport { linkFieldsSchemaPath } from '../shared.js'\nimport { unwrapLink } from '../utilities.js'\n\n/**\n * This function is called when a new link is created - not when an existing link is edited.\n */\nconst insertLink = (editor, fields) => {\n const isCollapsed = editor.selection && Range.isCollapsed(editor.selection)\n const data = reduceFieldsToValues(fields, true)\n\n const newLink = {\n type: 'link',\n children: [],\n doc: data.doc,\n fields: data.fields, // Any custom user-added fields are part of data.fields\n linkType: data.linkType,\n newTab: data.newTab,\n url: data.url,\n }\n\n if (isCollapsed || !editor.selection) {\n // If selection anchor and focus are the same,\n // Just inject a new node with children already set\n Transforms.insertNodes(editor, {\n ...newLink,\n children: [{ text: String(data.text) }],\n })\n } else if (editor.selection) {\n // Otherwise we need to wrap the selected node in a link,\n // Delete its old text,\n // Move the selection one position forward into the link,\n // And insert the text back into the new link\n Transforms.wrapNodes(editor, newLink, { split: true })\n Transforms.delete(editor, { at: editor.selection.focus.path, unit: 'word' })\n Transforms.move(editor, { distance: 1, unit: 'offset' })\n Transforms.insertText(editor, String(data.text), { at: editor.selection.focus.path })\n }\n\n ReactEditor.focus(editor)\n}\n\nexport const LinkButton: React.FC = () => {\n const { fieldProps } = useElementButton()\n const [initialState, setInitialState] = useState<FormState>({})\n\n const { t } = useTranslation()\n const editor = useSlate()\n const config = useConfig()\n\n const { closeModal, openModal } = useModal()\n const drawerSlug = useDrawerSlug('rich-text-link')\n const { schemaPath } = useFieldProps()\n\n const { richTextComponentMap } = fieldProps\n\n const fieldMap = richTextComponentMap.get(linkFieldsSchemaPath)\n\n return (\n <Fragment>\n <ElementButton\n className=\"link\"\n format=\"link\"\n onClick={async () => {\n if (isElementActive(editor, 'link')) {\n unwrapLink(editor)\n } else {\n openModal(drawerSlug)\n const isCollapsed = editor.selection && Range.isCollapsed(editor.selection)\n if (!isCollapsed) {\n const data = {\n text: editor.selection ? Editor.string(editor, editor.selection) : '',\n }\n const state = await getFormState({\n apiRoute: config.routes.api,\n body: {\n data,\n operation: 'update',\n schemaPath: `${schemaPath}.${linkFieldsSchemaPath}`,\n },\n serverURL: config.serverURL,\n })\n setInitialState(state)\n }\n }\n }}\n tooltip={t('fields:addLink')}\n >\n <LinkIcon />\n </ElementButton>\n <LinkDrawer\n drawerSlug={drawerSlug}\n fieldMap={Array.isArray(fieldMap) ? fieldMap : []}\n handleClose={() => {\n closeModal(drawerSlug)\n }}\n handleModalSubmit={(fields) => {\n insertLink(editor, fields)\n closeModal(drawerSlug)\n }}\n initialState={initialState}\n />\n </Fragment>\n )\n}\n"],"names":["useConfig","useDrawerSlug","useFieldProps","useModal","useTranslation","getFormState","reduceFieldsToValues","React","Fragment","useState","Editor","Range","Transforms","ReactEditor","useSlate","LinkIcon","useElementButton","ElementButton","isElementActive","LinkDrawer","linkFieldsSchemaPath","unwrapLink","insertLink","editor","fields","isCollapsed","selection","data","newLink","type","children","doc","linkType","newTab","url","insertNodes","text","String","wrapNodes","split","delete","at","focus","path","unit","move","distance","insertText","LinkButton","fieldProps","initialState","setInitialState","t","config","closeModal","openModal","drawerSlug","schemaPath","richTextComponentMap","fieldMap","get","className","format","onClick","string","state","apiRoute","routes","api","body","operation","serverURL","tooltip","Array","isArray","handleClose","handleModalSubmit"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../../src/field/elements/link/Button/index.tsx"],"sourcesContent":["'use client'\n\nimport type { FormState } from 'payload'\n\nimport {\n useDocumentInfo,\n useDrawerSlug,\n useModal,\n useServerFunctions,\n useTranslation,\n} from '@payloadcms/ui'\nimport { reduceFieldsToValues } from 'payload/shared'\nimport React, { Fragment, useState } from 'react'\nimport { Editor, Range, Transforms } from 'slate'\nimport { ReactEditor, useSlate } from 'slate-react'\n\nimport { LinkIcon } from '../../../icons/Link/index.js'\nimport { useElementButton } from '../../../providers/ElementButtonProvider.js'\nimport { ElementButton } from '../../Button.js'\nimport { isElementActive } from '../../isActive.js'\nimport { LinkDrawer } from '../LinkDrawer/index.js'\nimport { linkFieldsSchemaPath } from '../shared.js'\nimport { unwrapLink } from '../utilities.js'\n\n/**\n * This function is called when a new link is created - not when an existing link is edited.\n */\nconst insertLink = (editor, fields) => {\n const isCollapsed = editor.selection && Range.isCollapsed(editor.selection)\n const data = reduceFieldsToValues(fields, true)\n\n const newLink = {\n type: 'link',\n children: [],\n doc: data.doc,\n fields: data.fields, // Any custom user-added fields are part of data.fields\n linkType: data.linkType,\n newTab: data.newTab,\n url: data.url,\n }\n\n if (isCollapsed || !editor.selection) {\n // If selection anchor and focus are the same,\n // Just inject a new node with children already set\n Transforms.insertNodes(editor, {\n ...newLink,\n children: [{ text: String(data.text) }],\n })\n } else if (editor.selection) {\n // Otherwise we need to wrap the selected node in a link,\n // Delete its old text,\n // Move the selection one position forward into the link,\n // And insert the text back into the new link\n Transforms.wrapNodes(editor, newLink, { split: true })\n Transforms.delete(editor, { at: editor.selection.focus.path, unit: 'word' })\n Transforms.move(editor, { distance: 1, unit: 'offset' })\n Transforms.insertText(editor, String(data.text), { at: editor.selection.focus.path })\n }\n\n ReactEditor.focus(editor)\n}\n\nexport const LinkButton: React.FC<{\n schemaPath: string\n}> = ({ schemaPath }) => {\n const { fieldProps } = useElementButton()\n const [initialState, setInitialState] = useState<FormState>({})\n\n const { t } = useTranslation()\n const editor = useSlate()\n const { getFormState } = useServerFunctions()\n const { collectionSlug, docPermissions, getDocPreferences, globalSlug } = useDocumentInfo()\n\n const { closeModal, openModal } = useModal()\n const drawerSlug = useDrawerSlug('rich-text-link')\n\n const { componentMap } = fieldProps\n\n const fields = componentMap[linkFieldsSchemaPath]\n\n return (\n <Fragment>\n <ElementButton\n className=\"link\"\n format=\"link\"\n onClick={async () => {\n if (isElementActive(editor, 'link')) {\n unwrapLink(editor)\n } else {\n openModal(drawerSlug)\n const isCollapsed = editor.selection && Range.isCollapsed(editor.selection)\n\n if (!isCollapsed) {\n const data = {\n text: editor.selection ? Editor.string(editor, editor.selection) : '',\n }\n\n const { state } = await getFormState({\n collectionSlug,\n data,\n docPermissions,\n docPreferences: await getDocPreferences(),\n globalSlug,\n operation: 'update',\n renderAllFields: true,\n schemaPath: [...schemaPath.split('.'), ...linkFieldsSchemaPath.split('.')].join(\n '.',\n ),\n })\n\n setInitialState(state)\n }\n }\n }}\n tooltip={t('fields:addLink')}\n >\n <LinkIcon />\n </ElementButton>\n <LinkDrawer\n drawerSlug={drawerSlug}\n fields={Array.isArray(fields) ? fields : []}\n handleClose={() => {\n closeModal(drawerSlug)\n }}\n handleModalSubmit={(fields) => {\n insertLink(editor, fields)\n closeModal(drawerSlug)\n }}\n initialState={initialState}\n schemaPath={schemaPath}\n />\n </Fragment>\n )\n}\n"],"names":["useDocumentInfo","useDrawerSlug","useModal","useServerFunctions","useTranslation","reduceFieldsToValues","React","Fragment","useState","Editor","Range","Transforms","ReactEditor","useSlate","LinkIcon","useElementButton","ElementButton","isElementActive","LinkDrawer","linkFieldsSchemaPath","unwrapLink","insertLink","editor","fields","isCollapsed","selection","data","newLink","type","children","doc","linkType","newTab","url","insertNodes","text","String","wrapNodes","split","delete","at","focus","path","unit","move","distance","insertText","LinkButton","schemaPath","fieldProps","initialState","setInitialState","t","getFormState","collectionSlug","docPermissions","getDocPreferences","globalSlug","closeModal","openModal","drawerSlug","componentMap","className","format","onClick","string","state","docPreferences","operation","renderAllFields","join","tooltip","Array","isArray","handleClose","handleModalSubmit"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/field/elements/link/Element/index.tsx"],"names":[],"mappings":"AA4BA,OAAO,cAAc,CAAA;AA+BrB,eAAO,MAAM,WAAW,+CAoKvB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/field/elements/link/Element/index.tsx"],"names":[],"mappings":"AA2BA,OAAO,cAAc,CAAA;AAiCrB,eAAO,MAAM,WAAW,+CAsLvB,CAAA"}
@@ -1,10 +1,9 @@
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 { Button, Popup, Translation, useAuth, useConfig, useDocumentInfo, useDrawerSlug, useLocale, useModal, useTranslation } from '@payloadcms/ui';
5
- import { getFormState } from '@payloadcms/ui/shared';
4
+ import { Button, Popup, Translation, useConfig, useDocumentInfo, useDrawerSlug, useLocale, useModal, useServerFunctions, useTranslation } from '@payloadcms/ui';
6
5
  import { deepCopyObject, reduceFieldsToValues } from 'payload/shared';
7
- import React, { useCallback, useEffect, useState } from 'react';
6
+ import { useCallback, useEffect, useState } from 'react';
8
7
  import { Editor, Node, Transforms } from 'slate';
9
8
  import { ReactEditor, useSlate } from 'slate-react';
10
9
  import { useElement } from '../../../providers/ElementProvider.js';
@@ -25,7 +24,9 @@ const baseClass = 'rich-text-link';
25
24
  newTab: data.newTab,
26
25
  url: data.url
27
26
  };
28
- if (data.fields) newNode.fields = data.fields;
27
+ if (data.fields) {
28
+ newNode.fields = data.fields;
29
+ }
29
30
  Transforms.setNodes(editor, newNode, {
30
31
  at: parentPath
31
32
  });
@@ -45,18 +46,18 @@ const baseClass = 'rich-text-link';
45
46
  export const LinkElement = ()=>{
46
47
  const { attributes, children, editorRef, element, fieldProps, schemaPath } = useElement();
47
48
  const fieldMapPath = `${schemaPath}.${linkFieldsSchemaPath}`;
48
- const { richTextComponentMap } = fieldProps;
49
- const fieldMap = richTextComponentMap.get(linkFieldsSchemaPath);
49
+ const { componentMap } = fieldProps;
50
+ const fields = componentMap[linkFieldsSchemaPath];
51
+ const { id, collectionSlug, docPermissions, getDocPreferences, globalSlug } = useDocumentInfo();
50
52
  const editor = useSlate();
51
- const config = useConfig();
52
- const { user } = useAuth();
53
+ const { config } = useConfig();
53
54
  const { code: locale } = useLocale();
54
55
  const { i18n, t } = useTranslation();
55
56
  const { closeModal, openModal, toggleModal } = useModal();
56
57
  const [renderModal, setRenderModal] = useState(false);
57
58
  const [renderPopup, setRenderPopup] = useState(false);
58
59
  const [initialState, setInitialState] = useState({});
59
- const { id, collectionSlug } = useDocumentInfo();
60
+ const { getFormState } = useServerFunctions();
60
61
  const drawerSlug = useDrawerSlug('rich-text-link');
61
62
  const handleTogglePopup = useCallback((render)=>{
62
63
  if (!render) {
@@ -73,14 +74,15 @@ export const LinkElement = ()=>{
73
74
  text: Node.string(element),
74
75
  url: element.url
75
76
  };
76
- const state = await getFormState({
77
- apiRoute: config.routes.api,
78
- body: {
79
- data,
80
- operation: 'update',
81
- schemaPath: fieldMapPath
82
- },
83
- serverURL: config.serverURL
77
+ const { state } = await getFormState({
78
+ collectionSlug,
79
+ data,
80
+ docPermissions,
81
+ docPreferences: await getDocPreferences(),
82
+ globalSlug,
83
+ operation: 'update',
84
+ renderAllFields: true,
85
+ schemaPath: fieldMapPath ?? ''
84
86
  });
85
87
  setInitialState(state);
86
88
  };
@@ -90,13 +92,16 @@ export const LinkElement = ()=>{
90
92
  }, [
91
93
  renderModal,
92
94
  element,
93
- user,
94
95
  locale,
95
96
  t,
96
97
  collectionSlug,
97
98
  config,
98
99
  id,
99
- fieldMapPath
100
+ fieldMapPath,
101
+ getFormState,
102
+ globalSlug,
103
+ getDocPreferences,
104
+ docPermissions
100
105
  ]);
101
106
  return /*#__PURE__*/ _jsxs("span", {
102
107
  className: baseClass,
@@ -110,7 +115,7 @@ export const LinkElement = ()=>{
110
115
  children: [
111
116
  renderModal && /*#__PURE__*/ _jsx(LinkDrawer, {
112
117
  drawerSlug: drawerSlug,
113
- fieldMap: Array.isArray(fieldMap) ? fieldMap : [],
118
+ fields: Array.isArray(fields) ? fields : [],
114
119
  handleClose: ()=>{
115
120
  toggleModal(drawerSlug);
116
121
  setRenderModal(false);
@@ -120,7 +125,8 @@ export const LinkElement = ()=>{
120
125
  closeModal(drawerSlug);
121
126
  setRenderModal(false);
122
127
  },
123
- initialState: initialState
128
+ initialState: initialState,
129
+ schemaPath: schemaPath
124
130
  }),
125
131
  /*#__PURE__*/ _jsx(Popup, {
126
132
  boundingRef: editorRef,
@@ -193,7 +199,9 @@ export const LinkElement = ()=>{
193
199
  ].filter(Boolean).join(' '),
194
200
  onClick: ()=>setRenderPopup(true),
195
201
  onKeyDown: (e)=>{
196
- if (e.key === 'Enter') setRenderPopup(true);
202
+ if (e.key === 'Enter') {
203
+ setRenderPopup(true);
204
+ }
197
205
  },
198
206
  role: "button",
199
207
  tabIndex: 0,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/field/elements/link/Element/index.tsx"],"sourcesContent":["'use client'\nimport type { FormState } from 'payload'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport {\n Button,\n Popup,\n Translation,\n useAuth,\n useConfig,\n useDocumentInfo,\n useDrawerSlug,\n useLocale,\n useModal,\n useTranslation,\n} from '@payloadcms/ui'\nimport { getFormState } from '@payloadcms/ui/shared'\nimport { deepCopyObject, reduceFieldsToValues } from 'payload/shared'\nimport React, { useCallback, useEffect, useState } from 'react'\nimport { Editor, Node, Transforms } from 'slate'\nimport { ReactEditor, useSlate } from 'slate-react'\n\nimport type { LinkElementType } from '../types.js'\n\nimport { useElement } from '../../../providers/ElementProvider.js'\nimport { LinkDrawer } from '../LinkDrawer/index.js'\nimport { linkFieldsSchemaPath } from '../shared.js'\nimport { unwrapLink } from '../utilities.js'\nimport './index.scss'\n\nconst baseClass = 'rich-text-link'\n\n/**\n * This function is called when an existing link is edited.\n * When a link is first created, another function is called: {@link ../Button/index.tsx#insertLink}\n */\nconst insertChange = (editor, fields) => {\n const data = reduceFieldsToValues(fields, true)\n\n const [, parentPath] = Editor.above(editor)\n\n const newNode: Record<string, unknown> = {\n doc: data.doc,\n linkType: data.linkType,\n newTab: data.newTab,\n url: data.url,\n }\n\n if (data.fields) newNode.fields = data.fields\n\n Transforms.setNodes(editor, newNode, { at: parentPath })\n\n Transforms.delete(editor, { at: editor.selection.focus.path, unit: 'block' })\n Transforms.move(editor, { distance: 1, unit: 'offset' })\n Transforms.insertText(editor, String(data.text), { at: editor.selection.focus.path })\n\n ReactEditor.focus(editor)\n}\n\nexport const LinkElement = () => {\n const { attributes, children, editorRef, element, fieldProps, schemaPath } =\n useElement<LinkElementType>()\n\n const fieldMapPath = `${schemaPath}.${linkFieldsSchemaPath}`\n\n const { richTextComponentMap } = fieldProps\n const fieldMap = richTextComponentMap.get(linkFieldsSchemaPath)\n\n const editor = useSlate()\n const config = useConfig()\n const { user } = useAuth()\n const { code: locale } = useLocale()\n const { i18n, t } = useTranslation()\n const { closeModal, openModal, toggleModal } = useModal()\n const [renderModal, setRenderModal] = useState(false)\n const [renderPopup, setRenderPopup] = useState(false)\n const [initialState, setInitialState] = useState<FormState>({})\n const { id, collectionSlug } = useDocumentInfo()\n\n const drawerSlug = useDrawerSlug('rich-text-link')\n\n const handleTogglePopup = useCallback((render) => {\n if (!render) {\n setRenderPopup(render)\n }\n }, [])\n\n useEffect(() => {\n const awaitInitialState = async () => {\n const data = {\n doc: element.doc,\n fields: deepCopyObject(element.fields),\n linkType: element.linkType,\n newTab: element.newTab,\n text: Node.string(element),\n url: element.url,\n }\n\n const state = await getFormState({\n apiRoute: config.routes.api,\n body: {\n data,\n operation: 'update',\n schemaPath: fieldMapPath,\n },\n serverURL: config.serverURL,\n })\n\n setInitialState(state)\n }\n\n if (renderModal) {\n void awaitInitialState()\n }\n }, [renderModal, element, user, locale, t, collectionSlug, config, id, fieldMapPath])\n\n return (\n <span className={baseClass} {...attributes}>\n <span contentEditable={false} style={{ userSelect: 'none' }}>\n {renderModal && (\n <LinkDrawer\n drawerSlug={drawerSlug}\n fieldMap={Array.isArray(fieldMap) ? fieldMap : []}\n handleClose={() => {\n toggleModal(drawerSlug)\n setRenderModal(false)\n }}\n handleModalSubmit={(fields) => {\n insertChange(editor, fields)\n closeModal(drawerSlug)\n setRenderModal(false)\n }}\n initialState={initialState}\n />\n )}\n <Popup\n boundingRef={editorRef}\n buttonType=\"none\"\n forceOpen={renderPopup}\n horizontalAlign=\"left\"\n onToggleOpen={handleTogglePopup}\n render={() => (\n <div className={`${baseClass}__popup`}>\n {element.linkType === 'internal' && element.doc?.relationTo && element.doc?.value && (\n <Translation\n elements={{\n '0': ({ children }) => (\n <a\n className={`${baseClass}__link-label`}\n href={`${config.routes.admin}/collections/${element.doc.relationTo}/${element.doc.value}`}\n rel=\"noreferrer\"\n target=\"_blank\"\n title={`${config.routes.admin}/collections/${element.doc.relationTo}/${element.doc.value}`}\n >\n {children}\n </a>\n ),\n }}\n i18nKey=\"fields:linkedTo\"\n t={t}\n variables={{\n label: getTranslation(\n config.collections.find(({ slug }) => slug === element.doc.relationTo)?.labels\n ?.singular,\n i18n,\n ),\n }}\n />\n )}\n {(element.linkType === 'custom' || !element.linkType) && (\n <a\n className={`${baseClass}__link-label`}\n href={element.url}\n rel=\"noreferrer\"\n target=\"_blank\"\n title={element.url}\n >\n {element.url}\n </a>\n )}\n <Button\n buttonStyle=\"icon-label\"\n className={`${baseClass}__link-edit`}\n icon=\"edit\"\n onClick={(e) => {\n e.preventDefault()\n setRenderPopup(false)\n openModal(drawerSlug)\n setRenderModal(true)\n }}\n round\n tooltip={t('general:edit')}\n />\n <Button\n buttonStyle=\"icon-label\"\n className={`${baseClass}__link-close`}\n icon=\"x\"\n onClick={(e) => {\n e.preventDefault()\n unwrapLink(editor)\n }}\n round\n tooltip={t('general:remove')}\n />\n </div>\n )}\n size=\"fit-content\"\n verticalAlign=\"bottom\"\n />\n </span>\n <span\n className={[`${baseClass}__popup-toggler`].filter(Boolean).join(' ')}\n onClick={() => setRenderPopup(true)}\n onKeyDown={(e) => {\n if (e.key === 'Enter') setRenderPopup(true)\n }}\n role=\"button\"\n tabIndex={0}\n >\n {children}\n </span>\n </span>\n )\n}\n"],"names":["getTranslation","Button","Popup","Translation","useAuth","useConfig","useDocumentInfo","useDrawerSlug","useLocale","useModal","useTranslation","getFormState","deepCopyObject","reduceFieldsToValues","React","useCallback","useEffect","useState","Editor","Node","Transforms","ReactEditor","useSlate","useElement","LinkDrawer","linkFieldsSchemaPath","unwrapLink","baseClass","insertChange","editor","fields","data","parentPath","above","newNode","doc","linkType","newTab","url","setNodes","at","delete","selection","focus","path","unit","move","distance","insertText","String","text","LinkElement","attributes","children","editorRef","element","fieldProps","schemaPath","fieldMapPath","richTextComponentMap","fieldMap","get","config","user","code","locale","i18n","t","closeModal","openModal","toggleModal","renderModal","setRenderModal","renderPopup","setRenderPopup","initialState","setInitialState","id","collectionSlug","drawerSlug","handleTogglePopup","render","awaitInitialState","string","state","apiRoute","routes","api","body","operation","serverURL","span","className","contentEditable","style","userSelect","Array","isArray","handleClose","handleModalSubmit","boundingRef","buttonType","forceOpen","horizontalAlign","onToggleOpen","div","relationTo","value","elements","a","href","admin","rel","target","title","i18nKey","variables","label","collections","find","slug","labels","singular","buttonStyle","icon","onClick","e","preventDefault","round","tooltip","size","verticalAlign","filter","Boolean","join","onKeyDown","key","role","tabIndex"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../../src/field/elements/link/Element/index.tsx"],"sourcesContent":["'use client'\nimport type { FormState } from 'payload'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport {\n Button,\n Popup,\n Translation,\n useConfig,\n useDocumentInfo,\n useDrawerSlug,\n useLocale,\n useModal,\n useServerFunctions,\n useTranslation,\n} from '@payloadcms/ui'\nimport { deepCopyObject, reduceFieldsToValues } from 'payload/shared'\nimport { useCallback, useEffect, useState } from 'react'\nimport { Editor, Node, Transforms } from 'slate'\nimport { ReactEditor, useSlate } from 'slate-react'\n\nimport type { LinkElementType } from '../types.js'\n\nimport { useElement } from '../../../providers/ElementProvider.js'\nimport { LinkDrawer } from '../LinkDrawer/index.js'\nimport { linkFieldsSchemaPath } from '../shared.js'\nimport { unwrapLink } from '../utilities.js'\nimport './index.scss'\n\nconst baseClass = 'rich-text-link'\n\n/**\n * This function is called when an existing link is edited.\n * When a link is first created, another function is called: {@link ../Button/index.tsx#insertLink}\n */\nconst insertChange = (editor, fields) => {\n const data = reduceFieldsToValues(fields, true)\n\n const [, parentPath] = Editor.above(editor)\n\n const newNode: Record<string, unknown> = {\n doc: data.doc,\n linkType: data.linkType,\n newTab: data.newTab,\n url: data.url,\n }\n\n if (data.fields) {\n newNode.fields = data.fields\n }\n\n Transforms.setNodes(editor, newNode, { at: parentPath })\n\n Transforms.delete(editor, { at: editor.selection.focus.path, unit: 'block' })\n Transforms.move(editor, { distance: 1, unit: 'offset' })\n Transforms.insertText(editor, String(data.text), { at: editor.selection.focus.path })\n\n ReactEditor.focus(editor)\n}\n\nexport const LinkElement = () => {\n const { attributes, children, editorRef, element, fieldProps, schemaPath } =\n useElement<LinkElementType>()\n\n const fieldMapPath = `${schemaPath}.${linkFieldsSchemaPath}`\n\n const { componentMap } = fieldProps\n const fields = componentMap[linkFieldsSchemaPath]\n const { id, collectionSlug, docPermissions, getDocPreferences, globalSlug } = useDocumentInfo()\n\n const editor = useSlate()\n const { config } = useConfig()\n const { code: locale } = useLocale()\n const { i18n, t } = useTranslation()\n const { closeModal, openModal, toggleModal } = useModal()\n const [renderModal, setRenderModal] = useState(false)\n const [renderPopup, setRenderPopup] = useState(false)\n const [initialState, setInitialState] = useState<FormState>({})\n\n const { getFormState } = useServerFunctions()\n\n const drawerSlug = useDrawerSlug('rich-text-link')\n\n const handleTogglePopup = useCallback((render) => {\n if (!render) {\n setRenderPopup(render)\n }\n }, [])\n\n useEffect(() => {\n const awaitInitialState = async () => {\n const data = {\n doc: element.doc,\n fields: deepCopyObject(element.fields),\n linkType: element.linkType,\n newTab: element.newTab,\n text: Node.string(element),\n url: element.url,\n }\n\n const { state } = await getFormState({\n collectionSlug,\n data,\n docPermissions,\n docPreferences: await getDocPreferences(),\n globalSlug,\n operation: 'update',\n renderAllFields: true,\n schemaPath: fieldMapPath ?? '',\n })\n\n setInitialState(state)\n }\n\n if (renderModal) {\n void awaitInitialState()\n }\n }, [\n renderModal,\n element,\n locale,\n t,\n collectionSlug,\n config,\n id,\n fieldMapPath,\n getFormState,\n globalSlug,\n getDocPreferences,\n docPermissions,\n ])\n\n return (\n <span className={baseClass} {...attributes}>\n <span contentEditable={false} style={{ userSelect: 'none' }}>\n {renderModal && (\n <LinkDrawer\n drawerSlug={drawerSlug}\n fields={Array.isArray(fields) ? fields : []}\n handleClose={() => {\n toggleModal(drawerSlug)\n setRenderModal(false)\n }}\n handleModalSubmit={(fields) => {\n insertChange(editor, fields)\n closeModal(drawerSlug)\n setRenderModal(false)\n }}\n initialState={initialState}\n schemaPath={schemaPath}\n />\n )}\n <Popup\n boundingRef={editorRef}\n buttonType=\"none\"\n forceOpen={renderPopup}\n horizontalAlign=\"left\"\n onToggleOpen={handleTogglePopup}\n render={() => (\n <div className={`${baseClass}__popup`}>\n {element.linkType === 'internal' && element.doc?.relationTo && element.doc?.value && (\n <Translation\n elements={{\n '0': ({ children }) => (\n <a\n className={`${baseClass}__link-label`}\n href={`${config.routes.admin}/collections/${element.doc.relationTo}/${element.doc.value}`}\n rel=\"noreferrer\"\n target=\"_blank\"\n title={`${config.routes.admin}/collections/${element.doc.relationTo}/${element.doc.value}`}\n >\n {children}\n </a>\n ),\n }}\n i18nKey=\"fields:linkedTo\"\n t={t}\n variables={{\n label: getTranslation(\n config.collections.find(({ slug }) => slug === element.doc.relationTo)?.labels\n ?.singular,\n i18n,\n ),\n }}\n />\n )}\n {(element.linkType === 'custom' || !element.linkType) && (\n <a\n className={`${baseClass}__link-label`}\n href={element.url}\n rel=\"noreferrer\"\n target=\"_blank\"\n title={element.url}\n >\n {element.url}\n </a>\n )}\n <Button\n buttonStyle=\"icon-label\"\n className={`${baseClass}__link-edit`}\n icon=\"edit\"\n onClick={(e) => {\n e.preventDefault()\n setRenderPopup(false)\n openModal(drawerSlug)\n setRenderModal(true)\n }}\n round\n tooltip={t('general:edit')}\n />\n <Button\n buttonStyle=\"icon-label\"\n className={`${baseClass}__link-close`}\n icon=\"x\"\n onClick={(e) => {\n e.preventDefault()\n unwrapLink(editor)\n }}\n round\n tooltip={t('general:remove')}\n />\n </div>\n )}\n size=\"fit-content\"\n verticalAlign=\"bottom\"\n />\n </span>\n <span\n className={[`${baseClass}__popup-toggler`].filter(Boolean).join(' ')}\n onClick={() => setRenderPopup(true)}\n onKeyDown={(e) => {\n if (e.key === 'Enter') {\n setRenderPopup(true)\n }\n }}\n role=\"button\"\n tabIndex={0}\n >\n {children}\n </span>\n </span>\n )\n}\n"],"names":["getTranslation","Button","Popup","Translation","useConfig","useDocumentInfo","useDrawerSlug","useLocale","useModal","useServerFunctions","useTranslation","deepCopyObject","reduceFieldsToValues","useCallback","useEffect","useState","Editor","Node","Transforms","ReactEditor","useSlate","useElement","LinkDrawer","linkFieldsSchemaPath","unwrapLink","baseClass","insertChange","editor","fields","data","parentPath","above","newNode","doc","linkType","newTab","url","setNodes","at","delete","selection","focus","path","unit","move","distance","insertText","String","text","LinkElement","attributes","children","editorRef","element","fieldProps","schemaPath","fieldMapPath","componentMap","id","collectionSlug","docPermissions","getDocPreferences","globalSlug","config","code","locale","i18n","t","closeModal","openModal","toggleModal","renderModal","setRenderModal","renderPopup","setRenderPopup","initialState","setInitialState","getFormState","drawerSlug","handleTogglePopup","render","awaitInitialState","string","state","docPreferences","operation","renderAllFields","span","className","contentEditable","style","userSelect","Array","isArray","handleClose","handleModalSubmit","boundingRef","buttonType","forceOpen","horizontalAlign","onToggleOpen","div","relationTo","value","elements","a","href","routes","admin","rel","target","title","i18nKey","variables","label","collections","find","slug","labels","singular","buttonStyle","icon","onClick","e","preventDefault","round","tooltip","size","verticalAlign","filter","Boolean","join","onKeyDown","key","role","tabIndex"],"mappings":"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"}