Anxhelo Lushka
7 years ago
committed by
GitHub
1 changed files with 36 additions and 0 deletions
@ -0,0 +1,36 @@ |
|||
/* |
|||
* Replace all SVG images with inline SVG |
|||
*/ |
|||
jQuery('img.svg').each(function(){ |
|||
var $img = jQuery(this); |
|||
var imgID = $img.attr('id'); |
|||
var imgClass = $img.attr('class'); |
|||
var imgURL = $img.attr('src'); |
|||
|
|||
jQuery.get(imgURL, function(data) { |
|||
// Get the SVG tag, ignore the rest
|
|||
var $svg = jQuery(data).find('svg'); |
|||
|
|||
// Add replaced image's ID to the new SVG
|
|||
if(typeof imgID !== 'undefined') { |
|||
$svg = $svg.attr('id', imgID); |
|||
} |
|||
// Add replaced image's classes to the new SVG
|
|||
if(typeof imgClass !== 'undefined') { |
|||
$svg = $svg.attr('class', imgClass+' replaced-svg'); |
|||
} |
|||
|
|||
// Remove any invalid XML tags as per http://validator.w3.org
|
|||
$svg = $svg.removeAttr('xmlns:a'); |
|||
|
|||
// Check if the viewport is set, if the viewport is not set the SVG wont't scale.
|
|||
if(!$svg.attr('viewBox') && $svg.attr('height') && $svg.attr('width')) { |
|||
$svg.attr('viewBox', '0 0 ' + $svg.attr('height') + ' ' + $svg.attr('width')) |
|||
} |
|||
|
|||
// Replace image with new SVG
|
|||
$img.replaceWith($svg); |
|||
|
|||
}, 'xml'); |
|||
|
|||
}); |
Loading…
Reference in new issue