@atlaskit/editor-plugin-block-controls 6.1.1 → 6.3.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.
- package/CHANGELOG.md +22 -0
- package/dist/cjs/pm-plugins/decorations-anchor.js +7 -3
- package/dist/cjs/pm-plugins/decorations-drop-target-active.js +2 -1
- package/dist/cjs/pm-plugins/handle-mouse-over.js +36 -12
- package/dist/cjs/pm-plugins/main.js +3 -2
- package/dist/cjs/pm-plugins/quick-insert-calculate-position.js +2 -1
- package/dist/cjs/pm-plugins/utils/anchor-utils.js +3 -2
- package/dist/cjs/ui/block-menu.js +3 -2
- package/dist/cjs/ui/drag-handle.js +12 -10
- package/dist/cjs/ui/drop-target-layout.js +4 -2
- package/dist/cjs/ui/drop-target.js +20 -6
- package/dist/cjs/ui/global-styles.js +96 -1
- package/dist/cjs/ui/inline-drop-target.js +39 -5
- package/dist/cjs/ui/quick-insert-button.js +3 -2
- package/dist/cjs/ui/utils/anchor-name.js +4 -0
- package/dist/cjs/ui/utils/dom-attr-name.js +53 -0
- package/dist/es2019/pm-plugins/decorations-anchor.js +7 -3
- package/dist/es2019/pm-plugins/decorations-drop-target-active.js +2 -1
- package/dist/es2019/pm-plugins/handle-mouse-over.js +30 -12
- package/dist/es2019/pm-plugins/main.js +3 -2
- package/dist/es2019/pm-plugins/quick-insert-calculate-position.js +2 -1
- package/dist/es2019/pm-plugins/utils/anchor-utils.js +3 -2
- package/dist/es2019/ui/block-menu.js +3 -2
- package/dist/es2019/ui/drag-handle.js +12 -10
- package/dist/es2019/ui/drop-target-layout.js +4 -2
- package/dist/es2019/ui/drop-target.js +20 -6
- package/dist/es2019/ui/global-styles.js +131 -1
- package/dist/es2019/ui/inline-drop-target.js +39 -5
- package/dist/es2019/ui/quick-insert-button.js +4 -3
- package/dist/es2019/ui/utils/anchor-name.js +4 -0
- package/dist/es2019/ui/utils/dom-attr-name.js +47 -0
- package/dist/esm/pm-plugins/decorations-anchor.js +7 -3
- package/dist/esm/pm-plugins/decorations-drop-target-active.js +2 -1
- package/dist/esm/pm-plugins/handle-mouse-over.js +35 -12
- package/dist/esm/pm-plugins/main.js +3 -2
- package/dist/esm/pm-plugins/quick-insert-calculate-position.js +2 -1
- package/dist/esm/pm-plugins/utils/anchor-utils.js +3 -2
- package/dist/esm/ui/block-menu.js +3 -2
- package/dist/esm/ui/drag-handle.js +12 -10
- package/dist/esm/ui/drop-target-layout.js +4 -2
- package/dist/esm/ui/drop-target.js +20 -6
- package/dist/esm/ui/global-styles.js +96 -1
- package/dist/esm/ui/inline-drop-target.js +39 -5
- package/dist/esm/ui/quick-insert-button.js +4 -3
- package/dist/esm/ui/utils/anchor-name.js +4 -0
- package/dist/esm/ui/utils/dom-attr-name.js +47 -0
- package/dist/types/pm-plugins/decorations-anchor.d.ts +2 -0
- package/dist/types/ui/utils/dom-attr-name.d.ts +5 -0
- package/dist/types-ts4.5/pm-plugins/decorations-anchor.d.ts +2 -0
- package/dist/types-ts4.5/ui/utils/dom-attr-name.d.ts +5 -0
- package/package.json +8 -8
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,27 @@
|
|
|
1
1
|
# @atlaskit/editor-plugin-block-controls
|
|
2
2
|
|
|
3
|
+
## 6.3.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- [`4fb6d9ad07d59`](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/commits/4fb6d9ad07d59) -
|
|
8
|
+
ED-28777 Integrate native anchor for block controls
|
|
9
|
+
|
|
10
|
+
### Patch Changes
|
|
11
|
+
|
|
12
|
+
- Updated dependencies
|
|
13
|
+
|
|
14
|
+
## 6.2.0
|
|
15
|
+
|
|
16
|
+
### Minor Changes
|
|
17
|
+
|
|
18
|
+
- [`b367661ba720e`](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/commits/b367661ba720e) -
|
|
19
|
+
EDITOR-1562 bump adf-schema for afm
|
|
20
|
+
|
|
21
|
+
### Patch Changes
|
|
22
|
+
|
|
23
|
+
- Updated dependencies
|
|
24
|
+
|
|
3
25
|
## 6.1.1
|
|
4
26
|
|
|
5
27
|
### Patch Changes
|
|
@@ -4,15 +4,16 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
-
exports.shouldDescendIntoNode = exports.nodeDecorations = exports.findNodeDecs = void 0;
|
|
7
|
+
exports.shouldDescendIntoNode = exports.nodeDecorations = exports.findNodeDecs = exports.IGNORE_NODE_DESCENDANTS_ADVANCED_LAYOUT = exports.IGNORE_NODES_NEXT = void 0;
|
|
8
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
9
9
|
var _view = require("@atlaskit/editor-prosemirror/view");
|
|
10
|
+
var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
|
|
10
11
|
var _experiments = require("@atlaskit/tmp-editor-statsig/experiments");
|
|
11
12
|
var _decorationsCommon = require("./decorations-common");
|
|
12
13
|
var IGNORE_NODES = ['tableCell', 'tableHeader', 'tableRow', 'listItem', 'caption', 'layoutColumn'];
|
|
13
|
-
var IGNORE_NODES_NEXT = ['tableCell', 'tableHeader', 'tableRow', 'listItem', 'caption'];
|
|
14
|
+
var IGNORE_NODES_NEXT = exports.IGNORE_NODES_NEXT = ['tableCell', 'tableHeader', 'tableRow', 'listItem', 'caption'];
|
|
14
15
|
var IGNORE_NODE_DESCENDANTS = ['listItem', 'taskList', 'decisionList', 'mediaSingle'];
|
|
15
|
-
var IGNORE_NODE_DESCENDANTS_ADVANCED_LAYOUT = ['listItem', 'taskList', 'decisionList'];
|
|
16
|
+
var IGNORE_NODE_DESCENDANTS_ADVANCED_LAYOUT = exports.IGNORE_NODE_DESCENDANTS_ADVANCED_LAYOUT = ['listItem', 'taskList', 'decisionList'];
|
|
16
17
|
var shouldDescendIntoNode = exports.shouldDescendIntoNode = function shouldDescendIntoNode(node) {
|
|
17
18
|
// Optimisation to avoid drawing node decorations for empty table cells
|
|
18
19
|
if (['tableCell', 'tableHeader'].includes(node.type.name)) {
|
|
@@ -106,6 +107,9 @@ var findNodeDecs = exports.findNodeDecs = function findNodeDecs(state, decoratio
|
|
|
106
107
|
};
|
|
107
108
|
var nodeDecorations = exports.nodeDecorations = function nodeDecorations(newState, from, to) {
|
|
108
109
|
var decs = [];
|
|
110
|
+
if ((0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true)) {
|
|
111
|
+
return [];
|
|
112
|
+
}
|
|
109
113
|
var docFrom = from === undefined || from < 0 ? 0 : from;
|
|
110
114
|
var docTo = to === undefined || to > newState.doc.nodeSize - 2 ? newState.doc.nodeSize - 2 : to;
|
|
111
115
|
var ignore_nodes = (0, _experiments.editorExperiment)('advanced_layouts', true) ? IGNORE_NODES_NEXT : IGNORE_NODES;
|
|
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.getActiveDropTargetDecorations = exports.canMoveNodeOrSliceToPos = void 0;
|
|
7
7
|
var _selection = require("@atlaskit/editor-common/selection");
|
|
8
8
|
var _utils = require("@atlaskit/editor-common/utils");
|
|
9
|
+
var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
|
|
9
10
|
var _experiments = require("@atlaskit/tmp-editor-statsig/experiments");
|
|
10
11
|
var _decorationsCommon = require("./decorations-common");
|
|
11
12
|
var _decorationsDropTarget = require("./decorations-drop-target");
|
|
@@ -232,7 +233,7 @@ var getActiveDropTargetDecorations = exports.getActiveDropTargetDecorations = fu
|
|
|
232
233
|
}
|
|
233
234
|
}
|
|
234
235
|
}
|
|
235
|
-
_activeAnchorTracker.defaultActiveAnchorTracker.emit((0, _decorationsCommon.getNodeAnchor)(rootNodeWithPos.node));
|
|
236
|
+
_activeAnchorTracker.defaultActiveAnchorTracker.emit((0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? api.core.actions.getAnchorIdForNode(rootNodeWithPos.node, rootNodeWithPos.pos) || '' : (0, _decorationsCommon.getNodeAnchor)(rootNodeWithPos.node));
|
|
236
237
|
return {
|
|
237
238
|
decsToAdd: decsToAdd,
|
|
238
239
|
decsToRemove: decsToRemove
|
|
@@ -1,12 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
3
4
|
Object.defineProperty(exports, "__esModule", {
|
|
4
5
|
value: true
|
|
5
6
|
});
|
|
6
7
|
exports.handleMouseOver = void 0;
|
|
8
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
9
|
+
var _memoizeOne = _interopRequireDefault(require("memoize-one"));
|
|
7
10
|
var _platformFeatureFlags = require("@atlaskit/platform-feature-flags");
|
|
11
|
+
var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
|
|
8
12
|
var _expValEqualsNoExposure = require("@atlaskit/tmp-editor-statsig/exp-val-equals-no-exposure");
|
|
9
13
|
var _experiments = require("@atlaskit/tmp-editor-statsig/experiments");
|
|
14
|
+
var _domAttrName = require("../ui/utils/dom-attr-name");
|
|
15
|
+
var _decorationsAnchor = require("./decorations-anchor");
|
|
10
16
|
var isEmptyNestedParagraphOrHeading = function isEmptyNestedParagraphOrHeading(target) {
|
|
11
17
|
if (target instanceof HTMLHeadingElement || target instanceof HTMLParagraphElement) {
|
|
12
18
|
var _target$parentElement;
|
|
@@ -14,6 +20,24 @@ var isEmptyNestedParagraphOrHeading = function isEmptyNestedParagraphOrHeading(t
|
|
|
14
20
|
}
|
|
15
21
|
return false;
|
|
16
22
|
};
|
|
23
|
+
var getNodeSelector = function getNodeSelector(ignoreNodes, ignoreNodeDescendants) {
|
|
24
|
+
var baseSelector = "[".concat(_domAttrName.NODE_ANCHOR_ATTR_NAME, "]");
|
|
25
|
+
if (ignoreNodes.length === 0 && ignoreNodeDescendants.length === 0) {
|
|
26
|
+
return baseSelector;
|
|
27
|
+
}
|
|
28
|
+
var ignoreNodeSelectorList = ignoreNodes.map(function (node) {
|
|
29
|
+
return "[data-prosemirror-node-name=\"".concat(node, "\"]");
|
|
30
|
+
});
|
|
31
|
+
var ignoreNodeDescendantsSelectorList = ignoreNodeDescendants.map(function (node) {
|
|
32
|
+
return "[data-prosemirror-node-name=\"".concat(node, "\"] [data-node-anchor]");
|
|
33
|
+
});
|
|
34
|
+
var ignoreSelector = [].concat((0, _toConsumableArray2.default)(ignoreNodeSelectorList), (0, _toConsumableArray2.default)(ignoreNodeDescendantsSelectorList), ['[data-prosemirror-node-inline="true"]']).join(', ');
|
|
35
|
+
return "".concat(baseSelector, ":not(").concat(ignoreSelector, ")");
|
|
36
|
+
};
|
|
37
|
+
var getDefaultNodeSelector = (0, _memoizeOne.default)(function () {
|
|
38
|
+
// we don't show handler for node nested in table
|
|
39
|
+
return getNodeSelector((0, _toConsumableArray2.default)(_decorationsAnchor.IGNORE_NODES_NEXT), [].concat((0, _toConsumableArray2.default)(_decorationsAnchor.IGNORE_NODE_DESCENDANTS_ADVANCED_LAYOUT), ['table']));
|
|
40
|
+
});
|
|
17
41
|
var handleMouseOver = exports.handleMouseOver = function handleMouseOver(view, event, api) {
|
|
18
42
|
var _api$blockControls, _api$editorDisabled, _target$classList;
|
|
19
43
|
var _ref = (api === null || api === void 0 || (_api$blockControls = api.blockControls) === null || _api$blockControls === void 0 ? void 0 : _api$blockControls.sharedState.currentState()) || {},
|
|
@@ -43,21 +67,21 @@ var handleMouseOver = exports.handleMouseOver = function handleMouseOver(view, e
|
|
|
43
67
|
if (target !== null && target !== void 0 && (_target$classList = target.classList) !== null && _target$classList !== void 0 && _target$classList.contains('ProseMirror')) {
|
|
44
68
|
return false;
|
|
45
69
|
}
|
|
46
|
-
var rootElement = target === null || target === void 0 ? void 0 : target.closest('[data-drag-handler-anchor-name]
|
|
70
|
+
var rootElement = target === null || target === void 0 ? void 0 : target.closest((0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? getDefaultNodeSelector() : "[data-drag-handler-anchor-name]");
|
|
47
71
|
if (rootElement) {
|
|
48
72
|
var _rootElement$parentEl;
|
|
49
73
|
// We want to exlude handles from showing for empty paragraph and heading nodes
|
|
50
74
|
if (isEmptyNestedParagraphOrHeading(rootElement)) {
|
|
51
75
|
return false;
|
|
52
76
|
}
|
|
53
|
-
if (rootElement.getAttribute(
|
|
54
|
-
rootElement = rootElement.closest(
|
|
77
|
+
if (rootElement.getAttribute((0, _domAttrName.getTypeNameAttrName)()) === 'media' && (0, _experiments.editorExperiment)('advanced_layouts', true)) {
|
|
78
|
+
rootElement = rootElement.closest("[".concat((0, _domAttrName.getAnchorAttrName)(), "][").concat((0, _domAttrName.getTypeNameAttrName)(), "=\"mediaSingle\"]"));
|
|
55
79
|
if (!rootElement) {
|
|
56
80
|
return false;
|
|
57
81
|
}
|
|
58
82
|
}
|
|
59
|
-
var parentElement = (_rootElement$parentEl = rootElement.parentElement) === null || _rootElement$parentEl === void 0 ? void 0 : _rootElement$parentEl.closest(
|
|
60
|
-
var parentElementType = parentElement === null || parentElement === void 0 ? void 0 : parentElement.getAttribute('data-drag-handler-node-type');
|
|
83
|
+
var parentElement = (_rootElement$parentEl = rootElement.parentElement) === null || _rootElement$parentEl === void 0 ? void 0 : _rootElement$parentEl.closest("[".concat((0, _domAttrName.getAnchorAttrName)(), "]"));
|
|
84
|
+
var parentElementType = (0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? (0, _domAttrName.getTypeNameFromDom)(parentElement) : parentElement === null || parentElement === void 0 ? void 0 : parentElement.getAttribute('data-drag-handler-node-type');
|
|
61
85
|
if ((0, _experiments.editorExperiment)('advanced_layouts', true)) {
|
|
62
86
|
// We want to exclude handles from showing for direct descendant of table nodes (i.e. nodes in cells)
|
|
63
87
|
if ((0, _platformFeatureFlags.fg)('platform_editor_table_drag_handle_shift_fix')) {
|
|
@@ -65,8 +89,8 @@ var handleMouseOver = exports.handleMouseOver = function handleMouseOver(view, e
|
|
|
65
89
|
rootElement = parentElement;
|
|
66
90
|
} else if (parentElement && parentElementType === 'tableRow') {
|
|
67
91
|
var _parentElement$parent;
|
|
68
|
-
var grandparentElement = parentElement === null || parentElement === void 0 || (_parentElement$parent = parentElement.parentElement) === null || _parentElement$parent === void 0 ? void 0 : _parentElement$parent.closest(
|
|
69
|
-
var grandparentElementType = grandparentElement === null || grandparentElement === void 0 ? void 0 : grandparentElement.getAttribute('data-drag-handler-node-type');
|
|
92
|
+
var grandparentElement = parentElement === null || parentElement === void 0 || (_parentElement$parent = parentElement.parentElement) === null || _parentElement$parent === void 0 ? void 0 : _parentElement$parent.closest("[".concat((0, _domAttrName.getAnchorAttrName)(), "]"));
|
|
93
|
+
var grandparentElementType = (0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? (0, _domAttrName.getTypeNameFromDom)(grandparentElement) : grandparentElement === null || grandparentElement === void 0 ? void 0 : grandparentElement.getAttribute('data-drag-handler-node-type');
|
|
70
94
|
if (grandparentElement && grandparentElementType === 'table') {
|
|
71
95
|
rootElement = grandparentElement;
|
|
72
96
|
}
|
|
@@ -83,7 +107,7 @@ var handleMouseOver = exports.handleMouseOver = function handleMouseOver(view, e
|
|
|
83
107
|
|
|
84
108
|
// Ignored via go/ees005
|
|
85
109
|
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
86
|
-
var anchorName = rootElement.getAttribute(
|
|
110
|
+
var anchorName = rootElement.getAttribute((0, _domAttrName.getAnchorAttrName)());
|
|
87
111
|
// No need to update handle position if its already there
|
|
88
112
|
if ((activeNode === null || activeNode === void 0 ? void 0 : activeNode.anchorName) === anchorName) {
|
|
89
113
|
return false;
|
|
@@ -124,13 +148,13 @@ var handleMouseOver = exports.handleMouseOver = function handleMouseOver(view, e
|
|
|
124
148
|
if (targetPos !== rootPos) {
|
|
125
149
|
var rootDOM = view.nodeDOM(rootPos);
|
|
126
150
|
if (rootDOM instanceof HTMLElement) {
|
|
127
|
-
var _rootDOM$getAttribute
|
|
128
|
-
rootAnchorName = (_rootDOM$getAttribute = rootDOM.getAttribute(
|
|
129
|
-
rootNodeType = (
|
|
151
|
+
var _rootDOM$getAttribute;
|
|
152
|
+
rootAnchorName = (_rootDOM$getAttribute = rootDOM.getAttribute((0, _domAttrName.getAnchorAttrName)())) !== null && _rootDOM$getAttribute !== void 0 ? _rootDOM$getAttribute : undefined;
|
|
153
|
+
rootNodeType = (0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? (0, _domAttrName.getTypeNameFromDom)(rootDOM) : rootDOM.getAttribute('data-drag-handler-node-type');
|
|
130
154
|
}
|
|
131
155
|
}
|
|
132
156
|
}
|
|
133
|
-
var nodeType = rootElement.getAttribute('data-drag-handler-node-type');
|
|
157
|
+
var nodeType = (0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? (0, _domAttrName.getTypeNameFromDom)(rootElement) : rootElement.getAttribute('data-drag-handler-node-type');
|
|
134
158
|
if (nodeType) {
|
|
135
159
|
if ((0, _experiments.editorExperiment)('platform_editor_controls', 'variant1')) {
|
|
136
160
|
var _api$core, _api$blockControls2;
|
|
@@ -24,6 +24,7 @@ var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
|
|
|
24
24
|
var _expValEqualsNoExposure = require("@atlaskit/tmp-editor-statsig/exp-val-equals-no-exposure");
|
|
25
25
|
var _experiments = require("@atlaskit/tmp-editor-statsig/experiments");
|
|
26
26
|
var _consts = require("../ui/consts");
|
|
27
|
+
var _domAttrName = require("../ui/utils/dom-attr-name");
|
|
27
28
|
var _decorationsAnchor = require("./decorations-anchor");
|
|
28
29
|
var _decorationsDragHandle = require("./decorations-drag-handle");
|
|
29
30
|
var _decorationsDropTarget = require("./decorations-drop-target");
|
|
@@ -642,7 +643,7 @@ var createPlugin = exports.createPlugin = function createPlugin(api, getIntl, no
|
|
|
642
643
|
event.preventDefault();
|
|
643
644
|
return false;
|
|
644
645
|
}
|
|
645
|
-
var nodeElement = (_event$target = event.target) === null || _event$target === void 0 || (_event$target$closest = _event$target.closest) === null || _event$target$closest === void 0 ? void 0 : _event$target$closest.call(_event$target,
|
|
646
|
+
var nodeElement = (_event$target = event.target) === null || _event$target === void 0 || (_event$target$closest = _event$target.closest) === null || _event$target$closest === void 0 ? void 0 : _event$target$closest.call(_event$target, "[".concat((0, _domAttrName.getAnchorAttrName)(), "]"));
|
|
646
647
|
if (!nodeElement) {
|
|
647
648
|
return false;
|
|
648
649
|
}
|
|
@@ -683,7 +684,7 @@ var createPlugin = exports.createPlugin = function createPlugin(api, getIntl, no
|
|
|
683
684
|
if (isHTMLElement(event.target)) {
|
|
684
685
|
var closestParentElement = event.target.closest('[data-drag-handler-anchor-depth="0"]');
|
|
685
686
|
if (closestParentElement) {
|
|
686
|
-
var currentAnchor = closestParentElement.getAttribute(
|
|
687
|
+
var currentAnchor = closestParentElement.getAttribute((0, _domAttrName.getAnchorAttrName)());
|
|
687
688
|
if (currentAnchor) {
|
|
688
689
|
_activeAnchorTracker.defaultActiveAnchorTracker.emit(currentAnchor);
|
|
689
690
|
}
|
|
@@ -8,6 +8,7 @@ exports.calculatePosition = void 0;
|
|
|
8
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
9
9
|
var _consts = require("../ui/consts");
|
|
10
10
|
var _anchorName = require("../ui/utils/anchor-name");
|
|
11
|
+
var _domAttrName = require("../ui/utils/dom-attr-name");
|
|
11
12
|
var _dragHandlePositions = require("./utils/drag-handle-positions");
|
|
12
13
|
var _widgetPositions = require("./utils/widget-positions");
|
|
13
14
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
@@ -31,7 +32,7 @@ var calculatePosition = exports.calculatePosition = function calculatePosition(_
|
|
|
31
32
|
view: view,
|
|
32
33
|
anchorName: rootAnchorName
|
|
33
34
|
});
|
|
34
|
-
var dom = view.dom.querySelector("[
|
|
35
|
+
var dom = view.dom.querySelector("[".concat((0, _domAttrName.getAnchorAttrName)(), "=\"").concat(safeAnchorName, "\"]"));
|
|
35
36
|
var hasResizer = rootNodeType === 'table' || rootNodeType === 'mediaSingle';
|
|
36
37
|
var isExtension = rootNodeType === 'extension' || rootNodeType === 'bodiedExtension';
|
|
37
38
|
var isBlockCard = rootNodeType === 'blockCard';
|
|
@@ -9,6 +9,7 @@ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/cl
|
|
|
9
9
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
10
10
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
11
11
|
var _memoizeOne = _interopRequireDefault(require("memoize-one"));
|
|
12
|
+
var _domAttrName = require("../../ui/utils/dom-attr-name");
|
|
12
13
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
13
14
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
14
15
|
var isAnchorSupported = exports.isAnchorSupported = (0, _memoizeOne.default)(function () {
|
|
@@ -37,9 +38,9 @@ var AnchorRectCache = exports.AnchorRectCache = /*#__PURE__*/function () {
|
|
|
37
38
|
value: function getRects() {
|
|
38
39
|
if (this.isDirty) {
|
|
39
40
|
var _this$view;
|
|
40
|
-
var anchorElements = ((_this$view = this.view) === null || _this$view === void 0 ? void 0 : _this$view.dom.querySelectorAll(
|
|
41
|
+
var anchorElements = ((_this$view = this.view) === null || _this$view === void 0 ? void 0 : _this$view.dom.querySelectorAll("[".concat((0, _domAttrName.getAnchorAttrName)(), "]"))) || [];
|
|
41
42
|
this.anchorRectMap = Array.from(anchorElements).reduce(function (prev, curr) {
|
|
42
|
-
var anchorName = curr.getAttribute(
|
|
43
|
+
var anchorName = curr.getAttribute((0, _domAttrName.getAnchorAttrName)());
|
|
43
44
|
if (anchorName) {
|
|
44
45
|
return _objectSpread(_objectSpread({}, prev), {}, (0, _defineProperty2.default)({}, anchorName, {
|
|
45
46
|
height: curr.clientHeight,
|
|
@@ -14,6 +14,7 @@ var _editorSharedStyles = require("@atlaskit/editor-shared-styles");
|
|
|
14
14
|
var _experiments = require("@atlaskit/tmp-editor-statsig/experiments");
|
|
15
15
|
var _blockMenuItems = require("./block-menu-items");
|
|
16
16
|
var _consts = require("./consts");
|
|
17
|
+
var _domAttrName = require("./utils/dom-attr-name");
|
|
17
18
|
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
|
|
18
19
|
var BlockMenuContent = function BlockMenuContent(_ref) {
|
|
19
20
|
var editorView = _ref.editorView,
|
|
@@ -23,7 +24,7 @@ var BlockMenuContent = function BlockMenuContent(_ref) {
|
|
|
23
24
|
api = _ref.api,
|
|
24
25
|
menuTriggerBy = _ref.menuTriggerBy,
|
|
25
26
|
formatMessage = _ref.formatMessage;
|
|
26
|
-
var activeNodeSelector = "[
|
|
27
|
+
var activeNodeSelector = "[".concat((0, _domAttrName.getAnchorAttrName)(), "=").concat(menuTriggerBy, "]");
|
|
27
28
|
var targetHandleRef = document.querySelector(activeNodeSelector);
|
|
28
29
|
var items = (0, _blockMenuItems.getBlockMenuItems)(formatMessage);
|
|
29
30
|
var handleOpenChange = (0, _react.useCallback)(function (payload) {
|
|
@@ -108,7 +109,7 @@ var BlockMenu = function BlockMenu(_ref3) {
|
|
|
108
109
|
formatMessage: formatMessage
|
|
109
110
|
});
|
|
110
111
|
}
|
|
111
|
-
var activeNodeSelector = "[
|
|
112
|
+
var activeNodeSelector = "[".concat((0, _domAttrName.getAnchorAttrName)(), "=").concat(menuTriggerBy, "]");
|
|
112
113
|
var targetHandleRef = document.querySelector(activeNodeSelector);
|
|
113
114
|
var items = (0, _blockMenuItems.getBlockMenuItems)(formatMessage);
|
|
114
115
|
var handleOpenChange = function handleOpenChange(payload) {
|
|
@@ -31,6 +31,7 @@ var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
|
|
|
31
31
|
var _expValEqualsNoExposure = require("@atlaskit/tmp-editor-statsig/exp-val-equals-no-exposure");
|
|
32
32
|
var _experiments = require("@atlaskit/tmp-editor-statsig/experiments");
|
|
33
33
|
var _tooltip = _interopRequireDefault(require("@atlaskit/tooltip"));
|
|
34
|
+
var _decorationsCommon = require("../pm-plugins/decorations-common");
|
|
34
35
|
var _main = require("../pm-plugins/main");
|
|
35
36
|
var _analytics2 = require("../pm-plugins/utils/analytics");
|
|
36
37
|
var _dragHandlePositions = require("../pm-plugins/utils/drag-handle-positions");
|
|
@@ -39,6 +40,7 @@ var _selection = require("../pm-plugins/utils/selection");
|
|
|
39
40
|
var _consts2 = require("./consts");
|
|
40
41
|
var _dragPreview = require("./drag-preview");
|
|
41
42
|
var _anchorName = require("./utils/anchor-name");
|
|
43
|
+
var _domAttrName = require("./utils/dom-attr-name");
|
|
42
44
|
var _visibilityContainer = require("./visibility-container");
|
|
43
45
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
44
46
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /**
|
|
@@ -326,7 +328,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
326
328
|
}
|
|
327
329
|
// blockCard/datasource width is rendered correctly after this decoraton does. We need to observe for changes.
|
|
328
330
|
if (nodeType === 'blockCard') {
|
|
329
|
-
var dom = view.dom.querySelector("[
|
|
331
|
+
var dom = view.dom.querySelector("[".concat((0, _domAttrName.getAnchorAttrName)(), "=\"").concat(anchorName, "\"]"));
|
|
330
332
|
var container = dom === null || dom === void 0 ? void 0 : dom.querySelector('.datasourceView-content-inner-wrap');
|
|
331
333
|
if (container) {
|
|
332
334
|
var resizeObserver = new ResizeObserver(function (entries) {
|
|
@@ -545,7 +547,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
545
547
|
},
|
|
546
548
|
render: function render(_ref6) {
|
|
547
549
|
var container = _ref6.container;
|
|
548
|
-
var dom = view.dom.querySelector("[
|
|
550
|
+
var dom = view.dom.querySelector("[".concat((0, _domAttrName.getAnchorAttrName)(), "=\"").concat(anchorName, "\"]"));
|
|
549
551
|
if (!dom) {
|
|
550
552
|
return;
|
|
551
553
|
}
|
|
@@ -628,7 +630,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
628
630
|
setRecalculatePosition(recalculatePosition);
|
|
629
631
|
}
|
|
630
632
|
var pos = getPos();
|
|
631
|
-
var $pos = pos && view.state.doc.resolve(pos);
|
|
633
|
+
var $pos = (0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? typeof pos === 'number' && view.state.doc.resolve(pos) : pos && view.state.doc.resolve(pos);
|
|
632
634
|
var parentPos = $pos && $pos.depth ? $pos.before() : undefined;
|
|
633
635
|
var node = parentPos !== undefined ? view.state.doc.nodeAt(parentPos) : undefined;
|
|
634
636
|
var parentNodeType = node === null || node === void 0 ? void 0 : node.type.name;
|
|
@@ -638,7 +640,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
638
640
|
view: view,
|
|
639
641
|
anchorName: anchorName
|
|
640
642
|
}) : anchorName;
|
|
641
|
-
var dom = view.dom.querySelector("[
|
|
643
|
+
var dom = view.dom.querySelector("[".concat((0, _domAttrName.getAnchorAttrName)(), "=\"").concat(safeAnchorName, "\"]"));
|
|
642
644
|
var hasResizer = nodeType === 'table' || nodeType === 'mediaSingle';
|
|
643
645
|
var isExtension = nodeType === 'extension' || nodeType === 'bodiedExtension' || nodeType === 'multiBodiedExtension' && (0, _platformFeatureFlags.fg)('platform_editor_multi_body_extension_extensibility');
|
|
644
646
|
var isBlockCard = nodeType === 'blockCard';
|
|
@@ -663,7 +665,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
663
665
|
var bottom = (0, _experiments.editorExperiment)('platform_editor_controls', 'variant1') ? (0, _dragHandlePositions.getControlBottomCSSValue)(safeAnchorName, isSticky, isTopLevelNode, isLayoutColumn) : {};
|
|
664
666
|
return _objectSpread({
|
|
665
667
|
left: isEdgeCase ? "calc(anchor(".concat(safeAnchorName, " start) + ").concat((0, _dragHandlePositions.getLeftPosition)(dom, nodeType, innerContainer, isMacroInteractionUpdates, parentNodeType), ")") : (0, _experiments.editorExperiment)('advanced_layouts', true) && isLayoutColumn ? "calc((anchor(".concat(safeAnchorName, " right) + anchor(").concat(safeAnchorName, " left))/2 - ").concat(_consts2.DRAG_HANDLE_HEIGHT / 2, "px)") : "calc(anchor(".concat(safeAnchorName, " start) - ").concat(_styles.DRAG_HANDLE_WIDTH, "px - ").concat((0, _consts2.dragHandleGap)(nodeType, parentNodeType), "px)"),
|
|
666
|
-
top: (0, _experiments.editorExperiment)('advanced_layouts', true) && isLayoutColumn ? "calc(anchor(".concat(safeAnchorName, " top) - ").concat(_styles.DRAG_HANDLE_WIDTH, "px)") : "calc(anchor(".concat(safeAnchorName, " start) + ").concat((0,
|
|
668
|
+
top: (0, _experiments.editorExperiment)('advanced_layouts', true) && isLayoutColumn ? "calc(anchor(".concat(safeAnchorName, " top) - ").concat(_styles.DRAG_HANDLE_WIDTH, "px)") : "calc(anchor(".concat(safeAnchorName, " start) + ").concat((0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? $pos && $pos.nodeAfter && (0, _decorationsCommon.getNodeTypeWithLevel)($pos.nodeAfter) || nodeType : nodeType, "px)")
|
|
667
669
|
}, bottom);
|
|
668
670
|
}
|
|
669
671
|
var height = (0, _experiments.editorExperiment)('platform_editor_controls', 'variant1') ? (0, _dragHandlePositions.getControlHeightCSSValue)((0, _dragHandlePositions.getNodeHeight)(dom, safeAnchorName, anchorRectCache) || 0, isSticky, isTopLevelNode, "".concat(_consts2.DRAG_HANDLE_HEIGHT), isLayoutColumn) : {};
|
|
@@ -674,7 +676,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
674
676
|
}, [anchorName, getPos, view, nodeType, macroInteractionUpdates, anchorRectCache, isTopLevelNode, isLayoutColumn, recalculatePosition]);
|
|
675
677
|
var calculatePositionOld = (0, _react.useCallback)(function () {
|
|
676
678
|
var pos = getPos();
|
|
677
|
-
var $pos = pos && view.state.doc.resolve(pos);
|
|
679
|
+
var $pos = (0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? typeof pos === 'number' && view.state.doc.resolve(pos) : pos && view.state.doc.resolve(pos);
|
|
678
680
|
var parentPos = $pos && $pos.depth ? $pos.before() : undefined;
|
|
679
681
|
var node = parentPos !== undefined ? view.state.doc.nodeAt(parentPos) : undefined;
|
|
680
682
|
var parentNodeType = node === null || node === void 0 ? void 0 : node.type.name;
|
|
@@ -684,7 +686,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
684
686
|
view: view,
|
|
685
687
|
anchorName: anchorName
|
|
686
688
|
}) : anchorName;
|
|
687
|
-
var dom = view.dom.querySelector("[
|
|
689
|
+
var dom = view.dom.querySelector("[".concat((0, _domAttrName.getAnchorAttrName)(), "=\"").concat(safeAnchorName, "\"]"));
|
|
688
690
|
var hasResizer = nodeType === 'table' || nodeType === 'mediaSingle';
|
|
689
691
|
var isExtension = nodeType === 'extension' || nodeType === 'bodiedExtension' || nodeType === 'multiBodiedExtension' && (0, _platformFeatureFlags.fg)('platform_editor_multi_body_extension_extensibility');
|
|
690
692
|
var isBlockCard = nodeType === 'blockCard' && !!blockCardWidth;
|
|
@@ -709,7 +711,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
709
711
|
var bottom = (0, _experiments.editorExperiment)('platform_editor_controls', 'variant1') ? (0, _dragHandlePositions.getControlBottomCSSValue)(safeAnchorName, isSticky, isTopLevelNode, isLayoutColumn) : {};
|
|
710
712
|
return _objectSpread({
|
|
711
713
|
left: isEdgeCase ? "calc(anchor(".concat(safeAnchorName, " start) + ").concat((0, _dragHandlePositions.getLeftPosition)(dom, nodeType, innerContainer, isMacroInteractionUpdates, parentNodeType), ")") : (0, _experiments.editorExperiment)('advanced_layouts', true) && isLayoutColumn ? "calc((anchor(".concat(safeAnchorName, " right) + anchor(").concat(safeAnchorName, " left))/2 - ").concat(_consts2.DRAG_HANDLE_HEIGHT / 2, "px)") : "calc(anchor(".concat(safeAnchorName, " start) - ").concat(_styles.DRAG_HANDLE_WIDTH, "px - ").concat((0, _consts2.dragHandleGap)(nodeType, parentNodeType), "px)"),
|
|
712
|
-
top: (0, _experiments.editorExperiment)('advanced_layouts', true) && isLayoutColumn ? "calc(anchor(".concat(safeAnchorName, " top) - ").concat(_styles.DRAG_HANDLE_WIDTH, "px)") : "calc(anchor(".concat(safeAnchorName, " start) + ").concat((0, _consts2.topPositionAdjustment)(nodeType), "px)")
|
|
714
|
+
top: (0, _experiments.editorExperiment)('advanced_layouts', true) && isLayoutColumn ? "calc(anchor(".concat(safeAnchorName, " top) - ").concat(_styles.DRAG_HANDLE_WIDTH, "px)") : "calc(anchor(".concat(safeAnchorName, " start) + ").concat((0, _consts2.topPositionAdjustment)((0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? $pos && $pos.nodeAfter && (0, _decorationsCommon.getNodeTypeWithLevel)($pos.nodeAfter) || nodeType : nodeType), "px)")
|
|
713
715
|
}, bottom);
|
|
714
716
|
}
|
|
715
717
|
var height = (0, _experiments.editorExperiment)('platform_editor_controls', 'variant1') ? (0, _dragHandlePositions.getControlHeightCSSValue)((0, _dragHandlePositions.getNodeHeight)(dom, safeAnchorName, anchorRectCache) || 0, isSticky, isTopLevelNode, "".concat(_consts2.DRAG_HANDLE_HEIGHT), isLayoutColumn) : {};
|
|
@@ -724,7 +726,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
724
726
|
}
|
|
725
727
|
var cleanUpTransitionListener;
|
|
726
728
|
if (nodeType === 'extension' || nodeType === 'embedCard') {
|
|
727
|
-
var dom = view.dom.querySelector("[
|
|
729
|
+
var dom = view.dom.querySelector("[".concat((0, _domAttrName.getAnchorAttrName)(), "=\"").concat(anchorName, "\"]"));
|
|
728
730
|
if (!dom) {
|
|
729
731
|
return;
|
|
730
732
|
}
|
|
@@ -750,7 +752,7 @@ var DragHandle = exports.DragHandle = function DragHandle(_ref) {
|
|
|
750
752
|
}
|
|
751
753
|
var cleanUpTransitionListener;
|
|
752
754
|
if (nodeType === 'extension' || nodeType === 'embedCard') {
|
|
753
|
-
var dom = view.dom.querySelector("[
|
|
755
|
+
var dom = view.dom.querySelector("[".concat((0, _domAttrName.getAnchorAttrName)(), "=\"").concat(anchorName, "\"]"));
|
|
754
756
|
if (!dom) {
|
|
755
757
|
return;
|
|
756
758
|
}
|
|
@@ -13,10 +13,12 @@ var _editorSharedStyles = require("@atlaskit/editor-shared-styles");
|
|
|
13
13
|
var _box = require("@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box");
|
|
14
14
|
var _adapter = require("@atlaskit/pragmatic-drag-and-drop/element/adapter");
|
|
15
15
|
var _colors = require("@atlaskit/theme/colors");
|
|
16
|
+
var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
|
|
16
17
|
var _decorationsCommon = require("../pm-plugins/decorations-common");
|
|
17
18
|
var _activeAnchorTracker = require("../pm-plugins/utils/active-anchor-tracker");
|
|
18
19
|
var _anchorUtils = require("../pm-plugins/utils/anchor-utils");
|
|
19
20
|
var _updateSelection = require("../pm-plugins/utils/update-selection");
|
|
21
|
+
var _domAttrName = require("./utils/dom-attr-name");
|
|
20
22
|
/**
|
|
21
23
|
* @jsxRuntime classic
|
|
22
24
|
* @jsx jsx
|
|
@@ -53,7 +55,7 @@ var DropTargetLayout = exports.DropTargetLayout = function DropTargetLayout(prop
|
|
|
53
55
|
isDraggedOver = _useState2[0],
|
|
54
56
|
setIsDraggedOver = _useState2[1];
|
|
55
57
|
var anchorName = (0, _decorationsCommon.getNodeAnchor)(parent);
|
|
56
|
-
var nextNodeAnchorName = (_ref$current = ref.current) === null || _ref$current === void 0 || (_ref$current = _ref$current.parentElement) === null || _ref$current === void 0 || (_ref$current = _ref$current.nextElementSibling) === null || _ref$current === void 0 ? void 0 : _ref$current.getAttribute(
|
|
58
|
+
var nextNodeAnchorName = (_ref$current = ref.current) === null || _ref$current === void 0 || (_ref$current = _ref$current.parentElement) === null || _ref$current === void 0 || (_ref$current = _ref$current.nextElementSibling) === null || _ref$current === void 0 ? void 0 : _ref$current.getAttribute((0, _domAttrName.getAnchorAttrName)());
|
|
57
59
|
var height = '100%';
|
|
58
60
|
if (nextNodeAnchorName) {
|
|
59
61
|
if ((0, _anchorUtils.isAnchorSupported)()) {
|
|
@@ -127,7 +129,7 @@ var DropTargetLayout = exports.DropTargetLayout = function DropTargetLayout(prop
|
|
|
127
129
|
}, isDraggedOver ? (0, _react2.jsx)(_box.DropIndicator, {
|
|
128
130
|
edge: "right",
|
|
129
131
|
gap: "-".concat(DROP_TARGET_LAYOUT_DROP_ZONE_WIDTH, "px")
|
|
130
|
-
}) : isActiveAnchor && (0, _react2.jsx)("div", {
|
|
132
|
+
}) : (isActiveAnchor || (0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true)) && (0, _react2.jsx)("div", {
|
|
131
133
|
"data-testid": "block-ctrl-drop-hint"
|
|
132
134
|
// eslint-disable-next-line @atlaskit/design-system/consistent-css-prop-usage
|
|
133
135
|
,
|
|
@@ -14,6 +14,7 @@ var _hooks = require("@atlaskit/editor-common/hooks");
|
|
|
14
14
|
var _box = require("@atlaskit/pragmatic-drag-and-drop-react-drop-indicator/box");
|
|
15
15
|
var _adapter = require("@atlaskit/pragmatic-drag-and-drop/element/adapter");
|
|
16
16
|
var _constants = require("@atlaskit/theme/constants");
|
|
17
|
+
var _expValEquals = require("@atlaskit/tmp-editor-statsig/exp-val-equals");
|
|
17
18
|
var _experiments = require("@atlaskit/tmp-editor-statsig/experiments");
|
|
18
19
|
var _decorationsCommon = require("../pm-plugins/decorations-common");
|
|
19
20
|
var _activeAnchorTracker = require("../pm-plugins/utils/active-anchor-tracker");
|
|
@@ -79,17 +80,26 @@ var HoverZone = function HoverZone(_ref) {
|
|
|
79
80
|
onDragLeave = _ref.onDragLeave,
|
|
80
81
|
onDrop = _ref.onDrop,
|
|
81
82
|
node = _ref.node,
|
|
83
|
+
pos = _ref.pos,
|
|
82
84
|
parent = _ref.parent,
|
|
83
85
|
editorWidth = _ref.editorWidth,
|
|
84
86
|
anchorRectCache = _ref.anchorRectCache,
|
|
85
87
|
position = _ref.position,
|
|
86
88
|
isNestedDropTarget = _ref.isNestedDropTarget,
|
|
87
|
-
dropTargetStyle = _ref.dropTargetStyle
|
|
89
|
+
dropTargetStyle = _ref.dropTargetStyle,
|
|
90
|
+
api = _ref.api;
|
|
88
91
|
var ref = (0, _react.useRef)(null);
|
|
89
92
|
var isRemainingheight = dropTargetStyle === 'remainingHeight';
|
|
90
93
|
var anchorName = (0, _react.useMemo)(function () {
|
|
94
|
+
if ((0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true)) {
|
|
95
|
+
if (node && typeof pos === 'number') {
|
|
96
|
+
var posOffset = position === 'upper' ? -node.nodeSize : 0;
|
|
97
|
+
return (api === null || api === void 0 ? void 0 : api.core.actions.getAnchorIdForNode(node, pos + posOffset)) || '';
|
|
98
|
+
}
|
|
99
|
+
return '';
|
|
100
|
+
}
|
|
91
101
|
return node ? (0, _decorationsCommon.getNodeAnchor)(node) : '';
|
|
92
|
-
}, [node]);
|
|
102
|
+
}, [api, node, pos, position]);
|
|
93
103
|
var _useActiveAnchorTrack = (0, _activeAnchorTracker.useActiveAnchorTracker)(anchorName),
|
|
94
104
|
_useActiveAnchorTrack2 = (0, _slicedToArray2.default)(_useActiveAnchorTrack, 2),
|
|
95
105
|
_isActive = _useActiveAnchorTrack2[0],
|
|
@@ -134,7 +144,7 @@ var HoverZone = function HoverZone(_ref) {
|
|
|
134
144
|
// only apply upper drop zone
|
|
135
145
|
if (isRemainingheight && position === 'upper') {
|
|
136
146
|
// previous node
|
|
137
|
-
var _anchorName = node ? (0, _decorationsCommon.getNodeAnchor)(node) : '';
|
|
147
|
+
var _anchorName = node ? (0, _expValEquals.expValEquals)('platform_editor_native_anchor_support', 'isEnabled', true) ? (api === null || api === void 0 ? void 0 : api.core.actions.getAnchorIdForNode(node, pos || -1)) || '' : (0, _decorationsCommon.getNodeAnchor)(node) : '';
|
|
138
148
|
var top = 'unset';
|
|
139
149
|
if (_anchorName) {
|
|
140
150
|
var enabledDropZone = enableDropZone.includes((node === null || node === void 0 ? void 0 : node.type.name) || '');
|
|
@@ -162,7 +172,7 @@ var HoverZone = function HoverZone(_ref) {
|
|
|
162
172
|
});
|
|
163
173
|
}
|
|
164
174
|
return null;
|
|
165
|
-
}, [anchorRectCache, isRemainingheight, node, position]);
|
|
175
|
+
}, [anchorRectCache, api, isRemainingheight, node, pos, position]);
|
|
166
176
|
var isFullHeightInLayout = isRemainingheight && (parent === null || parent === void 0 ? void 0 : parent.type.name) === 'layoutColumn';
|
|
167
177
|
return (0, _react2.jsx)("div", {
|
|
168
178
|
ref: ref
|
|
@@ -228,11 +238,13 @@ var DropTarget = exports.DropTarget = function DropTarget(props) {
|
|
|
228
238
|
},
|
|
229
239
|
onDrop: onDrop,
|
|
230
240
|
node: prevNode,
|
|
241
|
+
pos: getPos(),
|
|
231
242
|
editorWidth: lineLength,
|
|
232
243
|
anchorRectCache: anchorRectCache,
|
|
233
244
|
position: "upper",
|
|
234
245
|
isNestedDropTarget: isNestedDropTarget,
|
|
235
|
-
dropTargetStyle: dropTargetStyle
|
|
246
|
+
dropTargetStyle: dropTargetStyle,
|
|
247
|
+
api: api
|
|
236
248
|
}), (0, _react2.jsx)("div", {
|
|
237
249
|
// eslint-disable-next-line @atlaskit/design-system/consistent-css-prop-usage
|
|
238
250
|
css: [styleDropTarget, isNestedDropTarget && nestedDropIndicatorStyle]
|
|
@@ -254,11 +266,13 @@ var DropTarget = exports.DropTarget = function DropTarget(props) {
|
|
|
254
266
|
},
|
|
255
267
|
onDrop: onDrop,
|
|
256
268
|
node: nextNode,
|
|
269
|
+
pos: getPos(),
|
|
257
270
|
parent: parentNode,
|
|
258
271
|
editorWidth: lineLength,
|
|
259
272
|
anchorRectCache: anchorRectCache,
|
|
260
273
|
position: "lower",
|
|
261
|
-
isNestedDropTarget: isNestedDropTarget
|
|
274
|
+
isNestedDropTarget: isNestedDropTarget,
|
|
275
|
+
api: api
|
|
262
276
|
}), (0, _inlineDropTarget.shouldAllowInlineDropTarget)(isNestedDropTarget, nextNode, isSameLayout, activeNode) && (0, _react2.jsx)(_react.Fragment, null, (0, _react2.jsx)(_inlineDropTarget2.InlineDropTarget
|
|
263
277
|
// Ignored via go/ees005
|
|
264
278
|
// eslint-disable-next-line react/jsx-props-no-spreading
|