@byline/richtext-lexical 0.9.3

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 (655) hide show
  1. package/LICENSE +373 -0
  2. package/README.md +18 -0
  3. package/dist/field/apply-value-plugin.d.ts +10 -0
  4. package/dist/field/apply-value-plugin.d.ts.map +1 -0
  5. package/dist/field/apply-value-plugin.js +60 -0
  6. package/dist/field/config/default.d.ts +6 -0
  7. package/dist/field/config/default.d.ts.map +1 -0
  8. package/dist/field/config/default.js +53 -0
  9. package/dist/field/config/editor-config-context.d.ts +14 -0
  10. package/dist/field/config/editor-config-context.d.ts.map +1 -0
  11. package/dist/field/config/editor-config-context.js +51 -0
  12. package/dist/field/config/types.d.ts +28 -0
  13. package/dist/field/config/types.d.ts.map +1 -0
  14. package/dist/field/config/types.js +1 -0
  15. package/dist/field/constants.d.ts +2 -0
  16. package/dist/field/constants.d.ts.map +1 -0
  17. package/dist/field/constants.js +2 -0
  18. package/dist/field/content-editable-inline.d.ts +13 -0
  19. package/dist/field/content-editable-inline.d.ts.map +1 -0
  20. package/dist/field/content-editable-inline.js +11 -0
  21. package/dist/field/content-editable.css +23 -0
  22. package/dist/field/content-editable.d.ts +13 -0
  23. package/dist/field/content-editable.d.ts.map +1 -0
  24. package/dist/field/content-editable.js +14 -0
  25. package/dist/field/context/shared-autocomplete-context.js +44 -0
  26. package/dist/field/context/shared-history-context.d.ts +19 -0
  27. package/dist/field/context/shared-history-context.d.ts.map +1 -0
  28. package/dist/field/context/shared-history-context.js +16 -0
  29. package/dist/field/context/shared-on-change-context.d.ts +13 -0
  30. package/dist/field/context/shared-on-change-context.d.ts.map +1 -0
  31. package/dist/field/context/shared-on-change-context.js +21 -0
  32. package/dist/field/debug.d.ts +10 -0
  33. package/dist/field/debug.d.ts.map +1 -0
  34. package/dist/field/debug.js +30 -0
  35. package/dist/field/editor-component.css +33 -0
  36. package/dist/field/editor-component.d.ts +13 -0
  37. package/dist/field/editor-component.d.ts.map +1 -0
  38. package/dist/field/editor-component.js +115 -0
  39. package/dist/field/editor-context.d.ts +23 -0
  40. package/dist/field/editor-context.d.ts.map +1 -0
  41. package/dist/field/editor-context.js +57 -0
  42. package/dist/field/editor-field.d.ts +34 -0
  43. package/dist/field/editor-field.d.ts.map +1 -0
  44. package/dist/field/editor-field.js +18 -0
  45. package/dist/field/editor.css +1449 -0
  46. package/dist/field/editor.d.ts +14 -0
  47. package/dist/field/editor.d.ts.map +1 -0
  48. package/dist/field/editor.js +190 -0
  49. package/dist/field/hooks/use-modal.d.ts +13 -0
  50. package/dist/field/hooks/use-modal.d.ts.map +1 -0
  51. package/dist/field/hooks/use-modal.js +37 -0
  52. package/dist/field/hooks/use-report.js +39 -0
  53. package/dist/field/lexical-populate-shared.d.ts +97 -0
  54. package/dist/field/lexical-populate-shared.d.ts.map +1 -0
  55. package/dist/field/lexical-populate-shared.js +60 -0
  56. package/dist/field/nodes/admonition-node/admonition-node-component.css +119 -0
  57. package/dist/field/nodes/admonition-node/admonition-node-component.d.ts +18 -0
  58. package/dist/field/nodes/admonition-node/admonition-node-component.d.ts.map +1 -0
  59. package/dist/field/nodes/admonition-node/admonition-node-component.js +190 -0
  60. package/dist/field/nodes/admonition-node/admonition-node.d.ts +35 -0
  61. package/dist/field/nodes/admonition-node/admonition-node.d.ts.map +1 -0
  62. package/dist/field/nodes/admonition-node/admonition-node.js +129 -0
  63. package/dist/field/nodes/admonition-node/icons/danger-icon.css +12 -0
  64. package/dist/field/nodes/admonition-node/icons/danger-icon.d.ts +8 -0
  65. package/dist/field/nodes/admonition-node/icons/danger-icon.d.ts.map +1 -0
  66. package/dist/field/nodes/admonition-node/icons/danger-icon.js +18 -0
  67. package/dist/field/nodes/admonition-node/icons/index.d.ts +5 -0
  68. package/dist/field/nodes/admonition-node/icons/index.d.ts.map +1 -0
  69. package/dist/field/nodes/admonition-node/icons/index.js +4 -0
  70. package/dist/field/nodes/admonition-node/icons/note-icon.css +12 -0
  71. package/dist/field/nodes/admonition-node/icons/note-icon.d.ts +8 -0
  72. package/dist/field/nodes/admonition-node/icons/note-icon.d.ts.map +1 -0
  73. package/dist/field/nodes/admonition-node/icons/note-icon.js +18 -0
  74. package/dist/field/nodes/admonition-node/icons/tip-icon.css +12 -0
  75. package/dist/field/nodes/admonition-node/icons/tip-icon.d.ts +8 -0
  76. package/dist/field/nodes/admonition-node/icons/tip-icon.d.ts.map +1 -0
  77. package/dist/field/nodes/admonition-node/icons/tip-icon.js +18 -0
  78. package/dist/field/nodes/admonition-node/icons/warning-icon.css +12 -0
  79. package/dist/field/nodes/admonition-node/icons/warning-icon.d.ts +8 -0
  80. package/dist/field/nodes/admonition-node/icons/warning-icon.d.ts.map +1 -0
  81. package/dist/field/nodes/admonition-node/icons/warning-icon.js +18 -0
  82. package/dist/field/nodes/admonition-node/index.d.ts +10 -0
  83. package/dist/field/nodes/admonition-node/index.d.ts.map +1 -0
  84. package/dist/field/nodes/admonition-node/index.js +2 -0
  85. package/dist/field/nodes/admonition-node/types.d.ts +21 -0
  86. package/dist/field/nodes/admonition-node/types.d.ts.map +1 -0
  87. package/dist/field/nodes/admonition-node/types.js +1 -0
  88. package/dist/field/nodes/document-relation.d.ts +33 -0
  89. package/dist/field/nodes/document-relation.d.ts.map +1 -0
  90. package/dist/field/nodes/document-relation.js +1 -0
  91. package/dist/field/nodes/index.d.ts +10 -0
  92. package/dist/field/nodes/index.d.ts.map +1 -0
  93. package/dist/field/nodes/index.js +37 -0
  94. package/dist/field/nodes/inline-image-node/index.d.ts +10 -0
  95. package/dist/field/nodes/inline-image-node/index.d.ts.map +1 -0
  96. package/dist/field/nodes/inline-image-node/index.js +2 -0
  97. package/dist/field/nodes/inline-image-node/inline-image-node-component.css +204 -0
  98. package/dist/field/nodes/inline-image-node/inline-image-node-component.d.ts +24 -0
  99. package/dist/field/nodes/inline-image-node/inline-image-node-component.d.ts.map +1 -0
  100. package/dist/field/nodes/inline-image-node/inline-image-node-component.js +221 -0
  101. package/dist/field/nodes/inline-image-node/inline-image-node.d.ts +45 -0
  102. package/dist/field/nodes/inline-image-node/inline-image-node.d.ts.map +1 -0
  103. package/dist/field/nodes/inline-image-node/inline-image-node.js +187 -0
  104. package/dist/field/nodes/inline-image-node/types.d.ts +30 -0
  105. package/dist/field/nodes/inline-image-node/types.d.ts.map +1 -0
  106. package/dist/field/nodes/inline-image-node/types.js +1 -0
  107. package/dist/field/nodes/layout-container-node/layout-container-node.d.ts +29 -0
  108. package/dist/field/nodes/layout-container-node/layout-container-node.d.ts.map +1 -0
  109. package/dist/field/nodes/layout-container-node/layout-container-node.js +54 -0
  110. package/dist/field/nodes/layout-container-node/layout-item-node.d.ts +23 -0
  111. package/dist/field/nodes/layout-container-node/layout-item-node.d.ts.map +1 -0
  112. package/dist/field/nodes/layout-container-node/layout-item-node.js +41 -0
  113. package/dist/field/nodes/link-nodes/auto-link-node.d.ts +17 -0
  114. package/dist/field/nodes/link-nodes/auto-link-node.d.ts.map +1 -0
  115. package/dist/field/nodes/link-nodes/auto-link-node.js +52 -0
  116. package/dist/field/nodes/link-nodes/index.d.ts +4 -0
  117. package/dist/field/nodes/link-nodes/index.d.ts.map +1 -0
  118. package/dist/field/nodes/link-nodes/index.js +3 -0
  119. package/dist/field/nodes/link-nodes/link-node.d.ts +49 -0
  120. package/dist/field/nodes/link-nodes/link-node.d.ts.map +1 -0
  121. package/dist/field/nodes/link-nodes/link-node.js +253 -0
  122. package/dist/field/nodes/link-nodes/types.d.ts +26 -0
  123. package/dist/field/nodes/link-nodes/types.d.ts.map +1 -0
  124. package/dist/field/nodes/link-nodes/types.js +1 -0
  125. package/dist/field/nodes/vimeo-node/index.d.ts +30 -0
  126. package/dist/field/nodes/vimeo-node/index.d.ts.map +1 -0
  127. package/dist/field/nodes/vimeo-node/index.js +109 -0
  128. package/dist/field/nodes/youtube-node/index.d.ts +30 -0
  129. package/dist/field/nodes/youtube-node/index.d.ts.map +1 -0
  130. package/dist/field/nodes/youtube-node/index.js +110 -0
  131. package/dist/field/plugins/admonition-plugin/admonition-modal.css +26 -0
  132. package/dist/field/plugins/admonition-plugin/admonition-modal.d.ts +12 -0
  133. package/dist/field/plugins/admonition-plugin/admonition-modal.d.ts.map +1 -0
  134. package/dist/field/plugins/admonition-plugin/admonition-modal.js +165 -0
  135. package/dist/field/plugins/admonition-plugin/fields.d.ts +21 -0
  136. package/dist/field/plugins/admonition-plugin/fields.d.ts.map +1 -0
  137. package/dist/field/plugins/admonition-plugin/fields.js +55 -0
  138. package/dist/field/plugins/admonition-plugin/index.d.ts +15 -0
  139. package/dist/field/plugins/admonition-plugin/index.d.ts.map +1 -0
  140. package/dist/field/plugins/admonition-plugin/index.js +54 -0
  141. package/dist/field/plugins/admonition-plugin/types.d.ts +34 -0
  142. package/dist/field/plugins/admonition-plugin/types.d.ts.map +1 -0
  143. package/dist/field/plugins/admonition-plugin/types.js +1 -0
  144. package/dist/field/plugins/auto-embed-plugin/auto-embed-modal.css +16 -0
  145. package/dist/field/plugins/auto-embed-plugin/auto-embed-modal.d.ts +8 -0
  146. package/dist/field/plugins/auto-embed-plugin/auto-embed-modal.d.ts.map +1 -0
  147. package/dist/field/plugins/auto-embed-plugin/auto-embed-modal.js +105 -0
  148. package/dist/field/plugins/auto-embed-plugin/index.d.ts +21 -0
  149. package/dist/field/plugins/auto-embed-plugin/index.d.ts.map +1 -0
  150. package/dist/field/plugins/auto-embed-plugin/index.js +152 -0
  151. package/dist/field/plugins/code-highlight-plugin/index.d.ts +10 -0
  152. package/dist/field/plugins/code-highlight-plugin/index.d.ts.map +1 -0
  153. package/dist/field/plugins/code-highlight-plugin/index.js +11 -0
  154. package/dist/field/plugins/drag-drop-paste-plugin/index.js +1 -0
  155. package/dist/field/plugins/floating-text-format-toolbar-plugin/index.css +148 -0
  156. package/dist/field/plugins/floating-text-format-toolbar-plugin/index.d.ts +13 -0
  157. package/dist/field/plugins/floating-text-format-toolbar-plugin/index.d.ts.map +1 -0
  158. package/dist/field/plugins/floating-text-format-toolbar-plugin/index.js +279 -0
  159. package/dist/field/plugins/inline-image-plugin/fields.d.ts +12 -0
  160. package/dist/field/plugins/inline-image-plugin/fields.d.ts.map +1 -0
  161. package/dist/field/plugins/inline-image-plugin/fields.js +22 -0
  162. package/dist/field/plugins/inline-image-plugin/index.d.ts +34 -0
  163. package/dist/field/plugins/inline-image-plugin/index.d.ts.map +1 -0
  164. package/dist/field/plugins/inline-image-plugin/index.js +107 -0
  165. package/dist/field/plugins/inline-image-plugin/inline-image-modal.css +25 -0
  166. package/dist/field/plugins/inline-image-plugin/inline-image-modal.d.ts +11 -0
  167. package/dist/field/plugins/inline-image-plugin/inline-image-modal.d.ts.map +1 -0
  168. package/dist/field/plugins/inline-image-plugin/inline-image-modal.js +271 -0
  169. package/dist/field/plugins/inline-image-plugin/populate.d.ts +10 -0
  170. package/dist/field/plugins/inline-image-plugin/populate.d.ts.map +1 -0
  171. package/dist/field/plugins/inline-image-plugin/populate.js +28 -0
  172. package/dist/field/plugins/inline-image-plugin/types.d.ts +37 -0
  173. package/dist/field/plugins/inline-image-plugin/types.d.ts.map +1 -0
  174. package/dist/field/plugins/inline-image-plugin/types.js +1 -0
  175. package/dist/field/plugins/inline-image-plugin/utils.d.ts +42 -0
  176. package/dist/field/plugins/inline-image-plugin/utils.d.ts.map +1 -0
  177. package/dist/field/plugins/inline-image-plugin/utils.js +46 -0
  178. package/dist/field/plugins/layout-plugin/insert-layout-modal.css +20 -0
  179. package/dist/field/plugins/layout-plugin/insert-layout-modal.d.ts +22 -0
  180. package/dist/field/plugins/layout-plugin/insert-layout-modal.d.ts.map +1 -0
  181. package/dist/field/plugins/layout-plugin/insert-layout-modal.js +97 -0
  182. package/dist/field/plugins/layout-plugin/layout-plugin.d.ts +10 -0
  183. package/dist/field/plugins/layout-plugin/layout-plugin.d.ts.map +1 -0
  184. package/dist/field/plugins/layout-plugin/layout-plugin.js +81 -0
  185. package/dist/field/plugins/link-plugin/auto-link/auto-link-plugin.d.ts +22 -0
  186. package/dist/field/plugins/link-plugin/auto-link/auto-link-plugin.d.ts.map +1 -0
  187. package/dist/field/plugins/link-plugin/auto-link/auto-link-plugin.js +185 -0
  188. package/dist/field/plugins/link-plugin/auto-link/index.d.ts +10 -0
  189. package/dist/field/plugins/link-plugin/auto-link/index.d.ts.map +1 -0
  190. package/dist/field/plugins/link-plugin/auto-link/index.js +15 -0
  191. package/dist/field/plugins/link-plugin/link/floating-link-editor.css +124 -0
  192. package/dist/field/plugins/link-plugin/link/floating-link-editor.d.ts +15 -0
  193. package/dist/field/plugins/link-plugin/link/floating-link-editor.d.ts.map +1 -0
  194. package/dist/field/plugins/link-plugin/link/floating-link-editor.js +234 -0
  195. package/dist/field/plugins/link-plugin/link/index.d.ts +2 -0
  196. package/dist/field/plugins/link-plugin/link/index.d.ts.map +1 -0
  197. package/dist/field/plugins/link-plugin/link/index.js +43 -0
  198. package/dist/field/plugins/link-plugin/link/link-modal.d.ts +11 -0
  199. package/dist/field/plugins/link-plugin/link/link-modal.d.ts.map +1 -0
  200. package/dist/field/plugins/link-plugin/link/link-modal.js +311 -0
  201. package/dist/field/plugins/link-plugin/link/types.d.ts +19 -0
  202. package/dist/field/plugins/link-plugin/link/types.d.ts.map +1 -0
  203. package/dist/field/plugins/link-plugin/link/types.js +1 -0
  204. package/dist/field/plugins/link-plugin/populate.d.ts +22 -0
  205. package/dist/field/plugins/link-plugin/populate.d.ts.map +1 -0
  206. package/dist/field/plugins/link-plugin/populate.js +28 -0
  207. package/dist/field/plugins/table-action-menu-plugin/index.d.ts +6 -0
  208. package/dist/field/plugins/table-action-menu-plugin/index.d.ts.map +1 -0
  209. package/dist/field/plugins/table-action-menu-plugin/index.js +598 -0
  210. package/dist/field/plugins/table-plugin/index.d.ts +4 -0
  211. package/dist/field/plugins/table-plugin/index.d.ts.map +1 -0
  212. package/dist/field/plugins/table-plugin/index.js +26 -0
  213. package/dist/field/plugins/table-plugin/table-modal.css +20 -0
  214. package/dist/field/plugins/table-plugin/table-modal.d.ts +21 -0
  215. package/dist/field/plugins/table-plugin/table-modal.d.ts.map +1 -0
  216. package/dist/field/plugins/table-plugin/table-modal.js +111 -0
  217. package/dist/field/plugins/toolbar-plugin/index.d.ts +17 -0
  218. package/dist/field/plugins/toolbar-plugin/index.d.ts.map +1 -0
  219. package/dist/field/plugins/toolbar-plugin/index.js +837 -0
  220. package/dist/field/plugins/treeview-plugin/index.d.ts +10 -0
  221. package/dist/field/plugins/treeview-plugin/index.d.ts.map +1 -0
  222. package/dist/field/plugins/treeview-plugin/index.js +17 -0
  223. package/dist/field/plugins/vimeo-plugin/index.d.ts +4 -0
  224. package/dist/field/plugins/vimeo-plugin/index.d.ts.map +1 -0
  225. package/dist/field/plugins/vimeo-plugin/index.js +24 -0
  226. package/dist/field/plugins/youtube-plugin/index.d.ts +4 -0
  227. package/dist/field/plugins/youtube-plugin/index.d.ts.map +1 -0
  228. package/dist/field/plugins/youtube-plugin/index.js +24 -0
  229. package/dist/field/shared/canUseDOM.d.ts +9 -0
  230. package/dist/field/shared/canUseDOM.d.ts.map +1 -0
  231. package/dist/field/shared/canUseDOM.js +2 -0
  232. package/dist/field/shared/environment.d.ts +23 -0
  233. package/dist/field/shared/environment.d.ts.map +1 -0
  234. package/dist/field/shared/environment.js +10 -0
  235. package/dist/field/shared/invariant.d.ts +9 -0
  236. package/dist/field/shared/invariant.d.ts.map +1 -0
  237. package/dist/field/shared/invariant.js +6 -0
  238. package/dist/field/shared/simpleDiffWithCursor.js +15 -0
  239. package/dist/field/shared/useLayoutEffect.js +5 -0
  240. package/dist/field/shared/useModalFormState.d.ts +23 -0
  241. package/dist/field/shared/useModalFormState.d.ts.map +1 -0
  242. package/dist/field/shared/useModalFormState.js +23 -0
  243. package/dist/field/shared/warnOnlyOnce.js +9 -0
  244. package/dist/field/themes/lexical-editor-theme.css +537 -0
  245. package/dist/field/themes/lexical-editor-theme.d.ts +10 -0
  246. package/dist/field/themes/lexical-editor-theme.d.ts.map +1 -0
  247. package/dist/field/themes/lexical-editor-theme.js +105 -0
  248. package/dist/field/toolbar-extensions.d.ts +32 -0
  249. package/dist/field/toolbar-extensions.d.ts.map +1 -0
  250. package/dist/field/toolbar-extensions.js +56 -0
  251. package/dist/field/types.js +1 -0
  252. package/dist/field/ui/button.css +31 -0
  253. package/dist/field/ui/button.js +19 -0
  254. package/dist/field/ui/checkbox.css +46 -0
  255. package/dist/field/ui/color-picker.css +75 -0
  256. package/dist/field/ui/color-picker.d.ts +21 -0
  257. package/dist/field/ui/color-picker.d.ts.map +1 -0
  258. package/dist/field/ui/color-picker.js +360 -0
  259. package/dist/field/ui/dialog.css +18 -0
  260. package/dist/field/ui/dialog.js +17 -0
  261. package/dist/field/ui/dropdown.d.ts +25 -0
  262. package/dist/field/ui/dropdown.d.ts.map +1 -0
  263. package/dist/field/ui/dropdown.js +150 -0
  264. package/dist/field/ui/file-input.js +27 -0
  265. package/dist/field/ui/input.css +23 -0
  266. package/dist/field/ui/modal.css +73 -0
  267. package/dist/field/ui/modal.d.ts +17 -0
  268. package/dist/field/ui/modal.d.ts.map +1 -0
  269. package/dist/field/ui/modal.js +69 -0
  270. package/dist/field/ui/placeholder-inline.d.ts +14 -0
  271. package/dist/field/ui/placeholder-inline.d.ts.map +1 -0
  272. package/dist/field/ui/placeholder-inline.js +12 -0
  273. package/dist/field/ui/placeholder.css +26 -0
  274. package/dist/field/ui/placeholder.d.ts +14 -0
  275. package/dist/field/ui/placeholder.d.ts.map +1 -0
  276. package/dist/field/ui/placeholder.js +14 -0
  277. package/dist/field/ui/select.css +32 -0
  278. package/dist/field/ui/select.js +28 -0
  279. package/dist/field/ui/switch.js +25 -0
  280. package/dist/field/ui/text-area.css +31 -0
  281. package/dist/field/ui/text-area.js +28 -0
  282. package/dist/field/ui/text-input.d.ts +20 -0
  283. package/dist/field/ui/text-input.d.ts.map +1 -0
  284. package/dist/field/ui/text-input.js +29 -0
  285. package/dist/field/utils/cloneDeep.js +26 -0
  286. package/dist/field/utils/deepEqual.js +19 -0
  287. package/dist/field/utils/emoji-list.js +21389 -0
  288. package/dist/field/utils/getDOMRangeRect.d.ts +9 -0
  289. package/dist/field/utils/getDOMRangeRect.d.ts.map +1 -0
  290. package/dist/field/utils/getDOMRangeRect.js +11 -0
  291. package/dist/field/utils/getSelectedNode.d.ts +3 -0
  292. package/dist/field/utils/getSelectedNode.d.ts.map +1 -0
  293. package/dist/field/utils/getSelectedNode.js +12 -0
  294. package/dist/field/utils/guard.js +4 -0
  295. package/dist/field/utils/hashSerializedState.d.ts +3 -0
  296. package/dist/field/utils/hashSerializedState.d.ts.map +1 -0
  297. package/dist/field/utils/hashSerializedState.js +22 -0
  298. package/dist/field/utils/isMobileWidth.js +1 -0
  299. package/dist/field/utils/joinClasses.js +4 -0
  300. package/dist/field/utils/point.js +34 -0
  301. package/dist/field/utils/rect.js +95 -0
  302. package/dist/field/utils/setFloatingElemPosition.d.ts +2 -0
  303. package/dist/field/utils/setFloatingElemPosition.d.ts.map +1 -0
  304. package/dist/field/utils/setFloatingElemPosition.js +22 -0
  305. package/dist/field/utils/setFloatingElemPositionForLinkEditor.d.ts +2 -0
  306. package/dist/field/utils/setFloatingElemPositionForLinkEditor.d.ts.map +1 -0
  307. package/dist/field/utils/setFloatingElemPositionForLinkEditor.js +22 -0
  308. package/dist/field/utils/swipe.js +77 -0
  309. package/dist/field/utils/url.d.ts +11 -0
  310. package/dist/field/utils/url.d.ts.map +1 -0
  311. package/dist/field/utils/url.js +30 -0
  312. package/dist/index.d.ts +12 -0
  313. package/dist/index.d.ts.map +1 -0
  314. package/dist/index.js +7 -0
  315. package/dist/lexical-editor.d.ts +41 -0
  316. package/dist/lexical-editor.d.ts.map +1 -0
  317. package/dist/lexical-editor.js +13 -0
  318. package/dist/richtext-field.d.ts +25 -0
  319. package/dist/richtext-field.d.ts.map +1 -0
  320. package/dist/richtext-field.js +62 -0
  321. package/dist/richtext-field.module.js +8 -0
  322. package/dist/richtext-field_module.css +18 -0
  323. package/dist/server.d.ts +64 -0
  324. package/dist/server.d.ts.map +1 -0
  325. package/dist/server.js +20 -0
  326. package/dist/static/svg/3-columns.svg +3 -0
  327. package/dist/static/svg/admonition.svg +1 -0
  328. package/dist/static/svg/ai.svg +5 -0
  329. package/dist/static/svg/arrow-clockwise.svg +1 -0
  330. package/dist/static/svg/arrow-counterclockwise.svg +1 -0
  331. package/dist/static/svg/bg-color.svg +1 -0
  332. package/dist/static/svg/camera.svg +1 -0
  333. package/dist/static/svg/caret-right-fill.svg +1 -0
  334. package/dist/static/svg/chat-square-quote.svg +1 -0
  335. package/dist/static/svg/chevron-down.svg +1 -0
  336. package/dist/static/svg/clipboard.svg +1 -0
  337. package/dist/static/svg/close.svg +1 -0
  338. package/dist/static/svg/code.svg +1 -0
  339. package/dist/static/svg/copy.svg +1 -0
  340. package/dist/static/svg/diagram-2.svg +1 -0
  341. package/dist/static/svg/download.svg +1 -0
  342. package/dist/static/svg/dropdown-more.svg +1 -0
  343. package/dist/static/svg/file-image.svg +1 -0
  344. package/dist/static/svg/filetype-gif.svg +1 -0
  345. package/dist/static/svg/font-color.svg +1 -0
  346. package/dist/static/svg/font-family.svg +1 -0
  347. package/dist/static/svg/gear.svg +1 -0
  348. package/dist/static/svg/horizontal-rule.svg +1 -0
  349. package/dist/static/svg/indent.svg +1 -0
  350. package/dist/static/svg/journal-code.svg +1 -0
  351. package/dist/static/svg/justify.svg +1 -0
  352. package/dist/static/svg/link.svg +1 -0
  353. package/dist/static/svg/list-ol.svg +1 -0
  354. package/dist/static/svg/list-ul.svg +1 -0
  355. package/dist/static/svg/lock-fill.svg +1 -0
  356. package/dist/static/svg/lock.svg +1 -0
  357. package/dist/static/svg/markdown.svg +1 -0
  358. package/dist/static/svg/mic.svg +1 -0
  359. package/dist/static/svg/outdent.svg +1 -0
  360. package/dist/static/svg/paint-bucket.svg +1 -0
  361. package/dist/static/svg/palette.svg +1 -0
  362. package/dist/static/svg/pencil-fill.svg +1 -0
  363. package/dist/static/svg/plug-fill.svg +1 -0
  364. package/dist/static/svg/plug.svg +1 -0
  365. package/dist/static/svg/plus.svg +1 -0
  366. package/dist/static/svg/prettier-error.svg +1 -0
  367. package/dist/static/svg/prettier.svg +1 -0
  368. package/dist/static/svg/square-check.svg +1 -0
  369. package/dist/static/svg/success.svg +1 -0
  370. package/dist/static/svg/table.svg +1 -0
  371. package/dist/static/svg/text-center.svg +1 -0
  372. package/dist/static/svg/text-left.svg +1 -0
  373. package/dist/static/svg/text-paragraph.svg +1 -0
  374. package/dist/static/svg/text-right.svg +1 -0
  375. package/dist/static/svg/trash.svg +1 -0
  376. package/dist/static/svg/type-bold.svg +1 -0
  377. package/dist/static/svg/type-h1.svg +1 -0
  378. package/dist/static/svg/type-h2.svg +1 -0
  379. package/dist/static/svg/type-h3.svg +1 -0
  380. package/dist/static/svg/type-h4.svg +1 -0
  381. package/dist/static/svg/type-h5.svg +1 -0
  382. package/dist/static/svg/type-h6.svg +1 -0
  383. package/dist/static/svg/type-italic.svg +1 -0
  384. package/dist/static/svg/type-strikethrough.svg +1 -0
  385. package/dist/static/svg/type-subscript.svg +1 -0
  386. package/dist/static/svg/type-superscript.svg +1 -0
  387. package/dist/static/svg/type-underline.svg +1 -0
  388. package/dist/static/svg/upload.svg +1 -0
  389. package/dist/static/svg/user.svg +1 -0
  390. package/dist/static/svg/vimeo.svg +1 -0
  391. package/dist/static/svg/youtube.svg +1 -0
  392. package/dist/types.d.ts +37 -0
  393. package/dist/types.d.ts.map +1 -0
  394. package/dist/types.js +1 -0
  395. package/dist/validate/createEmptyEditorState.d.ts +25 -0
  396. package/dist/validate/createEmptyEditorState.d.ts.map +1 -0
  397. package/dist/validate/createEmptyEditorState.js +26 -0
  398. package/dist/validate/hasText.d.ts +3 -0
  399. package/dist/validate/hasText.d.ts.map +1 -0
  400. package/dist/validate/hasText.js +20 -0
  401. package/dist/validate/validate.d.ts +5 -0
  402. package/dist/validate/validate.d.ts.map +1 -0
  403. package/dist/validate/validate.js +7 -0
  404. package/package.json +120 -0
  405. package/src/declarations.d.ts +4 -0
  406. package/src/field/apply-value-plugin.tsx +104 -0
  407. package/src/field/config/default.ts +58 -0
  408. package/src/field/config/editor-config-context.tsx +60 -0
  409. package/src/field/config/types.ts +67 -0
  410. package/src/field/constants.ts +1 -0
  411. package/src/field/content-editable-inline.tsx +27 -0
  412. package/src/field/content-editable.css +29 -0
  413. package/src/field/content-editable.tsx +27 -0
  414. package/src/field/context/shared-autocomplete-context.tsx +61 -0
  415. package/src/field/context/shared-history-context.tsx +30 -0
  416. package/src/field/context/shared-on-change-context.tsx +32 -0
  417. package/src/field/debug.tsx +39 -0
  418. package/src/field/editor-component.css +46 -0
  419. package/src/field/editor-component.md +87 -0
  420. package/src/field/editor-component.test.tsx +170 -0
  421. package/src/field/editor-component.tsx +207 -0
  422. package/src/field/editor-context.tsx +102 -0
  423. package/src/field/editor-field.tsx +51 -0
  424. package/src/field/editor.css +1481 -0
  425. package/src/field/editor.tsx +245 -0
  426. package/src/field/hooks/use-media-queryts +21 -0
  427. package/src/field/hooks/use-modal.tsx +59 -0
  428. package/src/field/hooks/use-report.ts +62 -0
  429. package/src/field/images/LICENSE.md +5 -0
  430. package/src/field/images/assets.d.ts +27 -0
  431. package/src/field/images/cat-typing.gif +0 -0
  432. package/src/field/images/emoji/1F600.png +0 -0
  433. package/src/field/images/emoji/1F641.png +0 -0
  434. package/src/field/images/emoji/1F642.png +0 -0
  435. package/src/field/images/emoji/2764.png +0 -0
  436. package/src/field/images/emoji/LICENSE.md +5 -0
  437. package/src/field/images/icons/3-columns.svg +3 -0
  438. package/src/field/images/icons/LICENSE.md +5 -0
  439. package/src/field/images/icons/admonition.svg +1 -0
  440. package/src/field/images/icons/ai.svg +5 -0
  441. package/src/field/images/icons/arrow-clockwise.svg +1 -0
  442. package/src/field/images/icons/arrow-counterclockwise.svg +1 -0
  443. package/src/field/images/icons/bg-color.svg +1 -0
  444. package/src/field/images/icons/camera.svg +1 -0
  445. package/src/field/images/icons/card-checklist.svg +1 -0
  446. package/src/field/images/icons/caret-right-fill.svg +1 -0
  447. package/src/field/images/icons/chat-left-text.svg +1 -0
  448. package/src/field/images/icons/chat-right-dots.svg +1 -0
  449. package/src/field/images/icons/chat-right-text.svg +1 -0
  450. package/src/field/images/icons/chat-right.svg +1 -0
  451. package/src/field/images/icons/chat-square-quote.svg +1 -0
  452. package/src/field/images/icons/chevron-down.svg +1 -0
  453. package/src/field/images/icons/clipboard.svg +1 -0
  454. package/src/field/images/icons/close.svg +1 -0
  455. package/src/field/images/icons/code.svg +1 -0
  456. package/src/field/images/icons/comments.svg +1 -0
  457. package/src/field/images/icons/copy.svg +1 -0
  458. package/src/field/images/icons/diagram-2.svg +1 -0
  459. package/src/field/images/icons/download.svg +1 -0
  460. package/src/field/images/icons/draggable-block-menu.svg +1 -0
  461. package/src/field/images/icons/dropdown-more.svg +1 -0
  462. package/src/field/images/icons/figma.svg +1 -0
  463. package/src/field/images/icons/file-earmark-text.svg +4 -0
  464. package/src/field/images/icons/file-image.svg +1 -0
  465. package/src/field/images/icons/filetype-gif.svg +1 -0
  466. package/src/field/images/icons/font-color.svg +1 -0
  467. package/src/field/images/icons/font-family.svg +1 -0
  468. package/src/field/images/icons/gear.svg +1 -0
  469. package/src/field/images/icons/horizontal-rule.svg +1 -0
  470. package/src/field/images/icons/indent.svg +1 -0
  471. package/src/field/images/icons/journal-code.svg +1 -0
  472. package/src/field/images/icons/journal-text.svg +1 -0
  473. package/src/field/images/icons/justify.svg +1 -0
  474. package/src/field/images/icons/link.svg +1 -0
  475. package/src/field/images/icons/list-ol.svg +1 -0
  476. package/src/field/images/icons/list-ul.svg +1 -0
  477. package/src/field/images/icons/lock-fill.svg +1 -0
  478. package/src/field/images/icons/lock.svg +1 -0
  479. package/src/field/images/icons/markdown.svg +1 -0
  480. package/src/field/images/icons/mic.svg +1 -0
  481. package/src/field/images/icons/outdent.svg +1 -0
  482. package/src/field/images/icons/paint-bucket.svg +1 -0
  483. package/src/field/images/icons/palette.svg +1 -0
  484. package/src/field/images/icons/pencil-fill.svg +1 -0
  485. package/src/field/images/icons/plug-fill.svg +1 -0
  486. package/src/field/images/icons/plug.svg +1 -0
  487. package/src/field/images/icons/plus-slash-minus.svg +1 -0
  488. package/src/field/images/icons/plus.svg +1 -0
  489. package/src/field/images/icons/prettier-error.svg +1 -0
  490. package/src/field/images/icons/prettier.svg +1 -0
  491. package/src/field/images/icons/send.svg +1 -0
  492. package/src/field/images/icons/square-check.svg +1 -0
  493. package/src/field/images/icons/sticky.svg +1 -0
  494. package/src/field/images/icons/success-alt.svg +1 -0
  495. package/src/field/images/icons/success.svg +1 -0
  496. package/src/field/images/icons/table.svg +1 -0
  497. package/src/field/images/icons/text-center.svg +1 -0
  498. package/src/field/images/icons/text-left.svg +1 -0
  499. package/src/field/images/icons/text-paragraph.svg +1 -0
  500. package/src/field/images/icons/text-right.svg +1 -0
  501. package/src/field/images/icons/trash.svg +1 -0
  502. package/src/field/images/icons/trash3.svg +1 -0
  503. package/src/field/images/icons/tweet.svg +1 -0
  504. package/src/field/images/icons/type-bold.svg +1 -0
  505. package/src/field/images/icons/type-h1.svg +1 -0
  506. package/src/field/images/icons/type-h2.svg +1 -0
  507. package/src/field/images/icons/type-h3.svg +1 -0
  508. package/src/field/images/icons/type-h4.svg +1 -0
  509. package/src/field/images/icons/type-h5.svg +1 -0
  510. package/src/field/images/icons/type-h6.svg +1 -0
  511. package/src/field/images/icons/type-italic.svg +1 -0
  512. package/src/field/images/icons/type-strikethrough.svg +1 -0
  513. package/src/field/images/icons/type-subscript.svg +1 -0
  514. package/src/field/images/icons/type-superscript.svg +1 -0
  515. package/src/field/images/icons/type-underline.svg +1 -0
  516. package/src/field/images/icons/upload.svg +1 -0
  517. package/src/field/images/icons/user.svg +1 -0
  518. package/src/field/images/icons/vimeo.svg +1 -0
  519. package/src/field/images/icons/youtube.svg +1 -0
  520. package/src/field/images/landscape.jpg +0 -0
  521. package/src/field/images/logo.svg +1 -0
  522. package/src/field/images/yellow-flower-small.jpg +0 -0
  523. package/src/field/images/yellow-flower.jpg +0 -0
  524. package/src/field/lexical-populate-shared.ts +188 -0
  525. package/src/field/nodes/admonition-node/admonition-node-component.css +115 -0
  526. package/src/field/nodes/admonition-node/admonition-node-component.tsx +256 -0
  527. package/src/field/nodes/admonition-node/admonition-node.tsx +189 -0
  528. package/src/field/nodes/admonition-node/icons/danger-icon.css +11 -0
  529. package/src/field/nodes/admonition-node/icons/danger-icon.js +17 -0
  530. package/src/field/nodes/admonition-node/icons/danger-icon.tsx +19 -0
  531. package/src/field/nodes/admonition-node/icons/index.js +4 -0
  532. package/src/field/nodes/admonition-node/icons/index.ts +4 -0
  533. package/src/field/nodes/admonition-node/icons/note-icon.css +11 -0
  534. package/src/field/nodes/admonition-node/icons/note-icon.js +17 -0
  535. package/src/field/nodes/admonition-node/icons/note-icon.tsx +19 -0
  536. package/src/field/nodes/admonition-node/icons/tip-icon.css +11 -0
  537. package/src/field/nodes/admonition-node/icons/tip-icon.js +17 -0
  538. package/src/field/nodes/admonition-node/icons/tip-icon.tsx +19 -0
  539. package/src/field/nodes/admonition-node/icons/warning-icon.css +11 -0
  540. package/src/field/nodes/admonition-node/icons/warning-icon.js +17 -0
  541. package/src/field/nodes/admonition-node/icons/warning-icon.tsx +19 -0
  542. package/src/field/nodes/admonition-node/index.ts +14 -0
  543. package/src/field/nodes/admonition-node/types.ts +33 -0
  544. package/src/field/nodes/document-relation.ts +33 -0
  545. package/src/field/nodes/index.ts +47 -0
  546. package/src/field/nodes/inline-image-node/index.ts +10 -0
  547. package/src/field/nodes/inline-image-node/inline-image-node-component.css +205 -0
  548. package/src/field/nodes/inline-image-node/inline-image-node-component.tsx +342 -0
  549. package/src/field/nodes/inline-image-node/inline-image-node.tsx +328 -0
  550. package/src/field/nodes/inline-image-node/types.ts +43 -0
  551. package/src/field/nodes/layout-container-node/layout-container-node.ts +97 -0
  552. package/src/field/nodes/layout-container-node/layout-item-node.ts +63 -0
  553. package/src/field/nodes/link-nodes/auto-link-node.ts +64 -0
  554. package/src/field/nodes/link-nodes/index.ts +3 -0
  555. package/src/field/nodes/link-nodes/link-node.ts +426 -0
  556. package/src/field/nodes/link-nodes/types.ts +33 -0
  557. package/src/field/nodes/vimeo-node/index.tsx +172 -0
  558. package/src/field/nodes/youtube-node/index.tsx +178 -0
  559. package/src/field/plugins/admonition-plugin/admonition-modal.css +25 -0
  560. package/src/field/plugins/admonition-plugin/admonition-modal.tsx +187 -0
  561. package/src/field/plugins/admonition-plugin/fields.ts +103 -0
  562. package/src/field/plugins/admonition-plugin/index.tsx +105 -0
  563. package/src/field/plugins/admonition-plugin/types.ts +37 -0
  564. package/src/field/plugins/auto-embed-plugin/auto-embed-modal.css +15 -0
  565. package/src/field/plugins/auto-embed-plugin/auto-embed-modal.tsx +110 -0
  566. package/src/field/plugins/auto-embed-plugin/index.tsx +323 -0
  567. package/src/field/plugins/code-highlight-plugin/index.ts +23 -0
  568. package/src/field/plugins/drag-drop-paste-plugin/index.ts +47 -0
  569. package/src/field/plugins/floating-text-format-toolbar-plugin/index.css +148 -0
  570. package/src/field/plugins/floating-text-format-toolbar-plugin/index.tsx +398 -0
  571. package/src/field/plugins/inline-image-plugin/fields.ts +21 -0
  572. package/src/field/plugins/inline-image-plugin/index.tsx +202 -0
  573. package/src/field/plugins/inline-image-plugin/inline-image-modal.css +29 -0
  574. package/src/field/plugins/inline-image-plugin/inline-image-modal.tsx +314 -0
  575. package/src/field/plugins/inline-image-plugin/populate.ts +48 -0
  576. package/src/field/plugins/inline-image-plugin/types.ts +39 -0
  577. package/src/field/plugins/inline-image-plugin/utils.ts +113 -0
  578. package/src/field/plugins/layout-plugin/insert-layout-modal.css +19 -0
  579. package/src/field/plugins/layout-plugin/insert-layout-modal.tsx +100 -0
  580. package/src/field/plugins/layout-plugin/layout-plugin.tsx +162 -0
  581. package/src/field/plugins/link-plugin/auto-link/auto-link-plugin.tsx +327 -0
  582. package/src/field/plugins/link-plugin/auto-link/index.tsx +35 -0
  583. package/src/field/plugins/link-plugin/link/floating-link-editor.css +128 -0
  584. package/src/field/plugins/link-plugin/link/floating-link-editor.tsx +348 -0
  585. package/src/field/plugins/link-plugin/link/index.tsx +99 -0
  586. package/src/field/plugins/link-plugin/link/link-modal.tsx +376 -0
  587. package/src/field/plugins/link-plugin/link/types.ts +20 -0
  588. package/src/field/plugins/link-plugin/populate.ts +48 -0
  589. package/src/field/plugins/table-action-menu-plugin/index.tsx +804 -0
  590. package/src/field/plugins/table-plugin/index.tsx +33 -0
  591. package/src/field/plugins/table-plugin/table-modal.css +19 -0
  592. package/src/field/plugins/table-plugin/table-modal.tsx +127 -0
  593. package/src/field/plugins/toolbar-plugin/index.tsx +937 -0
  594. package/src/field/plugins/treeview-plugin/index.tsx +29 -0
  595. package/src/field/plugins/vimeo-plugin/index.ts +42 -0
  596. package/src/field/plugins/youtube-plugin/index.ts +43 -0
  597. package/src/field/shared/canUseDOM.ts +10 -0
  598. package/src/field/shared/caretFromPoint.bak +40 -0
  599. package/src/field/shared/environment.ts +44 -0
  600. package/src/field/shared/invariant.ts +25 -0
  601. package/src/field/shared/simpleDiffWithCursor.ts +40 -0
  602. package/src/field/shared/useLayoutEffect.ts +15 -0
  603. package/src/field/shared/useModalFormState.ts +48 -0
  604. package/src/field/shared/warnOnlyOnce.ts +21 -0
  605. package/src/field/themes/lexical-editor-theme.css +565 -0
  606. package/src/field/themes/lexical-editor-theme.js +104 -0
  607. package/src/field/themes/lexical-editor-theme.tsx +115 -0
  608. package/src/field/toolbar-extensions.tsx +93 -0
  609. package/src/field/types.ts +19 -0
  610. package/src/field/ui/button.css +45 -0
  611. package/src/field/ui/button.tsx +51 -0
  612. package/src/field/ui/checkbox.css +52 -0
  613. package/src/field/ui/color-picker.css +88 -0
  614. package/src/field/ui/color-picker.tsx +395 -0
  615. package/src/field/ui/dialog.css +17 -0
  616. package/src/field/ui/dialog.tsx +29 -0
  617. package/src/field/ui/dropdown.tsx +217 -0
  618. package/src/field/ui/file-input.tsx +44 -0
  619. package/src/field/ui/input.css +32 -0
  620. package/src/field/ui/modal.css +84 -0
  621. package/src/field/ui/modal.tsx +106 -0
  622. package/src/field/ui/placeholder-inline.tsx +28 -0
  623. package/src/field/ui/placeholder.css +33 -0
  624. package/src/field/ui/placeholder.tsx +32 -0
  625. package/src/field/ui/select.css +34 -0
  626. package/src/field/ui/select.tsx +38 -0
  627. package/src/field/ui/switch.tsx +33 -0
  628. package/src/field/ui/text-area.css +45 -0
  629. package/src/field/ui/text-area.tsx +50 -0
  630. package/src/field/ui/text-input.tsx +51 -0
  631. package/src/field/utils/cloneDeep.ts +57 -0
  632. package/src/field/utils/deepEqual.ts +54 -0
  633. package/src/field/utils/emoji-list.ts +16615 -0
  634. package/src/field/utils/getDOMRangeRect.ts +24 -0
  635. package/src/field/utils/getSelectedNode.ts +25 -0
  636. package/src/field/utils/guard.ts +10 -0
  637. package/src/field/utils/hashSerializedState.ts +34 -0
  638. package/src/field/utils/isMobileWidth.ts +7 -0
  639. package/src/field/utils/joinClasses.ts +11 -0
  640. package/src/field/utils/point.ts +52 -0
  641. package/src/field/utils/rect.ts +142 -0
  642. package/src/field/utils/setFloatingElemPosition.ts +48 -0
  643. package/src/field/utils/setFloatingElemPositionForLinkEditor.ts +46 -0
  644. package/src/field/utils/swipe.ts +129 -0
  645. package/src/field/utils/url.ts +49 -0
  646. package/src/index.ts +26 -0
  647. package/src/lexical-editor.tsx +56 -0
  648. package/src/richtext-field.module.css +29 -0
  649. package/src/richtext-field.tsx +113 -0
  650. package/src/server.ts +85 -0
  651. package/src/types.ts +43 -0
  652. package/src/validate/createEmptyEditorState.ts +52 -0
  653. package/src/validate/hasText.test.ts +89 -0
  654. package/src/validate/hasText.ts +34 -0
  655. package/src/validate/validate.ts +18 -0
@@ -0,0 +1,34 @@
1
+ /**
2
+ * This Source Code is subject to the terms of the Mozilla Public
3
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
4
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
5
+ *
6
+ * Copyright (c) Infonomic Company Limited
7
+ *
8
+ * Portions Copyright (c) Meta Platforms, Inc. and affiliates.
9
+ */
10
+ import type * as React from 'react';
11
+ import { type LexicalCommand, type NodeKey } from 'lexical';
12
+ import type { InlineImageAttributes } from '../../nodes/inline-image-node/types';
13
+ export type InsertInlineImagePayload = Readonly<InlineImageAttributes>;
14
+ export type UpdateInlineImagePayload = Readonly<{
15
+ nodeKey: NodeKey;
16
+ attributes: InlineImageAttributes;
17
+ }>;
18
+ export type OpenInlineImageModalPayload = Readonly<{
19
+ nodeKey?: NodeKey;
20
+ }> | null;
21
+ /**
22
+ * Asks the InlineImagePlugin to open its modal. Pass `null` (or omit
23
+ * `nodeKey`) for insert mode; pass a `nodeKey` to edit an existing node
24
+ * with its current attributes pre-filled.
25
+ */
26
+ export declare const OPEN_INLINE_IMAGE_MODAL_COMMAND: LexicalCommand<OpenInlineImageModalPayload>;
27
+ /** Inserts a new InlineImageNode at the current selection. */
28
+ export declare const INSERT_INLINE_IMAGE_COMMAND: LexicalCommand<InsertInlineImagePayload>;
29
+ /** Updates the InlineImageNode identified by `nodeKey` in place. */
30
+ export declare const UPDATE_INLINE_IMAGE_COMMAND: LexicalCommand<UpdateInlineImagePayload>;
31
+ export declare function InlineImagePlugin({ collection }: {
32
+ collection: string;
33
+ }): React.JSX.Element;
34
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/field/plugins/inline-image-plugin/index.tsx"],"names":[],"mappings":"AAEA;;;;;;;;GAQG;AAEH,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAA;AAKnC,OAAO,EAQL,KAAK,cAAc,EAEnB,KAAK,OAAO,EACb,MAAM,SAAS,CAAA;AAQhB,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAA;AAGhF,MAAM,MAAM,wBAAwB,GAAG,QAAQ,CAAC,qBAAqB,CAAC,CAAA;AACtE,MAAM,MAAM,wBAAwB,GAAG,QAAQ,CAAC;IAC9C,OAAO,EAAE,OAAO,CAAA;IAChB,UAAU,EAAE,qBAAqB,CAAA;CAClC,CAAC,CAAA;AACF,MAAM,MAAM,2BAA2B,GAAG,QAAQ,CAAC;IAAE,OAAO,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC,GAAG,IAAI,CAAA;AAEhF;;;;GAIG;AACH,eAAO,MAAM,+BAA+B,EAAE,cAAc,CAAC,2BAA2B,CACtC,CAAA;AAElD,8DAA8D;AAC9D,eAAO,MAAM,2BAA2B,EAAE,cAAc,CAAC,wBAAwB,CAEhF,CAAA;AAED,oEAAoE;AACpE,eAAO,MAAM,2BAA2B,EAAE,cAAc,CAAC,wBAAwB,CAEhF,CAAA;AA0CD,wBAAgB,iBAAiB,CAAC,EAAE,UAAU,EAAE,EAAE;IAAE,UAAU,EAAE,MAAM,CAAA;CAAE,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,CAiG3F"}
@@ -0,0 +1,107 @@
1
+ "use client";
2
+ import { jsx } from "react/jsx-runtime";
3
+ import { useCallback, useEffect, useState } from "react";
4
+ import { useLexicalComposerContext } from "@lexical/react/LexicalComposerContext";
5
+ import { $wrapNodeInElement, mergeRegister } from "@lexical/utils";
6
+ import { $createParagraphNode, $getNodeByKey, $insertNodes, $isRootOrShadowRoot, COMMAND_PRIORITY_EDITOR, COMMAND_PRIORITY_NORMAL, createCommand } from "lexical";
7
+ import { $createInlineImageNode, $isInlineImageNode, InlineImageNode } from "../../nodes/inline-image-node/index.js";
8
+ import { InlineImageModal } from "./inline-image-modal.js";
9
+ const OPEN_INLINE_IMAGE_MODAL_COMMAND = createCommand('OPEN_INLINE_IMAGE_MODAL_COMMAND');
10
+ const INSERT_INLINE_IMAGE_COMMAND = createCommand('INSERT_INLINE_IMAGE_COMMAND');
11
+ const UPDATE_INLINE_IMAGE_COMMAND = createCommand('UPDATE_INLINE_IMAGE_COMMAND');
12
+ const CLOSED_STATE = {
13
+ mode: 'insert',
14
+ open: false,
15
+ nodeKey: null,
16
+ initialData: void 0
17
+ };
18
+ function readNodeAsInitialData(editor, nodeKey) {
19
+ let data;
20
+ editor.getEditorState().read(()=>{
21
+ const node = $getNodeByKey(nodeKey);
22
+ if (!$isInlineImageNode(node)) return;
23
+ data = {
24
+ documentRelation: node.getRelation(),
25
+ src: node.getSrc(),
26
+ altText: node.getAltText(),
27
+ position: node.getPosition(),
28
+ showCaption: node.getShowCaption()
29
+ };
30
+ });
31
+ return data;
32
+ }
33
+ function InlineImagePlugin({ collection }) {
34
+ const [editor] = useLexicalComposerContext();
35
+ const [modalState, setModalState] = useState(CLOSED_STATE);
36
+ useEffect(()=>{
37
+ if (!editor.hasNodes([
38
+ InlineImageNode
39
+ ])) throw new Error('InlineImagePlugin: InlineImageNode not registered on editor');
40
+ return mergeRegister(editor.registerCommand(OPEN_INLINE_IMAGE_MODAL_COMMAND, (payload)=>{
41
+ const nodeKey = payload?.nodeKey;
42
+ if (null != nodeKey) {
43
+ const initialData = readNodeAsInitialData(editor, nodeKey);
44
+ setModalState({
45
+ mode: 'edit',
46
+ open: true,
47
+ nodeKey,
48
+ initialData
49
+ });
50
+ } else setModalState({
51
+ mode: 'insert',
52
+ open: true,
53
+ nodeKey: null,
54
+ initialData: void 0
55
+ });
56
+ return true;
57
+ }, COMMAND_PRIORITY_NORMAL), editor.registerCommand(INSERT_INLINE_IMAGE_COMMAND, (payload)=>{
58
+ const imageNode = $createInlineImageNode(payload);
59
+ $insertNodes([
60
+ imageNode
61
+ ]);
62
+ if ($isRootOrShadowRoot(imageNode.getParentOrThrow())) $wrapNodeInElement(imageNode, $createParagraphNode).selectEnd();
63
+ return true;
64
+ }, COMMAND_PRIORITY_EDITOR), editor.registerCommand(UPDATE_INLINE_IMAGE_COMMAND, ({ nodeKey, attributes })=>{
65
+ const node = $getNodeByKey(nodeKey);
66
+ if ($isInlineImageNode(node)) {
67
+ node.update(attributes);
68
+ return true;
69
+ }
70
+ return false;
71
+ }, COMMAND_PRIORITY_EDITOR));
72
+ }, [
73
+ editor
74
+ ]);
75
+ const handleSubmit = useCallback((data)=>{
76
+ if (null == data.documentRelation) return;
77
+ const attributes = {
78
+ ...data.documentRelation,
79
+ src: data.src,
80
+ altText: data.altText,
81
+ position: data.position,
82
+ width: data.width,
83
+ height: data.height,
84
+ showCaption: data.showCaption
85
+ };
86
+ if ('edit' === modalState.mode && null != modalState.nodeKey) editor.dispatchCommand(UPDATE_INLINE_IMAGE_COMMAND, {
87
+ nodeKey: modalState.nodeKey,
88
+ attributes
89
+ });
90
+ else editor.dispatchCommand(INSERT_INLINE_IMAGE_COMMAND, attributes);
91
+ }, [
92
+ editor,
93
+ modalState.mode,
94
+ modalState.nodeKey
95
+ ]);
96
+ const handleClose = useCallback(()=>{
97
+ setModalState(CLOSED_STATE);
98
+ }, []);
99
+ return /*#__PURE__*/ jsx(InlineImageModal, {
100
+ isOpen: modalState.open,
101
+ collection: collection,
102
+ data: modalState.initialData,
103
+ onSubmit: handleSubmit,
104
+ onClose: handleClose
105
+ });
106
+ }
107
+ export { INSERT_INLINE_IMAGE_COMMAND, InlineImagePlugin, OPEN_INLINE_IMAGE_MODAL_COMMAND, UPDATE_INLINE_IMAGE_COMMAND };
@@ -0,0 +1,25 @@
1
+ .inline-image-plugin--modal-image {
2
+ margin-bottom: 2rem;
3
+ }
4
+
5
+ .inline-image-plugin--modal-media-display {
6
+ margin-bottom: 2em;
7
+ }
8
+
9
+ .inline-image-plugin--modal-alt-text {
10
+ margin-bottom: 1em;
11
+ }
12
+
13
+ .inline-image-plugin--modal-position {
14
+ margin-bottom: 2em;
15
+ }
16
+
17
+ .inline-image-plugin--modal-show-caption {
18
+ margin-bottom: 1em;
19
+ }
20
+
21
+ .inline-image-plugin--modal-actions {
22
+ gap: 12px;
23
+ display: flex;
24
+ }
25
+
@@ -0,0 +1,11 @@
1
+ /**
2
+ * This Source Code is subject to the terms of the Mozilla Public
3
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
4
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
5
+ *
6
+ * Copyright (c) Infonomic Company Limited
7
+ */
8
+ import type * as React from 'react';
9
+ import type { InlineImageModalProps } from './types';
10
+ export declare const InlineImageModal: React.FC<InlineImageModalProps>;
11
+ //# sourceMappingURL=inline-image-modal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inline-image-modal.d.ts","sourceRoot":"","sources":["../../../../src/field/plugins/inline-image-plugin/inline-image-modal.tsx"],"names":[],"mappings":"AAEA;;;;;;GAMG;AAEH,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAA;AAyBnC,OAAO,KAAK,EAAmB,qBAAqB,EAAE,MAAM,SAAS,CAAA;AA4BrE,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CA0P5D,CAAA"}
@@ -0,0 +1,271 @@
1
+ "use client";
2
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
3
+ import { useMemo, useState } from "react";
4
+ import { getCollectionDefinition } from "@byline/core";
5
+ import { RelationPicker } from "@byline/ui";
6
+ import { Button, Checkbox, CloseIcon, ErrorText, IconButton, Input, Label, Modal, RadioGroup, RadioGroupItem } from "@infonomic/uikit/react";
7
+ import { useEditorConfig } from "../../config/editor-config-context.js";
8
+ import { useModalFormState } from "../../shared/useModalFormState.js";
9
+ import { isAltTextValid, positionOptions } from "./fields.js";
10
+ import { deriveImageSizes, getPreferredSize } from "./utils.js";
11
+ function emptyState() {
12
+ return {
13
+ documentRelation: null,
14
+ altText: '',
15
+ position: 'full',
16
+ showCaption: false
17
+ };
18
+ }
19
+ function fromInlineImageData(data) {
20
+ if (!data) return emptyState();
21
+ return {
22
+ documentRelation: data.documentRelation ?? null,
23
+ altText: data.altText ?? '',
24
+ position: data.position ?? 'full',
25
+ showCaption: data.showCaption ?? false
26
+ };
27
+ }
28
+ const InlineImageModal = ({ isOpen, collection, data: dataFromProps, onSubmit, onClose })=>{
29
+ const [pickerOpen, setPickerOpen] = useState(false);
30
+ const [altError, setAltError] = useState(null);
31
+ const [imageError, setImageError] = useState(null);
32
+ const { config: editorSettings } = useEditorConfig();
33
+ const [state, setState] = useModalFormState(isOpen, ()=>fromInlineImageData(dataFromProps), ()=>{
34
+ setAltError(null);
35
+ setImageError(null);
36
+ });
37
+ const targetDef = getCollectionDefinition(collection);
38
+ const pickedImage = useMemo(()=>{
39
+ const img = state.documentRelation?.document?.image;
40
+ return img ?? null;
41
+ }, [
42
+ state.documentRelation
43
+ ]);
44
+ const pickedThumbUrl = useMemo(()=>{
45
+ if (!pickedImage?.storageUrl) return null;
46
+ if ('image/svg+xml' === pickedImage.mimeType) return pickedImage.storageUrl;
47
+ if (pickedImage.thumbnailGenerated) return pickedImage.storageUrl.replace(/\.[^.]+$/, '-thumbnail.avif');
48
+ return pickedImage.storageUrl;
49
+ }, [
50
+ pickedImage
51
+ ]);
52
+ const pickedTitle = useMemo(()=>{
53
+ const title = state.documentRelation?.document?.title;
54
+ return 'string' == typeof title && title.length > 0 ? title : null;
55
+ }, [
56
+ state.documentRelation
57
+ ]);
58
+ const handlePickerSelect = (selection)=>{
59
+ setPickerOpen(false);
60
+ const fields = selection.record?.fields ?? {};
61
+ const image = fields.image;
62
+ const title = 'string' == typeof fields.title ? fields.title : void 0;
63
+ const altTextFromMedia = 'string' == typeof fields.altText ? fields.altText : void 0;
64
+ const sizes = image ? deriveImageSizes(image) : [];
65
+ setState((s)=>{
66
+ const document = {};
67
+ if (title) document.title = title;
68
+ if (altTextFromMedia) document.altText = altTextFromMedia;
69
+ if (image) document.image = image;
70
+ if (sizes.length > 0) document.sizes = sizes;
71
+ return {
72
+ ...s,
73
+ documentRelation: {
74
+ targetDocumentId: selection.targetDocumentId,
75
+ targetCollectionId: selection.targetCollectionId,
76
+ targetCollectionPath: collection,
77
+ document: Object.keys(document).length > 0 ? document : void 0
78
+ },
79
+ altText: s.altText.length > 0 ? s.altText : altTextFromMedia ?? ''
80
+ };
81
+ });
82
+ setImageError(null);
83
+ };
84
+ const handleSave = ()=>{
85
+ if (!state.documentRelation || !pickedImage) return void setImageError('Pick an image');
86
+ if (!isAltTextValid(state.altText)) return void setAltError('Alt text is required');
87
+ const preferred = getPreferredSize(state.position, pickedImage);
88
+ const persistedRelation = editorSettings.embedRelationsOnSave ? state.documentRelation : {
89
+ targetDocumentId: state.documentRelation.targetDocumentId,
90
+ targetCollectionId: state.documentRelation.targetCollectionId,
91
+ targetCollectionPath: state.documentRelation.targetCollectionPath
92
+ };
93
+ const data = {
94
+ documentRelation: persistedRelation,
95
+ src: preferred?.url ?? pickedImage.storageUrl ?? '',
96
+ altText: state.altText.trim(),
97
+ position: state.position,
98
+ width: preferred?.width,
99
+ height: preferred?.height,
100
+ showCaption: state.showCaption
101
+ };
102
+ onSubmit(data);
103
+ onClose();
104
+ };
105
+ if (!isOpen) return null;
106
+ return /*#__PURE__*/ jsxs(Fragment, {
107
+ children: [
108
+ /*#__PURE__*/ jsx(Modal, {
109
+ isOpen: isOpen,
110
+ onDismiss: onClose,
111
+ closeOnOverlayClick: false,
112
+ children: /*#__PURE__*/ jsxs(Modal.Container, {
113
+ style: {
114
+ maxWidth: '520px',
115
+ width: '100%'
116
+ },
117
+ children: [
118
+ /*#__PURE__*/ jsxs(Modal.Header, {
119
+ className: "flex items-center justify-between pt-4 mb-2",
120
+ children: [
121
+ /*#__PURE__*/ jsx("h3", {
122
+ className: "m-0 text-xl",
123
+ children: "Inline image"
124
+ }),
125
+ /*#__PURE__*/ jsx(IconButton, {
126
+ "aria-label": "Close",
127
+ size: "xs",
128
+ onClick: onClose,
129
+ children: /*#__PURE__*/ jsx(CloseIcon, {
130
+ width: "15px",
131
+ height: "15px",
132
+ svgClassName: "white-icon"
133
+ })
134
+ })
135
+ ]
136
+ }),
137
+ /*#__PURE__*/ jsx(Modal.Content, {
138
+ children: /*#__PURE__*/ jsxs("div", {
139
+ className: "flex flex-col gap-4",
140
+ children: [
141
+ /*#__PURE__*/ jsxs("div", {
142
+ className: "flex flex-col gap-2",
143
+ children: [
144
+ /*#__PURE__*/ jsx("span", {
145
+ className: "text-sm font-medium",
146
+ children: "Image"
147
+ }),
148
+ /*#__PURE__*/ jsxs("div", {
149
+ className: "flex items-center gap-3",
150
+ children: [
151
+ pickedThumbUrl ? /*#__PURE__*/ jsx("img", {
152
+ src: pickedThumbUrl,
153
+ alt: pickedTitle ?? '',
154
+ className: "w-18 h-18 object-cover rounded border border-gray-700"
155
+ }) : /*#__PURE__*/ jsx("div", {
156
+ className: "w-18 h-18 flex items-center justify-center bg-gray-800 rounded border border-gray-700 text-xs text-gray-500",
157
+ children: "—"
158
+ }),
159
+ /*#__PURE__*/ jsx(Button, {
160
+ size: "sm",
161
+ className: "min-w-[70px]",
162
+ variant: "outlined",
163
+ intent: "noeffect",
164
+ type: "button",
165
+ onClick: ()=>setPickerOpen(true),
166
+ children: state.documentRelation ? 'Change image…' : `Pick ${targetDef?.labels.singular ?? 'image'}…`
167
+ }),
168
+ pickedTitle && /*#__PURE__*/ jsx("span", {
169
+ className: "text-sm text-gray-200 truncate",
170
+ children: pickedTitle
171
+ })
172
+ ]
173
+ }),
174
+ imageError && /*#__PURE__*/ jsx(ErrorText, {
175
+ id: "image-error",
176
+ text: imageError
177
+ })
178
+ ]
179
+ }),
180
+ /*#__PURE__*/ jsx(Input, {
181
+ id: "inline-image-alt",
182
+ name: "altText",
183
+ label: "Alt text",
184
+ required: true,
185
+ placeholder: "Describe the image for screen readers",
186
+ value: state.altText,
187
+ error: null != altError,
188
+ errorText: altError ?? void 0,
189
+ onChange: (e)=>{
190
+ setAltError(null);
191
+ setState((s)=>({
192
+ ...s,
193
+ altText: e.target.value
194
+ }));
195
+ }
196
+ }),
197
+ /*#__PURE__*/ jsxs("div", {
198
+ className: "flex flex-col gap-2 mb-3",
199
+ children: [
200
+ /*#__PURE__*/ jsx(Label, {
201
+ htmlFor: "inline-image-position",
202
+ id: "inline-image-position-label",
203
+ className: "text-sm font-medium",
204
+ label: "Position"
205
+ }),
206
+ /*#__PURE__*/ jsx(RadioGroup, {
207
+ id: "inline-image-position",
208
+ name: "position",
209
+ "aria-labelledby": "inline-image-position-label",
210
+ direction: "row",
211
+ value: state.position ?? 'full',
212
+ onValueChange: (value)=>setState((s)=>({
213
+ ...s,
214
+ position: value
215
+ })),
216
+ children: positionOptions.map((opt)=>/*#__PURE__*/ jsx(RadioGroupItem, {
217
+ id: `inline-image-position-${opt.value}`,
218
+ value: String(opt.value),
219
+ label: opt.label
220
+ }, String(opt.value)))
221
+ })
222
+ ]
223
+ }),
224
+ /*#__PURE__*/ jsx(Checkbox, {
225
+ id: "inline-image-caption",
226
+ name: "showCaption",
227
+ label: "Show caption",
228
+ checked: state.showCaption,
229
+ onCheckedChange: (checked)=>setState((s)=>({
230
+ ...s,
231
+ showCaption: true === checked
232
+ }))
233
+ })
234
+ ]
235
+ })
236
+ }),
237
+ /*#__PURE__*/ jsxs(Modal.Actions, {
238
+ className: "flex gap-3",
239
+ children: [
240
+ /*#__PURE__*/ jsx(Button, {
241
+ size: "sm",
242
+ intent: "noeffect",
243
+ type: "button",
244
+ onClick: onClose,
245
+ className: "min-w-[70px]",
246
+ children: "Cancel"
247
+ }),
248
+ /*#__PURE__*/ jsx(Button, {
249
+ size: "sm",
250
+ intent: "primary",
251
+ type: "button",
252
+ onClick: handleSave,
253
+ className: "min-w-[70px]",
254
+ children: "Save"
255
+ })
256
+ ]
257
+ })
258
+ ]
259
+ })
260
+ }),
261
+ /*#__PURE__*/ jsx(RelationPicker, {
262
+ targetCollectionPath: collection,
263
+ targetDefinition: targetDef,
264
+ isOpen: pickerOpen,
265
+ onSelect: handlePickerSelect,
266
+ onDismiss: ()=>setPickerOpen(false)
267
+ })
268
+ ]
269
+ });
270
+ };
271
+ export { InlineImageModal };
@@ -0,0 +1,10 @@
1
+ /**
2
+ * This Source Code is subject to the terms of the Mozilla Public
3
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
4
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
5
+ *
6
+ * Copyright (c) Infonomic Company Limited
7
+ */
8
+ import type { LexicalNodeVisitor } from '../../lexical-populate-shared';
9
+ export declare const inlineImageVisitor: LexicalNodeVisitor;
10
+ //# sourceMappingURL=populate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"populate.d.ts","sourceRoot":"","sources":["../../../../src/field/plugins/inline-image-plugin/populate.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAgBH,OAAO,KAAK,EAAmB,kBAAkB,EAAE,MAAM,+BAA+B,CAAA;AAExF,eAAO,MAAM,kBAAkB,EAAE,kBAuBhC,CAAA"}
@@ -0,0 +1,28 @@
1
+ import { deriveImageSizes } from "./utils.js";
2
+ const inlineImageVisitor = {
3
+ match (node) {
4
+ if ('inline-image' !== node.type) return null;
5
+ const collectionPath = node.targetCollectionPath;
6
+ const documentId = node.targetDocumentId;
7
+ if (!collectionPath || !documentId) return null;
8
+ return {
9
+ node,
10
+ collectionPath,
11
+ documentId,
12
+ apply (target) {
13
+ const targetFields = target.fields ?? {};
14
+ const image = targetFields.image;
15
+ const sizes = image ? deriveImageSizes(image) : [];
16
+ const next = {
17
+ ...node.document ?? {}
18
+ };
19
+ if ('string' == typeof targetFields.title) next.title = targetFields.title;
20
+ if ('string' == typeof targetFields.altText) next.altText = targetFields.altText;
21
+ if (null != image) next.image = image;
22
+ if (sizes.length > 0) next.sizes = sizes;
23
+ node.document = next;
24
+ }
25
+ };
26
+ }
27
+ };
28
+ export { inlineImageVisitor };
@@ -0,0 +1,37 @@
1
+ /**
2
+ * This Source Code is subject to the terms of the Mozilla Public
3
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
4
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
5
+ *
6
+ * Copyright (c) Infonomic Company Limited
7
+ */
8
+ import type { DocumentRelation } from '../../nodes/document-relation';
9
+ import type { Position } from '../../nodes/inline-image-node/types';
10
+ /**
11
+ * The form-shape carried into / out of the inline image modal. Mirrors
12
+ * `InlineImageAttributes` minus the Lexical-managed bits (`key`, `caption:
13
+ * LexicalEditor`) — those don't belong in form state. The document-reference
14
+ * envelope is carried as an optional nested `DocumentRelation` here (rather
15
+ * than spread flat) because the modal needs a single null/non-null state to
16
+ * represent "user hasn't picked a document yet".
17
+ */
18
+ export interface InlineImageData {
19
+ documentRelation: DocumentRelation | null;
20
+ src: string;
21
+ altText?: string;
22
+ position?: Position;
23
+ width?: number | string;
24
+ height?: number | string;
25
+ showCaption?: boolean;
26
+ }
27
+ export interface InlineImageModalProps {
28
+ /** Modal visibility — driven by the plugin's open/close commands. */
29
+ isOpen: boolean;
30
+ /** The collection path the picker should target — typically `'media'`. */
31
+ collection: string;
32
+ /** Pre-filled data when the modal opens in edit mode; undefined for insert. */
33
+ data?: InlineImageData;
34
+ onSubmit: (data: InlineImageData) => void;
35
+ onClose: () => void;
36
+ }
37
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/field/plugins/inline-image-plugin/types.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAA;AACrE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAA;AAEnE;;;;;;;GAOG;AACH,MAAM,WAAW,eAAe;IAC9B,gBAAgB,EAAE,gBAAgB,GAAG,IAAI,CAAA;IACzC,GAAG,EAAE,MAAM,CAAA;IACX,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,QAAQ,CAAA;IACnB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACvB,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACxB,WAAW,CAAC,EAAE,OAAO,CAAA;CACtB;AAED,MAAM,WAAW,qBAAqB;IACpC,qEAAqE;IACrE,MAAM,EAAE,OAAO,CAAA;IACf,0EAA0E;IAC1E,UAAU,EAAE,MAAM,CAAA;IAClB,+EAA+E;IAC/E,IAAI,CAAC,EAAE,eAAe,CAAA;IACtB,QAAQ,EAAE,CAAC,IAAI,EAAE,eAAe,KAAK,IAAI,CAAA;IACzC,OAAO,EAAE,MAAM,IAAI,CAAA;CACpB"}
@@ -0,0 +1 @@
1
+ export { };
@@ -0,0 +1,42 @@
1
+ /**
2
+ * This Source Code is subject to the terms of the Mozilla Public
3
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
4
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
5
+ *
6
+ * Copyright (c) Infonomic Company Limited
7
+ */
8
+ import type { StoredFileValue } from '@byline/core';
9
+ import type { Position } from '../../nodes/inline-image-node/types';
10
+ export interface PreferredSize {
11
+ url: string;
12
+ width?: number;
13
+ height?: number;
14
+ }
15
+ /**
16
+ * Choose a sensible image URL + dimensions for the editor preview given the
17
+ * picked media's `image` field and the user's chosen position. Reads
18
+ * directly from `image.variants` (persisted on the file value at upload
19
+ * time). SVGs return the original `storageUrl`; missing/empty variants
20
+ * fall back to the original.
21
+ */
22
+ export declare function getPreferredSize(position: Position, image: StoredFileValue | null | undefined): PreferredSize | null;
23
+ /**
24
+ * One denormalised image variant — the renderer-facing shape used by the
25
+ * inline-image node and richtext after-read hook. Mirrors the persisted
26
+ * `PersistedVariant` with `storageUrl` renamed to `url` for renderer
27
+ * ergonomics.
28
+ */
29
+ export interface DerivedImageSize {
30
+ name: string;
31
+ url: string;
32
+ width?: number;
33
+ height?: number;
34
+ format: string;
35
+ }
36
+ /**
37
+ * Map a `StoredFileValue.variants` array into the renderer shape. SVGs and
38
+ * variant-less images return `[]` so renderers fall back to
39
+ * `image.storageUrl`.
40
+ */
41
+ export declare function deriveImageSizes(image: StoredFileValue | null | undefined): DerivedImageSize[];
42
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/field/plugins/inline-image-plugin/utils.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAEnD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAA;AAsBnE,MAAM,WAAW,aAAa;IAC5B,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAC9B,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,eAAe,GAAG,IAAI,GAAG,SAAS,GACxC,aAAa,GAAG,IAAI,CA0BtB;AAED;;;;;GAKG;AACH,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAA;IACZ,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;CACf;AAED;;;;GAIG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,eAAe,GAAG,IAAI,GAAG,SAAS,GAAG,gBAAgB,EAAE,CAiB9F"}
@@ -0,0 +1,46 @@
1
+ function variantFor(position) {
2
+ switch(position){
3
+ case 'left':
4
+ case 'right':
5
+ return 'card';
6
+ case 'wide':
7
+ return 'desktop';
8
+ default:
9
+ return 'tablet';
10
+ }
11
+ }
12
+ function getPreferredSize(position, image) {
13
+ if (image?.storageUrl == null) return null;
14
+ if ('image/svg+xml' === image.mimeType) return {
15
+ url: image.storageUrl,
16
+ width: image.imageWidth,
17
+ height: image.imageHeight
18
+ };
19
+ const wanted = variantFor(position);
20
+ const match = image.variants?.find((v)=>v.name === wanted);
21
+ if (match?.storageUrl) return {
22
+ url: match.storageUrl,
23
+ width: match.width ?? image.imageWidth,
24
+ height: match.height ?? image.imageHeight
25
+ };
26
+ return {
27
+ url: image.storageUrl,
28
+ width: image.imageWidth,
29
+ height: image.imageHeight
30
+ };
31
+ }
32
+ function deriveImageSizes(image) {
33
+ if (!image?.storageUrl) return [];
34
+ if ('image/svg+xml' === image.mimeType) return [];
35
+ if (!image.variants || 0 === image.variants.length) return [];
36
+ const out = [];
37
+ for (const variant of image.variants)if (variant.storageUrl) out.push({
38
+ name: variant.name,
39
+ url: variant.storageUrl,
40
+ width: variant.width,
41
+ height: variant.height,
42
+ format: variant.format ?? 'avif'
43
+ });
44
+ return out;
45
+ }
46
+ export { deriveImageSizes, getPreferredSize };
@@ -0,0 +1,20 @@
1
+ .insert-layout-modal-container {
2
+ min-width: 340px;
3
+ max-width: 600px;
4
+ }
5
+
6
+ .insert-layout-modal-select {
7
+ margin: 2rem 0 0;
8
+ }
9
+
10
+ @media screen and (min-width: 640px) {
11
+ .insert-layout-modal-select {
12
+ width: 100%;
13
+ margin: 1rem 0 .5rem;
14
+ }
15
+
16
+ .insert-layout-modal-actions {
17
+ margin: 0;
18
+ }
19
+ }
20
+