@gravity-ui/markdown-editor 15.19.0 → 15.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 (264) hide show
  1. package/build/cjs/bundle/config/action-names.d.ts +1 -1
  2. package/build/cjs/bundle/toolbar/ToolbarButtonWithPopupMenu.d.ts +2 -2
  3. package/build/cjs/bundle/toolbar/ToolbarButtonWithPopupMenu.js.map +1 -1
  4. package/build/cjs/bundle/toolbar/custom/ToolbarColors.js +1 -1
  5. package/build/cjs/bundle/toolbar/custom/ToolbarColors.js.map +1 -1
  6. package/build/cjs/bundle/wysiwyg-preset.js +5 -1
  7. package/build/cjs/bundle/wysiwyg-preset.js.map +1 -1
  8. package/build/cjs/extensions/markdown/Lists/ListsSpecs/schema.js +2 -3
  9. package/build/cjs/extensions/markdown/Lists/ListsSpecs/schema.js.map +1 -1
  10. package/build/cjs/extensions/yfm/YfmTable/index.d.ts +15 -1
  11. package/build/cjs/extensions/yfm/YfmTable/index.js +4 -2
  12. package/build/cjs/extensions/yfm/YfmTable/index.js.map +1 -1
  13. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/actions.d.ts +6 -0
  14. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/actions.js +5 -8
  15. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/actions.js.map +1 -1
  16. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/clear-cells.d.ts +7 -0
  17. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/clear-cells.js +41 -0
  18. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/clear-cells.js.map +1 -0
  19. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-column.d.ts +6 -0
  20. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-column.js +59 -0
  21. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-column.js.map +1 -0
  22. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-row.d.ts +6 -0
  23. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-row.js +54 -0
  24. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-row.js.map +1 -0
  25. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-column-range.d.ts +6 -0
  26. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-column-range.js +77 -0
  27. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-column-range.js.map +1 -0
  28. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-row-range.d.ts +6 -0
  29. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-row-range.js +74 -0
  30. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-row-range.js.map +1 -0
  31. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.d.ts +10 -0
  32. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.js +45 -0
  33. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.js.map +1 -0
  34. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/index.d.ts +1 -0
  35. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/index.js +5 -0
  36. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/index.js.map +1 -0
  37. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.d.ts +15 -0
  38. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.js +67 -0
  39. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.js.map +1 -0
  40. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/index.d.ts +1 -0
  41. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/index.js +5 -0
  42. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/index.js.map +1 -0
  43. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/FloatingPlusButton.d.ts +4 -0
  44. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/FloatingPlusButton.js +26 -0
  45. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/FloatingPlusButton.js.map +1 -0
  46. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/InsertCursor.d.ts +6 -0
  47. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/InsertCursor.js +68 -0
  48. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/InsertCursor.js.map +1 -0
  49. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.d.ts +6 -0
  50. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.js +26 -0
  51. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.js.map +1 -0
  52. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/index.d.ts +1 -0
  53. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/index.js +5 -0
  54. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/index.js.map +1 -0
  55. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/FloatingPlusControl.d.ts +9 -0
  56. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/FloatingPlusControl.js +38 -0
  57. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/FloatingPlusControl.js.map +1 -0
  58. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/index.d.ts +1 -0
  59. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/index.js +5 -0
  60. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/index.js.map +1 -0
  61. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.css +14 -0
  62. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.d.ts +13 -0
  63. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.js +58 -0
  64. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.js.map +1 -0
  65. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/index.d.ts +1 -0
  66. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/index.js +5 -0
  67. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/index.js.map +1 -0
  68. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/const.d.ts +13 -0
  69. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/const.js +18 -0
  70. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/const.js.map +1 -0
  71. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-drop-cursor.d.ts +36 -0
  72. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-drop-cursor.js +144 -0
  73. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-drop-cursor.js.map +1 -0
  74. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.css +19 -0
  75. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.d.ts +31 -0
  76. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.js +467 -0
  77. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.js.map +1 -0
  78. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/index.d.ts +12 -0
  79. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/index.js +11 -0
  80. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/index.js.map +1 -0
  81. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.d.ts +6 -0
  82. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.js +288 -0
  83. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.js.map +1 -0
  84. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-view.css +4 -0
  85. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-view.d.ts +3 -0
  86. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-view.js +100 -0
  87. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-view.js.map +1 -0
  88. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.d.ts +23 -0
  89. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.js +119 -0
  90. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.js.map +1 -0
  91. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/focus-plugin.d.ts +17 -0
  92. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/focus-plugin.js +158 -0
  93. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/focus-plugin.js.map +1 -0
  94. package/build/cjs/i18n/yfm-table/en.json +3 -0
  95. package/build/cjs/i18n/yfm-table/index.d.ts +4 -1
  96. package/build/cjs/i18n/yfm-table/ru.json +3 -0
  97. package/build/cjs/icons/index.d.ts +2 -5
  98. package/build/cjs/icons/index.js +5 -8
  99. package/build/cjs/icons/index.js.map +1 -1
  100. package/build/cjs/lodash.d.ts +3 -1
  101. package/build/cjs/lodash.js +5 -1
  102. package/build/cjs/lodash.js.map +1 -1
  103. package/build/cjs/table-utils/table-desc.d.ts +50 -6
  104. package/build/cjs/table-utils/table-desc.js +196 -3
  105. package/build/cjs/table-utils/table-desc.js.map +1 -1
  106. package/build/cjs/toolbar/ToolbarButtonPopup.js +2 -2
  107. package/build/cjs/toolbar/ToolbarButtonPopup.js.map +1 -1
  108. package/build/cjs/toolbar/ToolbarListButton.js +1 -1
  109. package/build/cjs/toolbar/ToolbarListButton.js.map +1 -1
  110. package/build/cjs/version.js +1 -1
  111. package/build/cjs/version.js.map +1 -1
  112. package/build/esm/bundle/config/action-names.d.ts +1 -1
  113. package/build/esm/bundle/toolbar/ToolbarButtonWithPopupMenu.d.ts +2 -2
  114. package/build/esm/bundle/toolbar/ToolbarButtonWithPopupMenu.js.map +1 -1
  115. package/build/esm/bundle/toolbar/custom/ToolbarColors.js +1 -1
  116. package/build/esm/bundle/toolbar/custom/ToolbarColors.js.map +1 -1
  117. package/build/esm/bundle/wysiwyg-preset.js +5 -1
  118. package/build/esm/bundle/wysiwyg-preset.js.map +1 -1
  119. package/build/esm/extensions/markdown/Lists/ListsSpecs/schema.js +2 -3
  120. package/build/esm/extensions/markdown/Lists/ListsSpecs/schema.js.map +1 -1
  121. package/build/esm/extensions/yfm/YfmTable/index.d.ts +15 -1
  122. package/build/esm/extensions/yfm/YfmTable/index.js +4 -2
  123. package/build/esm/extensions/yfm/YfmTable/index.js.map +1 -1
  124. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/actions.d.ts +7 -1
  125. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/actions.js +2 -6
  126. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/actions.js.map +1 -1
  127. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/clear-cells.d.ts +7 -0
  128. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/clear-cells.js +37 -0
  129. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/clear-cells.js.map +1 -0
  130. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-column.d.ts +6 -0
  131. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-column.js +55 -0
  132. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-column.js.map +1 -0
  133. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-row.d.ts +6 -0
  134. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-row.js +50 -0
  135. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/insert-empty-row.js.map +1 -0
  136. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-column-range.d.ts +6 -0
  137. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-column-range.js +73 -0
  138. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-column-range.js.map +1 -0
  139. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-row-range.d.ts +6 -0
  140. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-row-range.js +70 -0
  141. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/commands/remove-row-range.js.map +1 -0
  142. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.d.ts +10 -0
  143. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.js +41 -0
  144. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.js.map +1 -0
  145. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/index.d.ts +1 -0
  146. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/index.js +2 -0
  147. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/index.js.map +1 -0
  148. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.d.ts +15 -0
  149. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.js +63 -0
  150. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.js.map +1 -0
  151. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/index.d.ts +1 -0
  152. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/index.js +2 -0
  153. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/index.js.map +1 -0
  154. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/FloatingPlusButton.d.ts +4 -0
  155. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/FloatingPlusButton.js +22 -0
  156. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/FloatingPlusButton.js.map +1 -0
  157. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/InsertCursor.d.ts +6 -0
  158. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/InsertCursor.js +64 -0
  159. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/InsertCursor.js.map +1 -0
  160. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.d.ts +6 -0
  161. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.js +22 -0
  162. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.js.map +1 -0
  163. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/index.d.ts +1 -0
  164. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/index.js +2 -0
  165. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/index.js.map +1 -0
  166. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/FloatingPlusControl.d.ts +9 -0
  167. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/FloatingPlusControl.js +35 -0
  168. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/FloatingPlusControl.js.map +1 -0
  169. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/index.d.ts +1 -0
  170. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/index.js +2 -0
  171. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/index.js.map +1 -0
  172. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.css +14 -0
  173. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.d.ts +13 -0
  174. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.js +54 -0
  175. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.js.map +1 -0
  176. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/index.d.ts +1 -0
  177. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/index.js +2 -0
  178. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/index.js.map +1 -0
  179. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/const.d.ts +13 -0
  180. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/const.js +15 -0
  181. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/const.js.map +1 -0
  182. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-drop-cursor.d.ts +36 -0
  183. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-drop-cursor.js +139 -0
  184. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-drop-cursor.js.map +1 -0
  185. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.css +19 -0
  186. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.d.ts +31 -0
  187. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.js +463 -0
  188. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.js.map +1 -0
  189. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/index.d.ts +12 -0
  190. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/index.js +7 -0
  191. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/index.js.map +1 -0
  192. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.d.ts +6 -0
  193. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.js +284 -0
  194. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.js.map +1 -0
  195. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-view.css +4 -0
  196. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-view.d.ts +3 -0
  197. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-view.js +96 -0
  198. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-view.js.map +1 -0
  199. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.d.ts +23 -0
  200. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.js +108 -0
  201. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.js.map +1 -0
  202. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/focus-plugin.d.ts +17 -0
  203. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/focus-plugin.js +153 -0
  204. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/focus-plugin.js.map +1 -0
  205. package/build/esm/i18n/yfm-table/en.json +3 -0
  206. package/build/esm/i18n/yfm-table/index.d.ts +4 -1
  207. package/build/esm/i18n/yfm-table/ru.json +3 -0
  208. package/build/esm/icons/index.d.ts +2 -5
  209. package/build/esm/icons/index.js +4 -7
  210. package/build/esm/icons/index.js.map +1 -1
  211. package/build/esm/lodash.d.ts +3 -1
  212. package/build/esm/lodash.js +3 -1
  213. package/build/esm/lodash.js.map +1 -1
  214. package/build/esm/table-utils/table-desc.d.ts +50 -6
  215. package/build/esm/table-utils/table-desc.js +196 -3
  216. package/build/esm/table-utils/table-desc.js.map +1 -1
  217. package/build/esm/toolbar/ToolbarButtonPopup.js +2 -2
  218. package/build/esm/toolbar/ToolbarButtonPopup.js.map +1 -1
  219. package/build/esm/toolbar/ToolbarListButton.js +1 -1
  220. package/build/esm/toolbar/ToolbarListButton.js.map +1 -1
  221. package/build/esm/version.js +1 -1
  222. package/build/esm/version.js.map +1 -1
  223. package/build/styles.css +31 -116
  224. package/package.json +2 -2
  225. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/buttons.d.ts +0 -14
  226. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/buttons.js +0 -97
  227. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/buttons.js.map +0 -1
  228. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/view.css +0 -85
  229. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/view.d.ts +0 -4
  230. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/view.js +0 -62
  231. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/view.js.map +0 -1
  232. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/yfmTableCellView.css +0 -37
  233. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/yfmTableCellView.d.ts +0 -4
  234. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/yfmTableCellView.js +0 -212
  235. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/yfmTableCellView.js.map +0 -1
  236. package/build/cjs/icons/Mermaid.d.ts +0 -3
  237. package/build/cjs/icons/Mermaid.js +0 -11
  238. package/build/cjs/icons/Mermaid.js.map +0 -1
  239. package/build/cjs/icons/Mono.d.ts +0 -3
  240. package/build/cjs/icons/Mono.js +0 -6
  241. package/build/cjs/icons/Mono.js.map +0 -1
  242. package/build/cjs/icons/Tabs.d.ts +0 -3
  243. package/build/cjs/icons/Tabs.js +0 -6
  244. package/build/cjs/icons/Tabs.js.map +0 -1
  245. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/buttons.d.ts +0 -14
  246. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/buttons.js +0 -95
  247. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/buttons.js.map +0 -1
  248. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/view.css +0 -85
  249. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/view.d.ts +0 -4
  250. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/view.js +0 -58
  251. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/view.js.map +0 -1
  252. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/yfmTableCellView.css +0 -37
  253. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/yfmTableCellView.d.ts +0 -4
  254. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/yfmTableCellView.js +0 -208
  255. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/yfmTableCellView.js.map +0 -1
  256. package/build/esm/icons/Mermaid.d.ts +0 -3
  257. package/build/esm/icons/Mermaid.js +0 -9
  258. package/build/esm/icons/Mermaid.js.map +0 -1
  259. package/build/esm/icons/Mono.d.ts +0 -3
  260. package/build/esm/icons/Mono.js +0 -4
  261. package/build/esm/icons/Mono.js.map +0 -1
  262. package/build/esm/icons/Tabs.d.ts +0 -3
  263. package/build/esm/icons/Tabs.js +0 -4
  264. package/build/esm/icons/Tabs.js.map +0 -1
@@ -0,0 +1,6 @@
1
+ import { type QAProps } from '@gravity-ui/uikit';
2
+ export type PlusButtonProps = QAProps & {
3
+ onClick: () => void;
4
+ onHoverChange: (hover: boolean) => void;
5
+ };
6
+ export declare const PlusButton: React.FC<PlusButtonProps>;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PlusButton = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const icons_1 = require("@gravity-ui/icons");
7
+ const uikit_1 = require("@gravity-ui/uikit");
8
+ const react_utils_1 = require("../../../../../../../react-utils/index.js");
9
+ const PlusButton = function YfmTablePlusButton({ qa, onClick, onHoverChange, }) {
10
+ const [hovered, setHovered, unsetHovered] = (0, react_utils_1.useBooleanState)(false);
11
+ (0, react_1.useEffect)(() => {
12
+ onHoverChange(hovered);
13
+ }, [hovered, onHoverChange]);
14
+ return ((0, jsx_runtime_1.jsx)(uikit_1.Flex, { centerContent: true, width: 20, height: 20, onMouseEnter: setHovered, onMouseLeave: unsetHovered, style: {
15
+ borderRadius: '100px', // button circle border radius
16
+ backgroundColor: hovered ? 'var(--g-color-base-background)' : undefined,
17
+ }, children: (0, jsx_runtime_1.jsx)(uikit_1.Button, { qa: qa, size: "xs", pin: "circle-circle", view: hovered ? 'outlined-action' : 'normal', onClick: onClick, style: {
18
+ '--g-button-height': hovered ? undefined : '4px',
19
+ '--_--background-color-hover': hovered
20
+ ? 'var(--g-color-base-background)'
21
+ : undefined,
22
+ color: hovered ? undefined : 'var(--g-color-base-generic)',
23
+ }, children: (0, jsx_runtime_1.jsx)(uikit_1.Icon, { data: icons_1.Plus }) }) }));
24
+ };
25
+ exports.PlusButton = PlusButton;
26
+ //# sourceMappingURL=PlusButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PlusButton.js","sourceRoot":"../../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.tsx"],"names":[],"mappings":";;;;AAAA,iCAAgC;AAEhC,6CAAmD;AACnD,6CAAmE;AAEnE,2EAAgD;AAOzC,MAAM,UAAU,GAA8B,SAAS,kBAAkB,CAAC,EAC7E,EAAE,EACF,OAAO,EACP,aAAa,GAChB;IACG,MAAM,CAAC,OAAO,EAAE,UAAU,EAAE,YAAY,CAAC,GAAG,IAAA,6BAAe,EAAC,KAAK,CAAC,CAAC;IACnE,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,aAAa,CAAC,OAAO,CAAC,CAAC;IAC3B,CAAC,EAAE,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;IAE7B,OAAO,CACH,uBAAC,YAAI,IACD,aAAa,QACb,KAAK,EAAE,EAAE,EACT,MAAM,EAAE,EAAE,EACV,YAAY,EAAE,UAAU,EACxB,YAAY,EAAE,YAAY,EAC1B,KAAK,EAAE;YACH,YAAY,EAAE,OAAO,EAAE,8BAA8B;YACrD,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC,SAAS;SAC1E,YAED,uBAAC,cAAM,IACH,EAAE,EAAE,EAAE,EACN,IAAI,EAAC,IAAI,EACT,GAAG,EAAC,eAAe,EACnB,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,QAAQ,EAC5C,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE;gBACH,mBAAmB,EAAE,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK;gBAChD,6BAA6B,EAAE,OAAO;oBAClC,CAAC,CAAC,gCAAgC;oBAClC,CAAC,CAAC,SAAS;gBACf,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,6BAA6B;aAC7D,YAED,uBAAC,YAAI,IAAC,IAAI,EAAE,YAAQ,GAAI,GACnB,GACN,CACV,CAAC;AACN,CAAC,CAAC;AAxCW,QAAA,UAAU,cAwCrB","sourcesContent":["import {useEffect} from 'react';\n\nimport {Plus as PlusIcon} from '@gravity-ui/icons';\nimport {Button, Flex, Icon, type QAProps} from '@gravity-ui/uikit';\n\nimport {useBooleanState} from 'src/react-utils';\n\nexport type PlusButtonProps = QAProps & {\n onClick: () => void;\n onHoverChange: (hover: boolean) => void;\n};\n\nexport const PlusButton: React.FC<PlusButtonProps> = function YfmTablePlusButton({\n qa,\n onClick,\n onHoverChange,\n}) {\n const [hovered, setHovered, unsetHovered] = useBooleanState(false);\n useEffect(() => {\n onHoverChange(hovered);\n }, [hovered, onHoverChange]);\n\n return (\n <Flex\n centerContent\n width={20} // xs button\n height={20} // xs button\n onMouseEnter={setHovered}\n onMouseLeave={unsetHovered}\n style={{\n borderRadius: '100px', // button circle border radius\n backgroundColor: hovered ? 'var(--g-color-base-background)' : undefined,\n }}\n >\n <Button\n qa={qa}\n size=\"xs\"\n pin=\"circle-circle\"\n view={hovered ? 'outlined-action' : 'normal'}\n onClick={onClick}\n style={{\n '--g-button-height': hovered ? undefined : '4px',\n '--_--background-color-hover': hovered\n ? 'var(--g-color-base-background)'\n : undefined,\n color: hovered ? undefined : 'var(--g-color-base-generic)',\n }}\n >\n <Icon data={PlusIcon} />\n </Button>\n </Flex>\n );\n};\n"]}
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ tslib_1.__exportStar(require("./FloatingPlusButton.js"), exports);
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"../../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/index.ts"],"names":[],"mappings":";;;AAAA,kEAAqC","sourcesContent":["export * from './FloatingPlusButton';\n"]}
@@ -0,0 +1,9 @@
1
+ import { type FloatingPlusButtonProps } from "../FloatingPlusButton/index.js";
2
+ export type FloatingPlusControlProps = {
3
+ type: FloatingPlusButtonProps['type'];
4
+ index: number;
5
+ cellElem: Element;
6
+ tableElem: Element;
7
+ onClick: (rowIdx: number) => void;
8
+ };
9
+ export declare const FloatingPlusControl: import("react").NamedExoticComponent<FloatingPlusControlProps>;
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FloatingPlusControl = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const FloatingPlusButton_1 = require("../FloatingPlusButton/index.js");
7
+ exports.FloatingPlusControl = (0, react_1.memo)(function YfmTableRowFloatingPlusControl({ type, index, cellElem, tableElem, onClick }) {
8
+ const anchor = (0, react_1.useMemo)(() => ({
9
+ contextElement: tableElem,
10
+ getBoundingClientRect() {
11
+ const cellRect = cellElem.getBoundingClientRect();
12
+ const tableRect = tableElem.getBoundingClientRect();
13
+ return type === 'row'
14
+ ? {
15
+ x: tableRect.x,
16
+ y: cellRect.y,
17
+ width: tableRect.width,
18
+ height: cellRect.height,
19
+ top: cellRect.top,
20
+ left: tableRect.left,
21
+ right: tableRect.right,
22
+ bottom: cellRect.top,
23
+ }
24
+ : {
25
+ x: cellRect.x,
26
+ y: tableRect.y,
27
+ width: cellRect.width,
28
+ height: tableRect.height,
29
+ top: tableRect.top,
30
+ left: cellRect.left,
31
+ right: cellRect.right,
32
+ bottom: tableRect.top,
33
+ };
34
+ },
35
+ }), [cellElem, tableElem, type]);
36
+ return (0, jsx_runtime_1.jsx)(FloatingPlusButton_1.FloatingPlusButton, { anchor: anchor, type: type, onClick: () => onClick(index) });
37
+ });
38
+ //# sourceMappingURL=FloatingPlusControl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FloatingPlusControl.js","sourceRoot":"../../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/FloatingPlusControl.tsx"],"names":[],"mappings":";;;;AAAA,iCAAoC;AAKpC,uEAAuF;AAU1E,QAAA,mBAAmB,GAAG,IAAA,YAAI,EACnC,SAAS,8BAA8B,CAAC,EAAC,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAC;IAC/E,MAAM,MAAM,GAAG,IAAA,eAAO,EAClB,GAAG,EAAE,CAAC,CAAC;QACH,cAAc,EAAE,SAAS;QACzB,qBAAqB;YACjB,MAAM,QAAQ,GAAG,QAAQ,CAAC,qBAAqB,EAAE,CAAC;YAClD,MAAM,SAAS,GAAG,SAAS,CAAC,qBAAqB,EAAE,CAAC;YAEpD,OAAO,IAAI,KAAK,KAAK;gBACjB,CAAC,CAAC;oBACI,CAAC,EAAE,SAAS,CAAC,CAAC;oBACd,CAAC,EAAE,QAAQ,CAAC,CAAC;oBACb,KAAK,EAAE,SAAS,CAAC,KAAK;oBACtB,MAAM,EAAE,QAAQ,CAAC,MAAM;oBACvB,GAAG,EAAE,QAAQ,CAAC,GAAG;oBACjB,IAAI,EAAE,SAAS,CAAC,IAAI;oBACpB,KAAK,EAAE,SAAS,CAAC,KAAK;oBACtB,MAAM,EAAE,QAAQ,CAAC,GAAG;iBACvB;gBACH,CAAC,CAAC;oBACI,CAAC,EAAE,QAAQ,CAAC,CAAC;oBACb,CAAC,EAAE,SAAS,CAAC,CAAC;oBACd,KAAK,EAAE,QAAQ,CAAC,KAAK;oBACrB,MAAM,EAAE,SAAS,CAAC,MAAM;oBACxB,GAAG,EAAE,SAAS,CAAC,GAAG;oBAClB,IAAI,EAAE,QAAQ,CAAC,IAAI;oBACnB,KAAK,EAAE,QAAQ,CAAC,KAAK;oBACrB,MAAM,EAAE,SAAS,CAAC,GAAG;iBACxB,CAAC;QACZ,CAAC;KACJ,CAAC,EACF,CAAC,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,CAC9B,CAAC;IAEF,OAAO,uBAAC,uCAAkB,IAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,GAAI,CAAC;AAC7F,CAAC,CACJ,CAAC","sourcesContent":["import {memo, useMemo} from 'react';\n\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport type {VirtualElement} from '@floating-ui/dom';\n\nimport {FloatingPlusButton, type FloatingPlusButtonProps} from '../FloatingPlusButton';\n\nexport type FloatingPlusControlProps = {\n type: FloatingPlusButtonProps['type'];\n index: number;\n cellElem: Element;\n tableElem: Element;\n onClick: (rowIdx: number) => void;\n};\n\nexport const FloatingPlusControl = memo<FloatingPlusControlProps>(\n function YfmTableRowFloatingPlusControl({type, index, cellElem, tableElem, onClick}) {\n const anchor = useMemo<VirtualElement>(\n () => ({\n contextElement: tableElem,\n getBoundingClientRect() {\n const cellRect = cellElem.getBoundingClientRect();\n const tableRect = tableElem.getBoundingClientRect();\n\n return type === 'row'\n ? {\n x: tableRect.x,\n y: cellRect.y,\n width: tableRect.width,\n height: cellRect.height,\n top: cellRect.top,\n left: tableRect.left,\n right: tableRect.right,\n bottom: cellRect.top,\n }\n : {\n x: cellRect.x,\n y: tableRect.y,\n width: cellRect.width,\n height: tableRect.height,\n top: tableRect.top,\n left: cellRect.left,\n right: cellRect.right,\n bottom: tableRect.top,\n };\n },\n }),\n [cellElem, tableElem, type],\n );\n\n return <FloatingPlusButton anchor={anchor} type={type} onClick={() => onClick(index)} />;\n },\n);\n"]}
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ tslib_1.__exportStar(require("./FloatingPlusControl.js"), exports);
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"../../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusControl/index.ts"],"names":[],"mappings":";;;AAAA,mEAAsC","sourcesContent":["export * from './FloatingPlusControl';\n"]}
@@ -0,0 +1,14 @@
1
+ .g-md-yfm-table-floating-popup {
2
+ position: relative;
3
+ border-radius: var(--g-border-radius-xs);
4
+ outline: none;
5
+ background-color: var(--g-color-base-float);
6
+ }
7
+ .g-md-yfm-table-floating-popup > :first-child {
8
+ border-start-start-radius: inherit;
9
+ border-start-end-radius: inherit;
10
+ }
11
+ .g-md-yfm-table-floating-popup > :last-child {
12
+ border-end-end-radius: inherit;
13
+ border-end-start-radius: inherit;
14
+ }
@@ -0,0 +1,13 @@
1
+ import { type OffsetOptions, type Placement, type ReferenceType } from '@floating-ui/react';
2
+ import { type DOMProps, type QAProps } from '@gravity-ui/uikit';
3
+ import "./FloatingPopup.css";
4
+ export type FloatingPopupProps = QAProps & DOMProps & {
5
+ open?: boolean;
6
+ zIndex?: number;
7
+ placement: Placement;
8
+ offset?: OffsetOptions;
9
+ anchorElement: ReferenceType | undefined | null;
10
+ children: React.ReactNode;
11
+ floatingStyles?: React.CSSProperties;
12
+ };
13
+ export declare const FloatingPopup: React.FC<FloatingPopupProps>;
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FloatingPopup = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ ///
6
+ /// Fork of Popup component from @gravity-ui/uikit
7
+ /// This fork does not use floating focus manager
8
+ ///
9
+ const react_1 = require("react");
10
+ // eslint-disable-next-line import/no-extraneous-dependencies
11
+ const react_2 = require("@floating-ui/react");
12
+ const uikit_1 = require("@gravity-ui/uikit");
13
+ const classname_1 = require("../../../../../../../classname.js");
14
+ require("./FloatingPopup.css");
15
+ const b = (0, classname_1.cn)('yfm-table-floating-popup');
16
+ const FloatingPopup = function YfmTableFloatingPopup(props) {
17
+ const { anchorElement, zIndex = 1000, style, className, qa, children, floatingStyles: floatingStylesFromProps, } = props;
18
+ const nodeId = (0, react_2.useFloatingNodeId)();
19
+ const parentId = (0, react_2.useFloatingParentNodeId)();
20
+ const middleware = (0, react_1.useMemo)(() => [(0, react_2.offset)(props.offset)], [props.offset]);
21
+ const { refs, elements, floatingStyles, placement, context: { open }, update, } = (0, react_2.useFloating)({
22
+ nodeId,
23
+ open: props.open,
24
+ placement: props.placement,
25
+ middleware,
26
+ });
27
+ const { getFloatingProps } = (0, react_2.useInteractions)();
28
+ (0, react_1.useEffect)(() => {
29
+ if (anchorElement !== undefined && anchorElement !== refs.reference.current) {
30
+ refs.setReference(anchorElement);
31
+ }
32
+ }, [anchorElement, refs]);
33
+ (0, react_1.useEffect)(() => {
34
+ if (elements.reference && elements.floating) {
35
+ return (0, react_2.autoUpdate)(elements.reference, elements.floating, update);
36
+ }
37
+ return undefined;
38
+ }, [elements, update]);
39
+ function wrapper(node) {
40
+ if (parentId === null) {
41
+ return (0, jsx_runtime_1.jsx)(react_2.FloatingTree, { children: node });
42
+ }
43
+ return node;
44
+ }
45
+ return wrapper((0, jsx_runtime_1.jsx)(react_2.FloatingNode, { id: nodeId, children: open ? ((0, jsx_runtime_1.jsx)(uikit_1.Portal, { children: (0, jsx_runtime_1.jsx)("div", { ref: refs.setFloating, style: {
46
+ position: 'absolute',
47
+ top: 0,
48
+ left: 0,
49
+ zIndex,
50
+ width: 'max-content',
51
+ pointerEvents: 'auto',
52
+ outline: 'none',
53
+ ...floatingStylesFromProps,
54
+ ...floatingStyles,
55
+ }, "data-floating-ui-placement": placement, ...getFloatingProps(), children: (0, jsx_runtime_1.jsx)("div", { className: b(null, className), style: style, "data-qa": qa, children: children }) }) })) : null }));
56
+ };
57
+ exports.FloatingPopup = FloatingPopup;
58
+ //# sourceMappingURL=FloatingPopup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FloatingPopup.js","sourceRoot":"../../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/FloatingPopup.tsx"],"names":[],"mappings":";;;;AAAA,GAAG;AACH,kDAAkD;AAClD,iDAAiD;AACjD,GAAG;AAEH,iCAAyC;AAEzC,6DAA6D;AAC7D,8CAY4B;AAC5B,6CAAsE;AAEtE,iEAAiC;AAEjC,+BAA8B;AAE9B,MAAM,CAAC,GAAG,IAAA,cAAE,EAAC,0BAA0B,CAAC,CAAC;AAalC,MAAM,aAAa,GAAiC,SAAS,qBAAqB,CACrF,KAAyB;IAEzB,MAAM,EACF,aAAa,EACb,MAAM,GAAG,IAAI,EACb,KAAK,EACL,SAAS,EACT,EAAE,EACF,QAAQ,EACR,cAAc,EAAE,uBAAuB,GAC1C,GAAG,KAAK,CAAC;IAEV,MAAM,MAAM,GAAG,IAAA,yBAAiB,GAAE,CAAC;IACnC,MAAM,QAAQ,GAAG,IAAA,+BAAuB,GAAE,CAAC;IAE3C,MAAM,UAAU,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,CAAC,IAAA,cAAgB,EAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IAEnF,MAAM,EACF,IAAI,EACJ,QAAQ,EACR,cAAc,EACd,SAAS,EACT,OAAO,EAAE,EAAC,IAAI,EAAC,EACf,MAAM,GACT,GAAG,IAAA,mBAAW,EAAC;QACZ,MAAM;QACN,IAAI,EAAE,KAAK,CAAC,IAAI;QAChB,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,UAAU;KACb,CAAC,CAAC;IAEH,MAAM,EAAC,gBAAgB,EAAC,GAAG,IAAA,uBAAe,GAAE,CAAC;IAE7C,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,IAAI,aAAa,KAAK,SAAS,IAAI,aAAa,KAAK,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;YAC1E,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QACrC,CAAC;IACL,CAAC,EAAE,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC;IAE1B,IAAA,iBAAS,EAAC,GAAG,EAAE;QACX,IAAI,QAAQ,CAAC,SAAS,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC;YAC1C,OAAO,IAAA,kBAAU,EAAC,QAAQ,CAAC,SAAS,EAAE,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QACD,OAAO,SAAS,CAAC;IACrB,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC;IAEvB,SAAS,OAAO,CAAC,IAAiB;QAC9B,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;YACpB,OAAO,uBAAC,oBAAY,cAAE,IAAI,GAAgB,CAAC;QAC/C,CAAC;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,OAAO,OAAO,CACV,uBAAC,oBAAY,IAAC,EAAE,EAAE,MAAM,YACnB,IAAI,CAAC,CAAC,CAAC,CACJ,uBAAC,cAAM,cACH,gCACI,GAAG,EAAE,IAAI,CAAC,WAAW,EACrB,KAAK,EAAE;oBACH,QAAQ,EAAE,UAAU;oBACpB,GAAG,EAAE,CAAC;oBACN,IAAI,EAAE,CAAC;oBACP,MAAM;oBACN,KAAK,EAAE,aAAa;oBACpB,aAAa,EAAE,MAAM;oBACrB,OAAO,EAAE,MAAM;oBACf,GAAG,uBAAuB;oBAC1B,GAAG,cAAc;iBACpB,gCAC2B,SAAS,KACjC,gBAAgB,EAAE,YAEtB,gCAAK,SAAS,EAAE,CAAC,CAAC,IAAI,EAAE,SAAS,CAAC,EAAE,KAAK,EAAE,KAAK,aAAW,EAAE,YACxD,QAAQ,GACP,GACJ,GACD,CACZ,CAAC,CAAC,CAAC,IAAI,GACG,CAClB,CAAC;AACN,CAAC,CAAC;AAnFW,QAAA,aAAa,iBAmFxB","sourcesContent":["///\n/// Fork of Popup component from @gravity-ui/uikit\n/// This fork does not use floating focus manager\n///\n\nimport {useEffect, useMemo} from 'react';\n\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport {\n FloatingNode,\n FloatingTree,\n type OffsetOptions,\n type Placement,\n type ReferenceType,\n autoUpdate,\n offset as offsetMiddleware,\n useFloating,\n useFloatingNodeId,\n useFloatingParentNodeId,\n useInteractions,\n} from '@floating-ui/react';\nimport {type DOMProps, Portal, type QAProps} from '@gravity-ui/uikit';\n\nimport {cn} from 'src/classname';\n\nimport './FloatingPopup.scss';\n\nconst b = cn('yfm-table-floating-popup');\n\nexport type FloatingPopupProps = QAProps &\n DOMProps & {\n open?: boolean;\n zIndex?: number;\n placement: Placement;\n offset?: OffsetOptions;\n anchorElement: ReferenceType | undefined | null;\n children: React.ReactNode;\n floatingStyles?: React.CSSProperties;\n };\n\nexport const FloatingPopup: React.FC<FloatingPopupProps> = function YfmTableFloatingPopup(\n props: FloatingPopupProps,\n) {\n const {\n anchorElement,\n zIndex = 1000,\n style,\n className,\n qa,\n children,\n floatingStyles: floatingStylesFromProps,\n } = props;\n\n const nodeId = useFloatingNodeId();\n const parentId = useFloatingParentNodeId();\n\n const middleware = useMemo(() => [offsetMiddleware(props.offset)], [props.offset]);\n\n const {\n refs,\n elements,\n floatingStyles,\n placement,\n context: {open},\n update,\n } = useFloating({\n nodeId,\n open: props.open,\n placement: props.placement,\n middleware,\n });\n\n const {getFloatingProps} = useInteractions();\n\n useEffect(() => {\n if (anchorElement !== undefined && anchorElement !== refs.reference.current) {\n refs.setReference(anchorElement);\n }\n }, [anchorElement, refs]);\n\n useEffect(() => {\n if (elements.reference && elements.floating) {\n return autoUpdate(elements.reference, elements.floating, update);\n }\n return undefined;\n }, [elements, update]);\n\n function wrapper(node: JSX.Element) {\n if (parentId === null) {\n return <FloatingTree>{node}</FloatingTree>;\n }\n\n return node;\n }\n\n return wrapper(\n <FloatingNode id={nodeId}>\n {open ? (\n <Portal>\n <div\n ref={refs.setFloating}\n style={{\n position: 'absolute',\n top: 0,\n left: 0,\n zIndex,\n width: 'max-content',\n pointerEvents: 'auto',\n outline: 'none',\n ...floatingStylesFromProps,\n ...floatingStyles,\n }}\n data-floating-ui-placement={placement}\n {...getFloatingProps()}\n >\n <div className={b(null, className)} style={style} data-qa={qa}>\n {children}\n </div>\n </div>\n </Portal>\n ) : null}\n </FloatingNode>,\n );\n};\n"]}
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ tslib_1.__exportStar(require("./FloatingPopup.js"), exports);
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"../../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPopup/index.ts"],"names":[],"mappings":";;;AAAA,6DAAgC","sourcesContent":["export * from './FloatingPopup';\n"]}
@@ -0,0 +1,13 @@
1
+ export declare const YfmTableDecorationTypeKey = "__yfm-table-deco-type";
2
+ export declare const YfmTableDecorationUniqKey = "__yfm-table-deco-uniq-key";
3
+ export declare enum YfmTableDecorationType {
4
+ FocusTable = "table--focus",
5
+ ShowRowControl = "cell--show-row-control",// to show the row control in the cell
6
+ ShowColumnControl = "cell--show-column-control",// to show the column control in the cell
7
+ OpenRowMenu = "cell--open-row-menu",// sign of opening the row menu in the cell
8
+ OpenColumnMenu = "cell--open-column-menu",// sign of opening the column menu in the cell
9
+ ActivateRow = "row--active",
10
+ ActivateColumnCells = "cell--active-column",
11
+ ActivateDangerRow = "row--danger",
12
+ ActivateDangerColumnCells = "cell--danger-column"
13
+ }
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.YfmTableDecorationType = exports.YfmTableDecorationUniqKey = exports.YfmTableDecorationTypeKey = void 0;
4
+ exports.YfmTableDecorationTypeKey = '__yfm-table-deco-type';
5
+ exports.YfmTableDecorationUniqKey = '__yfm-table-deco-uniq-key';
6
+ var YfmTableDecorationType;
7
+ (function (YfmTableDecorationType) {
8
+ YfmTableDecorationType["FocusTable"] = "table--focus";
9
+ YfmTableDecorationType["ShowRowControl"] = "cell--show-row-control";
10
+ YfmTableDecorationType["ShowColumnControl"] = "cell--show-column-control";
11
+ YfmTableDecorationType["OpenRowMenu"] = "cell--open-row-menu";
12
+ YfmTableDecorationType["OpenColumnMenu"] = "cell--open-column-menu";
13
+ YfmTableDecorationType["ActivateRow"] = "row--active";
14
+ YfmTableDecorationType["ActivateColumnCells"] = "cell--active-column";
15
+ YfmTableDecorationType["ActivateDangerRow"] = "row--danger";
16
+ YfmTableDecorationType["ActivateDangerColumnCells"] = "cell--danger-column";
17
+ })(YfmTableDecorationType || (exports.YfmTableDecorationType = YfmTableDecorationType = {}));
18
+ //# sourceMappingURL=const.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"const.js","sourceRoot":"../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/const.ts"],"names":[],"mappings":";;;AAAa,QAAA,yBAAyB,GAAG,uBAAuB,CAAC;AACpD,QAAA,yBAAyB,GAAG,2BAA2B,CAAC;AAErE,IAAY,sBAcX;AAdD,WAAY,sBAAsB;IAC9B,qDAA2B,CAAA;IAE3B,mEAAyC,CAAA;IACzC,yEAA+C,CAAA;IAE/C,6DAAmC,CAAA;IACnC,mEAAyC,CAAA;IAEzC,qDAA2B,CAAA;IAC3B,qEAA2C,CAAA;IAE3C,2DAAiC,CAAA;IACjC,2EAAiD,CAAA;AACrD,CAAC,EAdW,sBAAsB,sCAAtB,sBAAsB,QAcjC","sourcesContent":["export const YfmTableDecorationTypeKey = '__yfm-table-deco-type';\nexport const YfmTableDecorationUniqKey = '__yfm-table-deco-uniq-key';\n\nexport enum YfmTableDecorationType {\n FocusTable = 'table--focus',\n\n ShowRowControl = 'cell--show-row-control', // to show the row control in the cell\n ShowColumnControl = 'cell--show-column-control', // to show the column control in the cell\n\n OpenRowMenu = 'cell--open-row-menu', // sign of opening the row menu in the cell\n OpenColumnMenu = 'cell--open-column-menu', // sign of opening the column menu in the cell\n\n ActivateRow = 'row--active',\n ActivateColumnCells = 'cell--active-column',\n\n ActivateDangerRow = 'row--danger',\n ActivateDangerColumnCells = 'cell--danger-column',\n}\n"]}
@@ -0,0 +1,36 @@
1
+ import type { EditorView } from "../../../../../../pm/view.js";
2
+ /** Same as `DropCursorOptions` from _prosemirror-dropcursor_ package */
3
+ export type DropCursorParams = {
4
+ /** The color of the cursor. Defaults to `black`. Use `false` to apply no color and rely only on class. */
5
+ color?: string | false;
6
+ /** The precise width of the cursor in pixels. Defaults to 1. */
7
+ width?: number;
8
+ /** A CSS class name to add to the cursor element. */
9
+ class?: string;
10
+ };
11
+ type Rect = {
12
+ left: number;
13
+ right: number;
14
+ top: number;
15
+ bottom: number;
16
+ };
17
+ export declare class DropCursor {
18
+ protected readonly editorView: EditorView;
19
+ protected readonly width: number;
20
+ protected readonly color: string | undefined;
21
+ protected readonly class: string | undefined;
22
+ protected cursorElem: HTMLElement | null;
23
+ private cursorPos;
24
+ constructor(editorView: EditorView, params?: DropCursorParams);
25
+ getPos(): number | null;
26
+ setPos(val: number): void;
27
+ clear(): void;
28
+ update(): void;
29
+ protected render(rect: Rect, { isBlock }: {
30
+ isBlock: boolean;
31
+ }): void;
32
+ }
33
+ export declare class TableColumnDropCursor extends DropCursor {
34
+ update(): void;
35
+ }
36
+ export {};
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TableColumnDropCursor = exports.DropCursor = void 0;
4
+ const utils_1 = require("../../../../../../pm/utils.js");
5
+ const table_utils_1 = require("../../../../../../table-utils/index.js");
6
+ class DropCursor {
7
+ editorView;
8
+ width;
9
+ color;
10
+ class;
11
+ cursorElem = null;
12
+ cursorPos = null;
13
+ constructor(editorView, params = {}) {
14
+ this.editorView = editorView;
15
+ this.width = params.width ?? 1;
16
+ this.color = params.color === false ? undefined : params.color || 'black';
17
+ this.class = params.class;
18
+ }
19
+ getPos() {
20
+ return this.cursorPos;
21
+ }
22
+ setPos(val) {
23
+ if (typeof val !== 'number' || isNaN(val))
24
+ throw new Error('"val" is not a number');
25
+ if (this.cursorPos === val)
26
+ return;
27
+ this.cursorPos = val;
28
+ this.update();
29
+ }
30
+ clear() {
31
+ this.cursorPos = null;
32
+ this.cursorElem?.remove();
33
+ this.cursorElem = null;
34
+ }
35
+ update() {
36
+ const { cursorPos } = this;
37
+ if (cursorPos === null)
38
+ return;
39
+ const $pos = this.editorView.state.doc.resolve(cursorPos);
40
+ const isBlock = !$pos.parent.inlineContent;
41
+ let rect;
42
+ if (isBlock) {
43
+ const before = $pos.nodeBefore, after = $pos.nodeAfter;
44
+ if (before || after) {
45
+ const node = this.editorView.nodeDOM(cursorPos - (before ? before.nodeSize : 0));
46
+ if (node) {
47
+ const nodeRect = node.getBoundingClientRect();
48
+ let top = before ? nodeRect.bottom : nodeRect.top;
49
+ if (before && after)
50
+ top =
51
+ (top +
52
+ this.editorView.nodeDOM(cursorPos).getBoundingClientRect().top) /
53
+ 2;
54
+ rect = {
55
+ left: nodeRect.left,
56
+ right: nodeRect.right,
57
+ top: top - this.width / 2,
58
+ bottom: top + this.width / 2,
59
+ };
60
+ }
61
+ }
62
+ }
63
+ if (!rect) {
64
+ const coords = this.editorView.coordsAtPos(cursorPos);
65
+ rect = {
66
+ left: coords.left - this.width / 2,
67
+ right: coords.left + this.width / 2,
68
+ top: coords.top,
69
+ bottom: coords.bottom,
70
+ };
71
+ }
72
+ this.render(rect, { isBlock });
73
+ }
74
+ render(rect, { isBlock }) {
75
+ const parent = this.editorView.dom.offsetParent;
76
+ if (!this.cursorElem) {
77
+ this.cursorElem = parent.appendChild(document.createElement('div'));
78
+ if (this.class)
79
+ this.cursorElem.className = this.class;
80
+ this.cursorElem.style.cssText =
81
+ 'position: absolute; z-index: 50; pointer-events: none;';
82
+ if (this.color) {
83
+ this.cursorElem.style.backgroundColor = this.color;
84
+ }
85
+ }
86
+ this.cursorElem.classList.toggle('prosemirror-dropcursor-block', isBlock);
87
+ this.cursorElem.classList.toggle('prosemirror-dropcursor-inline', !isBlock);
88
+ let parentLeft, parentTop;
89
+ if (!parent ||
90
+ (parent === document.body && getComputedStyle(parent).position === 'static')) {
91
+ parentLeft = -pageXOffset;
92
+ parentTop = -pageYOffset;
93
+ }
94
+ else {
95
+ const rect = parent.getBoundingClientRect();
96
+ parentLeft = rect.left - parent.scrollLeft;
97
+ parentTop = rect.top - parent.scrollTop;
98
+ }
99
+ this.cursorElem.style.left = rect.left - parentLeft + 'px';
100
+ this.cursorElem.style.top = rect.top - parentTop + 'px';
101
+ this.cursorElem.style.width = rect.right - rect.left + 'px';
102
+ this.cursorElem.style.height = rect.bottom - rect.top + 'px';
103
+ }
104
+ }
105
+ exports.DropCursor = DropCursor;
106
+ class TableColumnDropCursor extends DropCursor {
107
+ update() {
108
+ const cursorPos = this.getPos();
109
+ if (cursorPos === null)
110
+ return;
111
+ const $cursorPos = this.editorView.state.doc.resolve(cursorPos);
112
+ const parentTable = (0, utils_1.findParentNodeClosestToPos)($cursorPos, table_utils_1.isTableNode);
113
+ if (!parentTable)
114
+ return;
115
+ let side;
116
+ let tcellPos;
117
+ if ($cursorPos.nodeAfter && (0, table_utils_1.isTableCellNode)($cursorPos.nodeAfter)) {
118
+ side = 'left';
119
+ tcellPos = cursorPos;
120
+ }
121
+ else if ($cursorPos.nodeBefore && (0, table_utils_1.isTableCellNode)($cursorPos.nodeBefore)) {
122
+ side = 'right';
123
+ tcellPos = cursorPos - $cursorPos.nodeBefore.nodeSize;
124
+ }
125
+ else {
126
+ this.cursorElem?.remove();
127
+ this.cursorElem = null;
128
+ return;
129
+ }
130
+ const tdElem = this.editorView.nodeDOM(tcellPos);
131
+ const tableElem = this.editorView.nodeDOM(parentTable.pos);
132
+ const tdRect = tdElem.getBoundingClientRect();
133
+ const tableRect = tableElem.getBoundingClientRect();
134
+ const rect = {
135
+ left: tdRect[side] - this.width / 2,
136
+ right: tdRect[side] + this.width / 2,
137
+ top: tableRect.top,
138
+ bottom: tableRect.bottom,
139
+ };
140
+ this.render(rect, { isBlock: true });
141
+ }
142
+ }
143
+ exports.TableColumnDropCursor = TableColumnDropCursor;
144
+ //# sourceMappingURL=dnd-drop-cursor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dnd-drop-cursor.js","sourceRoot":"../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-drop-cursor.ts"],"names":[],"mappings":"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","sourcesContent":["import {findParentNodeClosestToPos} from '#pm/utils';\nimport type {EditorView} from '#pm/view';\nimport {isTableCellNode, isTableNode} from 'src/table-utils';\n\n/** Same as `DropCursorOptions` from _prosemirror-dropcursor_ package */\nexport type DropCursorParams = {\n /** The color of the cursor. Defaults to `black`. Use `false` to apply no color and rely only on class. */\n color?: string | false;\n\n /** The precise width of the cursor in pixels. Defaults to 1. */\n width?: number;\n\n /** A CSS class name to add to the cursor element. */\n class?: string;\n};\n\ntype Rect = {\n left: number;\n right: number;\n top: number;\n bottom: number;\n};\n\nexport class DropCursor {\n protected readonly editorView: EditorView;\n\n protected readonly width: number;\n protected readonly color: string | undefined;\n protected readonly class: string | undefined;\n\n protected cursorElem: HTMLElement | null = null;\n private cursorPos: number | null = null;\n\n constructor(editorView: EditorView, params: DropCursorParams = {}) {\n this.editorView = editorView;\n this.width = params.width ?? 1;\n this.color = params.color === false ? undefined : params.color || 'black';\n this.class = params.class;\n }\n\n getPos(): number | null {\n return this.cursorPos;\n }\n\n setPos(val: number) {\n if (typeof val !== 'number' || isNaN(val)) throw new Error('\"val\" is not a number');\n if (this.cursorPos === val) return;\n this.cursorPos = val;\n this.update();\n }\n\n clear() {\n this.cursorPos = null;\n this.cursorElem?.remove();\n this.cursorElem = null;\n }\n\n update() {\n const {cursorPos} = this;\n if (cursorPos === null) return;\n\n const $pos = this.editorView.state.doc.resolve(cursorPos);\n const isBlock = !$pos.parent.inlineContent;\n let rect: Rect | undefined;\n if (isBlock) {\n const before = $pos.nodeBefore,\n after = $pos.nodeAfter;\n if (before || after) {\n const node = this.editorView.nodeDOM(cursorPos - (before ? before.nodeSize : 0));\n if (node) {\n const nodeRect = (node as HTMLElement).getBoundingClientRect();\n let top = before ? nodeRect.bottom : nodeRect.top;\n if (before && after)\n top =\n (top +\n (\n this.editorView.nodeDOM(cursorPos) as HTMLElement\n ).getBoundingClientRect().top) /\n 2;\n rect = {\n left: nodeRect.left,\n right: nodeRect.right,\n top: top - this.width / 2,\n bottom: top + this.width / 2,\n };\n }\n }\n }\n if (!rect) {\n const coords = this.editorView.coordsAtPos(cursorPos);\n rect = {\n left: coords.left - this.width / 2,\n right: coords.left + this.width / 2,\n top: coords.top,\n bottom: coords.bottom,\n };\n }\n\n this.render(rect, {isBlock});\n }\n\n protected render(rect: Rect, {isBlock}: {isBlock: boolean}) {\n const parent = this.editorView.dom.offsetParent!;\n if (!this.cursorElem) {\n this.cursorElem = parent.appendChild(document.createElement('div'));\n if (this.class) this.cursorElem.className = this.class;\n this.cursorElem.style.cssText =\n 'position: absolute; z-index: 50; pointer-events: none;';\n if (this.color) {\n this.cursorElem.style.backgroundColor = this.color;\n }\n }\n this.cursorElem.classList.toggle('prosemirror-dropcursor-block', isBlock);\n this.cursorElem.classList.toggle('prosemirror-dropcursor-inline', !isBlock);\n let parentLeft, parentTop;\n if (\n !parent ||\n (parent === document.body && getComputedStyle(parent).position === 'static')\n ) {\n parentLeft = -pageXOffset;\n parentTop = -pageYOffset;\n } else {\n const rect = parent.getBoundingClientRect();\n parentLeft = rect.left - parent.scrollLeft;\n parentTop = rect.top - parent.scrollTop;\n }\n this.cursorElem.style.left = rect.left - parentLeft + 'px';\n this.cursorElem.style.top = rect.top - parentTop + 'px';\n this.cursorElem.style.width = rect.right - rect.left + 'px';\n this.cursorElem.style.height = rect.bottom - rect.top + 'px';\n }\n}\n\nexport class TableColumnDropCursor extends DropCursor {\n update() {\n const cursorPos = this.getPos();\n if (cursorPos === null) return;\n\n const $cursorPos = this.editorView.state.doc.resolve(cursorPos);\n const parentTable = findParentNodeClosestToPos($cursorPos, isTableNode);\n if (!parentTable) return;\n\n let side: 'left' | 'right';\n let tcellPos: number;\n if ($cursorPos.nodeAfter && isTableCellNode($cursorPos.nodeAfter)) {\n side = 'left';\n tcellPos = cursorPos;\n } else if ($cursorPos.nodeBefore && isTableCellNode($cursorPos.nodeBefore)) {\n side = 'right';\n tcellPos = cursorPos - $cursorPos.nodeBefore.nodeSize;\n } else {\n this.cursorElem?.remove();\n this.cursorElem = null;\n return;\n }\n\n const tdElem = this.editorView.nodeDOM(tcellPos);\n const tableElem = this.editorView.nodeDOM(parentTable.pos);\n\n const tdRect = (tdElem as HTMLElement).getBoundingClientRect();\n const tableRect = (tableElem as HTMLElement).getBoundingClientRect();\n\n const rect: Rect = {\n left: tdRect[side] - this.width / 2,\n right: tdRect[side] + this.width / 2,\n top: tableRect.top,\n bottom: tableRect.bottom,\n };\n this.render(rect, {isBlock: true});\n }\n}\n"]}
@@ -0,0 +1,19 @@
1
+ .g-md-yfm-table-dnd-cursor-background {
2
+ position: fixed;
3
+ z-index: 100500;
4
+ inset: 0;
5
+ overflow: hidden;
6
+ cursor: grabbing;
7
+ background: transparent;
8
+ }
9
+
10
+ .yfm.ProseMirror .g-md-yfm-table-dnd-dragged-row,
11
+ .yfm.ProseMirror .g-md-yfm-table-dnd-dragged-column-cell {
12
+ opacity: 0.3;
13
+ background-color: var(--g-color-base-selection);
14
+ }
15
+
16
+ .yfm.ProseMirror .g-md-yfm-table-active-row,
17
+ .yfm.ProseMirror .g-md-yfm-table-active-column-cell {
18
+ background-color: var(--g-color-base-selection);
19
+ }
@@ -0,0 +1,31 @@
1
+ import { type Node } from "../../../../../../pm/model.js";
2
+ import type { EditorView } from "../../../../../../pm/view.js";
3
+ import type { Logger2 } from "../../../../../../logger.js";
4
+ import { type DropCursorParams } from "./dnd-drop-cursor.js";
5
+ import "./dnd.css";
6
+ export type DnDControlHandler = {
7
+ canDrag(): boolean;
8
+ control_handleMouseDown: React.MouseEventHandler<HTMLButtonElement>;
9
+ control_handleMouseMove: React.MouseEventHandler<HTMLButtonElement>;
10
+ control_handleMouseUp: React.MouseEventHandler<HTMLButtonElement>;
11
+ };
12
+ interface TableHandler {
13
+ update(node: Node): void;
14
+ destroy(): void;
15
+ }
16
+ export type YfmTableDnDHandlerParams = {
17
+ cellNode: Node;
18
+ cellGetPos: () => number | undefined;
19
+ logger: Logger2.ILogger;
20
+ dropCursor?: DropCursorParams;
21
+ };
22
+ export declare class YfmTableDnDHandler implements TableHandler {
23
+ private readonly _rowHandler;
24
+ private readonly _columnHandler;
25
+ get row(): DnDControlHandler;
26
+ get column(): DnDControlHandler;
27
+ constructor(view: EditorView, params: YfmTableDnDHandlerParams);
28
+ update(node: Node): void;
29
+ destroy(): void;
30
+ }
31
+ export {};