Make WordPress Core

Ticket #34204: 34204.2.diff

File 34204.2.diff, 20.0 KB (added by peterwilsoncc, 9 years ago)
  • Gruntfile.js

    diff --git a/Gruntfile.js b/Gruntfile.js
    index b8dd5f8..29173b4 100644
    a b module.exports = function(grunt) { 
    233233
    234234                                        // Exceptions
    235235                                        '!wp-includes/css/dashicons.css',
    236                                         '!wp-includes/css/wp-oembed-embed.css'
     236                                        '!wp-includes/css/wp-oembed-embed.css',
     237                                        '!wp-includes/css/wp-oembed-embed-ie.css'
    237238                                ]
    238239                        },
    239240                        colors: {
  • new file src/wp-includes/css/wp-oembed-embed-ie.css

    diff --git a/src/wp-includes/css/wp-oembed-embed-ie.css b/src/wp-includes/css/wp-oembed-embed-ie.css
    new file mode 100644
    index 0000000..dca8c07
    - +  
     1/* Dashicons */
     2.dashicons {
     3        *display: inline;
     4        *zoom: 1;
     5}
     6
     7.dashicons-no {
     8        background-image: url();
     9        *background-image: url(../images/embed/close.png);
     10}
     11
     12.dashicons-admin-comments {
     13        background-image: url();
     14        *background-image: url(../images/embed/comment.png);
     15        *background-position: 0 0;
     16}
     17
     18.wp-embed-comments a:hover .dashicons-admin-comments {
     19        background-image: url();
     20        *background-image: url(../images/embed/comment.png);
     21        *background-position: 0 -40px;
     22}
     23
     24.dashicons-share {
     25        background-image: url();
     26        *background-image: url(../images/embed/share.png);
     27        *background-position: 0 0;
     28}
     29
     30.wp-embed-share-dialog-open:hover .dashicons-share {
     31        background-image: url();
     32        *background-image: url(../images/embed/share.png);
     33        *background-position: 0 -40px;
     34}
     35
     36.wp-embed-share-dialog {
     37        *background-color: #222;
     38}
     39 No newline at end of file
  • src/wp-includes/css/wp-oembed-embed.css

    diff --git a/src/wp-includes/css/wp-oembed-embed.css b/src/wp-includes/css/wp-oembed-embed.css
    index 9ea586b..20c9a6e 100644
    a b body { 
    1919/* Dashicons */
    2020.dashicons {
    2121        display: inline-block;
     22        *display: inline;
     23        *zoom: 1;
    2224        width: 20px;
    2325        height: 20px;
    2426        background-color: transparent;
    p.wp-embed-heading { 
    139141.wp-embed-site-title a {
    140142        position: relative;
    141143        display: inline-block;
     144        *display: inline;
     145        *zoom: 1;
    142146        padding-left: 35px;
    143147}
    144148
    145149.wp-embed-site-title,
    146150.wp-embed-meta {
    147151        display: table-cell;
     152        *display: inline;
     153        *zoom: 1;
    148154}
    149155
    150156.wp-embed-meta {
    p.wp-embed-heading { 
    156162.wp-embed-comments,
    157163.wp-embed-share {
    158164        display: inline;
     165        *zoom: 1;
    159166}
    160167
    161168.wp-embed-meta a:hover {
    p.wp-embed-heading { 
    166173.wp-embed-comments a {
    167174        line-height: 25px;
    168175        display: inline-block;
     176        *display: inline;
     177        *zoom: 1;
    169178}
    170179
    171180.wp-embed-comments + .wp-embed-share {
    p.wp-embed-heading { 
    178187        left: 0;
    179188        right: 0;
    180189        bottom: 0;
     190        background-color: #222;
    181191        background-color: rgba(10, 10, 10, 0.9);
    182192        color: #fff;
    183193        opacity: 1;
    p.wp-embed-heading { 
    254264}
    255265
    256266.wp-embed-share-tab-button {
    257         display: inline;
     267        display: inline-block;
     268        *display: inline;
     269        *zoom: 1;
    258270}
    259271
    260272.wp-embed-share-tab-button button {
  • src/wp-includes/default-filters.php

    diff --git a/src/wp-includes/default-filters.php b/src/wp-includes/default-filters.php
    index 8bdebe5..44c5a1f 100644
    a b add_action( 'parse_query', 'wp_oembed_parse_query' ); 
    444444add_action( 'wp_head',              'wp_oembed_add_discovery_links'        );
    445445add_action( 'wp_head',              'wp_oembed_add_host_js'                );
    446446
     447add_action( 'oembed_head',          'wp_oembed_enqueue_scripts',     1     );
    447448add_action( 'oembed_head',          'print_emoji_detection_script'         );
    448449add_action( 'oembed_head',          'print_emoji_styles'                   );
    449450add_action( 'oembed_head',          'print_oembed_embed_styles'            );
  • src/wp-includes/embed-functions.php

    diff --git a/src/wp-includes/embed-functions.php b/src/wp-includes/embed-functions.php
    index 094d8cd..066db33 100644
    a b function wp_oembed_excerpt_attachment( $content ) { 
    802802}
    803803
    804804/**
     805 * Enqueue embed iframe default CSS and JS & fire do_action('wp_oembed_enqueue_scripts')
     806 *
     807 * Enqueue PNG fallback CSS for embed iframe for legacy versions of IE.
     808 *
     809 * Allows plugins to queue scripts for the embed iframe end using wp_enqueue_script().
     810 * Runs first in oembed_head().
     811 *
     812 * @since 4.4.0
     813 */
     814function wp_oembed_enqueue_scripts() {
     815        wp_enqueue_style( 'open-sans' );
     816        wp_enqueue_style( 'wp-oembed-embed-ie' );
     817        /**
     818         * Fires when scripts and styles are enqueued for the embed iframe.
     819         *
     820         * @since 4.4.0
     821         */
     822        do_action( 'wp_oembed_enqueue_scripts' );
     823}
     824
     825/**
    805826 * Prints the CSS in the embed iframe header.
    806827 *
    807828 * @since 4.4.0
  • src/wp-includes/embed-template.php

    diff --git a/src/wp-includes/embed-template.php b/src/wp-includes/embed-template.php
    index 7a70b1d..cb6729f 100644
    a b if ( ! headers_sent() ) { 
    1414        header( 'X-WP-oembed: true' );
    1515}
    1616
    17 wp_enqueue_style( 'open-sans' );
    18 
    1917?>
    2018<!DOCTYPE html>
    2119<html <?php language_attributes(); ?>>
    if ( have_posts() ) : 
    170168                                                </div>
    171169                                        <?php endif; ?>
    172170                                        <div class="wp-embed-share">
    173                                                 <button type="button" class="wp-embed-share-dialog-open"
     171                                                <button type="button" id="wp-embed-share-dialog-open"
     172                                                        class="wp-embed-share-dialog-open"
    174173                                                        aria-label="<?php esc_attr_e( 'Open sharing dialog' ); ?>">
    175174                                                        <span class="dashicons dashicons-share"></span>
    176175                                                </button>
    177176                                        </div>
    178177                                </div>
    179178                        </div>
    180                         <div class="wp-embed-share-dialog hidden">
     179                        <div id="wp-embed-share-dialog" class="wp-embed-share-dialog hidden">
    181180                                <div class="wp-embed-share-dialog-content">
    182181                                        <div class="wp-embed-share-dialog-text">
    183                                                 <ul class="wp-embed-share-tabs" role="tablist">
     182                                                <ul id="wp-embed-share-tabs" class="wp-embed-share-tabs" role="tablist">
    184183                                                        <li id="wp-embed-share-tab-button-wordpress" class="wp-embed-share-tab-button" role="presentation">
    185184                                                                <button role="tab" aria-controls="wp-embed-share-tab-wordpress" aria-selected="true" tabindex="0"><?php esc_html_e( 'WordPress Embed' ); ?></button>
    186185                                                        </li>
    if ( have_posts() ) : 
    204203                                                </div>
    205204                                        </div>
    206205
    207                                         <button type="button" class="wp-embed-share-dialog-close" aria-label="<?php esc_attr_e( 'Close sharing dialog' ); ?>">
     206                                        <button type="button" id="wp-embed-share-dialog-close"
     207                                                class="wp-embed-share-dialog-close"
     208                                                aria-label="<?php esc_attr_e( 'Close sharing dialog' ); ?>">
    208209                                                <span class="dashicons dashicons-no"></span>
    209210                                        </button>
    210211                                </div>
  • src/wp-includes/js/wp-oembed-embed.js

    diff --git a/src/wp-includes/images/embed/close.png b/src/wp-includes/images/embed/close.png
    new file mode 100644
    index 0000000..1f7ca13
    Binary files /dev/null and b/src/wp-includes/images/embed/close.png differ
    diff --git a/src/wp-includes/images/embed/comment-hover.png b/src/wp-includes/images/embed/comment-hover.png
    new file mode 100644
    index 0000000..b00ccb3
    Binary files /dev/null and b/src/wp-includes/images/embed/comment-hover.png differ
    diff --git a/src/wp-includes/images/embed/comment.png b/src/wp-includes/images/embed/comment.png
    new file mode 100644
    index 0000000..06c153f
    Binary files /dev/null and b/src/wp-includes/images/embed/comment.png differ
    diff --git a/src/wp-includes/images/embed/share-hover.png b/src/wp-includes/images/embed/share-hover.png
    new file mode 100644
    index 0000000..d176c77
    Binary files /dev/null and b/src/wp-includes/images/embed/share-hover.png differ
    diff --git a/src/wp-includes/images/embed/share.png b/src/wp-includes/images/embed/share.png
    new file mode 100644
    index 0000000..22554f4
    Binary files /dev/null and b/src/wp-includes/images/embed/share.png differ
    diff --git a/src/wp-includes/js/wp-oembed-embed.js b/src/wp-includes/js/wp-oembed-embed.js
    index 847ebcf..407ba25 100644
    a b  
    11(function ( window, document ) {
    2         'use strict';
    32
    43        var secret = window.location.hash.replace( /.*secret=([\d\w]{10}).*/, '$1' ),
     4                querySelectorExists = ( 'querySelector' in document ),
     5                loaded = false,
    56                resizing;
    67
    78        function sendEmbedMessage( message, value ) {
     
    1314        }
    1415
    1516        function onLoad() {
    16                 var share_dialog = document.querySelector( '.wp-embed-share-dialog' ),
    17                         share_dialog_open = document.querySelector( '.wp-embed-share-dialog-open' ),
    18                         share_dialog_close = document.querySelector( '.wp-embed-share-dialog-close' ),
    19                         share_input = document.querySelectorAll( '.wp-embed-share-input' ),
    20                         share_dialog_tabs = document.querySelectorAll( '.wp-embed-share-tab-button button' ),
     17                if ( loaded ) {
     18                        return;
     19                }
     20                loaded = true;
     21
     22                var share_dialog = getElementById( 'wp-embed-share-dialog' ),
     23                        share_dialog_open = getElementById( 'wp-embed-share-dialog-open' ),
     24                        share_dialog_close = getElementById( 'wp-embed-share-dialog-close' ),
    2125                        links = document.getElementsByTagName( 'a' ),
     26                        share_input,
     27                        share_dialog_tabs,
     28                        current_dialog_tab,
    2229                        i;
    2330
    24                 if ( share_input ) {
    25                         for ( i = 0; i < share_input.length; i++ ) {
    26                                 share_input[ i ].addEventListener( 'click', function ( e ) {
    27                                         e.target.select();
    28                                 } );
     31                share_dialog_tabs = getElementById( 'wp-embed-share-tabs' );
     32                if ( share_dialog_tabs ) {
     33                        share_dialog_tabs = share_dialog_tabs.getElementsByTagName( 'button' );
     34                }
     35
     36                if ( querySelectorExists ) {
     37                        share_input = document.querySelectorAll( '.wp-embed-share-input' );
     38                        if ( share_input ) {
     39                                for ( i = 0; i < share_input.length; i++ ) {
     40                                        if ( !( 'select' in share_input[ i ] ) ) {
     41                                                // select unavailable, no need for events
     42                                                break;
     43                                        }
     44                                        addEvent( share_input[ i ], 'click', clickShareInput );
     45                                }
    2946                        }
    3047                }
    3148
     49                function clickShareInput() {
     50                        this.select();
     51                }
     52
    3253                function openSharingDialog() {
    3354                        share_dialog.className = share_dialog.className.replace( 'hidden', '' );
    34                         share_input[ 0 ].select();
     55                        if ( share_input && ( 'select' in share_input[ 0 ] ) ) {
     56                                share_input[ 0 ].select();
     57                        }
    3558                }
    3659
    3760                function closeSharingDialog() {
    3861                        share_dialog.className += ' hidden';
    39                         document.querySelector( '.wp-embed-share-dialog-open' ).focus();
     62                        if ( 'focus' in share_dialog_open ) {
     63                                share_dialog_open.focus();
     64                        }
    4065                }
    4166
    4267                if ( share_dialog_open ) {
    43                         share_dialog_open.addEventListener( 'click', function ( e ) {
     68                        addEvent( share_dialog_open, 'click', function ( e ) {
    4469                                openSharingDialog();
    4570                                e.preventDefault();
    4671                        } );
    4772                }
    4873
    4974                if ( share_dialog_close ) {
    50                         share_dialog_close.addEventListener( 'click', function ( e ) {
     75                        addEvent( share_dialog_close, 'click', function ( e ) {
    5176                                closeSharingDialog();
    5277                                e.preventDefault();
    5378                        } );
    5479                }
    5580
    56                 function shareClickHandler( e ) {
    57                         var currentTab = document.querySelector( '.wp-embed-share-tab-button [aria-selected="true"]' );
    58                         currentTab.setAttribute( 'aria-selected', 'false' );
    59                         document.querySelector( '#' + currentTab.getAttribute( 'aria-controls' ) ).setAttribute( 'aria-hidden', 'true' );
     81                function shareClickHandler() {
     82                        if ( current_dialog_tab ) {
     83                                current_dialog_tab.setAttribute( 'aria-selected', 'false' );
     84                                getElementById( current_dialog_tab.getAttribute( 'aria-controls' ) ).setAttribute( 'aria-hidden', 'true' );
     85                        }
    6086
    61                         e.target.setAttribute( 'aria-selected', 'true' );
    62                         document.querySelector( '#' + e.target.getAttribute( 'aria-controls' ) ).setAttribute( 'aria-hidden', 'false' );
     87                        this.setAttribute( 'aria-selected', 'true' );
     88                        getElementById( this.getAttribute( 'aria-controls' ) ).setAttribute( 'aria-hidden', 'false' );
     89                        current_dialog_tab = this;
    6390                }
    6491
    6592                function shareKeyHandler( e ) {
    66                         var target = e.target,
     93                        var target = this,
    6794                                previousSibling = target.parentElement.previousElementSibling,
    6895                                nextSibling = target.parentElement.nextElementSibling,
    6996                                newTab, newTabChild;
     
    85112
    86113                                target.setAttribute( 'tabindex', '-1' );
    87114                                target.setAttribute( 'aria-selected', false );
    88                                 document.querySelector( '#' + target.getAttribute( 'aria-controls' ) ).setAttribute( 'aria-hidden', 'true' );
     115                                getElementById( target.getAttribute( 'aria-controls' ) ).setAttribute( 'aria-hidden', 'true' );
    89116
    90117                                newTabChild.setAttribute( 'tabindex', '0' );
    91118                                newTabChild.setAttribute( 'aria-selected', 'true' );
    92119                                newTabChild.focus();
    93                                 document.querySelector( '#' + newTabChild.getAttribute( 'aria-controls' ) ).setAttribute( 'aria-hidden', 'false' );
     120                                getElementById( newTabChild.getAttribute( 'aria-controls' ) ).setAttribute( 'aria-hidden', 'false' );
    94121                        }
    95122                }
    96123
    97124                if ( share_dialog_tabs ) {
    98125                        for ( i = 0; i < share_dialog_tabs.length; i++ ) {
    99                                 share_dialog_tabs[ i ].addEventListener( 'click', shareClickHandler );
     126                                addEvent( share_dialog_tabs[ i ], 'click', shareClickHandler );
     127
     128                                addEvent( share_dialog_tabs[ i ], 'keydown', shareKeyHandler );
    100129
    101                                 share_dialog_tabs[ i ].addEventListener( 'keydown', shareKeyHandler );
     130                                if ( 'true' === share_dialog_tabs[ i ].getAttribute( 'aria-selected' ) ) {
     131                                        current_dialog_tab = share_dialog_tabs[ i ];
     132                                }
    102133                        }
    103134                }
    104135
    105                 document.addEventListener( 'keydown', function ( e ) {
     136                addEvent( document, 'keydown', function ( e ) {
    106137                        if ( e.keyCode === 27 && -1 === share_dialog.className.indexOf( 'hidden' ) ) {
    107138                                closeSharingDialog();
    108139                        }
    109                 }, false );
     140                });
    110141
    111142                if ( window.self === window.top ) {
    112143                        return;
     
    121152                 * Detect clicks to external (_top) links.
    122153                 */
    123154                function linkClickHandler( e ) {
    124                         var target = e.target,
     155                        var target = this,
    125156                                href;
    126157                        if ( target.hasAttribute( 'href' ) ) {
    127158                                href = target.getAttribute( 'href' );
     
    137168                }
    138169
    139170                for ( i = 0; i < links.length; i++ ) {
    140                         links[ i ].addEventListener( 'click', linkClickHandler );
     171                        addEvent( links[ i ], 'click', linkClickHandler );
    141172                }
    142173        }
    143174
    144         document.addEventListener( 'DOMContentLoaded', onLoad, false );
    145 
    146175        /**
    147176         * Iframe resize handler.
    148177         */
     
    158187                }, 100 );
    159188        }
    160189
    161         window.addEventListener( 'resize', onResize, false );
     190        /**
     191         * Internal function simplifying document.getElementById
     192         */
     193        function getElementById( id ) {
     194                return document.getElementById( id );
     195        }
     196
     197        /**
     198         * Cross browser event handling
     199         *
     200         * Source: http://dean.edwards.name/weblog/2005/10/add-event/
     201         */
     202        function addEvent(element, type, handler) {
     203                if (element.addEventListener) {
     204                        element.addEventListener(type, handler, false);
     205                } else {
     206                        // assign each event handler a unique ID
     207                        if (!handler.$$guid) handler.$$guid = addEvent.guid++;
     208                        // create a hash table of event types for the element
     209                        if (!element.events) element.events = {};
     210                        // create a hash table of event handlers for each element/event pair
     211                        var handlers = element.events[type];
     212                        if (!handlers) {
     213                                handlers = element.events[type] = {};
     214                                // store the existing event handler (if there is one)
     215                                if (element['on' + type]) {
     216                                        handlers[0] = element['on' + type];
     217                                }
     218                        }
     219                        // store the event handler in the hash table
     220                        handlers[handler.$$guid] = handler;
     221                        // assign a global event handler to do all the work
     222                        element['on' + type] = handleEvent;
     223                }
     224        }
     225        // a counter used to create unique IDs
     226        addEvent.guid = 1;
     227
     228        function handleEvent(event) {
     229                var returnValue = true;
     230                // grab the event object (IE uses a global event object)
     231                event = event || fixEvent(((this.ownerDocument || this.document || this).parentWindow || window).event);
     232                // get a reference to the hash table of event handlers
     233                var handlers = this.events[event.type];
     234                // execute each event handler
     235                for (var i in handlers) {
     236                        this.$$handleEvent = handlers[i];
     237                        if (this.$$handleEvent(event) === false) {
     238                                returnValue = false;
     239                        }
     240                }
     241                return returnValue;
     242        }
     243
     244        function fixEvent(event) {
     245                // add W3C standard event methods
     246                event.preventDefault = fixEvent.preventDefault;
     247                event.stopPropagation = fixEvent.stopPropagation;
     248                return event;
     249        }
     250
     251        fixEvent.preventDefault = function() {
     252                this.returnValue = false;
     253        };
     254
     255        fixEvent.stopPropagation = function() {
     256                this.cancelBubble = true;
     257        };
     258
     259        addEvent( document, 'DOMContentLoaded', onLoad, false );
     260        addEvent( window, 'load', onLoad, false );
     261        addEvent( window, 'resize', onResize, false );
    162262})( window, document );
  • src/wp-includes/js/wp-oembed.js

    diff --git a/src/wp-includes/js/wp-oembed.js b/src/wp-includes/js/wp-oembed.js
    index dd03bc0..bef8db9 100644
    a b  
    4444                }
    4545        };
    4646
    47         window.addEventListener( 'message', window.wp.receiveEmbedMessage, false );
    48 
    4947        function onLoad() {
     48                window.removeEventListener( 'load', onLoad, false );
     49
    5050                var isIE10 = -1 !== navigator.appVersion.indexOf( 'MSIE 10' ),
    5151                        isIE11 = !!navigator.userAgent.match( /Trident.*rv\:11\./ );
    5252
     
    6363                }
    6464        }
    6565
    66         document.addEventListener( 'DOMContentLoaded', onLoad, false );
     66        /**
     67         * Ensure required features exist.
     68         */
     69        function featurePass() {
     70                if ( ( 'addEventListener' in window ) &&
     71                         ( 'querySelector'    in document ) ) {
     72                                return true;
     73                }
     74                return false;
     75        }
     76
     77        if ( featurePass() ) {
     78                document.addEventListener( 'DOMContentLoaded', onLoad, false );
     79                window.addEventListener( 'load', onLoad, false );
     80                window.addEventListener( 'message', window.wp.receiveEmbedMessage, false );
     81        }
    6782})( window, document );
  • src/wp-includes/script-loader.php

    diff --git a/src/wp-includes/script-loader.php b/src/wp-includes/script-loader.php
    index e177d41..362271f 100644
    a b function wp_default_styles( &$styles ) { 
    728728        $styles->add( 'open-sans', $open_sans_font_url );
    729729
    730730        // Includes CSS
    731         $styles->add( 'admin-bar',         "/wp-includes/css/admin-bar$suffix.css", array( 'open-sans', 'dashicons' ) );
    732         $styles->add( 'wp-auth-check',     "/wp-includes/css/wp-auth-check$suffix.css", array( 'dashicons' ) );
    733         $styles->add( 'editor-buttons',    "/wp-includes/css/editor$suffix.css", array( 'dashicons' ) );
    734         $styles->add( 'media-views',       "/wp-includes/css/media-views$suffix.css", array( 'buttons', 'dashicons', 'wp-mediaelement' ) );
    735         $styles->add( 'wp-pointer',        "/wp-includes/css/wp-pointer$suffix.css", array( 'dashicons' ) );
    736         $styles->add( 'customize-preview', "/wp-includes/css/customize-preview$suffix.css" );
     731        $styles->add( 'admin-bar',           "/wp-includes/css/admin-bar$suffix.css", array( 'open-sans', 'dashicons' ) );
     732        $styles->add( 'wp-auth-check',       "/wp-includes/css/wp-auth-check$suffix.css", array( 'dashicons' ) );
     733        $styles->add( 'editor-buttons',      "/wp-includes/css/editor$suffix.css", array( 'dashicons' ) );
     734        $styles->add( 'media-views',         "/wp-includes/css/media-views$suffix.css", array( 'buttons', 'dashicons', 'wp-mediaelement' ) );
     735        $styles->add( 'wp-pointer',          "/wp-includes/css/wp-pointer$suffix.css", array( 'dashicons' ) );
     736        $styles->add( 'customize-preview',   "/wp-includes/css/customize-preview$suffix.css" );
     737        $styles->add( 'wp-oembed-embed-ie', "/wp-includes/css/wp-oembed-embed-ie$suffix.css" );
     738        $styles->add_data( 'wp-oembed-embed-ie', 'conditional', 'lte IE 8' );
    737739
    738740        // External libraries and friends
    739741        $styles->add( 'imgareaselect',       '/wp-includes/js/imgareaselect/imgareaselect.css', array(), '0.9.8' );