-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathaddViewBox.js
49 lines (42 loc) · 1.27 KB
/
addViewBox.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
'use strict';
exports.type = 'perItem';
exports.active = true;
exports.description = 'replaces width, height attributes of an svg with viewBox attribute to make it responsive';
var viewBoxElems = ['svg'];
/**
* Replaces width, height attributes of an svg with viewBox attribute to make it responsive.
*
* @see http://www.w3.org/TR/SVG/coords.html#ViewBoxAttribute
*
* @example
* <svg width="100" height="50">
* ⬇
* <svg viewBox="0 0 100 50">
*
* Requirment: add "- addViewBox" in svgo.yml file which is placed in the folder where svgo is installed.
* Usage: svgo --disable=removeViewBox --enable=addViewBox file.svg
*
* @param {Object} item current iteration item
* @return {Boolean} if false, item will be filtered out
*
* @author Guy Lando
*/
exports.fn = function(item) {
if (
item.isElem(viewBoxElems) &&
!item.hasAttr('viewBox') &&
item.hasAttr('width') &&
item.hasAttr('height')
) {
var width = parseFloat(item.attr('width').value.replace(/px$/, ''));
var height = parseFloat(item.attr('height').value.replace(/px$/, ''));
item.removeAttr('width');
item.removeAttr('height');
item.addAttr({
name: 'viewBox',
prefix: '',
local: 'viewBox',
value: '0 0 ' + width + ' ' + height
});
}
};