From 6183d245f947122d91a5f7ca3dfe761462c4a928 Mon Sep 17 00:00:00 2001 From: Andrew Nacin Date: Tue, 16 Nov 2010 05:11:41 +0000 Subject: [PATCH] Internal linking functionality updates. Scrap pagination for a river of results. props koopersmith, see #11420. git-svn-id: https://develop.svn.wordpress.org/trunk@16399 602fd350-edb4-49c9-b593-d223f7449a82 --- .../plugins/wplink/editor_plugin.dev.js | 2 +- .../tinymce/plugins/wplink/editor_plugin.js | 2 +- .../tinymce/plugins/wplink/js/wplink.dev.js | 98 +++++++++++------- .../js/tinymce/plugins/wplink/js/wplink.js | 2 +- .../js/tinymce/wp-mce-link-includes.php | 38 ++----- wp-includes/js/tinymce/wp-mce-link.php | 14 ++- wp-includes/js/tinymce/wp-tinymce.js.gz | Bin 85332 -> 87688 bytes 7 files changed, 82 insertions(+), 74 deletions(-) diff --git a/wp-includes/js/tinymce/plugins/wplink/editor_plugin.dev.js b/wp-includes/js/tinymce/plugins/wplink/editor_plugin.dev.js index 77c5117e7a..0660169f5c 100644 --- a/wp-includes/js/tinymce/plugins/wplink/editor_plugin.dev.js +++ b/wp-includes/js/tinymce/plugins/wplink/editor_plugin.dev.js @@ -14,7 +14,7 @@ ed.windowManager.open({ file : tinymce.baseURL + '/wp-mce-link.php', width : 480, - height : 400, + height : 430, inline : 1 }, { plugin_url : url // Plugin absolute URL diff --git a/wp-includes/js/tinymce/plugins/wplink/editor_plugin.js b/wp-includes/js/tinymce/plugins/wplink/editor_plugin.js index f329c78c00..fcc3da8c0a 100644 --- a/wp-includes/js/tinymce/plugins/wplink/editor_plugin.js +++ b/wp-includes/js/tinymce/plugins/wplink/editor_plugin.js @@ -1 +1 @@ -(function(){tinymce.create("tinymce.plugins.wpLink",{init:function(a,b){a.addCommand("WP_Link",function(){a.windowManager.open({file:tinymce.baseURL+"/wp-mce-link.php",width:480,height:400,inline:1},{plugin_url:b})});a.addButton("link",{title:a.getLang("advanced.link_desc"),cmd:"WP_Link"});a.addShortcut("alt+shift+a",a.getLang("advanced.link_desc"),"WP_Link");a.onNodeChange.add(function(d,c,e){c.setActive("wplink",e.nodeName=="A")})},getInfo:function(){return{longname:"WordPress Link Dialog",author:"WordPress",authorurl:"http://wordpress.org",infourl:"",version:"1.0"}}});tinymce.PluginManager.add("wplink",tinymce.plugins.wpLink)})(); \ No newline at end of file +(function(){tinymce.create("tinymce.plugins.wpLink",{init:function(a,b){a.addCommand("WP_Link",function(){a.windowManager.open({file:tinymce.baseURL+"/wp-mce-link.php",width:480,height:430,inline:1},{plugin_url:b})});a.addButton("link",{title:a.getLang("advanced.link_desc"),cmd:"WP_Link"});a.addShortcut("alt+shift+a",a.getLang("advanced.link_desc"),"WP_Link");a.onNodeChange.add(function(d,c,e){c.setActive("wplink",e.nodeName=="A")})},getInfo:function(){return{longname:"WordPress Link Dialog",author:"WordPress",authorurl:"http://wordpress.org",infourl:"",version:"1.0"}}});tinymce.PluginManager.add("wplink",tinymce.plugins.wpLink)})(); \ No newline at end of file diff --git a/wp-includes/js/tinymce/plugins/wplink/js/wplink.dev.js b/wp-includes/js/tinymce/plugins/wplink/js/wplink.dev.js index 0e6b0b5015..4ca58323aa 100644 --- a/wp-includes/js/tinymce/plugins/wplink/js/wplink.dev.js +++ b/wp-includes/js/tinymce/plugins/wplink/js/wplink.dev.js @@ -1,8 +1,16 @@ (function($){ var inputs = {}, results = {}, ed, wpLink = { + lastSearch: '', + riverDefaults: function() { + return { + page : 2, + allLoaded: false, + active: false + }; + }, init : function() { - var e, etarget, eclass; + var e; // Init shared vars ed = tinyMCEPopup.editor; @@ -17,12 +25,14 @@ // Result lists results.search = $('#search-results'); results.recent = $('#most-recent-results'); + results.search.data('river', wpLink.riverDefaults() ); + results.recent.data('river', wpLink.riverDefaults() ); // Bind event handlers $('#wp-update').click( wpLink.update ); $('#wp-cancel').click( function() { tinyMCEPopup.close(); } ); $('.query-results').delegate('li', 'click', wpLink.selectInternalLink ); - $('.wp-results-pagelinks').delegate('a', 'click', wpLink.selectPageLink ); + $('.query-results').scroll( wpLink.maybeLoadRiver ); inputs.search.keyup( wpLink.searchInternalLinks ); // If link exists, select proper values. @@ -34,6 +44,9 @@ if ( "_blank" == ed.dom.getAttrib(e, 'target') ) inputs.openInNewTab.attr('checked','checked'); } + + // Focus the URL field + inputs.url.focus(); }, update : function() { @@ -74,7 +87,7 @@ // If no selection exists, create a new link from scratch. if ( ed.selection.isCollapsed() ) { - var el = ed.dom.create('a', { href: "#mce_temp_url#" }, defaultContent); + el = ed.dom.create('a', { href: "#mce_temp_url#" }, defaultContent); ed.selection.setNode(el); // If a selection exists, wrap it in a link. } else { @@ -113,23 +126,43 @@ inputs.title.val( t.children('.item-title').text() ); }, - selectPageLink : function(e) { - var page = e.target.href.match(/page=(\d+)/); + maybeLoadRiver : function() { + var t = $(this), + ul = t.children('ul'), + river = t.data('river'), + waiting = t.find('.river-waiting'); - page = page ? page[1] : 1; // If there's no match, it's the first page. - e.preventDefault(); // Prevent the link from redirecting. + if( t.scrollTop() + t.height() != ul.height() || river.active || river.allLoaded ) + return; - wpLink.linkAJAX( $(this), { page : page }); + river.active = true; + waiting.show(); + + wpLink.linkAJAX( t, { page : river.page }, function(r) { + river.page++; + river.active = false; + river.allLoaded = !r; + waiting.hide(); + }, true); }, searchInternalLinks : function() { var t = $(this), waiting, title = t.val(); - if ( title ) { + if ( title.length > 2 ) { results.recent.hide(); results.search.show(); + + // Don't search if the keypress didn't change the title. + if ( wpLink.lastSearch == title ) + return; + + wpLink.lastSearch = title; waiting = t.siblings('img.waiting').show(); + + results.search.data('river', wpLink.riverDefaults() ); + results.search.scrollTop(0); wpLink.linkAJAX( results.search, { title : title }, function(){ waiting.hide(); }); } else { results.search.hide(); @@ -137,7 +170,7 @@ } }, - linkAJAX : function( $panel, params, callback ) { + linkAJAX : function( $panel, params, callback, append ) { if ( ! $panel.hasClass('query-results') ) $panel = $panel.parents('.query-results'); @@ -146,38 +179,31 @@ $.post( ajaxurl, $.extend({ action : 'wp-link-ajax' - }, params ), function(r) { - var pagelinks = $panel.children('.wp-results-pagelinks'); + }, params ), function( results ) { + var list = ''; + + if ( !results ) { + if ( !append ) { + list += '
  • ' + + wpLinkL10n.noMatchesFound + + '
  • '; + } + } else { + $.each( results, function() { + list += '
  • '; + list += ''; + list += this['title'] ? this['title'] : ''+ wpLinkL10n.untitled + ''; + list += '' + this['info'] + '
  • '; + }); + } // Set results - $panel.children('ul').html( wpLink.generateListMarkup( r['results'] ) ); - - // Handle page links - if ( r['page_links'] ) - pagelinks.html( r['page_links'] ).show(); - else - pagelinks.hide(); + $panel.children('ul')[ append ? 'append' : 'html' ]( list ); // Run callback if ( callback ) - callback( r['results'] ); + callback( results ); }, "json" ); - }, - - generateListMarkup : function( results ) { - var s = ''; - - if ( ! results ) - return '
  • ' + wpLinkL10n.noMatchesFound + '
  • '; - - $.each( results, function() { - s+= '
  • '; - s+= '' - s+= this['title'] ? this['title'] : ''+ wpLinkL10n.untitled + ''; - s+= '' + this['info'] + ''; - s+= '
  • '; - }); - return s; } } diff --git a/wp-includes/js/tinymce/plugins/wplink/js/wplink.js b/wp-includes/js/tinymce/plugins/wplink/js/wplink.js index 4ca22a8878..5e4b559b3d 100644 --- a/wp-includes/js/tinymce/plugins/wplink/js/wplink.js +++ b/wp-includes/js/tinymce/plugins/wplink/js/wplink.js @@ -1 +1 @@ -(function(d){var a={},c={},b,e={init:function(){var h,g,f;b=tinyMCEPopup.editor;a.url=d("#url-field");a.title=d("#link-title-field");a.openInNewTab=d("#link-target-checkbox");a.search=d("#search-field");c.search=d("#search-results");c.recent=d("#most-recent-results");d("#wp-update").click(e.update);d("#wp-cancel").click(function(){tinyMCEPopup.close()});d(".query-results").delegate("li","click",e.selectInternalLink);d(".wp-results-pagelinks").delegate("a","click",e.selectPageLink);a.search.keyup(e.searchInternalLinks);if(h=b.dom.getParent(b.selection.getNode(),"A")){a.url.val(h.href);a.title.val(b.dom.getAttrib(h,"title"));if("_blank"==b.dom.getAttrib(h,"target")){a.openInNewTab.attr("checked","checked")}}},update:function(){var j,g=tinyMCEPopup.editor,h={href:a.url.val(),title:a.title.val(),target:a.openInNewTab.attr("checked")?"_blank":""},k,f,i=h.title?h.title:h.href;tinyMCEPopup.restoreSelection();k=g.dom.getParent(g.selection.getNode(),"A");if(!h.href){if(g.selection.isCollapsed()){tinyMCEPopup.close();return}else{if(k){tinyMCEPopup.execCommand("mceBeginUndoLevel");f=g.selection.getBookmark();g.dom.remove(k,1);g.selection.moveToBookmark(f);tinyMCEPopup.execCommand("mceEndUndoLevel");tinyMCEPopup.close();return}}}tinyMCEPopup.execCommand("mceBeginUndoLevel");if(k==null){g.getDoc().execCommand("unlink",false,null);if(g.selection.isCollapsed()){var j=g.dom.create("a",{href:"#mce_temp_url#"},i);g.selection.setNode(j)}else{tinyMCEPopup.execCommand("CreateLink",false,"#mce_temp_url#",{skip_undo:1})}tinymce.each(g.dom.select("a"),function(l){if(g.dom.getAttrib(l,"href")=="#mce_temp_url#"){k=l;g.dom.setAttribs(k,h)}})}else{g.dom.setAttribs(k,h)}if(k.childNodes.length!=1||k.firstChild.nodeName!="IMG"){g.focus();g.selection.select(k);g.selection.collapse(0);tinyMCEPopup.storeSelection()}tinyMCEPopup.execCommand("mceEndUndoLevel");tinyMCEPopup.close()},selectInternalLink:function(){var f=d(this);if(f.hasClass("unselectable")){return}f.siblings(".selected").removeClass("selected");f.addClass("selected");a.url.val(f.children(".item-permalink").val());a.title.val(f.children(".item-title").text())},selectPageLink:function(g){var f=g.target.href.match(/page=(\d+)/);f=f?f[1]:1;g.preventDefault();e.linkAJAX(d(this),{page:f})},searchInternalLinks:function(){var f=d(this),h,g=f.val();if(g){c.recent.hide();c.search.show();h=f.siblings("img.waiting").show();e.linkAJAX(c.search,{title:g},function(){h.hide()})}else{c.search.hide();c.recent.show()}},linkAJAX:function(g,f,h){if(!g.hasClass("query-results")){g=g.parents(".query-results")}if(!g.length){return}d.post(ajaxurl,d.extend({action:"wp-link-ajax"},f),function(j){var i=g.children(".wp-results-pagelinks");g.children("ul").html(e.generateListMarkup(j.results));if(j.page_links){i.html(j.page_links).show()}else{i.hide()}if(h){h(j.results)}},"json")},generateListMarkup:function(f){var g="";if(!f){return'
  • '+wpLinkL10n.noMatchesFound+"
  • "}d.each(f,function(){g+='
  • ';g+='';g+=this["title"]?this["title"]:""+wpLinkL10n.untitled+"";g+=''+this["info"]+"";g+="
  • "});return g}};d(document).ready(e.init)})(jQuery); \ No newline at end of file +(function(d){var a={},c={},b,e={lastSearch:"",riverDefaults:function(){return{page:2,allLoaded:false,active:false}},init:function(){var f;b=tinyMCEPopup.editor;a.url=d("#url-field");a.title=d("#link-title-field");a.openInNewTab=d("#link-target-checkbox");a.search=d("#search-field");c.search=d("#search-results");c.recent=d("#most-recent-results");c.search.data("river",e.riverDefaults());c.recent.data("river",e.riverDefaults());d("#wp-update").click(e.update);d("#wp-cancel").click(function(){tinyMCEPopup.close()});d(".query-results").delegate("li","click",e.selectInternalLink);d(".query-results").scroll(e.maybeLoadRiver);a.search.keyup(e.searchInternalLinks);if(f=b.dom.getParent(b.selection.getNode(),"A")){a.url.val(f.href);a.title.val(b.dom.getAttrib(f,"title"));if("_blank"==b.dom.getAttrib(f,"target")){a.openInNewTab.attr("checked","checked")}}a.url.focus()},update:function(){var j,g=tinyMCEPopup.editor,h={href:a.url.val(),title:a.title.val(),target:a.openInNewTab.attr("checked")?"_blank":""},k,f,i=h.title?h.title:h.href;tinyMCEPopup.restoreSelection();k=g.dom.getParent(g.selection.getNode(),"A");if(!h.href){if(g.selection.isCollapsed()){tinyMCEPopup.close();return}else{if(k){tinyMCEPopup.execCommand("mceBeginUndoLevel");f=g.selection.getBookmark();g.dom.remove(k,1);g.selection.moveToBookmark(f);tinyMCEPopup.execCommand("mceEndUndoLevel");tinyMCEPopup.close();return}}}tinyMCEPopup.execCommand("mceBeginUndoLevel");if(k==null){g.getDoc().execCommand("unlink",false,null);if(g.selection.isCollapsed()){j=g.dom.create("a",{href:"#mce_temp_url#"},i);g.selection.setNode(j)}else{tinyMCEPopup.execCommand("CreateLink",false,"#mce_temp_url#",{skip_undo:1})}tinymce.each(g.dom.select("a"),function(l){if(g.dom.getAttrib(l,"href")=="#mce_temp_url#"){k=l;g.dom.setAttribs(k,h)}})}else{g.dom.setAttribs(k,h)}if(k.childNodes.length!=1||k.firstChild.nodeName!="IMG"){g.focus();g.selection.select(k);g.selection.collapse(0);tinyMCEPopup.storeSelection()}tinyMCEPopup.execCommand("mceEndUndoLevel");tinyMCEPopup.close()},selectInternalLink:function(){var f=d(this);if(f.hasClass("unselectable")){return}f.siblings(".selected").removeClass("selected");f.addClass("selected");a.url.val(f.children(".item-permalink").val());a.title.val(f.children(".item-title").text())},maybeLoadRiver:function(){var g=d(this),f=g.children("ul"),h=g.data("river"),i=g.find(".river-waiting");if(g.scrollTop()+g.height()!=f.height()||h.active||h.allLoaded){return}h.active=true;i.show();e.linkAJAX(g,{page:h.page},function(j){h.page++;h.active=false;h.allLoaded=!j;i.hide()},true)},searchInternalLinks:function(){var f=d(this),h,g=f.val();if(g.length>2){c.recent.hide();c.search.show();if(e.lastSearch==g){return}e.lastSearch=g;h=f.siblings("img.waiting").show();c.search.data("river",e.riverDefaults());c.search.scrollTop(0);e.linkAJAX(c.search,{title:g},function(){h.hide()})}else{c.search.hide();c.recent.show()}},linkAJAX:function(h,g,i,f){if(!h.hasClass("query-results")){h=h.parents(".query-results")}if(!h.length){return}d.post(ajaxurl,d.extend({action:"wp-link-ajax"},g),function(j){var k="";if(!j){if(!f){k+='
  • '+wpLinkL10n.noMatchesFound+"
  • "}}else{d.each(j,function(){k+='
  • ';k+='';k+=this["title"]?this["title"]:""+wpLinkL10n.untitled+"";k+=''+this["info"]+"
  • "})}h.children("ul")[f?"append":"html"](k);if(i){i(j)}},"json")}};d(document).ready(e.init)})(jQuery); \ No newline at end of file diff --git a/wp-includes/js/tinymce/wp-mce-link-includes.php b/wp-includes/js/tinymce/wp-mce-link-includes.php index b484603753..aa3edb6b30 100644 --- a/wp-includes/js/tinymce/wp-mce-link-includes.php +++ b/wp-includes/js/tinymce/wp-mce-link-includes.php @@ -20,12 +20,7 @@ function wp_link_query( $args = array() ) { if ( isset( $args['s'] ) ) $query['s'] = $args['s']; - $pagination = array( - 'current' => $args['pagenum'], - 'per_page' => $query['posts_per_page'], - ); - - $query['offset'] = $pagination['offset'] = $args['pagenum'] > 1 ? $query['posts_per_page'] * ( $args['pagenum'] - 1 ) : 0; + $query['offset'] = $args['pagenum'] > 1 ? $query['posts_per_page'] * ( $args['pagenum'] - 1 ) : 0; // Do main query. $get_posts = new WP_Query; @@ -47,27 +42,10 @@ function wp_link_query( $args = array() ) { 'title' => esc_html( strip_tags($post->post_title) ), 'permalink' => get_permalink( $post->ID ), 'info' => $info, - );; + ); } - // Remaining pagination values. - $pagination['max'] = $get_posts->max_num_pages; - $pagination['page_links'] = paginate_links( array( - 'prev_text' => __('«'), - 'next_text' => __('»'), - 'total' => $pagination['max'], - 'current' => $pagination['current'] - ) ); - - // Build response. - $resp = array( - 'query' => $get_posts, - 'objects' => $posts, - 'results' => $results, - 'pages' => $pagination, - ); - - return $resp; + return $results; } function wp_link_ajax( $request ) { @@ -76,16 +54,12 @@ function wp_link_ajax( $request ) { $args['s'] = stripslashes( $request['title'] ); $args['pagenum'] = ! empty( $request['page'] ) ? absint( $request['page'] ) : 1; - $resp = wp_link_query( $args ); + $results = wp_link_query( $args ); - if ( ! isset( $resp ) ) + if ( ! isset( $results ) ) die( '0' ); - - $json = array( 'results' => $resp['results'] ); - if ( isset( $resp['pages'] ) && !empty( $resp['pages']['page_links'] ) ) - $json['page_links'] = $resp['pages']['page_links']; - echo json_encode( $json ); + echo json_encode( $results ); echo "\n"; } diff --git a/wp-includes/js/tinymce/wp-mce-link.php b/wp-includes/js/tinymce/wp-mce-link.php index 4a44c46c70..6c830d52fc 100644 --- a/wp-includes/js/tinymce/wp-mce-link.php +++ b/wp-includes/js/tinymce/wp-mce-link.php @@ -23,7 +23,7 @@ var ajaxurl = '',
    @@ -181,7 +189,7 @@ img.waiting {