@wix/patterns-fields 1.17.0 → 1.20.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 (353) hide show
  1. package/cell-rich-content-input/package.json +5 -0
  2. package/dist/cjs/assets/locale/messages_en.json +7 -3
  3. package/dist/cjs/components/address/input/address-input.st.css.js +3 -3
  4. package/dist/cjs/components/address/input/address-input.st.css.js.map +1 -1
  5. package/dist/cjs/components/audio/actions/actions-menu/actions-menu.st.css.js +3 -3
  6. package/dist/cjs/components/audio/actions/actions-menu/actions-menu.st.css.js.map +1 -1
  7. package/dist/cjs/components/audio/audio-field/form-audio-field.st.css.js +4 -4
  8. package/dist/cjs/components/audio/audio-field/form-audio-field.st.css.js.map +1 -1
  9. package/dist/cjs/components/audio/audio-player/audio-player.st.css.js +2 -2
  10. package/dist/cjs/components/audio/audio-player/audio-player.st.css.js.map +1 -1
  11. package/dist/cjs/components/color-view/color-view.st.css.js +4 -4
  12. package/dist/cjs/components/color-view/color-view.st.css.js.map +1 -1
  13. package/dist/cjs/components/delete-dialog/delete-dialog.st.css.js +3 -3
  14. package/dist/cjs/components/delete-dialog/delete-dialog.st.css.js.map +1 -1
  15. package/dist/cjs/components/document/form-document-field.st.css.js +7 -7
  16. package/dist/cjs/components/document/form-document-field.st.css.js.map +1 -1
  17. package/dist/cjs/components/exclamation/exclamation.st.css.js +5 -5
  18. package/dist/cjs/components/exclamation/exclamation.st.css.js.map +1 -1
  19. package/dist/cjs/components/highlighted-text/highlighted-text.st.css.js +5 -5
  20. package/dist/cjs/components/highlighted-text/highlighted-text.st.css.js.map +1 -1
  21. package/dist/cjs/components/image/cell-image-edit.js +40 -146
  22. package/dist/cjs/components/image/cell-image-edit.js.map +1 -1
  23. package/dist/cjs/components/image/image-thumbnail.js +7 -6
  24. package/dist/cjs/components/image/image-thumbnail.js.map +1 -1
  25. package/dist/cjs/components/image/thumbnail-replace-overlay.js +29 -0
  26. package/dist/cjs/components/image/thumbnail-replace-overlay.js.map +1 -0
  27. package/dist/cjs/components/image/thumbnail-replace-overlay.st.css +15 -0
  28. package/dist/cjs/components/image/thumbnail-replace-overlay.st.css.js +23 -0
  29. package/dist/cjs/components/image/thumbnail-replace-overlay.st.css.js.map +1 -0
  30. package/dist/cjs/components/media-control/paste-url-button.st.css.js +4 -4
  31. package/dist/cjs/components/media-control/paste-url-button.st.css.js.map +1 -1
  32. package/dist/cjs/components/media-control/use-media-control.js +8 -9
  33. package/dist/cjs/components/media-control/use-media-control.js.map +1 -1
  34. package/dist/cjs/components/media-gallery/cell-media-gallery-edit.js +301 -0
  35. package/dist/cjs/components/media-gallery/cell-media-gallery-edit.js.map +1 -0
  36. package/dist/cjs/components/media-gallery/cell-media-gallery-view.js +45 -0
  37. package/dist/cjs/components/media-gallery/cell-media-gallery-view.js.map +1 -0
  38. package/dist/cjs/components/media-gallery/form-media-gallery-field.st.css.js +10 -10
  39. package/dist/cjs/components/media-gallery/form-media-gallery-field.st.css.js.map +1 -1
  40. package/dist/cjs/components/media-gallery/index.js +12 -0
  41. package/dist/cjs/components/media-gallery/index.js.map +1 -1
  42. package/dist/cjs/components/media-image/media-image.st.css.js +4 -4
  43. package/dist/cjs/components/media-image/media-image.st.css.js.map +1 -1
  44. package/dist/cjs/components/media-image/overlays/overlay.st.css.js +4 -4
  45. package/dist/cjs/components/media-image/overlays/overlay.st.css.js.map +1 -1
  46. package/dist/cjs/components/media-loader/media-loader.st.css.js +3 -3
  47. package/dist/cjs/components/media-loader/media-loader.st.css.js.map +1 -1
  48. package/dist/cjs/components/media-tag/web-media-tag/media-tag.st.css.js +2 -2
  49. package/dist/cjs/components/media-tag/web-media-tag/media-tag.st.css.js.map +1 -1
  50. package/dist/cjs/components/multi-document/multi-document-input/form-multi-document-field.js.map +1 -1
  51. package/dist/cjs/components/multi-document/multi-document-input/form-multi-document-view.js.map +1 -1
  52. package/dist/cjs/components/multi-document/multi-document-input/form-multi-document.st.css.js +5 -5
  53. package/dist/cjs/components/multi-document/multi-document-input/form-multi-document.st.css.js.map +1 -1
  54. package/dist/cjs/components/rich-content/cell-rich-content-input.js +1 -1
  55. package/dist/cjs/components/rich-content/cell-rich-content-input.js.map +1 -1
  56. package/dist/cjs/components/rich-content/cell-rich-content-view.js +1 -1
  57. package/dist/cjs/components/rich-content/cell-rich-content-view.js.map +1 -1
  58. package/dist/cjs/components/rich-content/editor.js +2 -10
  59. package/dist/cjs/components/rich-content/editor.js.map +1 -1
  60. package/dist/cjs/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.js +6 -6
  61. package/dist/cjs/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.js.map +1 -1
  62. package/dist/cjs/components/rich-content/rich-content-input/form-input/form-input.js +2 -1
  63. package/dist/cjs/components/rich-content/rich-content-input/form-input/form-input.js.map +1 -1
  64. package/dist/cjs/components/rich-content/rich-content-input/form-input/index.js +3 -4
  65. package/dist/cjs/components/rich-content/rich-content-input/form-input/index.js.map +1 -1
  66. package/dist/cjs/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.js +5 -5
  67. package/dist/cjs/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.js.map +1 -1
  68. package/dist/cjs/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.js +2 -2
  69. package/dist/cjs/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.js.map +1 -1
  70. package/dist/cjs/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.js +3 -3
  71. package/dist/cjs/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.js.map +1 -1
  72. package/dist/cjs/components/rich-content/rich-content-input/rich-content-common/publish-loader/publish-loader.st.css.js +3 -3
  73. package/dist/cjs/components/rich-content/rich-content-input/rich-content-common/publish-loader/publish-loader.st.css.js.map +1 -1
  74. package/dist/cjs/components/rich-content/rich-content-input/rich-content-common/toggle-fullscreen-button/toggle-fullscreen-button.st.css.js +2 -2
  75. package/dist/cjs/components/rich-content/rich-content-input/rich-content-common/toggle-fullscreen-button/toggle-fullscreen-button.st.css.js.map +1 -1
  76. package/dist/cjs/components/rich-content/rich-content-input/rich-content-editor/rich-content-editor.st.css.js +8 -8
  77. package/dist/cjs/components/rich-content/rich-content-input/rich-content-editor/rich-content-editor.st.css.js.map +1 -1
  78. package/dist/cjs/components/rich-content/rich-content-input/rich-content-editor/rich-content-toolbar.st.css.js +4 -4
  79. package/dist/cjs/components/rich-content/rich-content-input/rich-content-editor/rich-content-toolbar.st.css.js.map +1 -1
  80. package/dist/cjs/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.js +4 -4
  81. package/dist/cjs/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.js.map +1 -1
  82. package/dist/cjs/components/rich-text/cell-rich-text-editor.js +155 -0
  83. package/dist/cjs/components/rich-text/cell-rich-text-editor.js.map +1 -0
  84. package/dist/cjs/components/rich-text/cell-rich-text-input.js +153 -0
  85. package/dist/cjs/components/rich-text/cell-rich-text-input.js.map +1 -0
  86. package/dist/cjs/components/rich-text/cell-rich-text-view.js +30 -0
  87. package/dist/cjs/components/rich-text/cell-rich-text-view.js.map +1 -0
  88. package/dist/cjs/components/rich-text/index.js +18 -0
  89. package/dist/cjs/components/rich-text/index.js.map +1 -1
  90. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/rich-editor.js +13 -1
  91. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/rich-editor.js.map +1 -1
  92. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css +26 -22
  93. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.js +50 -46
  94. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.js.map +1 -1
  95. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.js +4 -4
  96. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.js.map +1 -1
  97. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/toolbar/header-dropdown.js +168 -157
  98. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/toolbar/header-dropdown.js.map +1 -1
  99. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css +13 -12
  100. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.js +22 -19
  101. package/dist/cjs/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.js.map +1 -1
  102. package/dist/cjs/components/text/text-view.st.css.js +3 -3
  103. package/dist/cjs/components/text/text-view.st.css.js.map +1 -1
  104. package/dist/cjs/components/video/cell-video-edit.js +424 -0
  105. package/dist/cjs/components/video/cell-video-edit.js.map +1 -0
  106. package/dist/cjs/components/video/index.js +3 -1
  107. package/dist/cjs/components/video/index.js.map +1 -1
  108. package/dist/cjs/exports/cell-rich-content-input.js +8 -0
  109. package/dist/cjs/exports/cell-rich-content-input.js.map +1 -0
  110. package/dist/cjs/exports/form-rich-content-input.js +3 -4
  111. package/dist/cjs/exports/form-rich-content-input.js.map +1 -1
  112. package/dist/cjs/hooks/index.js +6 -0
  113. package/dist/cjs/hooks/index.js.map +1 -1
  114. package/dist/cjs/hooks/use-cell-edit-keyboard.js +94 -0
  115. package/dist/cjs/hooks/use-cell-edit-keyboard.js.map +1 -0
  116. package/dist/cjs/index.js +11 -0
  117. package/dist/cjs/index.js.map +1 -1
  118. package/dist/cjs/services/translations.js.map +1 -1
  119. package/dist/cjs/styles.global.css +1 -1
  120. package/dist/esm/assets/locale/messages_en.json +7 -3
  121. package/dist/esm/components/address/input/address-input.st.css.js +2 -2
  122. package/dist/esm/components/address/input/address-input.st.css.js.map +1 -1
  123. package/dist/esm/components/audio/actions/actions-menu/actions-menu.st.css.js +2 -2
  124. package/dist/esm/components/audio/audio-field/form-audio-field.st.css.js +2 -2
  125. package/dist/esm/components/audio/audio-player/audio-player.st.css.js +2 -2
  126. package/dist/esm/components/color-view/color-view.st.css.js +2 -2
  127. package/dist/esm/components/delete-dialog/delete-dialog.st.css.js +2 -2
  128. package/dist/esm/components/document/form-document-field.st.css.js +2 -2
  129. package/dist/esm/components/exclamation/exclamation.st.css.js +2 -2
  130. package/dist/esm/components/exclamation/exclamation.st.css.js.map +1 -1
  131. package/dist/esm/components/highlighted-text/highlighted-text.st.css.js +3 -3
  132. package/dist/esm/components/image/cell-image-edit.js +11 -102
  133. package/dist/esm/components/image/cell-image-edit.js.map +1 -1
  134. package/dist/esm/components/image/image-thumbnail.js +9 -3
  135. package/dist/esm/components/image/image-thumbnail.js.map +1 -1
  136. package/dist/esm/components/image/thumbnail-replace-overlay.js +7 -0
  137. package/dist/esm/components/image/thumbnail-replace-overlay.js.map +1 -0
  138. package/dist/esm/components/image/thumbnail-replace-overlay.st.css +15 -0
  139. package/dist/esm/components/image/thumbnail-replace-overlay.st.css.js +15 -0
  140. package/dist/esm/components/image/thumbnail-replace-overlay.st.css.js.map +1 -0
  141. package/dist/esm/components/media-control/paste-url-button.st.css.js +2 -2
  142. package/dist/esm/components/media-control/use-media-control.js +9 -8
  143. package/dist/esm/components/media-control/use-media-control.js.map +1 -1
  144. package/dist/esm/components/media-gallery/cell-media-gallery-edit.js +103 -0
  145. package/dist/esm/components/media-gallery/cell-media-gallery-edit.js.map +1 -0
  146. package/dist/esm/components/media-gallery/cell-media-gallery-view.js +11 -0
  147. package/dist/esm/components/media-gallery/cell-media-gallery-view.js.map +1 -0
  148. package/dist/esm/components/media-gallery/form-media-gallery-field.st.css.js +2 -2
  149. package/dist/esm/components/media-gallery/form-media-gallery-field.st.css.js.map +1 -1
  150. package/dist/esm/components/media-gallery/index.js +2 -0
  151. package/dist/esm/components/media-gallery/index.js.map +1 -1
  152. package/dist/esm/components/media-image/media-image.st.css.js +3 -3
  153. package/dist/esm/components/media-image/media-image.st.css.js.map +1 -1
  154. package/dist/esm/components/media-image/overlays/overlay.st.css.js +3 -3
  155. package/dist/esm/components/media-image/overlays/overlay.st.css.js.map +1 -1
  156. package/dist/esm/components/media-loader/media-loader.st.css.js +2 -2
  157. package/dist/esm/components/media-tag/web-media-tag/media-tag.st.css.js +2 -2
  158. package/dist/esm/components/media-tag/web-media-tag/media-tag.st.css.js.map +1 -1
  159. package/dist/esm/components/multi-document/multi-document-input/form-multi-document-field.js.map +1 -1
  160. package/dist/esm/components/multi-document/multi-document-input/form-multi-document-view.js.map +1 -1
  161. package/dist/esm/components/multi-document/multi-document-input/form-multi-document.st.css.js +2 -2
  162. package/dist/esm/components/multi-document/multi-document-input/form-multi-document.st.css.js.map +1 -1
  163. package/dist/esm/components/rich-content/cell-rich-content-input.js.map +1 -1
  164. package/dist/esm/components/rich-content/cell-rich-content-view.js +1 -1
  165. package/dist/esm/components/rich-content/cell-rich-content-view.js.map +1 -1
  166. package/dist/esm/components/rich-content/editor.js +1 -2
  167. package/dist/esm/components/rich-content/editor.js.map +1 -1
  168. package/dist/esm/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.js +3 -3
  169. package/dist/esm/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.js.map +1 -1
  170. package/dist/esm/components/rich-content/rich-content-input/form-input/form-input.js +1 -1
  171. package/dist/esm/components/rich-content/rich-content-input/form-input/form-input.js.map +1 -1
  172. package/dist/esm/components/rich-content/rich-content-input/form-input/index.js +1 -1
  173. package/dist/esm/components/rich-content/rich-content-input/form-input/index.js.map +1 -1
  174. package/dist/esm/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.js +3 -3
  175. package/dist/esm/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.js.map +1 -1
  176. package/dist/esm/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.js +2 -2
  177. package/dist/esm/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.js.map +1 -1
  178. package/dist/esm/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.js +2 -2
  179. package/dist/esm/components/rich-content/rich-content-input/rich-content-common/publish-loader/publish-loader.st.css.js +2 -2
  180. package/dist/esm/components/rich-content/rich-content-input/rich-content-common/toggle-fullscreen-button/toggle-fullscreen-button.st.css.js +2 -2
  181. package/dist/esm/components/rich-content/rich-content-input/rich-content-editor/rich-content-editor.st.css.js +3 -3
  182. package/dist/esm/components/rich-content/rich-content-input/rich-content-editor/rich-content-toolbar.st.css.js +2 -2
  183. package/dist/esm/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.js +2 -2
  184. package/dist/esm/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.js.map +1 -1
  185. package/dist/esm/components/rich-text/cell-rich-text-editor.js +85 -0
  186. package/dist/esm/components/rich-text/cell-rich-text-editor.js.map +1 -0
  187. package/dist/esm/components/rich-text/cell-rich-text-input.js +77 -0
  188. package/dist/esm/components/rich-text/cell-rich-text-input.js.map +1 -0
  189. package/dist/esm/components/rich-text/cell-rich-text-view.js +11 -0
  190. package/dist/esm/components/rich-text/cell-rich-text-view.js.map +1 -0
  191. package/dist/esm/components/rich-text/index.js +3 -0
  192. package/dist/esm/components/rich-text/index.js.map +1 -1
  193. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/rich-editor.js +14 -2
  194. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/rich-editor.js.map +1 -1
  195. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css +26 -22
  196. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.js +4 -4
  197. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.js.map +1 -1
  198. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.js +2 -2
  199. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.js.map +1 -1
  200. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/toolbar/header-dropdown.js +64 -50
  201. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/toolbar/header-dropdown.js.map +1 -1
  202. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css +13 -12
  203. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.js +3 -3
  204. package/dist/esm/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.js.map +1 -1
  205. package/dist/esm/components/text/text-view.st.css.js +2 -2
  206. package/dist/esm/components/video/cell-video-edit.js +159 -0
  207. package/dist/esm/components/video/cell-video-edit.js.map +1 -0
  208. package/dist/esm/components/video/index.js +1 -0
  209. package/dist/esm/components/video/index.js.map +1 -1
  210. package/dist/esm/exports/cell-rich-content-input.js +2 -0
  211. package/dist/esm/exports/cell-rich-content-input.js.map +1 -0
  212. package/dist/esm/exports/form-rich-content-input.js +1 -1
  213. package/dist/esm/exports/form-rich-content-input.js.map +1 -1
  214. package/dist/esm/hooks/index.js +1 -0
  215. package/dist/esm/hooks/index.js.map +1 -1
  216. package/dist/esm/hooks/use-cell-edit-keyboard.js +81 -0
  217. package/dist/esm/hooks/use-cell-edit-keyboard.js.map +1 -0
  218. package/dist/esm/index.js +1 -0
  219. package/dist/esm/index.js.map +1 -1
  220. package/dist/esm/styles.global.css +1 -1
  221. package/dist/types/components/address/input/address-input.st.css.d.ts.map +1 -1
  222. package/dist/types/components/exclamation/exclamation.st.css.d.ts.map +1 -1
  223. package/dist/types/components/image/cell-image-edit.d.ts.map +1 -1
  224. package/dist/types/components/image/image-thumbnail.d.ts +1 -0
  225. package/dist/types/components/image/image-thumbnail.d.ts.map +1 -1
  226. package/dist/types/components/image/thumbnail-replace-overlay.d.ts +3 -0
  227. package/dist/types/components/image/thumbnail-replace-overlay.d.ts.map +1 -0
  228. package/dist/types/components/image/thumbnail-replace-overlay.st.css.d.ts +14 -0
  229. package/dist/types/components/image/thumbnail-replace-overlay.st.css.d.ts.map +1 -0
  230. package/dist/types/components/media-control/use-media-control.d.ts +3 -3
  231. package/dist/types/components/media-control/use-media-control.d.ts.map +1 -1
  232. package/dist/types/components/media-gallery/cell-media-gallery-edit.d.ts +15 -0
  233. package/dist/types/components/media-gallery/cell-media-gallery-edit.d.ts.map +1 -0
  234. package/dist/types/components/media-gallery/cell-media-gallery-view.d.ts +11 -0
  235. package/dist/types/components/media-gallery/cell-media-gallery-view.d.ts.map +1 -0
  236. package/dist/types/components/media-gallery/form-media-gallery-field.st.css.d.ts.map +1 -1
  237. package/dist/types/components/media-gallery/index.d.ts +2 -0
  238. package/dist/types/components/media-gallery/index.d.ts.map +1 -1
  239. package/dist/types/components/media-gallery/media-gallery-dialog/hooks.d.ts +2 -2
  240. package/dist/types/components/media-image/media-image.st.css.d.ts.map +1 -1
  241. package/dist/types/components/media-image/overlays/overlay.st.css.d.ts.map +1 -1
  242. package/dist/types/components/media-tag/web-media-tag/media-tag.st.css.d.ts.map +1 -1
  243. package/dist/types/components/multi-document/multi-document-input/form-multi-document-view.d.ts +1 -1
  244. package/dist/types/components/multi-document/multi-document-input/form-multi-document-view.d.ts.map +1 -1
  245. package/dist/types/components/multi-document/multi-document-input/form-multi-document.st.css.d.ts.map +1 -1
  246. package/dist/types/components/rich-content/cell-rich-content-input.d.ts.map +1 -1
  247. package/dist/types/components/rich-content/cell-rich-content-view.d.ts.map +1 -1
  248. package/dist/types/components/rich-content/editor.d.ts +1 -2
  249. package/dist/types/components/rich-content/editor.d.ts.map +1 -1
  250. package/dist/types/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.d.ts.map +1 -1
  251. package/dist/types/components/rich-content/rich-content-input/form-input/form-input.d.ts +1 -1
  252. package/dist/types/components/rich-content/rich-content-input/form-input/form-input.d.ts.map +1 -1
  253. package/dist/types/components/rich-content/rich-content-input/form-input/index.d.ts +1 -1
  254. package/dist/types/components/rich-content/rich-content-input/form-input/index.d.ts.map +1 -1
  255. package/dist/types/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.d.ts.map +1 -1
  256. package/dist/types/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.d.ts.map +1 -1
  257. package/dist/types/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.d.ts.map +1 -1
  258. package/dist/types/components/rich-text/cell-rich-text-editor.d.ts +21 -0
  259. package/dist/types/components/rich-text/cell-rich-text-editor.d.ts.map +1 -0
  260. package/dist/types/components/rich-text/cell-rich-text-input.d.ts +23 -0
  261. package/dist/types/components/rich-text/cell-rich-text-input.d.ts.map +1 -0
  262. package/dist/types/components/rich-text/cell-rich-text-view.d.ts +8 -0
  263. package/dist/types/components/rich-text/cell-rich-text-view.d.ts.map +1 -0
  264. package/dist/types/components/rich-text/index.d.ts +4 -0
  265. package/dist/types/components/rich-text/index.d.ts.map +1 -1
  266. package/dist/types/components/rich-text/rich-text-input/rich-text-editor/rich-editor.d.ts.map +1 -1
  267. package/dist/types/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.d.ts +4 -0
  268. package/dist/types/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.d.ts.map +1 -1
  269. package/dist/types/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.d.ts.map +1 -1
  270. package/dist/types/components/rich-text/rich-text-input/rich-text-editor/toolbar/header-dropdown.d.ts +1 -0
  271. package/dist/types/components/rich-text/rich-text-input/rich-text-editor/toolbar/header-dropdown.d.ts.map +1 -1
  272. package/dist/types/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.d.ts +3 -0
  273. package/dist/types/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.d.ts.map +1 -1
  274. package/dist/types/components/video/cell-video-edit.d.ts +20 -0
  275. package/dist/types/components/video/cell-video-edit.d.ts.map +1 -0
  276. package/dist/types/components/video/index.d.ts +2 -0
  277. package/dist/types/components/video/index.d.ts.map +1 -1
  278. package/dist/types/exports/cell-rich-content-input.d.ts +2 -0
  279. package/dist/types/exports/cell-rich-content-input.d.ts.map +1 -0
  280. package/dist/types/exports/form-rich-content-input.d.ts +1 -2
  281. package/dist/types/exports/form-rich-content-input.d.ts.map +1 -1
  282. package/dist/types/hooks/index.d.ts +1 -0
  283. package/dist/types/hooks/index.d.ts.map +1 -1
  284. package/dist/types/hooks/use-cell-edit-keyboard.d.ts +26 -0
  285. package/dist/types/hooks/use-cell-edit-keyboard.d.ts.map +1 -0
  286. package/dist/types/index.d.ts +1 -0
  287. package/dist/types/index.d.ts.map +1 -1
  288. package/dist/types/services/translations.d.ts +1 -1
  289. package/dist/types/services/translations.d.ts.map +1 -1
  290. package/package.json +11 -5
  291. package/src/assets/locale/messages_en.json +7 -3
  292. package/src/components/address/input/address-input.st.css.ts +2 -2
  293. package/src/components/audio/actions/actions-menu/actions-menu.st.css.ts +2 -2
  294. package/src/components/audio/audio-field/form-audio-field.st.css.ts +2 -2
  295. package/src/components/audio/audio-player/audio-player.st.css.ts +2 -2
  296. package/src/components/color-view/color-view.st.css.ts +2 -2
  297. package/src/components/delete-dialog/delete-dialog.st.css.ts +2 -2
  298. package/src/components/document/form-document-field.st.css.ts +2 -2
  299. package/src/components/exclamation/exclamation.st.css.ts +2 -2
  300. package/src/components/highlighted-text/highlighted-text.st.css.ts +3 -3
  301. package/src/components/image/cell-image-edit.tsx +11 -115
  302. package/src/components/image/image-thumbnail.tsx +10 -2
  303. package/src/components/image/thumbnail-replace-overlay.st.css +15 -0
  304. package/src/components/image/thumbnail-replace-overlay.st.css.ts +25 -0
  305. package/src/components/image/thumbnail-replace-overlay.tsx +11 -0
  306. package/src/components/media-control/paste-url-button.st.css.ts +2 -2
  307. package/src/components/media-control/use-media-control.ts +13 -13
  308. package/src/components/media-gallery/cell-media-gallery-edit.tsx +219 -0
  309. package/src/components/media-gallery/cell-media-gallery-view.tsx +32 -0
  310. package/src/components/media-gallery/form-media-gallery-field.st.css.ts +2 -2
  311. package/src/components/media-gallery/index.ts +2 -0
  312. package/src/components/media-image/media-image.st.css.ts +3 -3
  313. package/src/components/media-image/overlays/overlay.st.css.ts +3 -3
  314. package/src/components/media-loader/media-loader.st.css.ts +2 -2
  315. package/src/components/media-tag/web-media-tag/media-tag.st.css.ts +2 -2
  316. package/src/components/multi-document/multi-document-input/form-multi-document-field.tsx +1 -1
  317. package/src/components/multi-document/multi-document-input/form-multi-document-view.tsx +2 -2
  318. package/src/components/multi-document/multi-document-input/form-multi-document.st.css.ts +2 -2
  319. package/src/components/rich-content/cell-rich-content-input.tsx +2 -3
  320. package/src/components/rich-content/cell-rich-content-view.tsx +1 -4
  321. package/src/components/rich-content/editor.ts +1 -2
  322. package/src/components/rich-content/rich-content-input/default-value-input/rich-content-default-value-input.st.css.ts +3 -3
  323. package/src/components/rich-content/rich-content-input/form-input/form-input.tsx +1 -1
  324. package/src/components/rich-content/rich-content-input/form-input/index.ts +1 -1
  325. package/src/components/rich-content/rich-content-input/form-input/rich-content-form-input.st.css.ts +3 -3
  326. package/src/components/rich-content/rich-content-input/form-read-only-input/rich-content-form-read-only-input.st.css.ts +2 -2
  327. package/src/components/rich-content/rich-content-input/rich-content-common/fullscreen-modal/fullscreen-modal.st.css.ts +2 -2
  328. package/src/components/rich-content/rich-content-input/rich-content-common/publish-loader/publish-loader.st.css.ts +2 -2
  329. package/src/components/rich-content/rich-content-input/rich-content-common/toggle-fullscreen-button/toggle-fullscreen-button.st.css.ts +2 -2
  330. package/src/components/rich-content/rich-content-input/rich-content-editor/rich-content-editor.st.css.ts +3 -3
  331. package/src/components/rich-content/rich-content-input/rich-content-editor/rich-content-toolbar.st.css.ts +2 -2
  332. package/src/components/rich-content/rich-content-input/rich-content-viewer/rich-content-viewer.st.css.ts +2 -2
  333. package/src/components/rich-text/cell-rich-text-editor.tsx +173 -0
  334. package/src/components/rich-text/cell-rich-text-input.tsx +126 -0
  335. package/src/components/rich-text/cell-rich-text-view.tsx +19 -0
  336. package/src/components/rich-text/index.ts +4 -0
  337. package/src/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css +26 -22
  338. package/src/components/rich-text/rich-text-input/rich-text-editor/rich-editor.st.css.ts +4 -4
  339. package/src/components/rich-text/rich-text-input/rich-text-editor/rich-editor.tsx +22 -5
  340. package/src/components/rich-text/rich-text-input/rich-text-editor/rich-text-editor.st.css.ts +2 -2
  341. package/src/components/rich-text/rich-text-input/rich-text-editor/toolbar/header-dropdown.tsx +153 -126
  342. package/src/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css +13 -12
  343. package/src/components/rich-text/rich-text-input/rich-text-editor/toolbar/toolbar.st.css.ts +3 -3
  344. package/src/components/text/text-view.st.css.ts +2 -2
  345. package/src/components/video/cell-video-edit.tsx +308 -0
  346. package/src/components/video/index.ts +2 -0
  347. package/src/exports/cell-rich-content-input.ts +4 -0
  348. package/src/exports/form-rich-content-input.ts +1 -5
  349. package/src/hooks/index.ts +1 -0
  350. package/src/hooks/use-cell-edit-keyboard.ts +109 -0
  351. package/src/index.ts +1 -0
  352. package/src/services/translations.ts +5 -1
  353. package/src/styles.global.css +1 -1
@@ -2,6 +2,7 @@
2
2
  @property st-global(--wds-color-black-400);
3
3
  @property st-global(--wds-color-white);
4
4
  @property st-global(--wds-font-family-default);
5
+ @property st-global(--wsr-font-family);
5
6
  @property st-global(--wds-font-weight-medium);
6
7
  @property st-global(--wds-font-weight-bold);
7
8
  @property st-global(--wds-font-size-500);
@@ -10,8 +11,8 @@
10
11
  .root {
11
12
  padding: 12px 18px;
12
13
  display: flex;
13
- border-bottom: 1px solid var(--wds-color-blue-400);
14
- background: var(--wds-color-white);
14
+ border-bottom: 1px solid var(--wds-color-blue-400, var(--wsr-color-B40, #d6dcff));
15
+ background: var(--wds-color-white, var(--wsr-color-D80, #ffffff));
15
16
  align-items: center;
16
17
  }
17
18
 
@@ -30,7 +31,7 @@
30
31
  display: inline-flex;
31
32
  margin-right: 12px;
32
33
  border-left: 1px solid #ddd;
33
- height: 100%;
34
+ align-self: stretch;
34
35
  }
35
36
 
36
37
  .clearFormatting {
@@ -65,53 +66,53 @@
65
66
  font-weight: var(--wds-font-weight-bold) !important;
66
67
  font-size: 36px !important;
67
68
  line-height: 1.2 !important;
68
- font-family: var(--wds-font-family-default) !important;
69
+ font-family: var(--wds-font-family-default, var(--wsr-font-family, Madefor)) !important;
69
70
  }
70
71
  .dropdownHeaderTwo {
71
72
  font-weight: var(--wds-font-weight-bold) !important;
72
73
  font-size: 32px !important;
73
74
  line-height: 1.2 !important;
74
- font-family: var(--wds-font-family-default) !important;
75
+ font-family: var(--wds-font-family-default, Madefor, "Helvetica Neue", Helvetica, Arial, sans-serif) !important;
75
76
  }
76
77
  .dropdownHeaderThree {
77
78
  font-weight: var(--wds-font-weight-medium) !important;
78
79
  font-size: 28px !important;
79
80
  line-height: 1.2 !important;
80
- font-family: var(--wds-font-family-default) !important;
81
+ font-family: var(--wds-font-family-default, Madefor, "Helvetica Neue", Helvetica, Arial, sans-serif) !important;
81
82
  }
82
83
  .dropdownHeaderFour {
83
84
  font-weight: var(--wds-font-weight-bold) !important;
84
85
  font-size: 24px !important;
85
86
  line-height: 1.2 !important;
86
- font-family: var(--wds-font-family-default) !important;
87
+ font-family: var(--wds-font-family-default, Madefor, "Helvetica Neue", Helvetica, Arial, sans-serif) !important;
87
88
  }
88
89
  .dropdownHeaderFive {
89
90
  font-weight: var(--wds-font-weight-bold) !important;
90
91
  font-size: 22px !important;
91
92
  line-height: 1.2 !important;
92
- font-family: var(--wds-font-family-default) !important;
93
+ font-family: var(--wds-font-family-default, Madefor, "Helvetica Neue", Helvetica, Arial, sans-serif) !important;
93
94
  }
94
95
  .dropdownHeaderSix {
95
96
  font-weight: var(--wds-font-weight-medium) !important;
96
97
  font-size: 20px !important;
97
98
  line-height: 1.2 !important;
98
- font-family: var(--wds-font-family-default) !important;
99
+ font-family: var(--wds-font-family-default, Madefor, "Helvetica Neue", Helvetica, Arial, sans-serif) !important;
99
100
  }
100
101
  .dropdownParagraphOne {
101
102
  font-weight: var(--wds-font-weight-medium) !important;
102
103
  font-size: 18px !important;
103
104
  line-height: 1.33 !important;
104
- font-family: var(--wds-font-family-default) !important;
105
+ font-family: var(--wds-font-family-default, Madefor, "Helvetica Neue", Helvetica, Arial, sans-serif) !important;
105
106
  }
106
107
  .dropdownNormalText {
107
108
  font-weight: var(--wds-font-weight-medium) !important;
108
109
  font-size: var(--wds-font-size-500) !important;
109
110
  line-height: var(--wds-font-line-height-300) !important;
110
- font-family: var(--wds-font-family-default) !important;
111
+ font-family: var(--wds-font-family-default, Madefor, "Helvetica Neue", Helvetica, Arial, sans-serif) !important;
111
112
  }
112
113
  .dropdownParagraphThree {
113
114
  font-weight: var(--wds-font-weight-medium) !important;
114
115
  font-size: 14px !important;
115
116
  line-height: 1.29 !important;
116
- font-family: var(--wds-font-family-default) !important;
117
+ font-family: var(--wds-font-family-default, Madefor, "Helvetica Neue", Helvetica, Arial, sans-serif) !important;
117
118
  }
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../../../../stylable-esm-runti
5
5
 
6
6
 
7
7
 
8
- var _namespace_ = "toolbar2031504778";
8
+ var _namespace_ = "toolbar3885570681";
9
9
  var _style_ = classesRuntime.bind(null, _namespace_);
10
10
 
11
11
  export var cssStates = statesRuntime.bind(null, _namespace_);
@@ -13,12 +13,12 @@ export var style: import("@stylable/runtime").STFunction = _style_;
13
13
  export var st: import("@stylable/runtime").STFunction = _style_;
14
14
 
15
15
  export var namespace = _namespace_;
16
- export var classes = {"root":"toolbar2031504778__root","item":"toolbar2031504778__item","separator":"toolbar2031504778__separator","clearFormatting":"toolbar2031504778__clearFormatting","fullScreen":"toolbar2031504778__fullScreen","dropdownItemContent":"toolbar2031504778__dropdownItemContent","dropdownItemTitle":"toolbar2031504778__dropdownItemTitle","dropdownItemSubtitle":"toolbar2031504778__dropdownItemSubtitle","dropdownHeaderOne":"toolbar2031504778__dropdownHeaderOne","dropdownHeaderTwo":"toolbar2031504778__dropdownHeaderTwo","dropdownHeaderThree":"toolbar2031504778__dropdownHeaderThree","dropdownHeaderFour":"toolbar2031504778__dropdownHeaderFour","dropdownHeaderFive":"toolbar2031504778__dropdownHeaderFive","dropdownHeaderSix":"toolbar2031504778__dropdownHeaderSix","dropdownParagraphOne":"toolbar2031504778__dropdownParagraphOne","dropdownNormalText":"toolbar2031504778__dropdownNormalText","dropdownParagraphThree":"toolbar2031504778__dropdownParagraphThree"};
16
+ export var classes = {"root":"toolbar3885570681__root","item":"toolbar3885570681__item","separator":"toolbar3885570681__separator","clearFormatting":"toolbar3885570681__clearFormatting","fullScreen":"toolbar3885570681__fullScreen","dropdownItemContent":"toolbar3885570681__dropdownItemContent","dropdownItemTitle":"toolbar3885570681__dropdownItemTitle","dropdownItemSubtitle":"toolbar3885570681__dropdownItemSubtitle","dropdownHeaderOne":"toolbar3885570681__dropdownHeaderOne","dropdownHeaderTwo":"toolbar3885570681__dropdownHeaderTwo","dropdownHeaderThree":"toolbar3885570681__dropdownHeaderThree","dropdownHeaderFour":"toolbar3885570681__dropdownHeaderFour","dropdownHeaderFive":"toolbar3885570681__dropdownHeaderFive","dropdownHeaderSix":"toolbar3885570681__dropdownHeaderSix","dropdownParagraphOne":"toolbar3885570681__dropdownParagraphOne","dropdownNormalText":"toolbar3885570681__dropdownNormalText","dropdownParagraphThree":"toolbar3885570681__dropdownParagraphThree"};
17
17
  export var keyframes = {};
18
18
  export var layers = {};
19
19
  export var containers = {};
20
20
  export var stVars = {};
21
- export var vars = {"wds-color-blue-400":"--wds-color-blue-400","wds-color-black-400":"--wds-color-black-400","wds-color-white":"--wds-color-white","wds-font-family-default":"--wds-font-family-default","wds-font-weight-medium":"--wds-font-weight-medium","wds-font-weight-bold":"--wds-font-weight-bold","wds-font-size-500":"--wds-font-size-500","wds-font-line-height-300":"--wds-font-line-height-300"};
21
+ export var vars = {"wds-color-blue-400":"--wds-color-blue-400","wds-color-black-400":"--wds-color-black-400","wds-color-white":"--wds-color-white","wds-font-family-default":"--wds-font-family-default","wsr-font-family":"--wsr-font-family","wds-font-weight-medium":"--wds-font-weight-medium","wds-font-weight-bold":"--wds-font-weight-bold","wds-font-size-500":"--wds-font-size-500","wds-font-line-height-300":"--wds-font-line-height-300","wsr-color-B40":"--toolbar3885570681-wsr-color-B40","wsr-color-D80":"--toolbar3885570681-wsr-color-D80"};
22
22
 
23
23
 
24
24
 
@@ -5,7 +5,7 @@ import { classesRuntime, statesRuntime } from "../../stylable-esm-runtime.js";
5
5
 
6
6
 
7
7
 
8
- var _namespace_ = "textview4186768641";
8
+ var _namespace_ = "textview2328621760";
9
9
  var _style_ = classesRuntime.bind(null, _namespace_);
10
10
 
11
11
  export var cssStates = statesRuntime.bind(null, _namespace_);
@@ -13,7 +13,7 @@ export var style: import("@stylable/runtime").STFunction = _style_;
13
13
  export var st: import("@stylable/runtime").STFunction = _style_;
14
14
 
15
15
  export var namespace = _namespace_;
16
- export var classes = {"root":"textview4186768641__root","textView":"textview4186768641__textView"};
16
+ export var classes = {"root":"textview2328621760__root","textView":"textview2328621760__textView"};
17
17
  export var keyframes = {};
18
18
  export var layers = {};
19
19
  export var containers = {};
@@ -0,0 +1,308 @@
1
+ import React, { useCallback, useEffect, useRef, useState } from 'react';
2
+ import {
3
+ Box,
4
+ IconButton,
5
+ Loader,
6
+ PopoverMenu,
7
+ Tooltip,
8
+ } from '@wix/design-system';
9
+ import {
10
+ Add,
11
+ Delete,
12
+ Download,
13
+ Maximize,
14
+ MoreSmall,
15
+ Replace,
16
+ } from '@wix/wix-ui-icons-common';
17
+ import { MEDIA_TYPES } from '../../utils/media-utils';
18
+ import { useTranslations } from '../../hooks';
19
+ import { useMediaControl } from '../media-control';
20
+ import { ImageThumbnail } from '../image/image-thumbnail';
21
+ import { ThumbnailReplaceOverlay } from '../image/thumbnail-replace-overlay';
22
+ import { MediaPreviewModal } from '../media-gallery/media-preview-modal';
23
+
24
+ export interface CellVideoEditProps {
25
+ value: string | null | undefined;
26
+ onChange: (value: string | null) => void;
27
+ onCommit: () => void;
28
+ onCancel?: () => void;
29
+ /**
30
+ * Called before opening external UI (media manager) so the table can set
31
+ * isEditing=true and protect cell focus while the modal is open.
32
+ */
33
+ onStartEdit?: () => void;
34
+ /** Called to return focus to the table cell (e.g. on Escape or Tab-out). */
35
+ onRequestCellFocus?: () => void;
36
+ inputRef?: React.MutableRefObject<{ focus: () => void } | null | undefined>;
37
+ dataHook?: string;
38
+ }
39
+
40
+ export const CellVideoEdit: React.FC<CellVideoEditProps> = ({
41
+ value,
42
+ onChange,
43
+ onCommit,
44
+ onCancel,
45
+ onStartEdit,
46
+ onRequestCellFocus,
47
+ inputRef,
48
+ dataHook,
49
+ }) => {
50
+ const { t } = useTranslations();
51
+ const containerRef = useRef<HTMLDivElement | null>(null);
52
+ const [isPreviewOpen, setIsPreviewOpen] = useState(false);
53
+
54
+ // Explicit refs for each focusable button — avoids querySelectorAll on the container.
55
+ const thumbnailButtonRef = useRef<HTMLButtonElement | null>(null);
56
+ const addButtonRef = useRef<React.ElementRef<typeof IconButton> | null>(null);
57
+ const moreButtonRef = useRef<React.ElementRef<typeof IconButton> | null>(
58
+ null,
59
+ );
60
+
61
+ const onMediaChange = useCallback(
62
+ (uri: string) => {
63
+ onChange(uri);
64
+ onCommit();
65
+ },
66
+ [onChange, onCommit],
67
+ );
68
+
69
+ const { callMedia, downloadMedia, loading } = useMediaControl({
70
+ mediaType: MEDIA_TYPES.VIDEO,
71
+ value: value ?? undefined,
72
+ onChange: onMediaChange,
73
+ });
74
+
75
+ const handleCallMedia = useCallback(async () => {
76
+ onStartEdit?.();
77
+ const committed = await callMedia();
78
+ if (!committed) {
79
+ onCancel?.();
80
+ }
81
+ }, [onStartEdit, callMedia, onCancel]);
82
+
83
+ const handleDelete = useCallback(() => {
84
+ onChange(null);
85
+ onCommit();
86
+ }, [onChange, onCommit]);
87
+
88
+ const handleDownload = useCallback(() => {
89
+ if (value) {
90
+ downloadMedia(value);
91
+ }
92
+ }, [downloadMedia, value]);
93
+
94
+ // Wire inputRef so the table can focus the first button when activating edit mode.
95
+ useEffect(() => {
96
+ if (!inputRef) return;
97
+ inputRef.current = {
98
+ focus: () => {
99
+ // Only one of these is mounted at a time depending on whether value is set.
100
+ thumbnailButtonRef.current?.focus();
101
+ addButtonRef.current?.focus();
102
+ },
103
+ };
104
+ return () => {
105
+ inputRef.current = null;
106
+ };
107
+ }, [inputRef]);
108
+
109
+ const handleContainerFocus = useCallback(() => {
110
+ containerRef.current?.setAttribute('data-inner-focused', '');
111
+ }, []);
112
+
113
+ const handleContainerBlur = useCallback((e: React.FocusEvent) => {
114
+ if (!e.currentTarget.contains(e.relatedTarget as Node | null)) {
115
+ containerRef.current?.removeAttribute('data-inner-focused');
116
+ }
117
+ }, []);
118
+
119
+ // Native keydown listener to intercept Tab/Escape before useKeyboardNavigation.
120
+ useEffect(() => {
121
+ const el = containerRef.current;
122
+ if (!el) return;
123
+
124
+ const handleKeyDown = (e: KeyboardEvent) => {
125
+ if (e.key === 'Escape') {
126
+ e.preventDefault();
127
+ e.stopPropagation();
128
+ onCancel?.();
129
+ onRequestCellFocus?.();
130
+ return;
131
+ }
132
+
133
+ if (e.key === 'Tab') {
134
+ const active = document.activeElement as HTMLElement | null;
135
+ if (!active || !el.contains(active)) return;
136
+
137
+ const hook = active.getAttribute('data-hook');
138
+ const isPrimary =
139
+ hook === 'video-edit-thumbnail' || hook === 'video-edit-add-button';
140
+ const isMore = hook === 'video-edit-more-button';
141
+ if (!isPrimary && !isMore) return;
142
+
143
+ e.preventDefault();
144
+ e.stopPropagation();
145
+
146
+ const focusPrimary = () => {
147
+ thumbnailButtonRef.current?.focus();
148
+ addButtonRef.current?.focus();
149
+ };
150
+
151
+ if (!e.shiftKey) {
152
+ // Forward: primary → more → cell
153
+ if (isPrimary && moreButtonRef.current) {
154
+ moreButtonRef.current.focus();
155
+ } else {
156
+ onRequestCellFocus?.();
157
+ }
158
+ } else {
159
+ // Backward: more → primary → cell
160
+ if (isMore) {
161
+ focusPrimary();
162
+ } else {
163
+ onRequestCellFocus?.();
164
+ }
165
+ }
166
+ }
167
+ };
168
+
169
+ el.addEventListener('keydown', handleKeyDown);
170
+ return () => el.removeEventListener('keydown', handleKeyDown);
171
+ }, [onCancel, onRequestCellFocus]);
172
+
173
+ if (loading) {
174
+ return (
175
+ <Box
176
+ dataHook={dataHook}
177
+ verticalAlign="middle"
178
+ width="100%"
179
+ height="100%"
180
+ padding="0 8px"
181
+ >
182
+ <Loader size="tiny" />
183
+ </Box>
184
+ );
185
+ }
186
+
187
+ return (
188
+ <div
189
+ ref={containerRef}
190
+ data-hook={dataHook}
191
+ style={{ width: '100%', height: '100%' }}
192
+ onFocus={handleContainerFocus}
193
+ onBlur={handleContainerBlur}
194
+ >
195
+ <Box
196
+ align="space-between"
197
+ verticalAlign="middle"
198
+ height="100%"
199
+ padding="0 8px"
200
+ style={{ boxSizing: 'border-box' }}
201
+ >
202
+ {value ? (
203
+ /* Has value: clickable thumbnail button with replace overlay */
204
+ <Tooltip content={t('CMS.video.change')} appendTo="window">
205
+ <Box>
206
+ <button
207
+ ref={thumbnailButtonRef}
208
+ type="button"
209
+ data-hook="video-edit-thumbnail"
210
+ onClick={handleCallMedia}
211
+ style={{
212
+ cursor: 'pointer',
213
+ lineHeight: 0,
214
+ position: 'relative',
215
+ background: 'none',
216
+ border: 'none',
217
+ padding: 0,
218
+ }}
219
+ >
220
+ <ImageThumbnail value={value} showVideoIndicator={false} />
221
+ <ThumbnailReplaceOverlay />
222
+ </button>
223
+ </Box>
224
+ </Tooltip>
225
+ ) : (
226
+ /* Empty: icon button opens media manager */
227
+ <Tooltip content={t('CMS.video.add')} appendTo="window">
228
+ <IconButton
229
+ ref={addButtonRef}
230
+ size="tiny"
231
+ priority="secondary"
232
+ dataHook="video-edit-add-button"
233
+ onClick={handleCallMedia}
234
+ >
235
+ <Add />
236
+ </IconButton>
237
+ </Tooltip>
238
+ )}
239
+
240
+ <MediaPreviewModal
241
+ isOpen={isPreviewOpen}
242
+ onClose={() => setIsPreviewOpen(false)}
243
+ value={value ?? undefined}
244
+ onRequestMedia={handleCallMedia}
245
+ onClearMedia={handleDelete}
246
+ onDownloadMedia={() => handleDownload()}
247
+ textKeys={{
248
+ replace: 'CMS.video.change',
249
+ download: 'CMS.video.download',
250
+ delete: 'CMS.video.delete',
251
+ }}
252
+ />
253
+ {value ? (
254
+ /* Has value: "..." menu with Change / Preview / Download / Delete */
255
+ <PopoverMenu
256
+ textSize="small"
257
+ appendTo="window"
258
+ triggerElement={
259
+ <Tooltip
260
+ content={t('auto-patterns.fields.more_actions_tooltip')}
261
+ appendTo="window"
262
+ >
263
+ <IconButton
264
+ ref={moreButtonRef}
265
+ size="tiny"
266
+ priority="tertiary"
267
+ dataHook="video-edit-more-button"
268
+ >
269
+ <MoreSmall />
270
+ </IconButton>
271
+ </Tooltip>
272
+ }
273
+ >
274
+ <PopoverMenu.MenuItem
275
+ dataHook="video-edit-action-change"
276
+ text={t('CMS.video.change')}
277
+ prefixIcon={<Replace />}
278
+ onClick={handleCallMedia}
279
+ />
280
+ <PopoverMenu.Divider />
281
+ <PopoverMenu.MenuItem
282
+ dataHook="video-edit-action-preview"
283
+ text={t('CMS.video.preview')}
284
+ prefixIcon={<Maximize />}
285
+ onClick={() => setIsPreviewOpen(true)}
286
+ />
287
+ <PopoverMenu.MenuItem
288
+ dataHook="video-edit-action-download"
289
+ text={t('CMS.video.download')}
290
+ prefixIcon={<Download />}
291
+ onClick={handleDownload}
292
+ />
293
+ <PopoverMenu.Divider />
294
+ <PopoverMenu.MenuItem
295
+ dataHook="video-edit-action-delete"
296
+ text={t('CMS.video.delete')}
297
+ skin="destructive"
298
+ prefixIcon={<Delete />}
299
+ onClick={handleDelete}
300
+ />
301
+ </PopoverMenu>
302
+ ) : null}
303
+ </Box>
304
+ </div>
305
+ );
306
+ };
307
+
308
+ CellVideoEdit.displayName = 'CellVideoEdit';
@@ -1,2 +1,4 @@
1
1
  export { VideoView } from './video-view';
2
2
  export type { VideoViewProps } from './video-view';
3
+ export { CellVideoEdit } from './cell-video-edit';
4
+ export type { CellVideoEditProps } from './cell-video-edit';
@@ -0,0 +1,4 @@
1
+ export {
2
+ CellRichContentInput,
3
+ CellRichContentInputProps,
4
+ } from '../components/rich-content/cell-rich-content-input';
@@ -1,5 +1 @@
1
- export {
2
- FormRichContentInput,
3
- CellRichContentInput,
4
- } from '../components/rich-content/editor';
5
- export type { CellRichContentInputProps } from '../components/rich-content/editor';
1
+ export { FormRichContentInput } from '../components/rich-content/rich-content-input/form-input/form-input';
@@ -6,3 +6,4 @@ export * from './use-open-state';
6
6
  export * from './use-translations';
7
7
  export * from './use-with-callback';
8
8
  export * from './use-resize-effect';
9
+ export * from './use-cell-edit-keyboard';
@@ -0,0 +1,109 @@
1
+ import { useCallback, useEffect } from 'react';
2
+ import React from 'react';
3
+
4
+ interface UseCellEditKeyboardOptions {
5
+ containerRef: React.RefObject<HTMLDivElement | null>;
6
+ onCancel?: () => void;
7
+ inputRef?: React.MutableRefObject<{ focus: () => void } | null | undefined>;
8
+ }
9
+
10
+ interface UseCellEditKeyboardResult {
11
+ handleContainerFocus: () => void;
12
+ handleContainerBlur: (e: React.FocusEvent) => void;
13
+ }
14
+
15
+ /**
16
+ * Shared keyboard/focus wiring for cell-edit components that contain buttons.
17
+ *
18
+ * - Wires inputRef so the parent table can focus the first button on Enter.
19
+ * - Sets/removes data-inner-focused on the container for CSS styling.
20
+ * - Native keydown handler: Escape → onCancel + return focus to gridcell;
21
+ * Tab / Shift+Tab → cycle through buttons, Tab off last returns to gridcell.
22
+ *
23
+ * Must use a native listener (not React onKeyDown) so stopPropagation fires
24
+ * before the React root's useKeyboardNavigation intercepts Tab.
25
+ */
26
+ export function useCellEditKeyboard({
27
+ containerRef,
28
+ onCancel,
29
+ inputRef,
30
+ }: UseCellEditKeyboardOptions): UseCellEditKeyboardResult {
31
+ useEffect(() => {
32
+ if (!inputRef) return;
33
+ inputRef.current = {
34
+ focus: () => {
35
+ const first =
36
+ containerRef.current?.querySelectorAll<HTMLElement>('button')[0];
37
+ first?.focus();
38
+ },
39
+ };
40
+ return () => {
41
+ inputRef.current = null;
42
+ };
43
+ }, [inputRef, containerRef]);
44
+
45
+ const handleContainerFocus = useCallback(() => {
46
+ containerRef.current?.setAttribute('data-inner-focused', '');
47
+ }, [containerRef]);
48
+
49
+ const handleContainerBlur = useCallback(
50
+ (e: React.FocusEvent) => {
51
+ if (!e.currentTarget.contains(e.relatedTarget as Node | null)) {
52
+ containerRef.current?.removeAttribute('data-inner-focused');
53
+ }
54
+ },
55
+ [containerRef],
56
+ );
57
+
58
+ const focusCell = useCallback(() => {
59
+ const cellDiv = containerRef.current?.closest(
60
+ '[role="gridcell"]',
61
+ ) as HTMLElement | null;
62
+ cellDiv?.focus({ preventScroll: true });
63
+ }, [containerRef]);
64
+
65
+ useEffect(() => {
66
+ const el = containerRef.current;
67
+ if (!el) return;
68
+
69
+ const handleKeyDown = (e: KeyboardEvent) => {
70
+ if (e.key === 'Escape') {
71
+ e.preventDefault();
72
+ e.stopPropagation();
73
+ onCancel?.();
74
+ focusCell();
75
+ return;
76
+ }
77
+
78
+ if (e.key === 'Tab') {
79
+ const buttons = Array.from(el.querySelectorAll<HTMLElement>('button'));
80
+ const currentIdx = buttons.indexOf(
81
+ document.activeElement as HTMLElement,
82
+ );
83
+ if (currentIdx === -1) return;
84
+
85
+ e.preventDefault();
86
+ e.stopPropagation();
87
+
88
+ if (!e.shiftKey) {
89
+ if (currentIdx >= buttons.length - 1) {
90
+ focusCell();
91
+ } else {
92
+ buttons[currentIdx + 1]?.focus();
93
+ }
94
+ } else {
95
+ if (currentIdx <= 0) {
96
+ focusCell();
97
+ } else {
98
+ buttons[currentIdx - 1]?.focus();
99
+ }
100
+ }
101
+ }
102
+ };
103
+
104
+ el.addEventListener('keydown', handleKeyDown);
105
+ return () => el.removeEventListener('keydown', handleKeyDown);
106
+ }, [focusCell, onCancel, containerRef]);
107
+
108
+ return { handleContainerFocus, handleContainerBlur };
109
+ }
package/src/index.ts CHANGED
@@ -3,3 +3,4 @@ export * from './hooks';
3
3
  export * from './services';
4
4
  export * from './types';
5
5
  export * from './utils';
6
+ export { HTMLToText } from './auto-field-types';
@@ -67,7 +67,6 @@ export type TranslationsKeys =
67
67
  | 'CMS.richTextEditor.toolbar.headerDropdown.option.p3.subtitle'
68
68
  | 'CMS.richTextEditor.toolbar.headerDropdown.option.p3.title'
69
69
  | 'CMS.richTextEditor.toolbar.headerDropdown.button.info'
70
- | 'CMS.richTextEditor.toolbar.headerDropdown.button.info.link'
71
70
  | 'CMS.richTextEditor.toolbar.headerDropdown.help.text'
72
71
  | 'CMS.richTextEditor.toolbar.button.tooltip.align'
73
72
  | 'CMS.richTextEditor.toolbar.button.tooltip.bold'
@@ -158,6 +157,11 @@ export type TranslationsKeys =
158
157
  | 'CMS.image.replaceWithUrl.title'
159
158
  | 'CMS.image.download'
160
159
  | 'CMS.image.clear'
160
+ | 'CMS.video.add'
161
+ | 'CMS.video.change'
162
+ | 'CMS.video.preview'
163
+ | 'CMS.video.download'
164
+ | 'CMS.video.delete'
161
165
  | 'CMS.document.delete.title'
162
166
  | 'CMS.document.delete.message'
163
167
  | 'auto-patterns.fields.type_mismatch_convert'