First pass at fixing search for add menu item boxes. props koopersmith, see #13283.

git-svn-id: https://develop.svn.wordpress.org/trunk@14686 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Nacin 2010-05-16 05:39:53 +00:00
parent d7e1bbb65b
commit 2839ecfd01
5 changed files with 83 additions and 158 deletions

View File

@ -406,7 +406,7 @@ function wp_nav_menu_locations_meta_box() {
$mods = get_nav_menu_locations(); $mods = get_nav_menu_locations();
$menus = wp_get_nav_menus(); $menus = wp_get_nav_menus();
$menu_locations = get_nav_menu_locations(); $menu_locations = get_nav_menu_locations();
//var_dump( $menus );
foreach ( $locations as $location => $description ) { foreach ( $locations as $location => $description ) {
?> ?>
<p> <p>
@ -619,8 +619,9 @@ function wp_nav_menu_item_post_type_meta_box( $object, $post_type ) {
} }
?> ?>
<p class="quick-search-wrap"> <p class="quick-search-wrap">
<input type="text" class="quick-search regular-text" value="<?php echo $searched; ?>" name="quick-search-posttype-<?php echo $post_type_name; ?>" /> <input type="text" class="quick-search regular-text input-with-default-title" title="<?php esc_attr_e('Search'); ?>" value="<?php echo $searched; ?>" name="quick-search-posttype-<?php echo $post_type_name; ?>" />
<input type="submit" class="quick-search-submit button-secondary" value="<?php esc_attr_e('Search'); ?>" /> <img class="waiting" src="<?php echo esc_url( admin_url( 'images/wpspin_light.gif' ) ); ?>" alt="" />
<input type="submit" class="quick-search-submit button-secondary hide-if-js" value="<?php esc_attr_e('Search'); ?>" />
</p> </p>
<ul id="<?php echo $post_type_name; ?>-search-checklist" class="list:<?php echo $post_type_name?> categorychecklist form-no-clear"> <ul id="<?php echo $post_type_name; ?>-search-checklist" class="list:<?php echo $post_type_name?> categorychecklist form-no-clear">
@ -794,8 +795,9 @@ function wp_nav_menu_item_taxonomy_meta_box( $object, $taxonomy ) {
} }
?> ?>
<p class="quick-search-wrap"> <p class="quick-search-wrap">
<input type="text" class="quick-search regular-text" value="<?php echo $searched; ?>" name="quick-search-taxonomy-<?php echo $taxonomy_name; ?>" /> <input type="text" class="quick-search regular-text input-with-default-title" title="<?php esc_attr_e('Search'); ?>" value="<?php echo $searched; ?>" name="quick-search-taxonomy-<?php echo $taxonomy_name; ?>" />
<input type="submit" class="quick-search-submit button-secondary" value="<?php esc_attr_e('Search'); ?>" /> <img class="waiting" src="<?php echo esc_url( admin_url( 'images/wpspin_light.gif' ) ); ?>" alt="" />
<input type="submit" class="quick-search-submit button-secondary hide-if-js" value="<?php esc_attr_e('Search'); ?>" />
</p> </p>
<ul id="<?php echo $taxonomy_name; ?>-search-checklist" class="list:<?php echo $taxonomy_name?> categorychecklist form-no-clear"> <ul id="<?php echo $taxonomy_name; ?>-search-checklist" class="list:<?php echo $taxonomy_name?> categorychecklist form-no-clear">

View File

@ -21,8 +21,6 @@ var wpNavMenu;
menuList : undefined, // Set in init. menuList : undefined, // Set in init.
targetList : undefined, // Set in init. targetList : undefined, // Set in init.
autoCompleteData : {},
// Functions that run on init. // Functions that run on init.
init : function() { init : function() {
@ -346,44 +344,45 @@ var wpNavMenu;
}, },
attachQuickSearchListeners : function() { attachQuickSearchListeners : function() {
var that = this, var searchTimer;
form = $('#nav-menu-meta');
// auto-suggest for the quick-search boxes $('.quick-search').keypress(function(e){
$('input.quick-search').each(function(i, el) { var t = $(this);
that.setupQuickSearchEventListeners(el);
}); if( 13 == e.which ) {
form.find('.quick-search-submit').click(function() { api.updateQuickSearchResults( t );
$(this).trigger('wp-quick-search'); return false;
return false; }
});
form.find('.inside').children().bind('wp-quick-search', function() { if( searchTimer ) clearTimeout(searchTimer);
that.quickSearch( $(this).attr('id') );
}); searchTimer = setTimeout(function(){
api.updateQuickSearchResults( t );
}, 400);
}).attr('autocomplete','off');
}, },
quickSearch : function(id) { updateQuickSearchResults : function(input) {
var type = $('#' + id + ' .quick-search').attr('name'), var panel, params,
q = $('#' + id + ' .quick-search').val(), minSearchLength = 2,
menu = $('#menu').val(), q = input.val();
nonce = $('#menu-settings-column-nonce').val(),
params = {}, if( q.length < minSearchLength ) return;
that = this,
processMethod = function(){}; panel = input.parents('.tabs-panel');
processMethod = that.processQuickSearchQueryResponse;
params = { params = {
'action': 'menu-quick-search', 'action': 'menu-quick-search',
'response-format': 'markup', 'response-format': 'markup',
'menu': menu, 'menu': $('#menu').val(),
'menu-settings-column-nonce': nonce, 'menu-settings-column-nonce': $('#menu-settings-column-nonce').val(),
'q': q, 'q': q,
'type': type 'type': input.attr('name')
}; };
$('img.waiting', panel).show();
$.post( ajaxurl, params, function(menuMarkup) { $.post( ajaxurl, params, function(menuMarkup) {
processMethod.call(that, menuMarkup, params); api.processQuickSearchQueryResponse(menuMarkup, params, panel);
}); });
}, },
@ -463,38 +462,32 @@ var wpNavMenu;
attachTabsPanelListeners : function() { attachTabsPanelListeners : function() {
$('#menu-settings-column').bind('click', function(e) { $('#menu-settings-column').bind('click', function(e) {
var selectAreaMatch, activePanel, panelIdMatch, wrapper, inputs, i, items; var selectAreaMatch, activePanel, panelId, wrapper, items,
target = $(e.target);
if ( e.target && e.target.className && -1 != e.target.className.indexOf('nav-tab-link') ) { if ( target.hasClass('nav-tab-link') ) {
panelIdMatch = /#(.*)$/.exec(e.target.href); panelId = /#(.*)$/.exec(e.target.href);
wrapper = $(e.target).parents('.inside').first()[0]; if ( panelId && panelId[1] )
inputs = wrapper ? wrapper.getElementsByTagName('input') : []; panelId = panelId[1]
i = inputs.length; else
return false;
wrapper = target.parents('.inside').first();
// upon changing tabs, we want to uncheck all checkboxes // upon changing tabs, we want to uncheck all checkboxes
while( i-- ) $('input', wrapper).removeAttr('checked');
inputs[i].checked = false;
$('.tabs-panel-active', wrapper).removeClass('tabs-panel-active').addClass('tabs-panel-inactive');
$('#' + panelId, wrapper).removeClass('tabs-panel-inactive').addClass('tabs-panel-active');
$('.tabs-panel', wrapper).each(function() { $('.tabs', wrapper).removeClass('tabs');
if ( this.className ) target.parent().addClass('tabs');
this.className = this.className.replace('tabs-panel-active', 'tabs-panel-inactive');
});
$('.tabs', wrapper).each(function() { // select the search bar
this.className = this.className.replace('tabs', ''); $('.quick-search', wrapper).focus();
});
e.target.parentNode.className += ' tabs';
if ( panelIdMatch && panelIdMatch[1] ) {
activePanel = document.getElementById(panelIdMatch[1]);
if ( activePanel ) {
activePanel.className = activePanel.className.replace('tabs-panel-inactive', 'tabs-panel-active');
}
}
return false; return false;
} else if ( e.target && e.target.className && -1 != e.target.className.indexOf('select-all') ) { } else if ( target.hasClass('select-all') ) {
selectAreaMatch = /#(.*)$/.exec(e.target.href); selectAreaMatch = /#(.*)$/.exec(e.target.href);
if ( selectAreaMatch && selectAreaMatch[1] ) { if ( selectAreaMatch && selectAreaMatch[1] ) {
items = $('#' + selectAreaMatch[1] + ' .tabs-panel-active .menu-item-title input'); items = $('#' + selectAreaMatch[1] + ' .tabs-panel-active .menu-item-title input');
@ -611,37 +604,6 @@ var wpNavMenu;
}); });
}, },
/**
* Set up quick-search input fields' events.
*
* @param object el The input element.
*/
setupQuickSearchEventListeners : function(el) {
var that = this;
$(el).autocomplete( ajaxurl + '?action=menu-quick-search&type=' + el.name,
{
delay: 500,
formatItem: api.formatAutocompleteResponse,
formatResult: api.formatAutocompleteResult,
minchars: 2,
multiple: false
}
).bind('blur', function(e) {
var changedData = api.autoCompleteData[this.value],
inputEl = this;
if ( changedData ) {
$.post(
ajaxurl + '?action=menu-quick-search&type=get-post-item&response-format=markup',
changedData,
function(r) {
that.processQuickSearchQueryResponse.call(that, r, changedData);
api.autoCompleteData[inputEl.value] = false;
}
);
}
});
},
eventOnClickEditLink : function(clickedEl) { eventOnClickEditLink : function(clickedEl) {
var activeEdit, var activeEdit,
matchedSection = /#(.*)$/.exec(clickedEl.href); matchedSection = /#(.*)$/.exec(clickedEl.href);
@ -718,59 +680,40 @@ var wpNavMenu;
* *
* @param string resp The server response to the query. * @param string resp The server response to the query.
* @param object req The request arguments. * @param object req The request arguments.
* @param jQuery panel The tabs panel we're searching in.
*/ */
processQuickSearchQueryResponse : function(resp, req) { processQuickSearchQueryResponse : function(resp, req, panel) {
if ( ! req ) var i, matched, newID,
req = {}; takenIDs = {},
var wrap = document.createElement('ul'),
form = document.getElementById('nav-menu-meta'), form = document.getElementById('nav-menu-meta'),
i, pattern = new RegExp('menu-item\\[(\[^\\]\]*)', 'g'),
items, items = resp.match(/<li>.*<\/li>/g);
matched,
message,
newID,
pattern = new RegExp('menu-item\\[(\[^\\]\]*)'),
resultList;
// make a unique DB ID number if( ! items ) {
matched = pattern.exec(resp); $('.categorychecklist', panel).html( '<li><p>' + navMenuL10n.noResultsFound + '</p></li>' );
if ( matched && matched[1] ) { $('img.waiting', panel).hide();
newID = matched[1]; return;
while( form.elements['menu-item[' + newID + '][menu-item-type]'] ) {
newID--;
}
if ( newID != matched[1] ) {
resp = resp.replace(new RegExp('menu-item\\[' + matched[1] + '\\]', 'g'), 'menu-item[' + newID + ']');
}
} }
wrap.innerHTML = resp; i = items.length;
while( i-- ) {
// make a unique DB ID number
matched = pattern.exec(items[i]);
if ( matched && matched[1] ) {
newID = matched[1];
while( form.elements['menu-item[' + newID + '][menu-item-type]'] || takenIDs[ newID ] ) {
newID--;
}
items = wrap.getElementsByTagName('li'); takenIDs[newID] = true;
if ( newID != matched[1] ) {
if ( items[0] && req.object_type ) { items[i] = items[i].replace(new RegExp('menu-item\\[' + matched[1] + '\\]', 'g'), 'menu-item[' + newID + ']');
resultList = document.getElementById(req.object_type + '-search-checklist');
if ( resultList ) {
resultList.appendChild(items[0]);
}
} else if ( req.type ) {
matched = /quick-search-(posttype|taxonomy)-([a-zA-Z_-]*)/.exec(req.type);
if ( matched && matched[2] ) {
resultList = document.getElementById(matched[2] + '-search-checklist');
if ( resultList ) {
i = items.length;
if ( ! i ) {
message = document.createElement('li');
message.appendChild(document.createTextNode(navMenuL10n.noResultsFound));
resultList.appendChild(message);
}
while( i-- ) {
resultList.appendChild(items[i]);
}
} }
} }
} }
$('.categorychecklist', panel).html( items.join('') );
$('img.waiting', panel).hide();
}, },
removeMenuItem : function(el) { removeMenuItem : function(el) {
@ -783,25 +726,6 @@ var wpNavMenu;
children.shiftDepthClass(-1).updateParentMenuItemDBId(); children.shiftDepthClass(-1).updateParentMenuItemDBId();
}); });
}, },
formatAutocompleteResponse : function( resultRow, pos, total, queryTerm ) {
if ( resultRow && resultRow[0] ) {
var data = $.parseJSON(resultRow[0]);
if ( data.post_title ) {
if ( data.ID && data.post_type )
api.autoCompleteData[data.post_title] = {ID: data.ID, object_type: data.post_type};
return data.post_title;
}
}
},
formatAutocompleteResult : function( resultRow, pos, total, queryTerm ) {
if ( resultRow && resultRow[0] ) {
var data = $.parseJSON(resultRow[0]);
if ( data.post_title )
return data.post_title;
}
},
getListDataFromID : function(menuItemID, parentEl) { getListDataFromID : function(menuItemID, parentEl) {
if ( ! menuItemID ) if ( ! menuItemID )

File diff suppressed because one or more lines are too long

View File

@ -27,7 +27,6 @@ wp_enqueue_script( 'jquery' );
wp_enqueue_script( 'jquery-ui-draggable' ); wp_enqueue_script( 'jquery-ui-draggable' );
wp_enqueue_script( 'jquery-ui-droppable' ); wp_enqueue_script( 'jquery-ui-droppable' );
wp_enqueue_script( 'jquery-ui-sortable' ); wp_enqueue_script( 'jquery-ui-sortable' );
wp_enqueue_script( 'jquery-autocomplete' );
// Nav Menu functions // Nav Menu functions
wp_enqueue_script( 'nav-menu' ); wp_enqueue_script( 'nav-menu' );

View File

@ -393,7 +393,7 @@ function wp_default_scripts( &$scripts ) {
) ); ) );
// Custom Navigation // Custom Navigation
$scripts->add( 'nav-menu', "/wp-admin/js/nav-menu$suffix.js", false, '20100513' ); $scripts->add( 'nav-menu', "/wp-admin/js/nav-menu$suffix.js", false, '20100515' );
$scripts->localize( 'nav-menu', 'navMenuL10n', array( $scripts->localize( 'nav-menu', 'navMenuL10n', array(
'home' => _x('Home', 'nav menu home label'), 'home' => _x('Home', 'nav menu home label'),
'homeurl' => home_url('/'), 'homeurl' => home_url('/'),