Make WordPress Core

Ticket #28895: 28895.2.diff

File 28895.2.diff, 4.7 KB (added by ericlewis, 11 years ago)
  • src/wp-admin/includes/ajax-actions.php

    diff --git a/src/wp-admin/includes/ajax-actions.php b/src/wp-admin/includes/ajax-actions.php
    index 78cad54..55661dd 100644
    a b function wp_ajax_query_attachments() { 
    21562156        $query = isset( $_REQUEST['query'] ) ? (array) $_REQUEST['query'] : array();
    21572157        $query = array_intersect_key( $query, array_flip( array(
    21582158                's', 'order', 'orderby', 'posts_per_page', 'paged', 'post_mime_type',
    2159                 'post_parent', 'post__in', 'post__not_in',
     2159                'post_parent', 'post__in', 'post__not_in', 'year', 'monthnum'
    21602160        ) ) );
    21612161
    21622162        $query['post_type'] = 'attachment';
    function wp_ajax_parse_media_shortcode() { 
    27132713        if ( ! empty( $wp_scripts ) ) {
    27142714                $wp_scripts->done = array();
    27152715        }
    2716        
     2716
    27172717        if ( 'playlist' === $_REQUEST['type'] ) {
    27182718                wp_underscore_playlist_templates();
    27192719
  • src/wp-includes/js/media-grid.js

    diff --git a/src/wp-includes/js/media-grid.js b/src/wp-includes/js/media-grid.js
    index a1f2e30..bdb6b90 100644
    a b  
    448448
    449449                /**
    450450                 * Render the EditImage view into the frame's content region.
    451                  * 
     451                 *
    452452                 * @param {Object} contentRegion Basic object with a `view` property, which
    453453                 *                               should be set with the proper region view.
    454454                 */
     
    649649                }
    650650        });
    651651
     652        /**
     653         * A filter dropdown for month/dates.
     654         */
     655        media.view.DateFilter = media.view.AttachmentFilters.extend({
     656                createFilters: function() {
     657                        var filters = {};
     658                        _.each( media.view.settings.months || {}, function( value, index ) {
     659                                filters[ index ] = {
     660                                        text: value.text,
     661                                        props: {
     662                                                year: value.year,
     663                                                monthnum: value.month
     664                                        }
     665                                };
     666                        });
     667                        filters.all = {
     668                                text:  l10n.allDates,
     669                                props: {
     670                                        monthnum: false,
     671                                        year:  false
     672                                },
     673                                priority: 10
     674                        };
     675                        this.filters = filters;
     676                }
     677        });
     678
    652679}(jQuery, _, Backbone, wp));
     680 No newline at end of file
  • src/wp-includes/js/media-views.js

    diff --git a/src/wp-includes/js/media-views.js b/src/wp-includes/js/media-views.js
    index ce8eadf..ef3e787 100644
    a b  
    55065506                        this.select();
    55075507                },
    55085508
     5509                /**
     5510                 * @abstract
     5511                 */
    55095512                createFilters: function() {
    55105513                        this.filters = {};
    55115514                },
    55125515
     5516                /**
     5517                 * When the selection changes, set the Query properties
     5518                 * accordingly for the selected filter.
     5519                 */
    55135520                change: function() {
    55145521                        var filter = this.filters[ this.el.value ];
    5515 
    55165522                        if ( filter ) {
    55175523                                this.model.set( filter.props );
    55185524                        }
     
    57425748                                        priority: -90
    57435749                                }).render() );
    57445750
    5745                                 this.toolbar.set( 'BulkSelection', new media.view.BulkSelection({
     5751                                this.toolbar.set( 'bulkSelection', new media.view.BulkSelection({
    57465752                                        controller: this.controller,
    57475753                                        priority: -70
    57485754                                }).render() );
     5755                                this.toolbar.set( 'dateFilter', new media.view.DateFilter({
     5756                                        controller: this.controller,
     5757                                        model:      this.collection.props,
     5758                                        priority: -75
     5759                                }).render() );
    57495760                        }
    57505761
    57515762                        filters = this.options.filters;
  • src/wp-includes/media.php

    diff --git a/src/wp-includes/media.php b/src/wp-includes/media.php
    index fea3c34..cd32ae1 100644
    a b function wp_enqueue_media( $args = array() ) { 
    27722772        if ( did_action( 'wp_enqueue_media' ) )
    27732773                return;
    27742774
    2775         global $content_width, $wpdb;
     2775        global $content_width, $wpdb, $wp_locale;
    27762776
    27772777        $defaults = array(
    27782778                'post' => null,
    function wp_enqueue_media( $args = array() ) { 
    28252825                AND post_mime_type LIKE 'video%'
    28262826                LIMIT 1
    28272827        " );
     2828        $months = $wpdb->get_results( $wpdb->prepare( "
     2829                SELECT DISTINCT YEAR( post_date ) AS year, MONTH( post_date ) AS month
     2830                FROM $wpdb->posts
     2831                WHERE post_type = %s
     2832                ORDER BY post_date DESC
     2833        ", 'attachment' ) );
     2834        foreach ( $months as $month_year ) {
     2835                $month_year->text = sprintf( __( '%1$s %2$d' ), $wp_locale->get_month( $month_year->month ), $month_year->year );
     2836        }
    28282837
    28292838        $settings = array(
    28302839                'tabs'      => $tabs,
    function wp_enqueue_media( $args = array() ) { 
    28462855                'embedExts'    => $exts,
    28472856                'embedMimes'   => $ext_mimes,
    28482857                'contentWidth' => $content_width,
     2858                'months'       => $months,
    28492859        );
    28502860
    28512861        $post = null;
    function wp_enqueue_media( $args = array() ) { 
    29042914                'returnToLibrary'        => __( '← Return to library' ),
    29052915                'allMediaItems'          => __( 'All media items' ),
    29062916                'allMediaTypes'          => __( 'All media types' ),
     2917                'allDates'               => __( 'All dates' ),
    29072918                'noItemsFound'           => __( 'No items found.' ),
    29082919                'insertIntoPost'         => $hier ? __( 'Insert into page' ) : __( 'Insert into post' ),
    29092920                'uploadedToThisPost'     => $hier ? __( 'Uploaded to this page' ) : __( 'Uploaded to this post' ),