var itemKeystroke = function( item, keystroke )\r
{\r
var next, nextToolGroup, groupItemsCount;\r
+ var rtl = editor.lang.dir == 'rtl';\r
\r
switch ( keystroke )\r
{\r
- case 39 : // RIGHT-ARROW\r
+ case rtl ? 37 : 39 : // RIGHT-ARROW\r
case 9 : // TAB\r
do\r
{\r
- // Look for the previous item in the toolbar.\r
+ // Look for the next item in the toolbar.\r
next = item.next;\r
\r
if ( !next )\r
\r
return false;\r
\r
- case 37 : // LEFT-ARROW\r
+ case rtl ? 39 : 37 : // LEFT-ARROW\r
case CKEDITOR.SHIFT + 9 : // SHIFT + TAB\r
do\r
{\r
{\r
editor.toolbox = new toolbox();\r
\r
- var labelId = 'cke_' + CKEDITOR.tools.getNextNumber();\r
+ var labelId = CKEDITOR.tools.getNextId();\r
\r
- var output = [ '<div class="cke_toolbox" role="toolbar" aria-labelledby="', labelId, '"' ],\r
+ var output = [ '<div class="cke_toolbox" role="toolbar" aria-labelledby="', labelId, '" onmousedown="return false;"' ],\r
expanded = editor.config.toolbarStartupExpanded !== false,\r
groupStarted;\r
\r
if ( !row )\r
continue;\r
\r
- var toolbarId = 'cke_' + CKEDITOR.tools.getNextNumber(),\r
+ var toolbarId = CKEDITOR.tools.getNextId(),\r
toolbarObj = { id : toolbarId, items : [] };\r
\r
if ( groupStarted )\r
function()\r
{\r
editor.execCommand( 'toolbarCollapse' );\r
- } );\r
+ });\r
+\r
+ editor.on( 'destroy', function () {\r
+ CKEDITOR.tools.removeFunction( collapserFn );\r
+ });\r
\r
- var collapserId = 'cke_' + CKEDITOR.tools.getNextNumber();\r
+ var collapserId = CKEDITOR.tools.getNextId();\r
\r
editor.addCommand( 'toolbarCollapse',\r
{\r
exec : function( editor )\r
{\r
- var collapser = CKEDITOR.document.getById( collapserId );\r
- var toolbox = collapser.getPrevious();\r
- var contents = editor.getThemeSpace( 'contents' );\r
- var toolboxContainer = toolbox.getParent();\r
- var contentHeight = parseInt( contents.$.style.height, 10 );\r
- var previousHeight = toolboxContainer.$.offsetHeight;\r
- var collapsed = !toolbox.isVisible();\r
+ var collapser = CKEDITOR.document.getById( collapserId ),\r
+ toolbox = collapser.getPrevious(),\r
+ contents = editor.getThemeSpace( 'contents' ),\r
+ toolboxContainer = toolbox.getParent(),\r
+ contentHeight = parseInt( contents.$.style.height, 10 ),\r
+ previousHeight = toolboxContainer.$.offsetHeight,\r
+ collapsed = !toolbox.isVisible();\r
\r
if ( !collapsed )\r
{\r
* ['Form', 'Checkbox', 'Radio', 'TextField', 'Textarea', 'Select', 'Button', 'ImageButton', 'HiddenField'],\r
* '/',\r
* ['Bold','Italic','Underline','Strike','-','Subscript','Superscript'],\r
- * ['NumberedList','BulletedList','-','Outdent','Indent','Blockquote'],\r
+ * ['NumberedList','BulletedList','-','Outdent','Indent','Blockquote','CreateDiv'],\r
* ['JustifyLeft','JustifyCenter','JustifyRight','JustifyBlock'],\r
+ * ['BidiLtr', 'BidiRtl' ],\r
* ['Link','Unlink','Anchor'],\r
* ['Image','Flash','Table','HorizontalRule','Smiley','SpecialChar','PageBreak'],\r
* '/',\r
['Bold','Italic','Underline','Strike','-','Subscript','Superscript'],\r
['NumberedList','BulletedList','-','Outdent','Indent','Blockquote','CreateDiv'],\r
['JustifyLeft','JustifyCenter','JustifyRight','JustifyBlock'],\r
+ ['BidiLtr', 'BidiRtl' ],\r
['Link','Unlink','Anchor'],\r
['Image','Flash','Table','HorizontalRule','Smiley','SpecialChar','PageBreak'],\r
'/',\r