diff --git Gruntfile.js Gruntfile.js index 8bc1b48..3e1689a 100644 --- Gruntfile.js +++ Gruntfile.js @@ -233,7 +233,8 @@ module.exports = function(grunt) { // Exceptions '!wp-includes/css/dashicons.css', - '!wp-includes/css/wp-embed-template.css' + '!wp-includes/css/wp-embed-template.css', + '!wp-includes/css/wp-embed-template-ie.css' ] }, colors: { diff --git src/wp-includes/css/wp-embed-template-ie.css src/wp-includes/css/wp-embed-template-ie.css new file mode 100644 index 0000000..dca8c07 --- /dev/null +++ src/wp-includes/css/wp-embed-template-ie.css @@ -0,0 +1,38 @@ +/* Dashicons */ +.dashicons { + *display: inline; + *zoom: 1; +} + +.dashicons-no { + background-image: url(); + *background-image: url(../images/embed/close.png); +} + +.dashicons-admin-comments { + background-image: url(); + *background-image: url(../images/embed/comment.png); + *background-position: 0 0; +} + +.wp-embed-comments a:hover .dashicons-admin-comments { + background-image: url(); + *background-image: url(../images/embed/comment.png); + *background-position: 0 -40px; +} + +.dashicons-share { + background-image: url(); + *background-image: url(../images/embed/share.png); + *background-position: 0 0; +} + +.wp-embed-share-dialog-open:hover .dashicons-share { + background-image: url(); + *background-image: url(../images/embed/share.png); + *background-position: 0 -40px; +} + +.wp-embed-share-dialog { + *background-color: #222; +} \ No newline at end of file diff --git src/wp-includes/css/wp-embed-template.css src/wp-includes/css/wp-embed-template.css index 9ea586b..3db0216 100644 --- src/wp-includes/css/wp-embed-template.css +++ src/wp-includes/css/wp-embed-template.css @@ -19,6 +19,8 @@ body { /* Dashicons */ .dashicons { display: inline-block; + *display: inline; + *zoom: 1; width: 20px; height: 20px; background-color: transparent; @@ -46,6 +48,11 @@ body { .dashicons-share { background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%2020%2020%27%3E%3Cpath%20d%3D%27M14.5%2012q1.24%200%202.12.88T17.5%2015t-.88%202.12-2.12.88-2.12-.88T11.5%2015q0-.34.09-.69l-4.38-2.3Q6.32%2013%205%2013q-1.24%200-2.12-.88T2%2010t.88-2.12T5%207q1.3%200%202.21.99l4.38-2.3q-.09-.35-.09-.69%200-1.24.88-2.12T14.5%202t2.12.88T17.5%205t-.88%202.12T14.5%208q-1.3%200-2.21-.99l-4.38%202.3Q8%209.66%208%2010t-.09.69l4.38%202.3q.89-.99%202.21-.99z%27%20fill%3D%27%2382878c%27%2F%3E%3C%2Fsvg%3E"); + display: none; +} + +.js .dashicons-share { + display: block; } .wp-embed-share-dialog-open:hover .dashicons-share { @@ -139,12 +146,16 @@ p.wp-embed-heading { .wp-embed-site-title a { position: relative; display: inline-block; + *display: inline; + *zoom: 1; padding-left: 35px; } .wp-embed-site-title, .wp-embed-meta { display: table-cell; + *display: inline; + *zoom: 1; } .wp-embed-meta { @@ -156,6 +167,7 @@ p.wp-embed-heading { .wp-embed-comments, .wp-embed-share { display: inline; + *zoom: 1; } .wp-embed-meta a:hover { @@ -166,6 +178,8 @@ p.wp-embed-heading { .wp-embed-comments a { line-height: 25px; display: inline-block; + *display: inline; + *zoom: 1; } .wp-embed-comments + .wp-embed-share { @@ -178,6 +192,7 @@ p.wp-embed-heading { left: 0; right: 0; bottom: 0; + background-color: #222; background-color: rgba(10, 10, 10, 0.9); color: #fff; opacity: 1; @@ -254,7 +269,9 @@ p.wp-embed-heading { } .wp-embed-share-tab-button { - display: inline; + display: inline-block; + *display: inline; + *zoom: 1; } .wp-embed-share-tab-button button { diff --git src/wp-includes/default-filters.php src/wp-includes/default-filters.php index 31284d5..504b964 100644 --- src/wp-includes/default-filters.php +++ src/wp-includes/default-filters.php @@ -446,8 +446,8 @@ add_action( 'parse_query', 'wp_oembed_parse_query' ); add_action( 'wp_head', 'wp_oembed_add_discovery_links' ); add_action( 'wp_head', 'wp_oembed_add_host_js' ); +add_action( 'embed_head', 'enqueue_embed_scripts', 1 ); add_action( 'embed_head', 'print_emoji_detection_script' ); -add_action( 'embed_head', 'print_emoji_styles' ); add_action( 'embed_head', 'print_embed_styles' ); add_action( 'embed_head', 'print_embed_scripts' ); add_action( 'embed_head', 'wp_print_head_scripts', 20 ); diff --git src/wp-includes/embed-functions.php src/wp-includes/embed-functions.php index eff7ae4..a1a0d09 100644 --- src/wp-includes/embed-functions.php +++ src/wp-includes/embed-functions.php @@ -373,7 +373,6 @@ function wp_oembed_add_host_js() { wp_enqueue_script( 'wp-oembed' ); } - /** * Retrieves the URL to embed a specific post in an iframe. * @@ -802,6 +801,28 @@ function wp_embed_excerpt_attachment( $content ) { } /** + * Enqueue embed iframe default CSS and JS & fire do_action('enqueue_embed_scripts') + * + * Enqueue PNG fallback CSS for embed iframe for legacy versions of IE. + * + * Allows plugins to queue scripts for the embed iframe end using wp_enqueue_script(). + * Runs first in oembed_head(). + * + * @since 4.4.0 + */ +function enqueue_embed_scripts() { + wp_enqueue_style( 'open-sans' ); + wp_enqueue_style( 'wp-embed-template-ie' ); + + /** + * Fires when scripts and styles are enqueued for the embed iframe. + * + * @since 4.4.0 + */ + do_action( 'enqueue_embed_scripts' ); +} + +/** * Prints the CSS in the embed iframe header. * * @since 4.4.0 diff --git src/wp-includes/embed-template.php src/wp-includes/embed-template.php index d7bda9f..e0513d1 100644 --- src/wp-includes/embed-template.php +++ src/wp-includes/embed-template.php @@ -14,11 +14,9 @@ if ( ! headers_sent() ) { header( 'X-WP-embed: true' ); } -wp_enqueue_style( 'open-sans' ); - ?> -> + class="no-js"> <?php wp_title( '-', true, 'right' ); ?> diff --git src/wp-includes/js/wp-embed-template.js src/wp-includes/js/wp-embed-template.js index 847ebcf..b1dc73a 100644 --- src/wp-includes/js/wp-embed-template.js +++ src/wp-includes/js/wp-embed-template.js @@ -2,6 +2,8 @@ 'use strict'; var secret = window.location.hash.replace( /.*secret=([\d\w]{10}).*/, '$1' ), + supportedBrowser = ( document.querySelector && window.addEventListener ), + loaded = false, resizing; function sendEmbedMessage( message, value ) { @@ -13,6 +15,11 @@ } function onLoad() { + if ( loaded ) { + return; + } + loaded = true; + var share_dialog = document.querySelector( '.wp-embed-share-dialog' ), share_dialog_open = document.querySelector( '.wp-embed-share-dialog-open' ), share_dialog_close = document.querySelector( '.wp-embed-share-dialog-close' ), @@ -141,8 +148,6 @@ } } - document.addEventListener( 'DOMContentLoaded', onLoad, false ); - /** * Iframe resize handler. */ @@ -158,5 +163,10 @@ }, 100 ); } - window.addEventListener( 'resize', onResize, false ); + if ( supportedBrowser ) { + document.documentElement.className = document.documentElement.className.replace( /\bno-js\b/, '' ) + ' js'; + document.addEventListener( 'DOMContentLoaded', onLoad, false ); + window.addEventListener( 'load', onLoad, false ); + window.addEventListener( 'resize', onResize, false ); + } })( window, document ); diff --git src/wp-includes/js/wp-embed.js src/wp-includes/js/wp-embed.js index dd03bc0..167d8c2 100644 --- src/wp-includes/js/wp-embed.js +++ src/wp-includes/js/wp-embed.js @@ -1,6 +1,9 @@ (function ( window, document ) { 'use strict'; + var supportedBrowser = ( document.querySelector && window.addEventListener ), + loaded = false; + window.wp = window.wp || {}; if ( !! window.wp.receiveEmbedMessage ) { @@ -44,9 +47,12 @@ } }; - window.addEventListener( 'message', window.wp.receiveEmbedMessage, false ); - function onLoad() { + if ( loaded ) { + return; + } + loaded = true; + var isIE10 = -1 !== navigator.appVersion.indexOf( 'MSIE 10' ), isIE11 = !!navigator.userAgent.match( /Trident.*rv\:11\./ ); @@ -57,11 +63,14 @@ for ( var i = 0; i < iframes.length; i++ ) { iframeClone = iframes[ i ].cloneNode( true ); iframeClone.removeAttribute( 'security' ); - iframes[ i ].parentNode.insertBefore( iframeClone, iframes[ i ].nextSibling ); - iframes[ i ].parentNode.removeChild( iframes[ i ] ); + iframes[ i ].parentNode.replaceChild( iframeClone, iframes[ i ] ); } } } - document.addEventListener( 'DOMContentLoaded', onLoad, false ); + if ( supportedBrowser ) { + window.addEventListener( 'message', window.wp.receiveEmbedMessage, false ); + document.addEventListener( 'DOMContentLoaded', onLoad, false ); + window.addEventListener( 'load', onLoad, false ); + } })( window, document ); diff --git src/wp-includes/script-loader.php src/wp-includes/script-loader.php index d0fd4a3..ae29c7b 100644 --- src/wp-includes/script-loader.php +++ src/wp-includes/script-loader.php @@ -466,7 +466,7 @@ function wp_default_scripts( &$scripts ) { ), ) ); - $scripts->add( 'wp-oembed', "/wp-includes/js/wp-oembed$suffix.js" ); + $scripts->add( 'wp-embed', "/wp-includes/js/wp-embed$suffix.js" ); // To enqueue media-views or media-editor, call wp_enqueue_media(). // Both rely on numerous settings, styles, and templates to operate correctly. @@ -729,12 +729,14 @@ function wp_default_styles( &$styles ) { $styles->add( 'open-sans', $open_sans_font_url ); // Includes CSS - $styles->add( 'admin-bar', "/wp-includes/css/admin-bar$suffix.css", array( 'open-sans', 'dashicons' ) ); - $styles->add( 'wp-auth-check', "/wp-includes/css/wp-auth-check$suffix.css", array( 'dashicons' ) ); - $styles->add( 'editor-buttons', "/wp-includes/css/editor$suffix.css", array( 'dashicons' ) ); - $styles->add( 'media-views', "/wp-includes/css/media-views$suffix.css", array( 'buttons', 'dashicons', 'wp-mediaelement' ) ); - $styles->add( 'wp-pointer', "/wp-includes/css/wp-pointer$suffix.css", array( 'dashicons' ) ); - $styles->add( 'customize-preview', "/wp-includes/css/customize-preview$suffix.css" ); + $styles->add( 'admin-bar', "/wp-includes/css/admin-bar$suffix.css", array( 'open-sans', 'dashicons' ) ); + $styles->add( 'wp-auth-check', "/wp-includes/css/wp-auth-check$suffix.css", array( 'dashicons' ) ); + $styles->add( 'editor-buttons', "/wp-includes/css/editor$suffix.css", array( 'dashicons' ) ); + $styles->add( 'media-views', "/wp-includes/css/media-views$suffix.css", array( 'buttons', 'dashicons', 'wp-mediaelement' ) ); + $styles->add( 'wp-pointer', "/wp-includes/css/wp-pointer$suffix.css", array( 'dashicons' ) ); + $styles->add( 'customize-preview', "/wp-includes/css/customize-preview$suffix.css" ); + $styles->add( 'wp-embed-template-ie', "/wp-includes/css/wp-embed-template-ie$suffix.css" ); + $styles->add_data( 'wp-embed-template-ie', 'conditional', 'lte IE 8' ); // External libraries and friends $styles->add( 'imgareaselect', '/wp-includes/js/imgareaselect/imgareaselect.css', array(), '0.9.8' );