editor.execCommand( commandName );\r
},\r
this);\r
+\r
+ this.definition =\r
+ {\r
+ panel:\r
+ {\r
+ className : editor.skinClass + ' cke_contextmenu',\r
+ attributes :\r
+ {\r
+ 'aria-label' : editor.lang.contextmenu.options\r
+ }\r
+ }\r
+ };\r
},\r
\r
_ :\r
}\r
else\r
{\r
- menu = this._.menu = new CKEDITOR.menu( editor );\r
+ menu = this._.menu = new CKEDITOR.menu( editor, this.definition );\r
menu.onClick = CKEDITOR.tools.bind( function( item )\r
{\r
menu.hide();\r
\r
}, this );\r
\r
- menu.onEscape = function()\r
+ menu.onEscape = function( keystroke )\r
{\r
- editor.focus();\r
+ var parent = this.parent;\r
+ // 1. If it's sub-menu, restore the last focused item\r
+ // of upper level menu.\r
+ // 2. In case of a top-menu, close it.\r
+ if ( parent )\r
+ {\r
+ parent._.panel.hideChild();\r
+ // Restore parent block item focus.\r
+ var parentBlock = parent._.panel._.panel._.currentBlock,\r
+ parentFocusIndex = parentBlock._.focusIndex;\r
+ parentBlock._.markItem( parentFocusIndex );\r
+ }\r
+ else if ( keystroke == 27 )\r
+ {\r
+ this.hide();\r
+ editor.focus();\r
+ }\r
+ return false;\r
};\r
}\r
\r
}\r
\r
if ( nativeContextMenuOnCtrl\r
- && ( evt.$.ctrlKey || evt.$.metaKey ) )\r
+ && ( CKEDITOR.env.mac ? evt.$.metaKey : evt.$.ctrlKey ) )\r
return;\r
\r
var target = evt.getTarget();\r
if ( nativeContextMenuOnCtrl &&\r
// Safari on Windows always show 'ctrlKey' as true in 'contextmenu' event,\r
// which make this property unreliable. (#4826)\r
- ( CKEDITOR.env.webkit ? holdCtrlKey : domEvent.$.ctrlKey || domEvent.$.metaKey ) )\r
+ ( CKEDITOR.env.webkit ? holdCtrlKey : ( CKEDITOR.env.mac ? domEvent.$.metaKey : domEvent.$.ctrlKey ) ) )\r
return;\r
\r
- // Selection will be unavailable after context menu shows up\r
- // in IE, lock it now.\r
- if ( CKEDITOR.env.ie )\r
- {\r
- var selection = this.editor.getSelection();\r
- selection && selection.lock();\r
- }\r
\r
// Cancel the browser context menu.\r
domEvent.preventDefault();\r
\r
CKEDITOR.tools.setTimeout( function()\r
{\r
- this._.onMenu( offsetParent, null, offsetX, offsetY );\r
+ this.show( offsetParent, null, offsetX, offsetY );\r
},\r
0, this );\r
},\r
var holdCtrlKey,\r
onKeyDown = function( event )\r
{\r
- holdCtrlKey = event.data.$.ctrlKey || event.data.$.metaKey;\r
+ holdCtrlKey = CKEDITOR.env.mac ? event.data.$.metaKey : event.data.$.ctrlKey ;\r
},\r
resetOnKeyUp = function()\r
{\r
show : function( offsetParent, corner, offsetX, offsetY )\r
{\r
this.editor.focus();\r
+\r
+ // Selection will be unavailable after context menu shows up\r
+ // in IE, lock it now.\r
+ if ( CKEDITOR.env.ie )\r
+ {\r
+ var selection = this.editor.getSelection();\r
+ selection && selection.lock();\r
+ }\r
+\r
this._.onMenu( offsetParent || CKEDITOR.document.getDocumentElement(), corner, offsetX || 0, offsetY || 0 );\r
}\r
}\r