WordPress.org

Make WordPress Core

Ticket #11420: river.diff

File river.diff, 10.0 KB (added by koopersmith, 3 years ago)
  • wp-includes/js/tinymce/plugins/wplink/editor_plugin.js

     
    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)})(); 
    2  No newline at end of file 
     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: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)})(); 
     2 No newline at end of file 
  • wp-includes/js/tinymce/plugins/wplink/js/wplink.dev.js

     
    11(function($){    
    22        var inputs = {}, results = {}, ed, 
    33        wpLink = { 
     4                lastSearch: '', 
     5                riverDefaults: function() { 
     6                        return { 
     7                                page : 2, 
     8                                allLoaded: false, 
     9                                active: false 
     10                        }; 
     11                }, 
    412                init : function() { 
    513                        var e, etarget, eclass; 
    614                        // Init shared vars 
     
    1725                        // Result lists 
    1826                        results.search = $('#search-results'); 
    1927                        results.recent = $('#most-recent-results'); 
     28                        results.search.data('river', wpLink.riverDefaults() ); 
     29                        results.recent.data('river', wpLink.riverDefaults() ); 
    2030                         
    2131                        // Bind event handlers 
    2232                        $('#wp-update').click( wpLink.update ); 
    2333                        $('#wp-cancel').click( function() { tinyMCEPopup.close(); } ); 
    2434                        $('.query-results').delegate('li', 'click', wpLink.selectInternalLink ); 
    25                         $('.wp-results-pagelinks').delegate('a', 'click', wpLink.selectPageLink ); 
     35                        $('.query-results').scroll( wpLink.maybeLoadRiver ); 
    2636                        inputs.search.keyup( wpLink.searchInternalLinks ); 
    2737 
    2838                        // If link exists, select proper values. 
     
    3444                                if ( "_blank" == ed.dom.getAttrib(e, 'target') ) 
    3545                                        inputs.openInNewTab.attr('checked','checked'); 
    3646                        } 
     47                         
     48                        // Focus the URL field 
     49                        inputs.url.focus(); 
    3750                }, 
    3851                 
    3952                update : function() { 
     
    113126                        inputs.title.val( t.children('.item-title').text() ); 
    114127                }, 
    115128                 
    116                 selectPageLink : function(e) { 
    117                         var page = e.target.href.match(/page=(\d+)/); 
     129                maybeLoadRiver : function() { 
     130                        var t = $(this), 
     131                                ul = t.children('ul'), 
     132                                river = t.data('river'), 
     133                                waiting = t.find('.river-waiting'); 
    118134                         
    119                         page = page ? page[1] : 1; // If there's no match, it's the first page. 
    120                         e.preventDefault(); // Prevent the link from redirecting. 
     135                        if( t.scrollTop() + t.height() != ul.height() || river.active || river.allLoaded ) 
     136                                return; 
    121137                         
    122                         wpLink.linkAJAX( $(this), { page : page }); 
     138                        river.active = true; 
     139                        waiting.show(); 
     140                         
     141                        wpLink.linkAJAX( t, { page : river.page }, function(r) { 
     142                                river.page++; 
     143                                river.active = false; 
     144                                river.allLoaded = !r; 
     145                                waiting.hide(); 
     146                        }, true); 
    123147                }, 
    124148                 
    125149                searchInternalLinks : function() { 
    126150                        var t = $(this), waiting, 
    127151                                title = t.val(); 
    128152                         
    129                         if ( title ) { 
     153                        if ( title.length > 2 ) { 
    130154                                results.recent.hide(); 
    131155                                results.search.show(); 
     156                                 
     157                                // Don't search if the keypress didn't change the title. 
     158                                if ( wpLink.lastSearch == title ) 
     159                                        return; 
     160                                 
     161                                wpLink.lastSearch = title; 
    132162                                waiting = t.siblings('img.waiting').show(); 
     163                                 
     164                                results.search.data('river', wpLink.riverDefaults() ); 
     165                                results.search.scrollTop(0); 
    133166                                wpLink.linkAJAX( results.search, { title : title }, function(){ waiting.hide(); }); 
    134167                        } else { 
    135168                                results.search.hide(); 
     
    137170                        } 
    138171                }, 
    139172                 
    140                 linkAJAX : function( $panel, params, callback ) { 
     173                linkAJAX : function( $panel, params, callback, append ) { 
    141174                        if ( ! $panel.hasClass('query-results') ) 
    142175                                $panel = $panel.parents('.query-results'); 
    143176                         
     
    146179                         
    147180                        $.post( ajaxurl, $.extend({ 
    148181                                action : 'wp-link-ajax' 
    149                         }, params ), function(r) { 
    150                                 var pagelinks = $panel.children('.wp-results-pagelinks'); 
     182                        }, params ), function( results ) { 
     183                                var list = ''; 
    151184                                 
     185                                if ( !results ) { 
     186                                        if ( !append ) { 
     187                                                list += '<li class="no-matches-found unselectable"><span class="item-title"><em>' 
     188                                                + wpLinkL10n.noMatchesFound 
     189                                                + '</em></span></li>'; 
     190                                        } 
     191                                } else { 
     192                                        $.each( results, function() { 
     193                                                list += '<li><input type="hidden" class="item-permalink" value="' + this['permalink'] + '" />'; 
     194                                                list += '<span class="item-title">'; 
     195                                                list += this['title'] ? this['title'] : '<em>'+ wpLinkL10n.untitled + '</em>'; 
     196                                                list += '</span><span class="item-info">' + this['info'] + '</span></li>'; 
     197                                        }); 
     198                                } 
     199                                 
    152200                                // Set results 
    153                                 $panel.children('ul').html( wpLink.generateListMarkup( r['results'] ) ); 
     201                                $panel.children('ul')[ append ? 'append' : 'html' ]( list ); 
    154202                                 
    155                                 // Handle page links 
    156                                 if ( r['page_links'] ) 
    157                                         pagelinks.html( r['page_links'] ).show(); 
    158                                 else 
    159                                         pagelinks.hide(); 
    160                                  
    161203                                // Run callback 
    162204                                if ( callback ) 
    163                                         callback( r['results'] ); 
     205                                        callback( results ); 
    164206                        }, "json" ); 
    165                 }, 
    166                  
    167                 generateListMarkup : function( results ) { 
    168                         var s = ''; 
    169                          
    170                         if ( ! results ) 
    171                                 return '<li class="no-matches-found unselectable"><span class="item-title"><em>' + wpLinkL10n.noMatchesFound + '</em></span></li>'; 
    172                          
    173                         $.each( results, function() { 
    174                                 s+= '<li><input type="hidden" class="item-permalink" value="' + this['permalink'] + '" />'; 
    175                                 s+= '<span class="item-title">' 
    176                                 s+= this['title'] ? this['title'] : '<em>'+ wpLinkL10n.untitled + '</em>'; 
    177                                 s+= '</span><span class="item-info">' + this['info'] + '</span>'; 
    178                                 s+= '</li>'; 
    179                         }); 
    180                         return s; 
    181207                } 
    182208        } 
    183209         
  • wp-includes/js/tinymce/plugins/wplink/editor_plugin.dev.js

     
    1414                                ed.windowManager.open({ 
    1515                                        file : tinymce.baseURL + '/wp-mce-link.php', 
    1616                                        width : 480, 
    17                                         height : 400, 
     17                                        height : 430, 
    1818                                        inline : 1 
    1919                                }, { 
    2020                                        plugin_url : url // Plugin absolute URL 
  • wp-includes/js/tinymce/wp-mce-link.php

     
    127127#search-results { 
    128128        display: none; 
    129129} 
     130.river-waiting { 
     131        display: none; 
     132        padding: 10px 0; 
     133} 
     134.river-waiting img.waiting { 
     135        margin: 0 auto; 
     136        display: block; 
     137} 
    130138.submitbox { 
    131139        padding: 5px 5px 0; 
    132140        font-size: 11px; 
     
    181189                <div id="most-recent-results" class="query-results"> 
    182190                        <ul> 
    183191                                <li class="unselectable"><em><?php _e( 'No search term specified. Showing recent items.' ); ?></em></li> 
    184                                 <?php foreach ( $most_recent['results'] as $item ) : ?> 
     192                                <?php foreach ( $most_recent as $item ) : ?> 
    185193                                        <li> 
    186194                                                <input type="hidden" class="item-permalink" value="<?php echo esc_url( $item['permalink'] ); ?>" /> 
    187195                                                <span class="item-title"><?php echo $item['title']; ?></span> 
  • wp-includes/js/tinymce/wp-mce-link-includes.php

     
    2020        if ( isset( $args['s'] ) ) 
    2121                $query['s'] = $args['s']; 
    2222 
    23         $pagination = array( 
    24                 'current'  => $args['pagenum'], 
    25                 'per_page' => $query['posts_per_page'], 
    26         ); 
     23        $query['offset'] = $args['pagenum'] > 1 ? $query['posts_per_page'] * ( $args['pagenum'] - 1 ) : 0; 
    2724 
    28         $query['offset'] = $pagination['offset'] = $args['pagenum'] > 1 ? $query['posts_per_page'] * ( $args['pagenum'] - 1 ) : 0; 
    29  
    3025        // Do main query. 
    3126        $get_posts = new WP_Query; 
    3227        $posts = $get_posts->query( $query ); 
     
    4742                        'title' => esc_html( strip_tags($post->post_title) ), 
    4843                        'permalink' => get_permalink( $post->ID ), 
    4944                        'info' => $info, 
    50                 );; 
     45                ); 
    5146        } 
    5247 
    53         // Remaining pagination values. 
    54         $pagination['max'] = $get_posts->max_num_pages; 
    55         $pagination['page_links'] = paginate_links( array( 
    56                 'prev_text' => __('&laquo;'), 
    57                 'next_text' => __('&raquo;'), 
    58                 'total' => $pagination['max'], 
    59                 'current' => $pagination['current'] 
    60         ) ); 
    61  
    62         // Build response. 
    63         $resp = array( 
    64                 'query' => $get_posts, 
    65                 'objects' => $posts, 
    66                 'results' => $results, 
    67                 'pages' => $pagination, 
    68         ); 
    69  
    70         return $resp; 
     48        return $results; 
    7149} 
    7250 
    7351function wp_link_ajax( $request ) { 
     
    7654                $args['s'] = stripslashes( $request['title'] ); 
    7755        $args['pagenum'] = ! empty( $request['page'] ) ? absint( $request['page'] ) : 1; 
    7856 
    79         $resp = wp_link_query( $args ); 
     57        $results = wp_link_query( $args ); 
    8058 
    81         if ( ! isset( $resp ) ) 
     59        if ( ! isset( $results ) ) 
    8260                die( '0' ); 
    83  
    84         $json = array( 'results' => $resp['results'] ); 
    85         if ( isset( $resp['pages'] ) && !empty( $resp['pages']['page_links'] ) ) 
    86                 $json['page_links'] = $resp['pages']['page_links']; 
    8761         
    88         echo json_encode( $json ); 
     62        echo json_encode( $results ); 
    8963        echo "\n"; 
    9064} 
    9165