UNPKG

3.93 kBJavaScriptView Raw
1"use strict";
2
3var Browsers = require('./browsers');
4
5var utils = require('./utils');
6
7var vendor = require('postcss').vendor;
8/**
9 * Recursively clone objects
10 */
11
12
13function _clone(obj, parent) {
14 var cloned = new obj.constructor();
15
16 var _arr = Object.keys(obj || {});
17
18 for (var _i = 0; _i < _arr.length; _i++) {
19 var i = _arr[_i];
20 var value = obj[i];
21
22 if (i === 'parent' && typeof value === 'object') {
23 if (parent) {
24 cloned[i] = parent;
25 }
26 } else if (i === 'source' || i === null) {
27 cloned[i] = value;
28 } else if (value instanceof Array) {
29 cloned[i] = value.map(function (x) {
30 return _clone(x, cloned);
31 });
32 } else if (i !== '_autoprefixerPrefix' && i !== '_autoprefixerValues') {
33 if (typeof value === 'object' && value !== null) {
34 value = _clone(value, cloned);
35 }
36
37 cloned[i] = value;
38 }
39 }
40
41 return cloned;
42}
43
44var Prefixer =
45/*#__PURE__*/
46function () {
47 /**
48 * Add hack to selected names
49 */
50 Prefixer.hack = function hack(klass) {
51 var _this = this;
52
53 if (!this.hacks) {
54 this.hacks = {};
55 }
56
57 return klass.names.map(function (name) {
58 _this.hacks[name] = klass;
59 return _this.hacks[name];
60 });
61 }
62 /**
63 * Load hacks for some names
64 */
65 ;
66
67 Prefixer.load = function load(name, prefixes, all) {
68 var Klass = this.hacks && this.hacks[name];
69
70 if (Klass) {
71 return new Klass(name, prefixes, all);
72 } else {
73 return new this(name, prefixes, all);
74 }
75 }
76 /**
77 * Clone node and clean autprefixer custom caches
78 */
79 ;
80
81 Prefixer.clone = function clone(node, overrides) {
82 var cloned = _clone(node);
83
84 for (var name in overrides) {
85 cloned[name] = overrides[name];
86 }
87
88 return cloned;
89 };
90
91 function Prefixer(name, prefixes, all) {
92 this.prefixes = prefixes;
93 this.name = name;
94 this.all = all;
95 }
96 /**
97 * Find prefix in node parents
98 */
99
100
101 var _proto = Prefixer.prototype;
102
103 _proto.parentPrefix = function parentPrefix(node) {
104 var prefix;
105
106 if (typeof node._autoprefixerPrefix !== 'undefined') {
107 prefix = node._autoprefixerPrefix;
108 } else if (node.type === 'decl' && node.prop[0] === '-') {
109 prefix = vendor.prefix(node.prop);
110 } else if (node.type === 'root') {
111 prefix = false;
112 } else if (node.type === 'rule' && node.selector.indexOf(':-') !== -1 && /:(-\w+-)/.test(node.selector)) {
113 prefix = node.selector.match(/:(-\w+-)/)[1];
114 } else if (node.type === 'atrule' && node.name[0] === '-') {
115 prefix = vendor.prefix(node.name);
116 } else {
117 prefix = this.parentPrefix(node.parent);
118 }
119
120 if (Browsers.prefixes().indexOf(prefix) === -1) {
121 prefix = false;
122 }
123
124 node._autoprefixerPrefix = prefix;
125 return node._autoprefixerPrefix;
126 }
127 /**
128 * Clone node with prefixes
129 */
130 ;
131
132 _proto.process = function process(node, result) {
133 if (!this.check(node)) {
134 return undefined;
135 }
136
137 var parent = this.parentPrefix(node);
138 var prefixes = this.prefixes.filter(function (prefix) {
139 return !parent || parent === utils.removeNote(prefix);
140 });
141 var added = [];
142
143 for (var _iterator = prefixes, _isArray = Array.isArray(_iterator), _i2 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
144 var _ref;
145
146 if (_isArray) {
147 if (_i2 >= _iterator.length) break;
148 _ref = _iterator[_i2++];
149 } else {
150 _i2 = _iterator.next();
151 if (_i2.done) break;
152 _ref = _i2.value;
153 }
154
155 var prefix = _ref;
156
157 if (this.add(node, prefix, added.concat([prefix]), result)) {
158 added.push(prefix);
159 }
160 }
161
162 return added;
163 }
164 /**
165 * Shortcut for Prefixer.clone
166 */
167 ;
168
169 _proto.clone = function clone(node, overrides) {
170 return Prefixer.clone(node, overrides);
171 };
172
173 return Prefixer;
174}();
175
176module.exports = Prefixer;
\No newline at end of file