123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297 |
- /**
- * @license Copyright (c) 2003-2015, CKSource - Frederico Knabben. All rights reserved.
- * For licensing, see LICENSE.md or http://ckeditor.com/license
- */
- CKEDITOR.dialog.add( 'specialchar', function( editor ) {
- // Simulate "this" of a dialog for non-dialog events.
- // @type {CKEDITOR.dialog}
- var dialog,
- lang = editor.lang.specialchar;
- var onChoice = function( evt ) {
- var target, value;
- if ( evt.data )
- target = evt.data.getTarget();
- else
- target = new CKEDITOR.dom.element( evt );
- if ( target.getName() == 'a' && ( value = target.getChild( 0 ).getHtml() ) ) {
- target.removeClass( 'cke_light_background' );
- dialog.hide();
- // We must use "insertText" here to keep text styled.
- var span = editor.document.createElement( 'span' );
- span.setHtml( value );
- editor.insertText( span.getText() );
- }
- };
- var onClick = CKEDITOR.tools.addFunction( onChoice );
- var focusedNode;
- var onFocus = function( evt, target ) {
- var value;
- target = target || evt.data.getTarget();
- if ( target.getName() == 'span' )
- target = target.getParent();
- if ( target.getName() == 'a' && ( value = target.getChild( 0 ).getHtml() ) ) {
- // Trigger blur manually if there is focused node.
- if ( focusedNode )
- onBlur( null, focusedNode );
- var htmlPreview = dialog.getContentElement( 'info', 'htmlPreview' ).getElement();
- dialog.getContentElement( 'info', 'charPreview' ).getElement().setHtml( value );
- htmlPreview.setHtml( CKEDITOR.tools.htmlEncode( value ) );
- target.getParent().addClass( 'cke_light_background' );
- // Memorize focused node.
- focusedNode = target;
- }
- };
- var onBlur = function( evt, target ) {
- target = target || evt.data.getTarget();
- if ( target.getName() == 'span' )
- target = target.getParent();
- if ( target.getName() == 'a' ) {
- dialog.getContentElement( 'info', 'charPreview' ).getElement().setHtml( ' ' );
- dialog.getContentElement( 'info', 'htmlPreview' ).getElement().setHtml( ' ' );
- target.getParent().removeClass( 'cke_light_background' );
- focusedNode = undefined;
- }
- };
- var onKeydown = CKEDITOR.tools.addFunction( function( ev ) {
- ev = new CKEDITOR.dom.event( ev );
- // Get an Anchor element.
- var element = ev.getTarget();
- var relative, nodeToMove;
- var keystroke = ev.getKeystroke(),
- rtl = editor.lang.dir == 'rtl';
- switch ( keystroke ) {
- // UP-ARROW
- case 38:
- // relative is TR
- if ( ( relative = element.getParent().getParent().getPrevious() ) ) {
- nodeToMove = relative.getChild( [ element.getParent().getIndex(), 0 ] );
- nodeToMove.focus();
- onBlur( null, element );
- onFocus( null, nodeToMove );
- }
- ev.preventDefault();
- break;
- // DOWN-ARROW
- case 40:
- // relative is TR
- if ( ( relative = element.getParent().getParent().getNext() ) ) {
- nodeToMove = relative.getChild( [ element.getParent().getIndex(), 0 ] );
- if ( nodeToMove && nodeToMove.type == 1 ) {
- nodeToMove.focus();
- onBlur( null, element );
- onFocus( null, nodeToMove );
- }
- }
- ev.preventDefault();
- break;
- // SPACE
- // ENTER is already handled as onClick
- case 32:
- onChoice( { data: ev } );
- ev.preventDefault();
- break;
- // RIGHT-ARROW
- case rtl ? 37 : 39:
- // relative is TD
- if ( ( relative = element.getParent().getNext() ) ) {
- nodeToMove = relative.getChild( 0 );
- if ( nodeToMove.type == 1 ) {
- nodeToMove.focus();
- onBlur( null, element );
- onFocus( null, nodeToMove );
- ev.preventDefault( true );
- } else {
- onBlur( null, element );
- }
- }
- // relative is TR
- else if ( ( relative = element.getParent().getParent().getNext() ) ) {
- nodeToMove = relative.getChild( [ 0, 0 ] );
- if ( nodeToMove && nodeToMove.type == 1 ) {
- nodeToMove.focus();
- onBlur( null, element );
- onFocus( null, nodeToMove );
- ev.preventDefault( true );
- } else {
- onBlur( null, element );
- }
- }
- break;
- // LEFT-ARROW
- case rtl ? 39 : 37:
- // relative is TD
- if ( ( relative = element.getParent().getPrevious() ) ) {
- nodeToMove = relative.getChild( 0 );
- nodeToMove.focus();
- onBlur( null, element );
- onFocus( null, nodeToMove );
- ev.preventDefault( true );
- }
- // relative is TR
- else if ( ( relative = element.getParent().getParent().getPrevious() ) ) {
- nodeToMove = relative.getLast().getChild( 0 );
- nodeToMove.focus();
- onBlur( null, element );
- onFocus( null, nodeToMove );
- ev.preventDefault( true );
- } else {
- onBlur( null, element );
- }
- break;
- default:
- // Do not stop not handled events.
- return;
- }
- } );
- return {
- title: lang.title,
- minWidth: 430,
- minHeight: 280,
- buttons: [ CKEDITOR.dialog.cancelButton ],
- charColumns: 17,
- onLoad: function() {
- var columns = this.definition.charColumns,
- chars = editor.config.specialChars;
- var charsTableLabel = CKEDITOR.tools.getNextId() + '_specialchar_table_label';
- var html = [ '<table role="listbox" aria-labelledby="' + charsTableLabel + '"' +
- ' style="width: 320px; height: 100%; border-collapse: separate;"' +
- ' align="center" cellspacing="2" cellpadding="2" border="0">' ];
- var i = 0,
- size = chars.length,
- character, charDesc;
- while ( i < size ) {
- html.push( '<tr role="presentation">' );
- for ( var j = 0; j < columns; j++, i++ ) {
- if ( ( character = chars[ i ] ) ) {
- charDesc = '';
- if ( character instanceof Array ) {
- charDesc = character[ 1 ];
- character = character[ 0 ];
- } else {
- var _tmpName = character.replace( '&', '' ).replace( ';', '' ).replace( '#', '' );
- // Use character in case description unavailable.
- charDesc = lang[ _tmpName ] || character;
- }
- var charLabelId = 'cke_specialchar_label_' + i + '_' + CKEDITOR.tools.getNextNumber();
- html.push( '<td class="cke_dark_background" style="cursor: default" role="presentation">' +
- '<a href="javascript: void(0);" role="option"' +
- ' aria-posinset="' + ( i + 1 ) + '"', ' aria-setsize="' + size + '"', ' aria-labelledby="' + charLabelId + '"', ' class="cke_specialchar" title="', CKEDITOR.tools.htmlEncode( charDesc ), '"' +
- ' onkeydown="CKEDITOR.tools.callFunction( ' + onKeydown + ', event, this )"' +
- ' onclick="CKEDITOR.tools.callFunction(' + onClick + ', this); return false;"' +
- ' tabindex="-1">' +
- '<span style="margin: 0 auto;cursor: inherit">' +
- character +
- '</span>' +
- '<span class="cke_voice_label" id="' + charLabelId + '">' +
- charDesc +
- '</span></a>' );
- } else {
- html.push( '<td class="cke_dark_background"> ' );
- }
- html.push( '</td>' );
- }
- html.push( '</tr>' );
- }
- html.push( '</tbody></table>', '<span id="' + charsTableLabel + '" class="cke_voice_label">' + lang.options + '</span>' );
- this.getContentElement( 'info', 'charContainer' ).getElement().setHtml( html.join( '' ) );
- },
- contents: [ {
- id: 'info',
- label: editor.lang.common.generalTab,
- title: editor.lang.common.generalTab,
- padding: 0,
- align: 'top',
- elements: [ {
- type: 'hbox',
- align: 'top',
- widths: [ '320px', '90px' ],
- children: [ {
- type: 'html',
- id: 'charContainer',
- html: '',
- onMouseover: onFocus,
- onMouseout: onBlur,
- focus: function() {
- var firstChar = this.getElement().getElementsByTag( 'a' ).getItem( 0 );
- setTimeout( function() {
- firstChar.focus();
- onFocus( null, firstChar );
- }, 0 );
- },
- onShow: function() {
- var firstChar = this.getElement().getChild( [ 0, 0, 0, 0, 0 ] );
- setTimeout( function() {
- firstChar.focus();
- onFocus( null, firstChar );
- }, 0 );
- },
- onLoad: function( event ) {
- dialog = event.sender;
- }
- },
- {
- type: 'hbox',
- align: 'top',
- widths: [ '100%' ],
- children: [ {
- type: 'vbox',
- align: 'top',
- children: [
- {
- type: 'html',
- html: '<div></div>'
- },
- {
- type: 'html',
- id: 'charPreview',
- className: 'cke_dark_background',
- style: 'border:1px solid #eeeeee;font-size:28px;height:40px;width:70px;padding-top:9px;font-family:\'Microsoft Sans Serif\',Arial,Helvetica,Verdana;text-align:center;',
- html: '<div> </div>'
- },
- {
- type: 'html',
- id: 'htmlPreview',
- className: 'cke_dark_background',
- style: 'border:1px solid #eeeeee;font-size:14px;height:20px;width:70px;padding-top:2px;font-family:\'Microsoft Sans Serif\',Arial,Helvetica,Verdana;text-align:center;',
- html: '<div> </div>'
- }
- ]
- } ]
- } ]
- } ]
- } ]
- };
- } );
|