Final SVG painter fixes.
* wp.svgPainter and now moved to wp-admin. * Restore !important background-image handling. * Delay executing the IE9-specific base64 code if we don't need it. * Make painted icons lose their color after hover at the same speed as dashicons (100ms). props azaozz. fixes #26333. git-svn-id: https://develop.svn.wordpress.org/trunk@26693 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
74d3e9103e
commit
aa65527319
@ -2,9 +2,12 @@
|
|||||||
* Attempt to re-color SVG icons used in the admin menu or the toolbar
|
* Attempt to re-color SVG icons used in the admin menu or the toolbar
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
var svgPainter = ( function( $, window, document, undefined ) {
|
|
||||||
|
window.wp = window.wp || {};
|
||||||
|
|
||||||
|
wp.svgPainter = ( function( $, window, document, undefined ) {
|
||||||
'use strict';
|
'use strict';
|
||||||
var selector, base64,
|
var selector, base64, painter,
|
||||||
colorscheme = {},
|
colorscheme = {},
|
||||||
elements = [];
|
elements = [];
|
||||||
|
|
||||||
@ -12,7 +15,7 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
// detection for browser SVG capability
|
// detection for browser SVG capability
|
||||||
if ( document.implementation.hasFeature( 'http://www.w3.org/TR/SVG11/feature#Image', '1.1' ) ) {
|
if ( document.implementation.hasFeature( 'http://www.w3.org/TR/SVG11/feature#Image', '1.1' ) ) {
|
||||||
$( document.body ).removeClass( 'no-svg' ).addClass( 'svg' );
|
$( document.body ).removeClass( 'no-svg' ).addClass( 'svg' );
|
||||||
svgPainter.init();
|
wp.svgPainter.init();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -35,6 +38,7 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
r256 = [256],
|
r256 = [256],
|
||||||
i = 0;
|
i = 0;
|
||||||
|
|
||||||
|
function init() {
|
||||||
while( i < 256 ) {
|
while( i < 256 ) {
|
||||||
c = String.fromCharCode(i);
|
c = String.fromCharCode(i);
|
||||||
a256 += c;
|
a256 += c;
|
||||||
@ -42,6 +46,7 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
r64[i] = b64.indexOf(c);
|
r64[i] = b64.indexOf(c);
|
||||||
++i;
|
++i;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function code( s, discard, alpha, beta, w1, w2 ) {
|
function code( s, discard, alpha, beta, w1, w2 ) {
|
||||||
var tmp, length,
|
var tmp, length,
|
||||||
@ -77,6 +82,10 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function btoa( plain ) {
|
function btoa( plain ) {
|
||||||
|
if ( ! c ) {
|
||||||
|
init();
|
||||||
|
}
|
||||||
|
|
||||||
plain = code( plain, false, r256, b64, 8, 6 );
|
plain = code( plain, false, r256, b64, 8, 6 );
|
||||||
return plain + '===='.slice( ( plain.length % 4 ) || 4 );
|
return plain + '===='.slice( ( plain.length % 4 ) || 4 );
|
||||||
}
|
}
|
||||||
@ -84,6 +93,10 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
function atob( coded ) {
|
function atob( coded ) {
|
||||||
var i;
|
var i;
|
||||||
|
|
||||||
|
if ( ! c ) {
|
||||||
|
init();
|
||||||
|
}
|
||||||
|
|
||||||
coded = coded.replace( /[^A-Za-z0-9\+\/\=]/g, '' );
|
coded = coded.replace( /[^A-Za-z0-9\+\/\=]/g, '' );
|
||||||
coded = String(coded).split('=');
|
coded = String(coded).split('=');
|
||||||
i = coded.length;
|
i = coded.length;
|
||||||
@ -105,6 +118,7 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
init: function() {
|
init: function() {
|
||||||
|
painter = this;
|
||||||
selector = $( '#adminmenu .wp-menu-image, #wpadminbar .ab-item' );
|
selector = $( '#adminmenu .wp-menu-image, #wpadminbar .ab-item' );
|
||||||
|
|
||||||
this.setColors();
|
this.setColors();
|
||||||
@ -139,15 +153,22 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
|
|
||||||
if ( $menuitem.hasClass( 'current' ) || $menuitem.hasClass( 'wp-has-current-submenu' ) ) {
|
if ( $menuitem.hasClass( 'current' ) || $menuitem.hasClass( 'wp-has-current-submenu' ) ) {
|
||||||
// paint icon in 'current' color
|
// paint icon in 'current' color
|
||||||
svgPainter.paintElement( $element, 'current' );
|
painter.paintElement( $element, 'current' );
|
||||||
} else {
|
} else {
|
||||||
// paint icon in base color
|
// paint icon in base color
|
||||||
svgPainter.paintElement( $element, 'base' );
|
painter.paintElement( $element, 'base' );
|
||||||
|
|
||||||
// set hover callbacks
|
// set hover callbacks
|
||||||
$menuitem.hover(
|
$menuitem.hover(
|
||||||
function() { svgPainter.paintElement( $element, 'focus' ); },
|
function() {
|
||||||
function() { svgPainter.paintElement( $element, 'base' ); }
|
painter.paintElement( $element, 'focus' );
|
||||||
|
},
|
||||||
|
function() {
|
||||||
|
// Match the delay from hoverIntent
|
||||||
|
window.setTimeout( function() {
|
||||||
|
painter.paintElement( $element, 'base' );
|
||||||
|
}, 100 );
|
||||||
|
}
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -169,19 +190,27 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
|
|
||||||
xml = $element.data( 'wp-ui-svg-' + color );
|
xml = $element.data( 'wp-ui-svg-' + color );
|
||||||
|
|
||||||
if ( ! xml ) {
|
if ( xml === 'none' ) {
|
||||||
encoded = $element.css( 'background-image' ).match( /.+data:image\/svg\+xml;base64,(.+?)['"]? ?\)/ );
|
|
||||||
|
|
||||||
if ( ! encoded || ! encoded[1] ) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( ! xml ) {
|
||||||
|
encoded = $element.css( 'background-image' ).match( /.+data:image\/svg\+xml;base64,([A-Za-z0-9\+\/\=]+)/ );
|
||||||
|
|
||||||
|
if ( ! encoded || ! encoded[1] ) {
|
||||||
|
$element.data( 'wp-ui-svg-' + color, 'none' );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
if ( 'atob' in window ) {
|
if ( 'atob' in window ) {
|
||||||
xml = window.atob( encoded[1] );
|
xml = window.atob( encoded[1] );
|
||||||
} else {
|
} else {
|
||||||
xml = base64.atob( encoded[1] );
|
xml = base64.atob( encoded[1] );
|
||||||
}
|
}
|
||||||
|
} catch ( error ) {}
|
||||||
|
|
||||||
|
if ( xml ) {
|
||||||
// replace `fill` attributes
|
// replace `fill` attributes
|
||||||
xml = xml.replace( /fill="(.+?)"/g, 'fill="' + color + '"');
|
xml = xml.replace( /fill="(.+?)"/g, 'fill="' + color + '"');
|
||||||
|
|
||||||
@ -198,9 +227,13 @@ var svgPainter = ( function( $, window, document, undefined ) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$element.data( 'wp-ui-svg-' + color, xml );
|
$element.data( 'wp-ui-svg-' + color, xml );
|
||||||
|
} else {
|
||||||
|
$element.data( 'wp-ui-svg-' + color, 'none' );
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$element.css( 'background-image', 'url("data:image/svg+xml;base64,' + xml + '")' );
|
$element.attr( 'style', 'background-image: url("data:image/svg+xml;base64,' + xml + '") !important;' );
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
/* global ajaxurl, pwsL10n, svgPainter */
|
/* global ajaxurl, pwsL10n */
|
||||||
(function($){
|
(function($){
|
||||||
|
|
||||||
function check_pass_strength() {
|
function check_pass_strength() {
|
||||||
@ -99,14 +99,14 @@
|
|||||||
$stylesheet.attr( 'href', $this.children( '.css_url' ).val() );
|
$stylesheet.attr( 'href', $this.children( '.css_url' ).val() );
|
||||||
|
|
||||||
// repaint icons
|
// repaint icons
|
||||||
if ( typeof window.svgPainter !== 'undefined' ) {
|
if ( typeof wp !== 'undefined' && wp.svgPainter ) {
|
||||||
try {
|
try {
|
||||||
colors = $.parseJSON( $this.children( '.icon_colors' ).val() );
|
colors = $.parseJSON( $this.children( '.icon_colors' ).val() );
|
||||||
} catch ( error ) {}
|
} catch ( error ) {}
|
||||||
|
|
||||||
if ( colors ) {
|
if ( colors ) {
|
||||||
svgPainter.setColors( colors );
|
wp.svgPainter.setColors( colors );
|
||||||
svgPainter.paint();
|
wp.svgPainter.paint();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -515,7 +515,7 @@ function wp_default_scripts( &$scripts ) {
|
|||||||
$scripts->add( 'custom-background', "/wp-admin/js/custom-background$suffix.js", array( 'wp-color-picker', 'media-views' ), false, 1 );
|
$scripts->add( 'custom-background', "/wp-admin/js/custom-background$suffix.js", array( 'wp-color-picker', 'media-views' ), false, 1 );
|
||||||
$scripts->add( 'media-gallery', "/wp-admin/js/media-gallery$suffix.js", array('jquery'), false, 1 );
|
$scripts->add( 'media-gallery', "/wp-admin/js/media-gallery$suffix.js", array('jquery'), false, 1 );
|
||||||
|
|
||||||
$scripts->add( 'svg-painter', '/wp-includes/js/svg-painter.js', array( 'jquery' ), false, 1 );
|
$scripts->add( 'svg-painter', '/wp-admin/js/svg-painter.js', array( 'jquery' ), false, 1 );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user