jenkins-bot has submitted this change and it was merged.

Change subject: Fix cursoring inside a caption node
......................................................................


Fix cursoring inside a caption node

Instead of checking if the table node is being editing, just check
if the first contenteditable ancestor is ce=true. This catches the
caption node case, and any future case where we might put ce=true
nodes inside ce=false nodes.

Bug: T96356
Change-Id: I03d90b7917a357fecf345b9b6c5cc100ac9fac27
---
M src/ce/ve.ce.Surface.js
1 file changed, 6 insertions(+), 5 deletions(-)

Approvals:
  Divec: Looks good to me, approved
  jenkins-bot: Verified



diff --git a/src/ce/ve.ce.Surface.js b/src/ce/ve.ce.Surface.js
index 33e797e..d3970a2 100644
--- a/src/ce/ve.ce.Surface.js
+++ b/src/ce/ve.ce.Surface.js
@@ -1287,7 +1287,7 @@
         * @returns {ve.ce.Node|null} node, or null if not in a focusable node
         */
        function getSurroundingFocusableNode( node, offset, direction ) {
-               var focusNode, $focusableNode;
+               var focusNode, $focusNode;
                if ( node.nodeType === Node.TEXT_NODE ) {
                        focusNode = node;
                } else if ( direction > 0 && offset < node.childNodes.length ) {
@@ -1297,12 +1297,13 @@
                } else {
                        focusNode = node;
                }
-               $focusableNode = $( focusNode ).closest( '.ve-ce-focusableNode, 
.ve-ce-tableNode' );
-               // If the first thing we found was a table node in editing 
mode, ignore it.
-               if ( $focusableNode.hasClass( 've-ce-tableNode-editing' ) ) {
+               $focusNode = $( focusNode );
+               // If the first ancestor with contenteditable set is ce=true, 
then we are allowed
+               // to be inside this focusalbe node (e.g. editing a table cell 
or caption)
+               if ( $focusNode.closest( '[contenteditable]' ).prop( 
'contenteditable' ) ) {
                        return null;
                }
-               return $focusableNode.data( 'view' ) || null;
+               return $focusNode.closest( '.ve-ce-focusableNode, 
.ve-ce-tableNode' ).data( 'view' ) || null;
        }
 
        /**

-- 
To view, visit https://gerrit.wikimedia.org/r/204739
To unsubscribe, visit https://gerrit.wikimedia.org/r/settings

Gerrit-MessageType: merged
Gerrit-Change-Id: I03d90b7917a357fecf345b9b6c5cc100ac9fac27
Gerrit-PatchSet: 1
Gerrit-Project: VisualEditor/VisualEditor
Gerrit-Branch: master
Gerrit-Owner: Esanders <esand...@wikimedia.org>
Gerrit-Reviewer: Catrope <roan.katt...@gmail.com>
Gerrit-Reviewer: Divec <da...@sheetmusic.org.uk>
Gerrit-Reviewer: jenkins-bot <>

_______________________________________________
MediaWiki-commits mailing list
MediaWiki-commits@lists.wikimedia.org
https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits

Reply via email to