Now all modules are in core modules folder

This commit is contained in:
Manuel Cillero 2017-08-08 12:14:45 +02:00
parent 5ba1cdfa0b
commit 05b6a91b0c
1907 changed files with 0 additions and 0 deletions

View file

@ -0,0 +1,114 @@
form {
padding: 0;
margin: 0;
}
.panel_wrapper {
display: none;
}
/*
.panel_wrap {
border: 1px solid #919b9c;
border-top: 0;
padding: .5em 0;
margin: 0;
background: #fff;
float: left;
width: 100%;
}*/
.panel_wrap .panel {
display: none;
}
.panel_wrap .current {
display: block;
width: 100%;
height: auto;
}
label {
margin-bottom: .5em;
display: block;
}
#form_browse {
margin: 0 .5em;
}
.mceActionPanel {
float: left;
margin: .5em 0 0 0;
}
.panel_wrap .nodes {
margin: 0;
padding: 0;
}
#nodelist {
padding: 0;
height: 13.5em;
width: 96%;
overflow: auto;
border: #D5D59D;
}
th {
font-size: 11px;
border-bottom: 1px solid #D5D59D;
}
td {
text-align: left;
padding: .05em .5em .05em 0;
white-space: nowrap;
}
tr {
cursor: pointer;
}
tr.head {
cursor: auto;
}
td.nid {
display: none;
}
#statusImg {
display: block;
position: absolute;
left: 15px;
top: 125px;
width: 90%;
font-size: 14px;
color: #333333;
width: auto;
padding-right: .5em;
line-height: 82px;
vertical-align: middle;
}
#statusImg img {
margin: 36px 10px;
float: left;
}
#browse_panel select {
background: #FFF;
}
#nodelist table {
margin: 5px
}
#nodelist table tr {
border: 1px #e0e0e0;
border-collapse: collapse;
}
#nodelist table tr td {
cursor: pointer;
}

View file

@ -0,0 +1,827 @@
/*
Copyright (c) 2003-2013, CKSource - Frederico Knabben. All rights reserved.
For licensing, see LICENSE.html or http://ckeditor.com/license
*/
CKEDITOR.dialog.add( 'linktomenu', function( editor )
{
//<!-- linktonode START -->
CKEDITOR.scriptLoader.load( Drupal.settings.basePath + "misc/jquery.js");
CKEDITOR.scriptLoader.load( Drupal.settings.ckeditor.module_path + "/plugins/linktomenu/jscripts/functions.js", function() {
loadCategories(null);
});
//<!-- linktonode END -->
// Handles the event when the "Target" selection box is changed.
var targetChanged = function()
{
var dialog = this.getDialog(),
popupFeatures = dialog.getContentElement( 'target', 'popupFeatures' ),
targetName = dialog.getContentElement( 'target', 'linkTargetName' ),
value = this.getValue();
if ( !popupFeatures || !targetName )
return;
popupFeatures = popupFeatures.getElement();
if ( value == 'popup' )
{
popupFeatures.show();
targetName.setLabel( editor.lang.link.targetPopupName );
}
else
{
popupFeatures.hide();
targetName.setLabel( editor.lang.link.targetFrameName );
this.getDialog().setValueOf( 'target', 'linkTargetName', value.charAt( 0 ) == '_' ? value : '' );
}
};
// Loads the parameters in a selected link to the link dialog fields.
var emailRegex = /^mailto:([^?]+)(?:\?(.+))?$/,
emailSubjectRegex = /subject=([^;?:@&=$,\/]*)/,
emailBodyRegex = /body=([^;?:@&=$,\/]*)/,
anchorRegex = /^#(.*)$/,
urlRegex = /^((?:http|https|ftp|news):\/\/)?(.*)$/,
selectableTargets = /^(_(?:self|top|parent|blank))$/;
var popupRegex =
/\s*window.open\(\s*this\.href\s*,\s*(?:'([^']*)'|null)\s*,\s*'([^']*)'\s*\)\s*;\s*return\s*false;*\s*/;
var popupFeaturesRegex = /(?:^|,)([^=]+)=(\d+|yes|no)/gi;
var parseLink = function( editor, element )
{
var href = element ? ( element.getAttribute( '_cke_saved_href' ) || element.getAttribute( 'href' ) ) : '',
emailMatch = '',
anchorMatch = '',
urlMatch = false,
retval = {};
if ( href )
{
emailMatch = href.match( emailRegex );
anchorMatch = href.match( anchorRegex );
urlMatch = href.match( urlRegex );
}
// Load the link type and URL.
if ( emailMatch )
{
var subjectMatch = href.match( emailSubjectRegex ),
bodyMatch = href.match( emailBodyRegex );
retval.type = 'email';
retval.email = {};
retval.email.address = emailMatch[1];
subjectMatch && ( retval.email.subject = decodeURIComponent( subjectMatch[1] ) );
bodyMatch && ( retval.email.body = decodeURIComponent( bodyMatch[1] ) );
}
else if ( anchorMatch )
{
retval.type = 'anchor';
retval.anchor = {};
retval.anchor.name = retval.anchor.id = anchorMatch[1];
}
else if ( href && urlMatch ) // urlRegex matches empty strings, so need to check for href as well.
{
retval.type = 'url';
retval.url = {};
retval.url.protocol = urlMatch[1];
retval.url.url = urlMatch[2];
}
else
retval.type = 'url';
// Load target and popup settings.
if ( element )
{
var target = element.getAttribute( 'target' );
retval.target = {};
retval.adv = {};
// IE BUG: target attribute is an empty string instead of null in IE if it's not set.
if ( !target )
{
var onclick = element.getAttribute( '_cke_pa_onclick' ) || element.getAttribute( 'onclick' ),
onclickMatch = onclick && onclick.match( popupRegex );
if ( onclickMatch )
{
retval.target.type = 'popup';
retval.target.name = onclickMatch[1];
var featureMatch;
while ( ( featureMatch = popupFeaturesRegex.exec( onclickMatch[2] ) ) )
{
if ( featureMatch[2] == 'yes' || featureMatch[2] == '1' )
retval.target[ featureMatch[1] ] = true;
else if ( isFinite( featureMatch[2] ) )
retval.target[ featureMatch[1] ] = featureMatch[2];
}
}
}
else
{
var targetMatch = target.match( selectableTargets );
if ( targetMatch )
retval.target.type = retval.target.name = target;
else
{
retval.target.type = 'frame';
retval.target.name = target;
}
}
var me = this;
var advAttr = function( inputName, attrName )
{
var value = element.getAttribute( attrName );
if ( value !== null )
retval.adv[ inputName ] = value || '';
};
advAttr( 'advId', 'id' );
advAttr( 'advLangDir', 'dir' );
advAttr( 'advAccessKey', 'accessKey' );
advAttr( 'advName', 'name' );
advAttr( 'advLangCode', 'lang' );
advAttr( 'advTabIndex', 'tabindex' );
advAttr( 'advTitle', 'title' );
advAttr( 'advContentType', 'type' );
advAttr( 'advCSSClasses', 'class' );
advAttr( 'advCharset', 'charset' );
advAttr( 'advStyles', 'style' );
}
// Find out whether we have any anchors in the editor.
// Get all IMG elements in CK document.
var elements = editor.document.getElementsByTag( 'img' ),
realAnchors = new CKEDITOR.dom.nodeList( editor.document.$.anchors ),
anchors = retval.anchors = [];
for( var i = 0; i < elements.count() ; i++ )
{
var item = elements.getItem( i );
if ( item.getAttribute( '_cke_realelement' ) && item.getAttribute( '_cke_real_element_type' ) == 'anchor' )
{
anchors.push( editor.restoreRealElement( item ) );
}
}
for ( i = 0 ; i < realAnchors.count() ; i++ )
anchors.push( realAnchors.getItem( i ) );
for ( i = 0 ; i < anchors.length ; i++ )
{
item = anchors[ i ];
anchors[ i ] = { name : item.getAttribute( 'name' ), id : item.getAttribute( 'id' ) };
}
// Record down the selected element in the dialog.
this._.selectedElement = element;
return retval;
};
var setupParams = function( page, data )
{
if ( data[page] )
this.setValue( data[page][this.id] || '' );
};
var setupPopupParams = function( data )
{
return setupParams.call( this, 'target', data );
};
var setupAdvParams = function( data )
{
return setupParams.call( this, 'adv', data );
};
var commitParams = function( page, data )
{
if ( !data[page] )
data[page] = {};
data[page][this.id] = this.getValue() || '';
};
var commitPopupParams = function( data )
{
return commitParams.call( this, 'target', data );
};
var commitAdvParams = function( data )
{
return commitParams.call( this, 'adv', data );
};
return {
title : 'Link to menu',
minWidth : 350,
minHeight : 230,
contents : [
{
id : 'info',
label : editor.lang.link.info,
title : editor.lang.link.info,
elements :
[
{
type : 'html',
html :
'<link rel="stylesheet" href="' + Drupal.settings.ckeditor.module_path + '/plugins/linktomenu/css/linktocontent.css" type="text/css" />' +
'<input id="linktomenu_url" type="hidden" />' +
'<input id="linktomenu_text" type="hidden" />' +
'<div class="panel_wrap">' +
'<div id="browse_panel" class="panel current">' +
'<form id="form_browse" action="#" onsubmit="return false;">' +
'<strong>Browse</strong>' +
'</form>' +
'</div>' +
'</div>' +
'<!-- node list -->' +
'<div class="panel_wrap" id="list">' +
'<div class="nodes">' +
'<div id="nodelist" class="scrollable accessible">' +
'<table cellspacing="0" summary="item list">' +
'<thead>' +
'<tr>' +
'<th><strong>Title</strong></th>' +
'</tr>' +
'</thead>' +
'<tbody>' +
'</tbody>' +
'</table>' +
'</div>' +
'</div>' +
'</div>' +
'<div id="statusImg"><img alt="loading" src="' + Drupal.settings.ckeditor.module_path + '/plugins/linktomenu/images/loading.gif" />loading...</div>'
}
]
},
{
id : 'target',
label : editor.lang.link.target,
title : editor.lang.link.target,
elements :
[
{
type : 'hbox',
widths : [ '50%', '50%' ],
children :
[
{
type : 'select',
id : 'linkTargetType',
label : editor.lang.link.target,
'default' : 'notSet',
style : 'width : 100%;',
'items' :
[
[ editor.lang.link.targetNotSet, 'notSet' ],
[ editor.lang.link.targetFrame, 'frame' ],
[ editor.lang.link.targetPopup, 'popup' ],
[ editor.lang.link.targetNew, '_blank' ],
[ editor.lang.link.targetTop, '_top' ],
[ editor.lang.link.targetSelf, '_self' ],
[ editor.lang.link.targetParent, '_parent' ]
],
onChange : targetChanged,
setup : function( data )
{
if ( data.target )
this.setValue( data.target.type );
},
commit : function( data )
{
if ( !data.target )
data.target = {};
data.target.type = this.getValue();
}
},
{
type : 'text',
id : 'linkTargetName',
label : editor.lang.link.targetFrameName,
'default' : '',
setup : function( data )
{
if ( data.target )
this.setValue( data.target.name );
},
commit : function( data )
{
if ( !data.target )
data.target = {};
data.target.name = this.getValue();
}
}
]
},
{
type : 'vbox',
width : 260,
align : 'center',
padding : 2,
id : 'popupFeatures',
children :
[
{
type : 'html',
html : CKEDITOR.tools.htmlEncode( editor.lang.link.popupFeatures )
},
{
type : 'hbox',
children :
[
{
type : 'checkbox',
id : 'resizable',
label : editor.lang.link.popupResizable,
setup : setupPopupParams,
commit : commitPopupParams
},
{
type : 'checkbox',
id : 'status',
label : editor.lang.link.popupStatusBar,
setup : setupPopupParams,
commit : commitPopupParams
}
]
},
{
type : 'hbox',
children :
[
{
type : 'checkbox',
id : 'location',
label : editor.lang.link.popupLocationBar,
setup : setupPopupParams,
commit : commitPopupParams
},
{
type : 'checkbox',
id : 'toolbar',
label : editor.lang.link.popupToolbar,
setup : setupPopupParams,
commit : commitPopupParams
}
]
},
{
type : 'hbox',
children :
[
{
type : 'checkbox',
id : 'menubar',
label : editor.lang.link.popupMenuBar,
setup : setupPopupParams,
commit : commitPopupParams
},
{
type : 'checkbox',
id : 'fullscreen',
label : editor.lang.link.popupFullScreen,
setup : setupPopupParams,
commit : commitPopupParams
}
]
},
{
type : 'hbox',
children :
[
{
type : 'checkbox',
id : 'scrollbars',
label : editor.lang.link.popupScrollBars,
setup : setupPopupParams,
commit : commitPopupParams
},
{
type : 'checkbox',
id : 'dependent',
label : editor.lang.link.popupDependent,
setup : setupPopupParams,
commit : commitPopupParams
}
]
},
{
type : 'hbox',
children :
[
{
type : 'text',
widths : [ '30%', '70%' ],
labelLayout : 'horizontal',
label : editor.lang.link.popupWidth,
id : 'width',
setup : setupPopupParams,
commit : commitPopupParams
},
{
type : 'text',
labelLayout : 'horizontal',
widths : [ '55%', '45%' ],
label : editor.lang.link.popupLeft,
id : 'left',
setup : setupPopupParams,
commit : commitPopupParams
}
]
},
{
type : 'hbox',
children :
[
{
type : 'text',
labelLayout : 'horizontal',
widths : [ '30%', '70%' ],
label : editor.lang.link.popupHeight,
id : 'height',
setup : setupPopupParams,
commit : commitPopupParams
},
{
type : 'text',
labelLayout : 'horizontal',
label : editor.lang.link.popupTop,
widths : [ '55%', '45%' ],
id : 'top',
setup : setupPopupParams,
commit : commitPopupParams
}
]
}
]
}
]
},
{
id : 'advanced',
label : editor.lang.link.advanced,
title : editor.lang.link.advanced,
elements :
[
{
type : 'vbox',
padding : 1,
children :
[
{
type : 'hbox',
widths : [ '45%', '35%', '20%' ],
children :
[
{
type : 'text',
id : 'advId',
label : editor.lang.link.id,
setup : setupAdvParams,
commit : commitAdvParams
},
{
type : 'select',
id : 'advLangDir',
label : editor.lang.link.langDir,
'default' : '',
style : 'width:110px',
items :
[
[ editor.lang.link.langDirNotSet, '' ],
[ editor.lang.link.langDirLTR, 'ltr' ],
[ editor.lang.link.langDirRTL, 'rtl' ]
],
setup : setupAdvParams,
commit : commitAdvParams
},
{
type : 'text',
id : 'advAccessKey',
width : '80px',
label : editor.lang.link.acccessKey,
maxLength : 1,
setup : setupAdvParams,
commit : commitAdvParams
}
]
},
{
type : 'hbox',
widths : [ '45%', '35%', '20%' ],
children :
[
{
type : 'text',
label : editor.lang.link.name,
id : 'advName',
setup : setupAdvParams,
commit : commitAdvParams
},
{
type : 'text',
label : editor.lang.link.langCode,
id : 'advLangCode',
width : '110px',
'default' : '',
setup : setupAdvParams,
commit : commitAdvParams
},
{
type : 'text',
label : editor.lang.link.tabIndex,
id : 'advTabIndex',
width : '80px',
maxLength : 5,
setup : setupAdvParams,
commit : commitAdvParams
}
]
}
]
},
{
type : 'vbox',
padding : 1,
children :
[
{
type : 'hbox',
widths : [ '45%', '55%' ],
children :
[
{
type : 'text',
label : editor.lang.link.advisoryTitle,
'default' : '',
id : 'advTitle',
setup : setupAdvParams,
commit : commitAdvParams
},
{
type : 'text',
label : editor.lang.link.advisoryContentType,
'default' : '',
id : 'advContentType',
setup : setupAdvParams,
commit : commitAdvParams
}
]
},
{
type : 'hbox',
widths : [ '45%', '55%' ],
children :
[
{
type : 'text',
label : editor.lang.link.cssClasses,
'default' : '',
id : 'advCSSClasses',
setup : setupAdvParams,
commit : commitAdvParams
},
{
type : 'text',
label : editor.lang.link.charset,
'default' : '',
id : 'advCharset',
setup : setupAdvParams,
commit : commitAdvParams
}
]
},
{
type : 'hbox',
children :
[
{
type : 'text',
label : editor.lang.link.styles,
'default' : '',
id : 'advStyles',
setup : setupAdvParams,
commit : commitAdvParams
}
]
}
]
}
]
}
],
onShow : function()
{
this.fakeObj = false;
var editor = this.getParentEditor(),
selection = editor.getSelection(),
ranges = selection.getRanges(),
element = null,
me = this;
// Fill in all the relevant fields if there's already one link selected.
if ( ranges.length == 1 )
{
var rangeRoot = ranges[0].getCommonAncestor( true );
element = rangeRoot.getAscendant( 'a', true );
if ( element && element.getAttribute( 'href' ) )
{
selection.selectElement( element );
}
else if ( ( element = rangeRoot.getAscendant( 'img', true ) ) &&
element.getAttribute( '_cke_real_element_type' ) &&
element.getAttribute( '_cke_real_element_type' ) == 'anchor' )
{
this.fakeObj = element;
element = editor.restoreRealElement( this.fakeObj );
selection.selectElement( this.fakeObj );
}
else
element = null;
}
this.setupContent( parseLink.apply( this, [ editor, element ] ) );
},
onOk : function()
{
var attributes = { href : 'javascript:void(0)/*' + CKEDITOR.tools.getNextNumber() + '*/' },
removeAttributes = [],
data = { href : attributes.href },
me = this, editor = this.getParentEditor();
this.commitContent( data );
//<!-- linktonode START -->
attributes._cke_saved_href = (Drupal.settings.ckeditor.linktomenu_basepath || '' ) + $('#linktomenu_url').val();
//<!-- linktonode END -->
// Popups and target.
if ( data.target )
{
if ( data.target.type == 'popup' )
{
var onclickList = [ 'window.open(this.href, \'',
data.target.name || '', '\', \'' ];
var featureList = [ 'resizable', 'status', 'location', 'toolbar', 'menubar', 'fullscreen',
'scrollbars', 'dependent' ];
var featureLength = featureList.length;
var addFeature = function( featureName )
{
if ( data.target[ featureName ] )
featureList.push( featureName + '=' + data.target[ featureName ] );
};
for ( var i = 0 ; i < featureLength ; i++ )
featureList[i] = featureList[i] + ( data.target[ featureList[i] ] ? '=yes' : '=no' ) ;
addFeature( 'width' );
addFeature( 'left' );
addFeature( 'height' );
addFeature( 'top' );
onclickList.push( featureList.join( ',' ), '\'); return false;' );
attributes[ CKEDITOR.env.ie || CKEDITOR.env.webkit ? '_cke_pa_onclick' : 'onclick' ] = onclickList.join( '' );
}
else
{
if ( data.target.type != 'notSet' && data.target.name )
attributes.target = data.target.name;
removeAttributes.push( '_cke_pa_onclick', 'onclick' );
}
}
// Advanced attributes.
if ( data.adv )
{
var advAttr = function( inputName, attrName )
{
var value = data.adv[ inputName ];
if ( value )
attributes[attrName] = value;
else
removeAttributes.push( attrName );
};
if ( this._.selectedElement )
advAttr( 'advId', 'id' );
advAttr( 'advLangDir', 'dir' );
advAttr( 'advAccessKey', 'accessKey' );
advAttr( 'advName', 'name' );
advAttr( 'advLangCode', 'lang' );
advAttr( 'advTabIndex', 'tabindex' );
advAttr( 'advTitle', 'title' );
advAttr( 'advContentType', 'type' );
advAttr( 'advCSSClasses', 'class' );
advAttr( 'advCharset', 'charset' );
advAttr( 'advStyles', 'style' );
}
if ( !this._.selectedElement )
{
// Create element if current selection is collapsed.
var selection = editor.getSelection(),
ranges = selection.getRanges();
if ( ranges.length == 1 && ranges[0].collapsed )
{
// <!-- linktonode START -->
var text = new CKEDITOR.dom.text( $('#linktomenu_text').val() || attributes._cke_saved_href, editor.document );
// <!-- linktonode END -->
ranges[0].insertNode( text );
ranges[0].selectNodeContents( text );
selection.selectRanges( ranges );
}
// Apply style.
var style = new CKEDITOR.style( { element : 'a', attributes : attributes } );
style.type = CKEDITOR.STYLE_INLINE; // need to override... dunno why.
style.apply( editor.document );
// Id. Apply only to the first link.
if ( data.adv && data.adv.advId )
{
var links = this.getParentEditor().document.$.getElementsByTagName( 'a' );
for ( i = 0 ; i < links.length ; i++ )
{
if ( links[i].href == attributes.href )
{
links[i].id = data.adv.advId;
break;
}
}
}
}
else
{
// We're only editing an existing link, so just overwrite the attributes.
var element = this._.selectedElement;
// IE BUG: Setting the name attribute to an existing link doesn't work.
// Must re-create the link from weired syntax to workaround.
if ( CKEDITOR.env.ie && attributes.name != element.getAttribute( 'name' ) )
{
var newElement = new CKEDITOR.dom.element( '<a name="' + CKEDITOR.tools.htmlEncode( attributes.name ) + '">',
editor.document );
selection = editor.getSelection();
element.moveChildren( newElement );
element.copyAttributes( newElement, { name : 1 } );
newElement.replace( element );
element = newElement;
selection.selectElement( element );
}
element.setAttributes( attributes );
element.removeAttributes( removeAttributes );
// Make the element display as an anchor if a name has been set.
if ( element.getAttribute( 'name' ) )
element.addClass( 'cke_anchor' );
else
element.removeClass( 'cke_anchor' );
if ( this.fakeObj )
editor.createFakeElement( element, 'cke_anchor', 'anchor' ).replace( this.fakeObj );
delete this._.selectedElement;
}
},
onLoad : function()
{
if ( !editor.config.linkShowAdvancedTab )
this.hidePage( 'advanced' ); //Hide Advanded tab.
if ( !editor.config.linkShowTargetTab )
this.hidePage( 'target' ); //Hide Target tab.
}
};
} );

Binary file not shown.

After

Width:  |  Height:  |  Size: 830 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 971 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.1 KiB

View file

@ -0,0 +1,302 @@
function selectRow(row) {
if (!row) {
return;
}
$('#nodelist tbody tr').each( function() {
$(this).css('background', 'transparent');
});
$(row).css('background', '#dadfe9');
selectedNode = row;
$('#linktomenu_url').val(row.cells[0].firstChild.nodeValue);
$('#linktomenu_text').val(row.cells[1].firstChild.nodeValue);
}
//save node/path urls
function SaveDrupalUrls()
{
//if ((!FCKConfig.DrupalLinkToContentSelect && FCKConfig.DrupalPathFilter) || GetE('cmbDrupalProtocol').value == 'internal') {
var url = CKEDITOR._._linkToNodeDialog.getContentElement( 'info', 'url' );
var type = CKEDITOR._._linkToNodeDialog.getContentElement( 'info', 'linkType' );
if ( type.getValue() == 'internal' ) {
url.setValue($('#txtUrlInternal').val());
}
else {
url.setValue($('#txtUrlPath').val());
}
}
/**
* loadCategories()
* @param obj parent Object
**/
function loadCategories(obj) {
var params = '';
var mid = '0';
var top = 95;
var objTop;
if (obj != null) {
mid = $(obj).get(0).value;
try {
objTop = $(obj).attr('id').match(/_(\d+)_sel/);
top += (objTop[1] * 17);
} catch (e) {
top += 0;
}
}
params = 'ltc-type=linktocontent_menu&ltc-menu-id=' + mid;
$('#statusImg').css( {
top : top + 'px'
}).show();
$.ajax( {
type : "POST",
url : Drupal.settings.basePath + 'index.php?q=linktocontent',
data : params,
error : function(xml, msg, exc) {
$('#statusImg').hide();
alert(Drupal.t('Error !msg', {'!msg' : msg + '\n' + xml.responseText }));
},
success : function(data) {
try {
var results = eval('(' + data + ');');
_clearNodeList();
if ((obj == null) || ($(obj).get(0).value > -1)) {
_fillDropdown(obj, results);
}
_fillNodelist(results);
} catch (e) {
alert(Drupal.t('Error on retrieving data from module.') + '\n' + e.name + '\n' + e.message);
} finally {
$('#statusImg').hide();
}
}
});
}
// dropdown functions
/**
*
* @access public
* @return void
*/
function _createDropdown(obj) {
var dropdown;
var elemname = '';
if (obj == null) {
elemname = 'browse_sel_-1';
} else {
elemname = $(obj).parent().attr('id');
_removeDescendant($(obj));
}
var level = parseInt(elemname.substring(elemname.lastIndexOf("_") + 1, elemname.length)) + 1;
var elemBase = elemname.substring(0, elemname.lastIndexOf("_") + 1);
// create surrounding <div>
var sel_div = $('<div></div>');
$(sel_div).attr('name', elemBase + level);
$(sel_div).attr('id', elemBase + level);
$(sel_div).attr('style', 'display: block; margin: 1px 0; padding: 0; border: 0;');
// create <select>
var select = $('<select></select>');
$(select).attr('size', 1);
$(select).attr('name', elemBase + level + '_sel');
$(select).attr('id', elemBase + level + '_sel');
// add event handler
$(select).change( function() {
_removeDescendant($(this).parent());
_clearNodeList();
loadCategories($(this));
});
// create image (only if level > 0)
if (level > 0) {
var img = $('<img />');
$(img).attr('id', elemname.substring(0, elemname.lastIndexOf('_') + 1) + level + '_img');
$(img).attr('alt', '');
$(img).attr('src', 'images/descendant.gif');
// extra margin for IE
$(img).css( {
margin : '0px 2px',
border : 0
});
$(img).css( {
marginLeft : String((parseInt(level) - 1) * 14) + 'px',
marginRight : '2px'
});
$(sel_div).append($(img));
}
$(sel_div).append($(select));
$(sel_div).hide();
$('#form_browse').append($(sel_div));
$(sel_div).show('slow');
return select;
}
/**
* _fillDropdown
* @return true if a dropdown was inserted
**/
function _fillDropdown(obj, results) {
if (results.menus != false) {
var select = _createDropdown(obj);
$(select).addOption(-1, "Choose Category");
for (key in results.menus) {
if (results.menus[key].hasChildren) {
$(select).addOption(results.menus[key].mid, results.menus[key].title);
}
}
return true;
}
return false;
}
/**
* remove "child" elements
**/
function _removeDescendant(elem) {
if (elem == null)
return;
$(elem).next().each( function() {
_removeDescendant($(this));
$(this).hide('slow').remove();
});
}
// nodelist functions
var selectedNode = null;
function _fillNodelist(results) {
if ((results == null) || (results.menus == null) || (results.menus == false))
return;
for (key in results.menus) {
if (results.menus[key].root) {
continue;
}
_addNodeToList(results.menus[key]);
}
}
function _clearNodeList() {
$('#nodelist tbody tr').each( function() {
$(this).remove();
});
}
function _addNodeToList(node) {
var tr = $('<tr></tr>').appendTo('#nodelist tbody');
tr.hover( function() {
if (!selectedNode || this != selectedNode)
$(this).css('background', '#cecece');
}, function() {
if (!selectedNode || this != selectedNode)
$(this).css('background', 'transparent');
});
tr.click( function() {
selectRow(this);
});
$('<td class="nid">' + node.path + '</td>').appendTo(tr);
$('<td>' + node.title + '</td>').appendTo(tr);
}
/**
* make the nodelist accessible by keyboard
**/
$('.accessible').keypress( function(e) {
switch (e.keyCode) {
case 39:
case 40: // move selection down
if (selectedNode == null)
selectedNode = $('#nodelist tbody tr').get(0);
else
selectedNode = $(selectedNode).next('tr').get(0);
selectRow(selectedNode);
break;
case 37:
case 38: // move selection up
if (selectedNode == null)
selectedNode = $('#nodelist tbody tr').get($('#nodelist tbody tr').length - 1);
else
selectedNode = $(selectedNode).prev('tr').get(0);
selectRow(selectedNode);
break;
}
});
// options
$.fn.addOption = function() {
if (arguments.length == 0)
return this;
// select option when added? default is false
var selectOption = false;
// multiple items
var multiple = false;
if (typeof arguments[0] == "object") {
multiple = true;
var items = arguments[0];
}
if (arguments.length >= 2) {
if (typeof arguments[1] == "boolean")
selectOption = arguments[1];
else if (typeof arguments[2] == "boolean")
selectOption = arguments[2];
if (!multiple) {
var value = arguments[0];
var text = arguments[1];
}
}
this.each( function() {
if (this.nodeName.toLowerCase() != "select")
return;
if (multiple) {
for (v in items) {
$(this).addOption(v, items[v], selectOption);
}
} else {
var option = document.createElement("option");
option.value = value;
option.text = text;
this.options.add(option);
}
if (selectOption) {
this.options[this.options.length - 1].selected = true;
}
})
return this;
}
$.fn.removeOption = function() {
if (arguments.length == 0)
return this;
if (typeof arguments[0] == "string")
var value = arguments[0];
else if (typeof arguments[0] == "number")
var index = arguments[0];
else
return this;
this.each( function() {
if (this.nodeName.toLowerCase() != "select")
return;
if (value) {
var optionsLength = this.options.length;
for ( var i = optionsLength - 1; i >= 0; i--) {
if (this.options[i].value == value) {
this.options[i] = null;
}
}
} else {
this.remove(index);
}
})
return this;
}

View file

@ -0,0 +1,56 @@
/*
Copyright (c) 2003-2013, CKSource - Frederico Knabben. All rights reserved.
For licensing, see LICENSE.html or http://ckeditor.com/license
*/
CKEDITOR.plugins.add( 'linktomenu',
{
init : function( editor )
{
// Add the link and unlink buttons.
editor.addCommand( 'linktomenu', new CKEDITOR.dialogCommand( 'linktomenu' ) );
editor.ui.addButton( 'LinkToMenu',
{
label : 'Link to menu',
icon : this.path + 'images/linktomenu.gif',
command : 'linktomenu'
} );
CKEDITOR.dialog.add( 'linktomenu', this.path + 'dialogs/link.js' );
// If the "menu" plugin is loaded, register the menu items.
if ( editor.addMenuItems )
{
editor.addMenuItems(
{
linktomenu :
{
label : 'Link to menu',
command : 'linktomenu',
group : 'linktomenu',
order : 1
}
});
}
// If the "contextmenu" plugin is loaded, register the listeners.
if ( editor.contextMenu )
{
editor.contextMenu.addListener( function( element, selection )
{
if ( !element )
return null;
var isAnchor = ( element.is( 'img' ) && element.getAttribute( '_cke_real_element_type' ) == 'anchor' );
if ( !isAnchor )
{
if ( !( element = element.getAscendant( 'a', true ) ) )
return null;
isAnchor = ( element.getAttribute( 'name' ) && !element.getAttribute( 'href' ) );
}
return { linktomenu : CKEDITOR.TRISTATE_OFF };
});
}
}
} );