@gravity-ui/markdown-editor 15.20.0 → 15.22.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 (114) hide show
  1. package/build/cjs/extensions/additional/FoldingHeading/plugins/folding.css +12 -9
  2. package/build/cjs/extensions/additional/Mermaid/MermaidNodeView/MermaidView.d.ts +2 -0
  3. package/build/cjs/extensions/additional/Mermaid/MermaidNodeView/MermaidView.js +11 -9
  4. package/build/cjs/extensions/additional/Mermaid/MermaidNodeView/MermaidView.js.map +1 -1
  5. package/build/cjs/extensions/additional/Mermaid/MermaidNodeView/NodeView.d.ts +1 -0
  6. package/build/cjs/extensions/additional/Mermaid/MermaidNodeView/NodeView.js +3 -1
  7. package/build/cjs/extensions/additional/Mermaid/MermaidNodeView/NodeView.js.map +1 -1
  8. package/build/cjs/extensions/additional/Mermaid/index.d.ts +4 -0
  9. package/build/cjs/extensions/additional/Mermaid/index.js +4 -4
  10. package/build/cjs/extensions/additional/Mermaid/index.js.map +1 -1
  11. package/build/cjs/extensions/additional/YfmHtmlBlock/YfmHtmlBlockNodeView/YfmHtmlBlockView.js +11 -8
  12. package/build/cjs/extensions/additional/YfmHtmlBlock/YfmHtmlBlockNodeView/YfmHtmlBlockView.js.map +1 -1
  13. package/build/cjs/extensions/additional/YfmHtmlBlock/index.d.ts +4 -0
  14. package/build/cjs/extensions/additional/YfmHtmlBlock/index.js.map +1 -1
  15. package/build/cjs/extensions/base/BaseSchema/BaseSchemaSpecs/index.js +2 -1
  16. package/build/cjs/extensions/base/BaseSchema/BaseSchemaSpecs/index.js.map +1 -1
  17. package/build/cjs/extensions/yfm/YfmConfigs/index.d.ts +5 -1
  18. package/build/cjs/extensions/yfm/YfmConfigs/index.js +7 -1
  19. package/build/cjs/extensions/yfm/YfmConfigs/index.js.map +1 -1
  20. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.d.ts +1 -1
  21. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.js.map +1 -1
  22. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.js +1 -0
  23. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.js.map +1 -1
  24. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.js +10 -7
  25. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.js.map +1 -1
  26. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/const.d.ts +2 -2
  27. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/const.js +2 -2
  28. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/const.js.map +1 -1
  29. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-ghost.d.ts +31 -0
  30. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-ghost.js +177 -0
  31. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-ghost.js.map +1 -0
  32. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.css +71 -6
  33. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.d.ts +1 -0
  34. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.js +40 -25
  35. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.js.map +1 -1
  36. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.js +4 -7
  37. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.js.map +1 -1
  38. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.d.ts +13 -4
  39. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.js +11 -9
  40. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.js.map +1 -1
  41. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/utils.d.ts +4 -0
  42. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/utils.js +50 -0
  43. package/build/cjs/extensions/yfm/YfmTable/plugins/YfmTableControls/utils.js.map +1 -0
  44. package/build/cjs/react-utils/hooks/useAutoSave.d.ts +23 -0
  45. package/build/cjs/react-utils/hooks/useAutoSave.js +59 -0
  46. package/build/cjs/react-utils/hooks/useAutoSave.js.map +1 -0
  47. package/build/cjs/react-utils/hooks.d.ts +1 -1
  48. package/build/cjs/react-utils/hooks.js +3 -1
  49. package/build/cjs/react-utils/hooks.js.map +1 -1
  50. package/build/cjs/version.js +1 -1
  51. package/build/cjs/version.js.map +1 -1
  52. package/build/cjs/view/components/YfmHtml/YfmStaticView.d.ts +13 -0
  53. package/build/cjs/view/components/YfmHtml/YfmStaticView.js +10 -4
  54. package/build/cjs/view/components/YfmHtml/YfmStaticView.js.map +1 -1
  55. package/build/cjs/view/components/YfmHtml/index.d.ts +1 -1
  56. package/build/cjs/view/components/YfmHtml/index.js.map +1 -1
  57. package/build/esm/extensions/additional/FoldingHeading/plugins/folding.css +12 -9
  58. package/build/esm/extensions/additional/Mermaid/MermaidNodeView/MermaidView.d.ts +2 -0
  59. package/build/esm/extensions/additional/Mermaid/MermaidNodeView/MermaidView.js +12 -10
  60. package/build/esm/extensions/additional/Mermaid/MermaidNodeView/MermaidView.js.map +1 -1
  61. package/build/esm/extensions/additional/Mermaid/MermaidNodeView/NodeView.d.ts +1 -0
  62. package/build/esm/extensions/additional/Mermaid/MermaidNodeView/NodeView.js +3 -1
  63. package/build/esm/extensions/additional/Mermaid/MermaidNodeView/NodeView.js.map +1 -1
  64. package/build/esm/extensions/additional/Mermaid/index.d.ts +4 -0
  65. package/build/esm/extensions/additional/Mermaid/index.js +4 -4
  66. package/build/esm/extensions/additional/Mermaid/index.js.map +1 -1
  67. package/build/esm/extensions/additional/YfmHtmlBlock/YfmHtmlBlockNodeView/YfmHtmlBlockView.js +12 -9
  68. package/build/esm/extensions/additional/YfmHtmlBlock/YfmHtmlBlockNodeView/YfmHtmlBlockView.js.map +1 -1
  69. package/build/esm/extensions/additional/YfmHtmlBlock/index.d.ts +4 -0
  70. package/build/esm/extensions/additional/YfmHtmlBlock/index.js.map +1 -1
  71. package/build/esm/extensions/base/BaseSchema/BaseSchemaSpecs/index.js +2 -1
  72. package/build/esm/extensions/base/BaseSchema/BaseSchemaSpecs/index.js.map +1 -1
  73. package/build/esm/extensions/yfm/YfmConfigs/index.d.ts +5 -1
  74. package/build/esm/extensions/yfm/YfmConfigs/index.js +7 -1
  75. package/build/esm/extensions/yfm/YfmConfigs/index.js.map +1 -1
  76. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.d.ts +1 -1
  77. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenu/FloatingMenu.js.map +1 -1
  78. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.js +1 -0
  79. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingMenuControl/FloatingMenuControl.js.map +1 -1
  80. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.js +10 -7
  81. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/components/FloatingPlusButton/PlusButton.js.map +1 -1
  82. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/const.d.ts +2 -2
  83. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/const.js +2 -2
  84. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/const.js.map +1 -1
  85. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-ghost.d.ts +31 -0
  86. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-ghost.js +173 -0
  87. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-ghost.js.map +1 -0
  88. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.css +71 -6
  89. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.d.ts +1 -0
  90. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.js +41 -26
  91. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.js.map +1 -1
  92. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.js +4 -7
  93. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/nodeviews/yfm-table-cell-view.js.map +1 -1
  94. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.d.ts +13 -4
  95. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.js +11 -9
  96. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/plugins/dnd-plugin.js.map +1 -1
  97. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/utils.d.ts +4 -0
  98. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/utils.js +46 -0
  99. package/build/esm/extensions/yfm/YfmTable/plugins/YfmTableControls/utils.js.map +1 -0
  100. package/build/esm/react-utils/hooks/useAutoSave.d.ts +23 -0
  101. package/build/esm/react-utils/hooks/useAutoSave.js +55 -0
  102. package/build/esm/react-utils/hooks/useAutoSave.js.map +1 -0
  103. package/build/esm/react-utils/hooks.d.ts +1 -1
  104. package/build/esm/react-utils/hooks.js +1 -0
  105. package/build/esm/react-utils/hooks.js.map +1 -1
  106. package/build/esm/version.js +1 -1
  107. package/build/esm/version.js.map +1 -1
  108. package/build/esm/view/components/YfmHtml/YfmStaticView.d.ts +13 -0
  109. package/build/esm/view/components/YfmHtml/YfmStaticView.js +9 -3
  110. package/build/esm/view/components/YfmHtml/YfmStaticView.js.map +1 -1
  111. package/build/esm/view/components/YfmHtml/index.d.ts +1 -1
  112. package/build/esm/view/components/YfmHtml/index.js.map +1 -1
  113. package/build/styles.css +83 -15
  114. package/package.json +1 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dnd-ghost.js","sourceRoot":"../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd-ghost.ts"],"names":[],"mappings":"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","sourcesContent":["import type {EditorView} from '#pm/view';\nimport type {TableDescBinded} from 'src/table-utils/table-desc';\n\ntype Event = Pick<MouseEvent, 'clientX' | 'clientY' | 'target'>;\n\ntype BuildGhostResult = {\n domElement: HTMLElement;\n shiftX: number;\n shiftY: number;\n};\n\nexport type YfmTableDnDGhostParams = {\n initial: Event;\n type: 'row' | 'column';\n rangeIdx: number;\n tableDesc: TableDescBinded;\n};\n\nexport class YfmTableDnDGhost {\n private _x: number;\n private _y: number;\n\n private readonly _dndBackgroundElem: HTMLElement;\n private readonly _ghostTable: HTMLElement;\n private readonly _ghostButton: HTMLElement | null = null;\n\n private readonly _tblShiftX: number;\n private readonly _tblShiftY: number;\n\n private readonly _btnShiftX: number = 0;\n private readonly _btnShiftY: number = 0;\n\n private _rafId: number;\n\n constructor(view: EditorView, params: YfmTableDnDGhostParams) {\n this._x = params.initial.clientX;\n this._y = params.initial.clientY;\n\n const document = view.dom.ownerDocument;\n\n this._dndBackgroundElem = document.createElement('div');\n this._dndBackgroundElem.classList.add('g-md-yfm-table-dnd-cursor-background');\n\n {\n const res = this._buildGhostButton(params);\n if (res) {\n this._ghostButton = res.domElement;\n this._btnShiftX = res.shiftX;\n this._btnShiftY = res.shiftY;\n this._dndBackgroundElem.appendChild(this._ghostButton);\n }\n }\n\n {\n const {domElement, shiftX, shiftY} =\n params.type === 'row'\n ? this._buildRowGhost(view, params)\n : this._buildColumnGhost(view, params);\n\n this._ghostTable = domElement;\n this._tblShiftX = shiftX;\n this._tblShiftY = shiftY;\n this._dndBackgroundElem.appendChild(this._ghostTable);\n }\n\n this._updatePositions();\n\n this._rafId = requestAnimationFrame(() => {\n document.body.append(this._dndBackgroundElem);\n this._startAnimation();\n });\n }\n\n move(event: Event) {\n this._x = event.clientX;\n this._y = event.clientY;\n }\n\n destroy() {\n cancelAnimationFrame(this._rafId);\n this._dndBackgroundElem.remove();\n }\n\n private _startAnimation() {\n const self = this;\n let last = {x: self._x, y: self._y};\n\n self._rafId = requestAnimationFrame(function update() {\n if (self._x !== last.x || self._y !== last.y) {\n last = {x: self._x, y: self._y};\n self._updatePositions();\n }\n self._rafId = requestAnimationFrame(update);\n });\n }\n\n private _updatePositions() {\n {\n const tx = this._x + this._tblShiftX;\n const ty = this._y + this._tblShiftY;\n this._ghostTable.style.transform = `translate(${tx}px, ${ty}px)`;\n }\n\n if (this._ghostButton) {\n const tx = this._x + this._btnShiftX;\n const ty = this._y + this._btnShiftY;\n this._ghostButton.style.transform = `translate(${tx}px, ${ty}px)`;\n }\n }\n\n private _buildRowGhost(\n view: EditorView,\n {tableDesc, rangeIdx}: YfmTableDnDGhostParams,\n ): BuildGhostResult {\n let shiftX = 0;\n let shiftY = 0;\n\n const document = view.dom.ownerDocument;\n const container = this._buildGhostContainer(view);\n\n const table = container.appendChild(document.createElement('table'));\n const tbody = table.appendChild(document.createElement('tbody'));\n\n {\n const tablePos = tableDesc.pos;\n const tableNode = view.domAtPos(tablePos + 1).node;\n const rect = (tableNode as Element).getBoundingClientRect();\n table.style.width = rect.width + 'px';\n }\n\n const range = tableDesc.base.getRowRanges()[rangeIdx];\n for (let rowIdx = range.startIdx; rowIdx <= range.endIdx; rowIdx++) {\n const tr = tbody.appendChild(document.createElement('tr'));\n\n for (let colIdx = 0; colIdx < tableDesc.cols; colIdx++) {\n const cellPos = tableDesc.getPosForCell(rowIdx, colIdx);\n if (cellPos.type === 'real') {\n const origNode = view.domAtPos(cellPos.from + 1).node as HTMLElement;\n const cloned = tr.appendChild(origNode.cloneNode(true));\n\n const rect = origNode.getBoundingClientRect();\n (cloned as HTMLElement).style.width = rect.width + 'px';\n (cloned as HTMLElement).style.height = rect.height + 'px';\n\n if (rowIdx === range.startIdx && colIdx === 0) {\n shiftX = rect.left - this._x;\n shiftY = rect.top - this._y;\n }\n }\n }\n }\n\n removeIdAttributes(table);\n\n return {domElement: container, shiftX, shiftY};\n }\n\n private _buildColumnGhost(\n view: EditorView,\n {tableDesc, rangeIdx}: YfmTableDnDGhostParams,\n ): BuildGhostResult {\n let shiftX = 0;\n let shiftY = 0;\n\n const document = view.dom.ownerDocument;\n const container = this._buildGhostContainer(view);\n\n {\n const tablePos = tableDesc.pos;\n const table = view.domAtPos(tablePos + 1).node;\n const rect = (table as Element).getBoundingClientRect();\n container.style.height = rect.height + 'px';\n }\n\n const table = container.appendChild(document.createElement('table'));\n const tbody = table.appendChild(document.createElement('tbody'));\n\n const range = tableDesc.base.getColumnRanges()[rangeIdx];\n for (let rowIdx = 0; rowIdx < tableDesc.rows; rowIdx++) {\n const tr = tbody.appendChild(document.createElement('tr'));\n\n for (let colIdx = range.startIdx; colIdx <= range.endIdx; colIdx++) {\n const cellPos = tableDesc.getPosForCell(rowIdx, colIdx);\n if (cellPos.type === 'real') {\n const origNode = view.domAtPos(cellPos.from + 1).node as HTMLElement;\n const cloned = tr.appendChild(origNode.cloneNode(true));\n\n const rect = origNode.getBoundingClientRect();\n (cloned as HTMLElement).style.width = rect.width + 'px';\n (cloned as HTMLElement).style.height = rect.height + 'px';\n\n if (rowIdx === 0 && colIdx === range.startIdx) {\n container.style.minWidth = rect.width + 'px';\n\n shiftX = rect.left - this._x;\n shiftY = rect.top - this._y;\n }\n }\n }\n }\n\n removeIdAttributes(table);\n\n return {domElement: container, shiftX, shiftY};\n }\n\n private _buildGhostButton({\n initial: {target},\n }: YfmTableDnDGhostParams): BuildGhostResult | null {\n if (!(target instanceof Element)) return null;\n\n const button = target.closest('.g-button');\n if (!button) return null;\n\n const container = button.ownerDocument.createElement('div');\n container.classList.add('g-md-yfm-table-dnd-ghost-button');\n\n const rect = button.getBoundingClientRect();\n const cloned = container.appendChild(button.cloneNode(true) as HTMLElement);\n\n removeIdAttributes(cloned);\n cloned.style.cursor = '';\n cloned.style.pointerEvents = 'none';\n\n return {\n domElement: container,\n shiftX: rect.left - this._x,\n shiftY: rect.top - this._y,\n };\n }\n\n private _buildGhostContainer(view: EditorView): HTMLElement {\n const container = view.dom.ownerDocument.createElement('div');\n container.setAttribute('aria-hidden', 'true');\n\n const yfmClasses = Array.from(view.dom.classList).filter((val) => val.startsWith('yfm_'));\n container.classList.add('g-md-yfm-table-dnd-ghost', 'yfm', ...yfmClasses);\n\n return container;\n }\n}\n\nfunction removeIdAttributes(elem: HTMLElement) {\n elem.removeAttribute('id');\n elem.querySelectorAll('[id]').forEach((el) => el.removeAttribute('id'));\n}\n"]}
@@ -7,13 +7,78 @@
7
7
  background: transparent;
8
8
  }
9
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);
10
+ .yfm.g-md-yfm-table-dnd-ghost,
11
+ .g-md-yfm-table-dnd-ghost-button {
12
+ position: fixed;
13
+ cursor: grabbing;
14
+ pointer-events: none;
15
+ transition: none;
16
+ will-change: transform;
17
+ }
18
+
19
+ .yfm.g-md-yfm-table-dnd-ghost > table {
20
+ border-color: var(--g-color-line-brand);
21
+ box-shadow: 0 8px 20px 1px var(--g-color-sfx-shadow);
22
+ }
23
+ .yfm.g-md-yfm-table-dnd-ghost > table > tbody > tr > td {
24
+ border-color: var(--g-color-line-brand);
25
+ }
26
+
27
+ .g-md-yfm-table-dnd-ghost-button {
28
+ --g-button-background-color-hover: var(--g-color-base-background);
29
+ --g-button-background-color: var(--g-color-base-background);
30
+ --g-button-border-color: var(--g-color-line-brand);
31
+ --g-button-text-color: var(--g-color-text-brand);
32
+ z-index: 2;
14
33
  }
15
34
 
16
- .yfm.ProseMirror .g-md-yfm-table-active-row,
17
- .yfm.ProseMirror .g-md-yfm-table-active-column-cell {
35
+ .yfm.ProseMirror table td {
36
+ position: relative;
37
+ }
38
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell {
39
+ overflow: unset;
40
+ border-color: var(--g-color-line-brand);
18
41
  background-color: var(--g-color-base-selection);
42
+ }
43
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell::after {
44
+ position: absolute;
45
+ z-index: 2;
46
+ inset: -1px;
47
+ display: inline-block;
48
+ content: "";
49
+ pointer-events: none;
50
+ border: 1px solid var(--g-color-line-brand);
51
+ }
52
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell_first-row::after {
53
+ top: 0;
54
+ }
55
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell_last-row::after {
56
+ bottom: 0;
57
+ }
58
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell_first-column::after {
59
+ left: 0;
60
+ }
61
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell_last-column::after {
62
+ right: 0;
63
+ }
64
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell_first-row.g-md-yfm-table-selected-cell_first-column::after {
65
+ border-top-left-radius: 8px;
66
+ }
67
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell_first-row.g-md-yfm-table-selected-cell_last-column::after {
68
+ border-top-right-radius: 8px;
69
+ }
70
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell_last-row.g-md-yfm-table-selected-cell_first-column::after {
71
+ border-bottom-left-radius: 8px;
72
+ }
73
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell_last-row.g-md-yfm-table-selected-cell_last-column::after {
74
+ border-bottom-right-radius: 8px;
75
+ }
76
+ .yfm.ProseMirror table td.g-md-yfm-table-selected-cell.dragged-cell::before {
77
+ position: absolute;
78
+ inset: 0;
79
+ display: inline-block;
80
+ content: "";
81
+ pointer-events: none;
82
+ opacity: 0.7;
83
+ background-color: var(--g-color-base-background);
19
84
  }
@@ -8,6 +8,7 @@ export type DnDControlHandler = {
8
8
  control_handleMouseDown: React.MouseEventHandler<HTMLButtonElement>;
9
9
  control_handleMouseMove: React.MouseEventHandler<HTMLButtonElement>;
10
10
  control_handleMouseUp: React.MouseEventHandler<HTMLButtonElement>;
11
+ control_handleMouseLeave: React.MouseEventHandler<HTMLButtonElement>;
11
12
  };
12
13
  interface TableHandler {
13
14
  update(node: Node): void;
@@ -1,13 +1,15 @@
1
1
  import { Slice } from "../../../../../../pm/model.js";
2
2
  import { TextSelection } from "../../../../../../pm/state.js";
3
3
  import { findParentNodeClosestToPos } from "../../../../../../pm/utils.js";
4
- import { debounce, range as iterate } from "../../../../../../lodash.js";
4
+ import { debounce } from "../../../../../../lodash.js";
5
5
  import { isTableNode } from "../../../../../../table-utils/index.js";
6
6
  import { TableDesc, } from "../../../../../../table-utils/table-desc.js";
7
7
  import { YfmTableNode } from "../../../YfmTableSpecs/index.js";
8
8
  import { clearAllSelections, selectDraggedColumn, selectDraggedRow } from "../plugins/dnd-plugin.js";
9
9
  import { hideHoverDecos } from "../plugins/focus-plugin.js";
10
+ import { getSelectedCellsForColumns, getSelectedCellsForRows } from "../utils.js";
10
11
  import { DropCursor as RowDropCursor, TableColumnDropCursor, } from "./dnd-drop-cursor.js";
12
+ import { YfmTableDnDGhost } from "./dnd-ghost.js";
11
13
  import "./dnd.css";
12
14
  const MOUSE_MOVE_DEBOUNCE = 100; // ms
13
15
  const DRAG_START_THRESHOLD = 4; // px
@@ -54,7 +56,7 @@ class YfmTableDnDAbstractHandler {
54
56
  }
55
57
  destroy() {
56
58
  this.__destroyed = true;
57
- this._clearDragging();
59
+ this._clearDragging(false);
58
60
  }
59
61
  control_handleMouseDown = (event) => {
60
62
  this.__dragMouseDown = { pageX: event.pageX, pageY: event.pageY };
@@ -63,12 +65,15 @@ class YfmTableDnDAbstractHandler {
63
65
  control_handleMouseUp = () => {
64
66
  this.__dragMouseDown = false;
65
67
  };
68
+ control_handleMouseLeave = () => {
69
+ this.__dragMouseDown = false;
70
+ };
66
71
  control_handleMouseMove = (event) => {
67
72
  if (!this._dragMouseDown || !isDragThresholdPassed(this._dragMouseDown, event))
68
73
  return;
69
74
  if (this._editorView.dragging || this._dragging)
70
75
  return;
71
- this._startDragging();
76
+ this._startDragging(event);
72
77
  };
73
78
  get _cellNode() {
74
79
  return this.__cellNode;
@@ -101,12 +106,13 @@ class YfmTableDnDAbstractHandler {
101
106
  }
102
107
  : null;
103
108
  }
104
- _clearDragging() {
109
+ _clearDragging(clearDecorations) {
105
110
  this.__dragging = false;
106
111
  this.__dragMouseDown = false;
107
112
  this._dropCursor.clear();
108
113
  this._editorView.dragging = null;
109
- this._editorView.dispatch(clearAllSelections(this._editorView.state.tr));
114
+ if (clearDecorations !== false)
115
+ this._editorView.dispatch(clearAllSelections(this._editorView.state.tr));
110
116
  }
111
117
  }
112
118
  class YfmTableRowDnDHandler extends YfmTableDnDAbstractHandler {
@@ -124,7 +130,7 @@ class YfmTableRowDnDHandler extends YfmTableDnDAbstractHandler {
124
130
  const rowRange = res.tableDesc.base.getRowRangeByRowIdx(res.cellInfo.row);
125
131
  return rowRange.safeTopBoundary && rowRange.safeBottomBoundary;
126
132
  }
127
- _startDragging = () => {
133
+ _startDragging = (event) => {
128
134
  const info = this._getTableDescAndCellInfo();
129
135
  if (!info)
130
136
  return;
@@ -138,7 +144,7 @@ class YfmTableRowDnDHandler extends YfmTableDnDAbstractHandler {
138
144
  {
139
145
  const { tr } = this._editorView.state;
140
146
  hideHoverDecos(tr);
141
- selectDraggedRow(tr, iterate(currRowRange.startIdx, currRowRange.endIdx + 1).map((rowIdx) => tableDesc.getPosForRow(rowIdx)));
147
+ selectDraggedRow(tr, getSelectedCellsForRows(info.tableDesc, currRowRange));
142
148
  this._editorView.dispatch(tr);
143
149
  }
144
150
  {
@@ -149,20 +155,27 @@ class YfmTableRowDnDHandler extends YfmTableDnDAbstractHandler {
149
155
  slice: this._editorView.state.doc.slice(from, to, false),
150
156
  };
151
157
  }
152
- const dndBackground = document.createElement('div');
153
- dndBackground.classList.add('g-md-yfm-table-dnd-cursor-background');
154
- document.body.append(dndBackground);
155
158
  const draggedRangeIdx = rowRanges.indexOf(currRowRange);
156
- const onMove = debounce((event) => {
159
+ const ghost = new YfmTableDnDGhost(this._editorView, {
160
+ type: 'row',
161
+ initial: event,
162
+ rangeIdx: draggedRangeIdx,
163
+ tableDesc,
164
+ });
165
+ const onMoveDebounced = debounce((event) => {
157
166
  this._moveDragging(event, {
158
167
  rangeIdx: draggedRangeIdx,
159
168
  tableDesc,
160
169
  });
161
170
  }, MOUSE_MOVE_DEBOUNCE, { maxWait: MOUSE_MOVE_DEBOUNCE });
171
+ const onMove = (event) => {
172
+ ghost.move(event);
173
+ onMoveDebounced(event);
174
+ };
162
175
  document.addEventListener('mousemove', onMove);
163
176
  document.addEventListener('mouseup', () => {
164
- onMove.flush();
165
- dndBackground.remove();
177
+ onMoveDebounced.flush();
178
+ ghost.destroy();
166
179
  document.removeEventListener('mousemove', onMove);
167
180
  this._endDragging(currRowRange, tableDesc);
168
181
  }, { once: true });
@@ -280,7 +293,7 @@ class YfmTableColumnDnDHandler extends YfmTableDnDAbstractHandler {
280
293
  const rowRange = res.tableDesc.base.getColumnRangeByColumnIdx(res.cellInfo.column);
281
294
  return rowRange.safeLeftBoundary && rowRange.safeRightBoundary;
282
295
  }
283
- _startDragging() {
296
+ _startDragging(event) {
284
297
  const info = this._getTableDescAndCellInfo();
285
298
  if (!info)
286
299
  return;
@@ -292,14 +305,9 @@ class YfmTableColumnDnDHandler extends YfmTableDnDAbstractHandler {
292
305
  this._dragging = true;
293
306
  this._logger.event({ event: 'column-drag-start' });
294
307
  {
295
- const columnCellsPos = [];
296
- for (const i of iterate(currColumnRange.startIdx, currColumnRange.endIdx + 1)) {
297
- columnCellsPos.push(...tableDesc.getPosForColumn(i));
298
- }
299
- const realPos = columnCellsPos.filter((cell) => cell.type === 'real');
300
308
  const { tr } = this._editorView.state;
301
309
  hideHoverDecos(tr);
302
- selectDraggedColumn(tr, realPos);
310
+ selectDraggedColumn(tr, getSelectedCellsForColumns(tableDesc, currColumnRange));
303
311
  this._editorView.dispatch(tr);
304
312
  }
305
313
  {
@@ -308,20 +316,27 @@ class YfmTableColumnDnDHandler extends YfmTableDnDAbstractHandler {
308
316
  slice: Slice.empty,
309
317
  };
310
318
  }
311
- const dndBackground = document.createElement('div');
312
- dndBackground.classList.add('g-md-yfm-table-dnd-cursor-background');
313
- document.body.append(dndBackground);
314
319
  const draggedRangeIdx = columnRanges.indexOf(currColumnRange);
315
- const onMove = debounce((event) => {
320
+ const ghost = new YfmTableDnDGhost(this._editorView, {
321
+ type: 'column',
322
+ initial: event,
323
+ rangeIdx: draggedRangeIdx,
324
+ tableDesc,
325
+ });
326
+ const onMoveDebounced = debounce((event) => {
316
327
  this._moveDragging(event, {
317
328
  rangeIdx: draggedRangeIdx,
318
329
  tableDesc,
319
330
  });
320
331
  }, MOUSE_MOVE_DEBOUNCE, { maxWait: MOUSE_MOVE_DEBOUNCE });
332
+ const onMove = (event) => {
333
+ ghost.move(event);
334
+ onMoveDebounced(event);
335
+ };
321
336
  document.addEventListener('mousemove', onMove);
322
337
  document.addEventListener('mouseup', () => {
323
- onMove.flush();
324
- dndBackground.remove();
338
+ onMoveDebounced.flush();
339
+ ghost.destroy();
325
340
  document.removeEventListener('mousemove', onMove);
326
341
  this._endDragging(currColumnRange, tableDesc);
327
342
  }, { once: true });
@@ -1 +1 @@
1
- {"version":3,"file":"dnd.js","sourceRoot":"../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.ts"],"names":[],"mappings":"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","sourcesContent":["import {type Node, Slice} from '#pm/model';\nimport {TextSelection} from '#pm/state';\nimport {findParentNodeClosestToPos} from '#pm/utils';\nimport type {EditorView} from '#pm/view';\nimport {debounce, range as iterate} from 'src/lodash';\nimport type {Logger2} from 'src/logger';\nimport {isTableNode} from 'src/table-utils';\nimport {\n type CellPos,\n type RealCellPos,\n type TableColumnRange,\n TableDesc,\n type TableDescBinded,\n type TableRowRange,\n} from 'src/table-utils/table-desc';\n\nimport {YfmTableNode} from '../../../YfmTableSpecs';\nimport {clearAllSelections, selectDraggedColumn, selectDraggedRow} from '../plugins/dnd-plugin';\nimport {hideHoverDecos} from '../plugins/focus-plugin';\n\nimport {\n type DropCursorParams,\n DropCursor as RowDropCursor,\n TableColumnDropCursor,\n} from './dnd-drop-cursor';\n\nimport './dnd.scss';\n\nconst MOUSE_MOVE_DEBOUNCE = 100; // ms\nconst DRAG_START_THRESHOLD = 4; // px\n\ntype PageCoords = Pick<MouseEvent, 'pageX' | 'pageY'>;\n\nexport type DnDControlHandler = {\n canDrag(): boolean;\n control_handleMouseDown: React.MouseEventHandler<HTMLButtonElement>;\n control_handleMouseMove: React.MouseEventHandler<HTMLButtonElement>;\n control_handleMouseUp: React.MouseEventHandler<HTMLButtonElement>;\n};\n\ninterface TableHandler {\n update(node: Node): void;\n destroy(): void;\n}\n\nexport type YfmTableDnDHandlerParams = {\n cellNode: Node;\n cellGetPos: () => number | undefined;\n logger: Logger2.ILogger;\n dropCursor?: DropCursorParams;\n};\n\nexport class YfmTableDnDHandler implements TableHandler {\n private readonly _rowHandler: YfmTableRowDnDHandler;\n private readonly _columnHandler: YfmTableColumnDnDHandler;\n\n get row(): DnDControlHandler {\n return this._rowHandler;\n }\n\n get column(): DnDControlHandler {\n return this._columnHandler;\n }\n\n constructor(view: EditorView, params: YfmTableDnDHandlerParams) {\n this._rowHandler = new YfmTableRowDnDHandler(view, params);\n this._columnHandler = new YfmTableColumnDnDHandler(view, params);\n }\n\n update(node: Node): void {\n this._rowHandler.update(node);\n this._columnHandler.update(node);\n }\n\n destroy(): void {\n this._rowHandler.destroy();\n this._columnHandler.destroy();\n }\n}\n\nabstract class YfmTableDnDAbstractHandler implements TableHandler, DnDControlHandler {\n protected readonly _cellGetPos: () => number | undefined;\n protected readonly _editorView: EditorView;\n protected readonly _logger: Logger2.ILogger;\n protected readonly _dropCursor: RowDropCursor;\n\n private __cellNode: Node;\n private __dragging = false;\n private __destroyed = false;\n private __dragMouseDown: false | PageCoords = false;\n\n constructor(\n view: EditorView,\n params: Omit<YfmTableDnDHandlerParams, 'dropCursor'> & {dropCursor: RowDropCursor},\n ) {\n this._editorView = view;\n this.__cellNode = params.cellNode;\n this._cellGetPos = params.cellGetPos;\n this._logger = params.logger;\n this._dropCursor = params.dropCursor;\n }\n\n update(cellnode: Node) {\n this.__cellNode = cellnode;\n }\n\n destroy() {\n this.__destroyed = true;\n this._clearDragging();\n }\n\n abstract canDrag(): boolean;\n\n control_handleMouseDown: React.MouseEventHandler<HTMLButtonElement> = (event) => {\n this.__dragMouseDown = {pageX: event.pageX, pageY: event.pageY};\n this._dropCursor.clear();\n };\n\n control_handleMouseUp: React.MouseEventHandler<HTMLButtonElement> = () => {\n this.__dragMouseDown = false;\n };\n\n control_handleMouseMove: React.MouseEventHandler<HTMLButtonElement> = (event) => {\n if (!this._dragMouseDown || !isDragThresholdPassed(this._dragMouseDown, event)) return;\n\n if (this._editorView.dragging || this._dragging) return;\n this._startDragging();\n };\n\n protected get _cellNode(): Node {\n return this.__cellNode;\n }\n\n protected get _dragging() {\n return this.__dragging;\n }\n\n protected set _dragging(val: boolean) {\n this.__dragging = val;\n }\n\n protected get _destroyed() {\n return this.__destroyed;\n }\n\n protected get _dragMouseDown() {\n return this.__dragMouseDown;\n }\n\n protected abstract _startDragging(): void;\n\n protected _getTableDescAndCellInfo() {\n const tcellPos = this._cellGetPos();\n const tableNode =\n tcellPos === undefined\n ? undefined\n : findParentNodeClosestToPos(\n this._editorView.state.doc.resolve(tcellPos),\n isTableNode,\n );\n const tableDesc = tableNode && TableDesc.create(tableNode.node)?.bind(tableNode.pos);\n const cellInfo = tableDesc?.base.getCellInfo(this._cellNode);\n return cellInfo\n ? {\n cellPos: tcellPos!,\n table: tableNode!,\n tableDesc: tableDesc!,\n cellInfo,\n }\n : null;\n }\n\n protected _clearDragging() {\n this.__dragging = false;\n this.__dragMouseDown = false;\n this._dropCursor.clear();\n this._editorView.dragging = null;\n this._editorView.dispatch(clearAllSelections(this._editorView.state.tr));\n }\n}\n\nclass YfmTableRowDnDHandler extends YfmTableDnDAbstractHandler {\n constructor(view: EditorView, params: YfmTableDnDHandlerParams) {\n super(view, {\n ...params,\n logger: params.logger.nested({component: 'row-dnd-handler'}),\n dropCursor: new RowDropCursor(view, params.dropCursor),\n });\n }\n\n canDrag(): boolean {\n const res = this._getTableDescAndCellInfo();\n if (!res) return false;\n const rowRange = res.tableDesc.base.getRowRangeByRowIdx(res.cellInfo.row);\n return rowRange.safeTopBoundary && rowRange.safeBottomBoundary;\n }\n\n protected _startDragging = () => {\n const info = this._getTableDescAndCellInfo();\n if (!info) return;\n\n const {tableDesc, cellInfo} = info;\n const rowRanges = tableDesc.base.getRowRanges();\n const currRowRange = tableDesc.base.getRowRangeByRowIdx(cellInfo.row);\n if (!currRowRange.safeTopBoundary || !currRowRange.safeBottomBoundary) return;\n\n this._dragging = true;\n this._logger.event({event: 'row-drag-start'});\n\n {\n const {tr} = this._editorView.state;\n hideHoverDecos(tr);\n selectDraggedRow(\n tr,\n iterate(currRowRange.startIdx, currRowRange.endIdx + 1).map((rowIdx) =>\n tableDesc.getPosForRow(rowIdx),\n ),\n );\n this._editorView.dispatch(tr);\n }\n\n {\n const from = tableDesc.getPosForRow(currRowRange.startIdx).from;\n const to = tableDesc.getPosForRow(currRowRange.endIdx).to;\n this._editorView.dragging = {\n move: true,\n slice: this._editorView.state.doc.slice(from, to, false),\n };\n }\n\n const dndBackground = document.createElement('div');\n dndBackground.classList.add('g-md-yfm-table-dnd-cursor-background');\n document.body.append(dndBackground);\n\n const draggedRangeIdx = rowRanges.indexOf(currRowRange);\n\n const onMove = debounce(\n (event: MouseEvent) => {\n this._moveDragging(event, {\n rangeIdx: draggedRangeIdx,\n tableDesc,\n });\n },\n MOUSE_MOVE_DEBOUNCE,\n {maxWait: MOUSE_MOVE_DEBOUNCE},\n );\n\n document.addEventListener('mousemove', onMove);\n\n document.addEventListener(\n 'mouseup',\n () => {\n onMove.flush();\n dndBackground.remove();\n document.removeEventListener('mousemove', onMove);\n this._endDragging(currRowRange, tableDesc);\n },\n {once: true},\n );\n };\n\n private _moveDragging(\n event: MouseEvent,\n {\n rangeIdx,\n tableDesc: initialTableDesc,\n }: {\n rangeIdx: number;\n tableDesc: TableDescBinded;\n },\n ) {\n if (this._destroyed || !this._dragging) return;\n\n const info = this._getTableDescAndCellInfo();\n if (!info || info.tableDesc.base !== initialTableDesc.base) {\n this._clearDragging();\n return;\n }\n\n const {tableDesc} = info;\n const ranges = tableDesc.base.getRowRanges();\n\n const boxes = ranges.map((range: Readonly<TableRowRange>) => {\n const firstRowStartPos = tableDesc.getPosForRow(range.startIdx).from;\n const lastRowPos = tableDesc.getPosForRow(range.endIdx);\n const lastRowStartPos = lastRowPos.from;\n const lastRowEndPos = lastRowPos.to;\n\n const firstRowElem = this._editorView.domAtPos(firstRowStartPos + 1).node as Element;\n const firstRowBox = firstRowElem.getBoundingClientRect();\n\n const lastRowElem = this._editorView.domAtPos(lastRowStartPos + 1).node as Element;\n const lastRowBox = lastRowElem.getBoundingClientRect();\n\n return {\n pos: {from: firstRowStartPos, to: lastRowEndPos},\n rect: {\n top: firstRowBox.top,\n bottom: lastRowBox.bottom,\n },\n safeTopBoundary: range.safeTopBoundary,\n safeBottomBoundary: range.safeBottomBoundary,\n };\n });\n\n const pos = ((): number | null => {\n const {clientY} = event;\n const draggedRangeBox = boxes[rangeIdx];\n const isDraggedFirst = rangeIdx === 0;\n const isDraggedLast = rangeIdx === boxes.length - 1;\n\n if (!isDraggedFirst && clientY < draggedRangeBox.rect.top) {\n for (const box of boxes.slice(0, rangeIdx).reverse()) {\n if (clientY < box.rect.top) continue;\n if (!box.safeTopBoundary) continue;\n return box.pos.from;\n }\n return boxes[0].pos.from;\n }\n\n if (!isDraggedLast && clientY > draggedRangeBox.rect.bottom) {\n for (const box of boxes.slice(rangeIdx + 1)) {\n if (clientY > box.rect.bottom) continue;\n if (!box.safeBottomBoundary) continue;\n return box.pos.to;\n }\n return boxes.at(-1)!.pos.to;\n }\n\n return null;\n })();\n\n if (typeof pos === 'number') this._dropCursor.setPos(pos);\n else this._dropCursor.clear();\n }\n\n private _endDragging(draggedRange: Readonly<TableRowRange>, initialTableDesc: TableDescBinded) {\n if (this._destroyed || !this._dragging) return;\n\n const point = this._dropCursor.getPos();\n this._clearDragging();\n this._logger.event({event: 'row-drag-end'});\n\n if (point === null) {\n this._editorView.focus();\n return;\n }\n\n const info = this._getTableDescAndCellInfo();\n if (!info || info.tableDesc.base !== initialTableDesc.base) {\n this._editorView.focus();\n return;\n }\n\n const rangeFrom = info.tableDesc.getPosForRow(draggedRange.startIdx).from;\n const rangeTo = info.tableDesc.getPosForRow(draggedRange.endIdx).to;\n if (point === rangeFrom || point === rangeTo) {\n this._editorView.focus();\n return;\n }\n\n const {tr} = this._editorView.state;\n const fragment = tr.doc.slice(rangeFrom, rangeTo, false).content;\n if (point > rangeFrom) {\n tr.insert(point, fragment);\n tr.delete(rangeFrom, rangeTo);\n } else {\n tr.delete(rangeFrom, rangeTo);\n tr.insert(point, fragment);\n }\n tr.setSelection(TextSelection.near(tr.doc.resolve(tr.mapping.map(point + 1)), 1));\n tr.scrollIntoView();\n this._editorView.dispatch(tr);\n\n this._editorView.focus();\n }\n}\n\nclass YfmTableColumnDnDHandler extends YfmTableDnDAbstractHandler {\n constructor(view: EditorView, params: YfmTableDnDHandlerParams) {\n super(view, {\n ...params,\n logger: params.logger.nested({component: 'column-dnd-handler'}),\n dropCursor: new TableColumnDropCursor(view, params.dropCursor),\n });\n }\n\n canDrag(): boolean {\n const res = this._getTableDescAndCellInfo();\n if (!res) return false;\n const rowRange = res.tableDesc.base.getColumnRangeByColumnIdx(res.cellInfo.column);\n return rowRange.safeLeftBoundary && rowRange.safeRightBoundary;\n }\n\n protected _startDragging() {\n const info = this._getTableDescAndCellInfo();\n if (!info) return;\n\n const {tableDesc, cellInfo} = info;\n const columnRanges = tableDesc.base.getColumnRanges();\n const currColumnRange = tableDesc.base.getColumnRangeByColumnIdx(cellInfo.column);\n if (!currColumnRange.safeLeftBoundary || !currColumnRange.safeRightBoundary) return;\n\n this._dragging = true;\n this._logger.event({event: 'column-drag-start'});\n\n {\n const columnCellsPos: CellPos[] = [];\n for (const i of iterate(currColumnRange.startIdx, currColumnRange.endIdx + 1)) {\n columnCellsPos.push(...tableDesc.getPosForColumn(i));\n }\n const realPos = columnCellsPos.filter((cell) => cell.type === 'real');\n\n const {tr} = this._editorView.state;\n hideHoverDecos(tr);\n selectDraggedColumn(tr, realPos);\n this._editorView.dispatch(tr);\n }\n {\n this._editorView.dragging = {\n move: true,\n slice: Slice.empty,\n };\n }\n\n const dndBackground = document.createElement('div');\n dndBackground.classList.add('g-md-yfm-table-dnd-cursor-background');\n document.body.append(dndBackground);\n\n const draggedRangeIdx = columnRanges.indexOf(currColumnRange);\n\n const onMove = debounce(\n (event: MouseEvent) => {\n this._moveDragging(event, {\n rangeIdx: draggedRangeIdx,\n tableDesc,\n });\n },\n MOUSE_MOVE_DEBOUNCE,\n {maxWait: MOUSE_MOVE_DEBOUNCE},\n );\n\n document.addEventListener('mousemove', onMove);\n\n document.addEventListener(\n 'mouseup',\n () => {\n onMove.flush();\n dndBackground.remove();\n document.removeEventListener('mousemove', onMove);\n this._endDragging(currColumnRange, tableDesc);\n },\n {once: true},\n );\n }\n\n private _moveDragging(\n event: MouseEvent,\n {\n rangeIdx,\n tableDesc: initialTableDesc,\n }: {\n rangeIdx: number;\n tableDesc: TableDescBinded;\n },\n ) {\n if (this._destroyed || !this._dragging) return;\n\n const info = this._getTableDescAndCellInfo();\n if (!info || info.tableDesc.base !== initialTableDesc.base) {\n this._clearDragging();\n return;\n }\n\n const {tableDesc} = info;\n const ranges = tableDesc.base.getColumnRanges();\n\n const boxes = ranges.map((range: Readonly<TableColumnRange>) => {\n const firstColStartPos = getCellPos(\n tableDesc.getPosForCell(0, range.startIdx),\n 'start',\n );\n const lastColPos = tableDesc.getPosForCell(0, range.startIdx);\n const lastColStartPos = getCellPos(lastColPos, 'start');\n const lastColEndPos = getCellPos(lastColPos, 'end');\n\n const firstColElem = this._editorView.domAtPos(firstColStartPos + 1).node as Element;\n const firstColBox = firstColElem.getBoundingClientRect();\n\n const lastColElem = this._editorView.domAtPos(lastColStartPos + 1).node as Element;\n const lastColBox = lastColElem.getBoundingClientRect();\n\n return {\n pos: {from: firstColStartPos, to: lastColEndPos},\n rect: {\n left: firstColBox.left,\n right: lastColBox.right,\n },\n safeLeftBoundary: range.safeLeftBoundary,\n safeRightBoundary: range.safeRightBoundary,\n };\n });\n\n const pos = ((): number | null => {\n const {clientX} = event;\n const draggedRangeBox = boxes[rangeIdx];\n const isDraggedFirst = rangeIdx === 0;\n const isDraggedLast = rangeIdx === boxes.length - 1;\n\n if (!isDraggedFirst && clientX < draggedRangeBox.rect.left) {\n for (const box of boxes.slice(0, rangeIdx).reverse()) {\n if (clientX < box.rect.left) continue;\n if (!box.safeLeftBoundary) continue;\n return box.pos.from;\n }\n return boxes[0].pos.from;\n }\n\n if (!isDraggedLast && clientX > draggedRangeBox.rect.right) {\n for (const box of boxes.slice(rangeIdx + 1)) {\n if (clientX > box.rect.right) continue;\n if (!box.safeRightBoundary) continue;\n return box.pos.to;\n }\n return boxes.at(-1)!.pos.to;\n }\n\n return null;\n })();\n\n if (typeof pos === 'number') this._dropCursor.setPos(pos);\n else this._dropCursor.clear();\n }\n\n private _endDragging(\n draggedRange: Readonly<TableColumnRange>,\n initialTableDesc: TableDescBinded,\n ) {\n if (this._destroyed || !this._dragging) return;\n\n const point = this._dropCursor.getPos();\n this._clearDragging();\n this._logger.event({event: 'column-drag-end'});\n\n if (point === null) {\n this._editorView.focus();\n return;\n }\n\n const info = this._getTableDescAndCellInfo();\n if (!info || info.tableDesc.base !== initialTableDesc.base) {\n this._editorView.focus();\n return;\n }\n\n const currRangeFrom = (\n info.tableDesc.getPosForCell(0, draggedRange.startIdx) as RealCellPos\n ).from;\n const currRangeTo = (info.tableDesc.getPosForCell(0, draggedRange.endIdx) as RealCellPos)\n .to;\n\n if (point === currRangeFrom || point === currRangeTo) return;\n\n const targetColumnIndex = ((): number | null => {\n if (point === info.tableDesc.getPosForRow(0).to - 1) {\n return info.tableDesc.cols;\n }\n\n const cellNode = this._editorView.state.doc.nodeAt(point);\n if (!cellNode || cellNode.type.name !== YfmTableNode.Cell) return null;\n\n const cellInfo = info.tableDesc.base.getCellInfo(cellNode);\n if (!cellInfo) return null;\n\n return cellInfo.column;\n })();\n\n if (\n targetColumnIndex === null ||\n targetColumnIndex === info.cellInfo.column ||\n targetColumnIndex === info.cellInfo.column + 1\n ) {\n this._editorView.focus();\n return;\n }\n\n const {tr} = this._editorView.state;\n\n for (let rowIdx = 0; rowIdx < info.tableDesc.rows; rowIdx++) {\n const from = getCellPos(\n info.tableDesc.getPosForCell(rowIdx, draggedRange.startIdx),\n 'start',\n );\n const to = getCellPos(info.tableDesc.getPosForCell(rowIdx, draggedRange.endIdx), 'end');\n if (from === to) continue;\n\n let targetPos;\n if (targetColumnIndex === info.tableDesc.cols) {\n targetPos = info.tableDesc.getPosForRow(rowIdx).to - 1;\n } else if (targetColumnIndex === 0) {\n targetPos = info.tableDesc.getPosForRow(rowIdx).from + 1;\n } else {\n targetPos = getCellPos(\n info.tableDesc.getPosForCell(rowIdx, targetColumnIndex),\n 'start',\n );\n }\n\n if (targetPos !== from && targetPos !== to) {\n const fragment = tr.doc.slice(from, to, false).content;\n tr.insert(tr.mapping.map(targetPos), fragment);\n tr.delete(tr.mapping.map(from), tr.mapping.map(to));\n }\n }\n\n this._editorView.dispatch(tr.scrollIntoView());\n this._editorView.focus();\n }\n}\n\nfunction getCellPos(pos: CellPos, dir: 'start' | 'end'): number {\n if (pos.type === 'virtual') return pos.closestPos;\n return dir === 'start' ? pos.from : pos.to;\n}\n\nfunction isDragThresholdPassed(init: PageCoords, curr: PageCoords): boolean {\n return (\n Math.abs(init.pageX - curr.pageX) >= DRAG_START_THRESHOLD ||\n Math.abs(init.pageY - curr.pageY) >= DRAG_START_THRESHOLD\n );\n}\n"]}
1
+ {"version":3,"file":"dnd.js","sourceRoot":"../../../../../../../../src","sources":["extensions/yfm/YfmTable/plugins/YfmTableControls/dnd/dnd.ts"],"names":[],"mappings":"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","sourcesContent":["import {type Node, Slice} from '#pm/model';\nimport {TextSelection} from '#pm/state';\nimport {findParentNodeClosestToPos} from '#pm/utils';\nimport type {EditorView} from '#pm/view';\nimport {debounce} from 'src/lodash';\nimport type {Logger2} from 'src/logger';\nimport {isTableNode} from 'src/table-utils';\nimport {\n type CellPos,\n type RealCellPos,\n type TableColumnRange,\n TableDesc,\n type TableDescBinded,\n type TableRowRange,\n} from 'src/table-utils/table-desc';\n\nimport {YfmTableNode} from '../../../YfmTableSpecs';\nimport {clearAllSelections, selectDraggedColumn, selectDraggedRow} from '../plugins/dnd-plugin';\nimport {hideHoverDecos} from '../plugins/focus-plugin';\nimport {getSelectedCellsForColumns, getSelectedCellsForRows} from '../utils';\n\nimport {\n type DropCursorParams,\n DropCursor as RowDropCursor,\n TableColumnDropCursor,\n} from './dnd-drop-cursor';\nimport {YfmTableDnDGhost} from './dnd-ghost';\n\nimport './dnd.scss';\n\nconst MOUSE_MOVE_DEBOUNCE = 100; // ms\nconst DRAG_START_THRESHOLD = 4; // px\n\ntype PageCoords = Pick<MouseEvent, 'pageX' | 'pageY'>;\n\nexport type DnDControlHandler = {\n canDrag(): boolean;\n control_handleMouseDown: React.MouseEventHandler<HTMLButtonElement>;\n control_handleMouseMove: React.MouseEventHandler<HTMLButtonElement>;\n control_handleMouseUp: React.MouseEventHandler<HTMLButtonElement>;\n control_handleMouseLeave: React.MouseEventHandler<HTMLButtonElement>;\n};\n\ninterface TableHandler {\n update(node: Node): void;\n destroy(): void;\n}\n\nexport type YfmTableDnDHandlerParams = {\n cellNode: Node;\n cellGetPos: () => number | undefined;\n logger: Logger2.ILogger;\n dropCursor?: DropCursorParams;\n};\n\nexport class YfmTableDnDHandler implements TableHandler {\n private readonly _rowHandler: YfmTableRowDnDHandler;\n private readonly _columnHandler: YfmTableColumnDnDHandler;\n\n get row(): DnDControlHandler {\n return this._rowHandler;\n }\n\n get column(): DnDControlHandler {\n return this._columnHandler;\n }\n\n constructor(view: EditorView, params: YfmTableDnDHandlerParams) {\n this._rowHandler = new YfmTableRowDnDHandler(view, params);\n this._columnHandler = new YfmTableColumnDnDHandler(view, params);\n }\n\n update(node: Node): void {\n this._rowHandler.update(node);\n this._columnHandler.update(node);\n }\n\n destroy(): void {\n this._rowHandler.destroy();\n this._columnHandler.destroy();\n }\n}\n\nabstract class YfmTableDnDAbstractHandler implements TableHandler, DnDControlHandler {\n protected readonly _cellGetPos: () => number | undefined;\n protected readonly _editorView: EditorView;\n protected readonly _logger: Logger2.ILogger;\n protected readonly _dropCursor: RowDropCursor;\n\n private __cellNode: Node;\n private __dragging = false;\n private __destroyed = false;\n private __dragMouseDown: false | PageCoords = false;\n\n constructor(\n view: EditorView,\n params: Omit<YfmTableDnDHandlerParams, 'dropCursor'> & {dropCursor: RowDropCursor},\n ) {\n this._editorView = view;\n this.__cellNode = params.cellNode;\n this._cellGetPos = params.cellGetPos;\n this._logger = params.logger;\n this._dropCursor = params.dropCursor;\n }\n\n update(cellnode: Node) {\n this.__cellNode = cellnode;\n }\n\n destroy() {\n this.__destroyed = true;\n this._clearDragging(false);\n }\n\n abstract canDrag(): boolean;\n\n control_handleMouseDown: React.MouseEventHandler<HTMLButtonElement> = (event) => {\n this.__dragMouseDown = {pageX: event.pageX, pageY: event.pageY};\n this._dropCursor.clear();\n };\n\n control_handleMouseUp: React.MouseEventHandler<HTMLButtonElement> = () => {\n this.__dragMouseDown = false;\n };\n\n control_handleMouseLeave: React.MouseEventHandler<HTMLButtonElement> = () => {\n this.__dragMouseDown = false;\n };\n\n control_handleMouseMove: React.MouseEventHandler<HTMLButtonElement> = (event) => {\n if (!this._dragMouseDown || !isDragThresholdPassed(this._dragMouseDown, event)) return;\n\n if (this._editorView.dragging || this._dragging) return;\n this._startDragging(event);\n };\n\n protected get _cellNode(): Node {\n return this.__cellNode;\n }\n\n protected get _dragging() {\n return this.__dragging;\n }\n\n protected set _dragging(val: boolean) {\n this.__dragging = val;\n }\n\n protected get _destroyed() {\n return this.__destroyed;\n }\n\n protected get _dragMouseDown() {\n return this.__dragMouseDown;\n }\n\n protected abstract _startDragging(event: React.MouseEvent): void;\n\n protected _getTableDescAndCellInfo() {\n const tcellPos = this._cellGetPos();\n const tableNode =\n tcellPos === undefined\n ? undefined\n : findParentNodeClosestToPos(\n this._editorView.state.doc.resolve(tcellPos),\n isTableNode,\n );\n const tableDesc = tableNode && TableDesc.create(tableNode.node)?.bind(tableNode.pos);\n const cellInfo = tableDesc?.base.getCellInfo(this._cellNode);\n return cellInfo\n ? {\n cellPos: tcellPos!,\n table: tableNode!,\n tableDesc: tableDesc!,\n cellInfo,\n }\n : null;\n }\n\n protected _clearDragging(clearDecorations?: boolean) {\n this.__dragging = false;\n this.__dragMouseDown = false;\n this._dropCursor.clear();\n this._editorView.dragging = null;\n if (clearDecorations !== false)\n this._editorView.dispatch(clearAllSelections(this._editorView.state.tr));\n }\n}\n\nclass YfmTableRowDnDHandler extends YfmTableDnDAbstractHandler {\n constructor(view: EditorView, params: YfmTableDnDHandlerParams) {\n super(view, {\n ...params,\n logger: params.logger.nested({component: 'row-dnd-handler'}),\n dropCursor: new RowDropCursor(view, params.dropCursor),\n });\n }\n\n canDrag(): boolean {\n const res = this._getTableDescAndCellInfo();\n if (!res) return false;\n const rowRange = res.tableDesc.base.getRowRangeByRowIdx(res.cellInfo.row);\n return rowRange.safeTopBoundary && rowRange.safeBottomBoundary;\n }\n\n protected _startDragging = (event: React.MouseEvent) => {\n const info = this._getTableDescAndCellInfo();\n if (!info) return;\n\n const {tableDesc, cellInfo} = info;\n const rowRanges = tableDesc.base.getRowRanges();\n const currRowRange = tableDesc.base.getRowRangeByRowIdx(cellInfo.row);\n if (!currRowRange.safeTopBoundary || !currRowRange.safeBottomBoundary) return;\n\n this._dragging = true;\n this._logger.event({event: 'row-drag-start'});\n\n {\n const {tr} = this._editorView.state;\n hideHoverDecos(tr);\n selectDraggedRow(tr, getSelectedCellsForRows(info.tableDesc, currRowRange));\n this._editorView.dispatch(tr);\n }\n\n {\n const from = tableDesc.getPosForRow(currRowRange.startIdx).from;\n const to = tableDesc.getPosForRow(currRowRange.endIdx).to;\n this._editorView.dragging = {\n move: true,\n slice: this._editorView.state.doc.slice(from, to, false),\n };\n }\n\n const draggedRangeIdx = rowRanges.indexOf(currRowRange);\n\n const ghost = new YfmTableDnDGhost(this._editorView, {\n type: 'row',\n initial: event,\n rangeIdx: draggedRangeIdx,\n tableDesc,\n });\n\n const onMoveDebounced = debounce(\n (event: MouseEvent) => {\n this._moveDragging(event, {\n rangeIdx: draggedRangeIdx,\n tableDesc,\n });\n },\n MOUSE_MOVE_DEBOUNCE,\n {maxWait: MOUSE_MOVE_DEBOUNCE},\n );\n\n const onMove = (event: MouseEvent) => {\n ghost.move(event);\n onMoveDebounced(event);\n };\n\n document.addEventListener('mousemove', onMove);\n\n document.addEventListener(\n 'mouseup',\n () => {\n onMoveDebounced.flush();\n ghost.destroy();\n document.removeEventListener('mousemove', onMove);\n this._endDragging(currRowRange, tableDesc);\n },\n {once: true},\n );\n };\n\n private _moveDragging(\n event: MouseEvent,\n {\n rangeIdx,\n tableDesc: initialTableDesc,\n }: {\n rangeIdx: number;\n tableDesc: TableDescBinded;\n },\n ) {\n if (this._destroyed || !this._dragging) return;\n\n const info = this._getTableDescAndCellInfo();\n if (!info || info.tableDesc.base !== initialTableDesc.base) {\n this._clearDragging();\n return;\n }\n\n const {tableDesc} = info;\n const ranges = tableDesc.base.getRowRanges();\n\n const boxes = ranges.map((range: Readonly<TableRowRange>) => {\n const firstRowStartPos = tableDesc.getPosForRow(range.startIdx).from;\n const lastRowPos = tableDesc.getPosForRow(range.endIdx);\n const lastRowStartPos = lastRowPos.from;\n const lastRowEndPos = lastRowPos.to;\n\n const firstRowElem = this._editorView.domAtPos(firstRowStartPos + 1).node as Element;\n const firstRowBox = firstRowElem.getBoundingClientRect();\n\n const lastRowElem = this._editorView.domAtPos(lastRowStartPos + 1).node as Element;\n const lastRowBox = lastRowElem.getBoundingClientRect();\n\n return {\n pos: {from: firstRowStartPos, to: lastRowEndPos},\n rect: {\n top: firstRowBox.top,\n bottom: lastRowBox.bottom,\n },\n safeTopBoundary: range.safeTopBoundary,\n safeBottomBoundary: range.safeBottomBoundary,\n };\n });\n\n const pos = ((): number | null => {\n const {clientY} = event;\n const draggedRangeBox = boxes[rangeIdx];\n const isDraggedFirst = rangeIdx === 0;\n const isDraggedLast = rangeIdx === boxes.length - 1;\n\n if (!isDraggedFirst && clientY < draggedRangeBox.rect.top) {\n for (const box of boxes.slice(0, rangeIdx).reverse()) {\n if (clientY < box.rect.top) continue;\n if (!box.safeTopBoundary) continue;\n return box.pos.from;\n }\n return boxes[0].pos.from;\n }\n\n if (!isDraggedLast && clientY > draggedRangeBox.rect.bottom) {\n for (const box of boxes.slice(rangeIdx + 1)) {\n if (clientY > box.rect.bottom) continue;\n if (!box.safeBottomBoundary) continue;\n return box.pos.to;\n }\n return boxes.at(-1)!.pos.to;\n }\n\n return null;\n })();\n\n if (typeof pos === 'number') this._dropCursor.setPos(pos);\n else this._dropCursor.clear();\n }\n\n private _endDragging(draggedRange: Readonly<TableRowRange>, initialTableDesc: TableDescBinded) {\n if (this._destroyed || !this._dragging) return;\n\n const point = this._dropCursor.getPos();\n this._clearDragging();\n this._logger.event({event: 'row-drag-end'});\n\n if (point === null) {\n this._editorView.focus();\n return;\n }\n\n const info = this._getTableDescAndCellInfo();\n if (!info || info.tableDesc.base !== initialTableDesc.base) {\n this._editorView.focus();\n return;\n }\n\n const rangeFrom = info.tableDesc.getPosForRow(draggedRange.startIdx).from;\n const rangeTo = info.tableDesc.getPosForRow(draggedRange.endIdx).to;\n if (point === rangeFrom || point === rangeTo) {\n this._editorView.focus();\n return;\n }\n\n const {tr} = this._editorView.state;\n const fragment = tr.doc.slice(rangeFrom, rangeTo, false).content;\n if (point > rangeFrom) {\n tr.insert(point, fragment);\n tr.delete(rangeFrom, rangeTo);\n } else {\n tr.delete(rangeFrom, rangeTo);\n tr.insert(point, fragment);\n }\n tr.setSelection(TextSelection.near(tr.doc.resolve(tr.mapping.map(point + 1)), 1));\n tr.scrollIntoView();\n this._editorView.dispatch(tr);\n\n this._editorView.focus();\n }\n}\n\nclass YfmTableColumnDnDHandler extends YfmTableDnDAbstractHandler {\n constructor(view: EditorView, params: YfmTableDnDHandlerParams) {\n super(view, {\n ...params,\n logger: params.logger.nested({component: 'column-dnd-handler'}),\n dropCursor: new TableColumnDropCursor(view, params.dropCursor),\n });\n }\n\n canDrag(): boolean {\n const res = this._getTableDescAndCellInfo();\n if (!res) return false;\n const rowRange = res.tableDesc.base.getColumnRangeByColumnIdx(res.cellInfo.column);\n return rowRange.safeLeftBoundary && rowRange.safeRightBoundary;\n }\n\n protected _startDragging(event: React.MouseEvent) {\n const info = this._getTableDescAndCellInfo();\n if (!info) return;\n\n const {tableDesc, cellInfo} = info;\n const columnRanges = tableDesc.base.getColumnRanges();\n const currColumnRange = tableDesc.base.getColumnRangeByColumnIdx(cellInfo.column);\n if (!currColumnRange.safeLeftBoundary || !currColumnRange.safeRightBoundary) return;\n\n this._dragging = true;\n this._logger.event({event: 'column-drag-start'});\n\n {\n const {tr} = this._editorView.state;\n hideHoverDecos(tr);\n selectDraggedColumn(tr, getSelectedCellsForColumns(tableDesc, currColumnRange));\n this._editorView.dispatch(tr);\n }\n {\n this._editorView.dragging = {\n move: true,\n slice: Slice.empty,\n };\n }\n\n const draggedRangeIdx = columnRanges.indexOf(currColumnRange);\n\n const ghost = new YfmTableDnDGhost(this._editorView, {\n type: 'column',\n initial: event,\n rangeIdx: draggedRangeIdx,\n tableDesc,\n });\n\n const onMoveDebounced = debounce(\n (event: MouseEvent) => {\n this._moveDragging(event, {\n rangeIdx: draggedRangeIdx,\n tableDesc,\n });\n },\n MOUSE_MOVE_DEBOUNCE,\n {maxWait: MOUSE_MOVE_DEBOUNCE},\n );\n\n const onMove = (event: MouseEvent) => {\n ghost.move(event);\n onMoveDebounced(event);\n };\n\n document.addEventListener('mousemove', onMove);\n\n document.addEventListener(\n 'mouseup',\n () => {\n onMoveDebounced.flush();\n ghost.destroy();\n document.removeEventListener('mousemove', onMove);\n this._endDragging(currColumnRange, tableDesc);\n },\n {once: true},\n );\n }\n\n private _moveDragging(\n event: MouseEvent,\n {\n rangeIdx,\n tableDesc: initialTableDesc,\n }: {\n rangeIdx: number;\n tableDesc: TableDescBinded;\n },\n ) {\n if (this._destroyed || !this._dragging) return;\n\n const info = this._getTableDescAndCellInfo();\n if (!info || info.tableDesc.base !== initialTableDesc.base) {\n this._clearDragging();\n return;\n }\n\n const {tableDesc} = info;\n const ranges = tableDesc.base.getColumnRanges();\n\n const boxes = ranges.map((range: Readonly<TableColumnRange>) => {\n const firstColStartPos = getCellPos(\n tableDesc.getPosForCell(0, range.startIdx),\n 'start',\n );\n const lastColPos = tableDesc.getPosForCell(0, range.startIdx);\n const lastColStartPos = getCellPos(lastColPos, 'start');\n const lastColEndPos = getCellPos(lastColPos, 'end');\n\n const firstColElem = this._editorView.domAtPos(firstColStartPos + 1).node as Element;\n const firstColBox = firstColElem.getBoundingClientRect();\n\n const lastColElem = this._editorView.domAtPos(lastColStartPos + 1).node as Element;\n const lastColBox = lastColElem.getBoundingClientRect();\n\n return {\n pos: {from: firstColStartPos, to: lastColEndPos},\n rect: {\n left: firstColBox.left,\n right: lastColBox.right,\n },\n safeLeftBoundary: range.safeLeftBoundary,\n safeRightBoundary: range.safeRightBoundary,\n };\n });\n\n const pos = ((): number | null => {\n const {clientX} = event;\n const draggedRangeBox = boxes[rangeIdx];\n const isDraggedFirst = rangeIdx === 0;\n const isDraggedLast = rangeIdx === boxes.length - 1;\n\n if (!isDraggedFirst && clientX < draggedRangeBox.rect.left) {\n for (const box of boxes.slice(0, rangeIdx).reverse()) {\n if (clientX < box.rect.left) continue;\n if (!box.safeLeftBoundary) continue;\n return box.pos.from;\n }\n return boxes[0].pos.from;\n }\n\n if (!isDraggedLast && clientX > draggedRangeBox.rect.right) {\n for (const box of boxes.slice(rangeIdx + 1)) {\n if (clientX > box.rect.right) continue;\n if (!box.safeRightBoundary) continue;\n return box.pos.to;\n }\n return boxes.at(-1)!.pos.to;\n }\n\n return null;\n })();\n\n if (typeof pos === 'number') this._dropCursor.setPos(pos);\n else this._dropCursor.clear();\n }\n\n private _endDragging(\n draggedRange: Readonly<TableColumnRange>,\n initialTableDesc: TableDescBinded,\n ) {\n if (this._destroyed || !this._dragging) return;\n\n const point = this._dropCursor.getPos();\n this._clearDragging();\n this._logger.event({event: 'column-drag-end'});\n\n if (point === null) {\n this._editorView.focus();\n return;\n }\n\n const info = this._getTableDescAndCellInfo();\n if (!info || info.tableDesc.base !== initialTableDesc.base) {\n this._editorView.focus();\n return;\n }\n\n const currRangeFrom = (\n info.tableDesc.getPosForCell(0, draggedRange.startIdx) as RealCellPos\n ).from;\n const currRangeTo = (info.tableDesc.getPosForCell(0, draggedRange.endIdx) as RealCellPos)\n .to;\n\n if (point === currRangeFrom || point === currRangeTo) return;\n\n const targetColumnIndex = ((): number | null => {\n if (point === info.tableDesc.getPosForRow(0).to - 1) {\n return info.tableDesc.cols;\n }\n\n const cellNode = this._editorView.state.doc.nodeAt(point);\n if (!cellNode || cellNode.type.name !== YfmTableNode.Cell) return null;\n\n const cellInfo = info.tableDesc.base.getCellInfo(cellNode);\n if (!cellInfo) return null;\n\n return cellInfo.column;\n })();\n\n if (\n targetColumnIndex === null ||\n targetColumnIndex === info.cellInfo.column ||\n targetColumnIndex === info.cellInfo.column + 1\n ) {\n this._editorView.focus();\n return;\n }\n\n const {tr} = this._editorView.state;\n\n for (let rowIdx = 0; rowIdx < info.tableDesc.rows; rowIdx++) {\n const from = getCellPos(\n info.tableDesc.getPosForCell(rowIdx, draggedRange.startIdx),\n 'start',\n );\n const to = getCellPos(info.tableDesc.getPosForCell(rowIdx, draggedRange.endIdx), 'end');\n if (from === to) continue;\n\n let targetPos;\n if (targetColumnIndex === info.tableDesc.cols) {\n targetPos = info.tableDesc.getPosForRow(rowIdx).to - 1;\n } else if (targetColumnIndex === 0) {\n targetPos = info.tableDesc.getPosForRow(rowIdx).from + 1;\n } else {\n targetPos = getCellPos(\n info.tableDesc.getPosForCell(rowIdx, targetColumnIndex),\n 'start',\n );\n }\n\n if (targetPos !== from && targetPos !== to) {\n const fragment = tr.doc.slice(from, to, false).content;\n tr.insert(tr.mapping.map(targetPos), fragment);\n tr.delete(tr.mapping.map(from), tr.mapping.map(to));\n }\n }\n\n this._editorView.dispatch(tr.scrollIntoView());\n this._editorView.focus();\n }\n}\n\nfunction getCellPos(pos: CellPos, dir: 'start' | 'end'): number {\n if (pos.type === 'virtual') return pos.closestPos;\n return dir === 'start' ? pos.from : pos.to;\n}\n\nfunction isDragThresholdPassed(init: PageCoords, curr: PageCoords): boolean {\n return (\n Math.abs(init.pageX - curr.pageX) >= DRAG_START_THRESHOLD ||\n Math.abs(init.pageY - curr.pageY) >= DRAG_START_THRESHOLD\n );\n}\n"]}
@@ -17,6 +17,7 @@ import { FloatingMenuControl } from "../components/FloatingMenuControl/index.js"
17
17
  import { YfmTableDecorationType as DecoType, YfmTableDecorationTypeKey as decoTypeKey, } from "../const.js";
18
18
  import { YfmTableDnDHandler } from "../dnd/dnd.js";
19
19
  import { activateColumns, activateRows, deactivateColumn, deactivateRow, } from "../plugins/dnd-plugin.js";
20
+ import { getSelectedCellsForColumns, getSelectedCellsForRows } from "../utils.js";
20
21
  const dropCursorParams = {
21
22
  color: 'var(--g-color-line-brand)',
22
23
  width: 2,
@@ -141,7 +142,7 @@ class YfmTableCellView {
141
142
  const rowRange = info.tableDesc.base.getRowRangeByRowIdx(info.cell.row);
142
143
  const tr = activateRows(this._view.state.tr, {
143
144
  controlCell: { from: info.pos, to: info.pos + this._node.nodeSize },
144
- rows: iterate(rowRange.startIdx, rowRange.endIdx + 1).map((rowIdx) => info.tableDesc.getPosForRow(rowIdx)),
145
+ cells: getSelectedCellsForRows(info.tableDesc, rowRange),
145
146
  uniqKey: this._decoRowUniqKey,
146
147
  });
147
148
  this._view.dispatch(tr);
@@ -159,14 +160,10 @@ class YfmTableCellView {
159
160
  if (!info)
160
161
  return;
161
162
  this._decoColumnUniqKey = Date.now();
162
- const currColumnRange = info.tableDesc.base.getColumnRangeByColumnIdx(info.cell.column);
163
- const cells = [];
164
- for (const i of iterate(currColumnRange.startIdx, currColumnRange.endIdx + 1)) {
165
- cells.push(...info.tableDesc.getPosForColumn(i));
166
- }
163
+ const columnRange = info.tableDesc.base.getColumnRangeByColumnIdx(info.cell.column);
167
164
  const tr = activateColumns(this._view.state.tr, {
168
165
  controlCell: { from: info.pos, to: info.pos + this._node.nodeSize },
169
- cells: cells.filter((pos) => pos.type === 'real'),
166
+ cells: getSelectedCellsForColumns(info.tableDesc, columnRange),
170
167
  uniqKey: this._decoColumnUniqKey,
171
168
  });
172
169
  this._view.dispatch(tr);