Ticket #3492: 3492_4.patch

File 3492_4.patch, 6.6 KB (added by Tobiasz Cudnik, 12 years ago)
  • _source/skins/v2/dialog.css

     
    1 /*
     1/*
    22Copyright (c) 2003-2009, CKSource - Frederico Knabben. All rights reserved.
    33For licensing, see LICENSE.html or http://ckeditor.com/license
    44*/
     
    591591{
    592592        color: #a0a0a0;
    593593}
     594
     595.cke_skin_v2 a.cke_smile img
     596{
     597        /* IE6 does not support transparent borders */
     598        border: 2px solid #eaead1;
     599}
     600
     601.cke_skin_v2 a.cke_smile:focus img,
     602.cke_skin_v2 a.cke_smile:active img,
     603.cke_skin_v2 a.cke_smile:hover img
     604{
     605        border-color: #C7C78F;
     606}
     607 No newline at end of file
  • _source/plugins/smiley/dialogs/smiley.js

     
    1 /*
     1/*
    22Copyright (c) 2003-2009, CKSource - Frederico Knabben. All rights reserved.
    33For licensing, see LICENSE.html or http://ckeditor.com/license
    44*/
     
    1010                columns = config.smiley_columns,
    1111                i;
    1212
     13        /**
     14         * Simulate "this" of a dialog for non-dialog events.
     15         * @type {CKEDITOR.dialog}
     16         */
     17        var dialog;
     18        var onClick = function( evt )
     19        {
     20                var target = evt.data.getTarget(),
     21                        targetName = target.getName();
     22
     23                if ( targetName == 'td' )
     24                        target = target.getChild( [ 0, 0 ] );
     25                else if ( targetName == 'a' )
     26                        target = target.getChild( 0 );
     27                else if ( targetName != 'img' )
     28                        return;
     29
     30                var src = target.getAttribute( 'cke_src' ),
     31                        title = target.getAttribute( 'title' );
     32
     33                var img = editor.document.createElement( 'img',
     34                        {
     35                                attributes :
     36                                {
     37                                        src : src,
     38                                        _cke_saved_src : src,
     39                                        title : title,
     40                                        alt : title
     41                                }
     42                        });
     43
     44                editor.insertElement( img );
     45
     46                dialog.hide();
     47        }
     48
     49        var onKeydown = CKEDITOR.tools.addFunction( function( ev, element )
     50        {
     51                ev = new CKEDITOR.dom.event( ev );
     52                element = new CKEDITOR.dom.element( element );
     53                var relative, nodeToMove;
     54
     55                var keystroke = ev.getKeystroke();
     56                switch ( keystroke )
     57                {
     58                        // RIGHT-ARROW
     59                        case 39 :
     60                                // relative is TD
     61                                if ( ( relative = element.getParent().getNext() ) )
     62                                {
     63                                        nodeToMove = relative.getChild( 0 );
     64                                        nodeToMove.focus();
     65                                }
     66                                ev.preventDefault();
     67                                break;
     68                        // LEFT-ARROW
     69                        case 37 :
     70                                // relative is TD
     71                                if ( ( relative = element.getParent().getPrevious() ) )
     72                                {
     73                                        nodeToMove = relative.getChild( 0 );
     74                                        nodeToMove.focus();
     75                                }
     76                                ev.preventDefault();
     77                                break;
     78                        // UP-ARROW
     79                        case 38 :
     80                                // relative is TR
     81                                if ( ( relative = element.getParent().getParent().getPrevious() ) )
     82                                {
     83                                        nodeToMove = relative.getChild( [element.getParent().getIndex(), 0] );
     84                                        nodeToMove.focus();
     85                                }
     86                                ev.preventDefault();
     87                                break;
     88                        // DOWN-ARROW
     89                        case 40 :
     90                                // relative is TR
     91                                if ( ( relative = element.getParent().getParent().getNext() ) )
     92                                {
     93                                        nodeToMove = relative.getChild( [element.getParent().getIndex(), 0] );
     94                                        if ( nodeToMove )
     95                                                nodeToMove.focus();
     96                                }
     97                                ev.preventDefault();
     98                                break;
     99                        // ENTER
     100                        // SPACE
     101                        case 13 :
     102                        case 32 :
     103                                onClick( { data: ev } );
     104                                ev.preventDefault();
     105                                break;
     106                        // TAB
     107                        case 9 :
     108                                // relative is TD
     109                                if ( ( relative = element.getParent().getNext() ) )
     110                                {
     111                                        nodeToMove = relative.getChild( 0 );
     112                                        nodeToMove.focus();
     113                                        ev.preventDefault(true);
     114                                }
     115                                // relative is TR
     116                                else if ( ( relative = element.getParent().getParent().getNext() ) )
     117                                {
     118                                        nodeToMove = relative.getChild( [0, 0] );
     119                                        if ( nodeToMove )
     120                                                nodeToMove.focus();
     121                                        ev.preventDefault(true);
     122                                }
     123                                break;
     124                        // SHIFT + TAB
     125                        case CKEDITOR.SHIFT + 9 :
     126                                // relative is TD
     127                                if ( ( relative = element.getParent().getPrevious() ) )
     128                                {
     129                                        nodeToMove = relative.getChild( 0 );
     130                                        nodeToMove.focus();
     131                                        ev.preventDefault(true);
     132                                }
     133                                // relative is TR
     134                                else if ( ( relative = element.getParent().getParent().getPrevious() ) )
     135                                {
     136                                        nodeToMove = relative.getLast().getChild( 0 );
     137                                        nodeToMove.focus();
     138                                        ev.preventDefault(true);
     139                                }
     140                                break;
     141                        default :
     142                                // Do not stop not handled events.
     143                                return;
     144                }
     145        });
     146
    13147        // Build the HTML for the smiley images table.
    14148        var html =
    15149        [
     
    25159
    26160                html.push(
    27161                        '<td class="dark_background hand centered" style="vertical-align: middle;">' +
    28                                 '<img border="0" class="hand" title="', config.smiley_descriptions[i], '"' +
    29                                         ' cke_src="', CKEDITOR.tools.htmlEncode( config.smiley_path + images[ i ] ), '"',
    30                                         ' src="', CKEDITOR.tools.htmlEncode( config.smiley_path + images[ i ] ), '"',
    31                                         // IE BUG: Below is a workaround to an IE image loading bug to ensure the image sizes are correct.
    32                                         ( CKEDITOR.env.ie ? ' onload="this.setAttribute(\'width\', 2); this.removeAttribute(\'width\');" ' : '' ),
    33                                 '>' +
    34                         '</td>' );
     162                                '<a class="cke_smile" tabindex="-1" onkeydown="CKEDITOR.tools.callFunction( ', onKeydown, ', event, this );">',
     163                                        '<img class="hand" title="', config.smiley_descriptions[i], '"' +
     164                                                ' cke_src="', CKEDITOR.tools.htmlEncode( config.smiley_path + images[ i ] ), '"',
     165                                                ' src="', CKEDITOR.tools.htmlEncode( config.smiley_path + images[ i ] ), '"',
     166                                                // IE BUG: Below is a workaround to an IE image loading bug to ensure the image sizes are correct.
     167                                                ( CKEDITOR.env.ie ? ' onload="this.setAttribute(\'width\', 2); this.removeAttribute(\'width\');" ' : '' ),
     168                                        '>' +
     169                                '</a>',
     170                        '</td>' );
    35171
    36172                if ( i % columns == columns - 1 )
    37173                        html.push( '</tr>' );
     
    50186        {
    51187                type : 'html',
    52188                html : html.join( '' ),
    53                 onClick : function( evt )
     189                onLoad : function( event )
    54190                {
    55                         var target = evt.data.getTarget(),
    56                                 targetName = target.getName();
    57 
    58                         if ( targetName == 'td' )
    59                                 target = target.getChild(0);
    60                         else if ( targetName != 'img' )
    61                                 return;
    62 
    63                         var src = target.getAttribute( 'cke_src' ),
    64                                 title = target.getAttribute( 'title' );
    65 
    66                         var img = editor.document.createElement( 'img',
    67                                 {
    68                                         attributes :
    69                                         {
    70                                                 src : src,
    71                                                 _cke_saved_src : src,
    72                                                 title : title,
    73                                                 alt : title
    74                                         }
    75                                 });
    76 
    77                         editor.insertElement( img );
    78 
    79                         this.getDialog().hide();
    80                 },
     191                        dialog = event.sender;
     192                },
     193                focus : function()
     194                {
     195                        var firstSmile = this.getElement().getChild( [0, 0, 0, 0] );
     196                        firstSmile.focus();
     197                },
     198                onClick : onClick,
    81199                style : 'width: 100%; height: 100%; border-collapse: separate;'
    82200        };
    83201
© 2003 – 2021 CKSource – Frederico Knabben. All rights reserved. | Terms of use | Privacy policy