postcss 7.0.2 → 7.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of postcss might be problematic. Click here for more details.

package/lib/container.js CHANGED
@@ -1,28 +1,21 @@
1
- 'use strict';
1
+ "use strict";
2
2
 
3
3
  exports.__esModule = true;
4
+ exports.default = void 0;
4
5
 
5
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
6
+ var _declaration = _interopRequireDefault(require("./declaration"));
6
7
 
7
- var _declaration = require('./declaration');
8
+ var _comment = _interopRequireDefault(require("./comment"));
8
9
 
9
- var _declaration2 = _interopRequireDefault(_declaration);
10
-
11
- var _comment = require('./comment');
12
-
13
- var _comment2 = _interopRequireDefault(_comment);
14
-
15
- var _node = require('./node');
16
-
17
- var _node2 = _interopRequireDefault(_node);
10
+ var _node = _interopRequireDefault(require("./node"));
18
11
 
19
12
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
20
13
 
21
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
14
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
22
15
 
23
- function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
16
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
24
17
 
25
- function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
18
+ function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
26
19
 
27
20
  function cleanSource(nodes) {
28
21
  return nodes.map(function (i) {
@@ -31,7 +24,6 @@ function cleanSource(nodes) {
31
24
  return i;
32
25
  });
33
26
  }
34
-
35
27
  /**
36
28
  * The {@link Root}, {@link AtRule}, and {@link Rule} container nodes
37
29
  * inherit some common methods to help work with their children.
@@ -43,21 +35,23 @@ function cleanSource(nodes) {
43
35
  * @abstract
44
36
  */
45
37
 
46
- var Container = function (_Node) {
47
- _inherits(Container, _Node);
48
38
 
49
- function Container() {
50
- _classCallCheck(this, Container);
39
+ var Container =
40
+ /*#__PURE__*/
41
+ function (_Node) {
42
+ _inheritsLoose(Container, _Node);
51
43
 
52
- return _possibleConstructorReturn(this, _Node.apply(this, arguments));
44
+ function Container() {
45
+ return _Node.apply(this, arguments) || this;
53
46
  }
54
47
 
55
- Container.prototype.push = function push(child) {
48
+ var _proto = Container.prototype;
49
+
50
+ _proto.push = function push(child) {
56
51
  child.parent = this;
57
52
  this.nodes.push(child);
58
53
  return this;
59
54
  };
60
-
61
55
  /**
62
56
  * Iterates through the container’s immediate children,
63
57
  * calling `callback` for each child.
@@ -93,31 +87,25 @@ var Container = function (_Node) {
93
87
  */
94
88
 
95
89
 
96
- Container.prototype.each = function each(callback) {
90
+ _proto.each = function each(callback) {
97
91
  if (!this.lastEach) this.lastEach = 0;
98
92
  if (!this.indexes) this.indexes = {};
99
-
100
93
  this.lastEach += 1;
101
94
  var id = this.lastEach;
102
95
  this.indexes[id] = 0;
103
-
104
96
  if (!this.nodes) return undefined;
97
+ var index, result;
105
98
 
106
- var index = void 0,
107
- result = void 0;
108
99
  while (this.indexes[id] < this.nodes.length) {
109
100
  index = this.indexes[id];
110
101
  result = callback(this.nodes[index], index);
111
102
  if (result === false) break;
112
-
113
103
  this.indexes[id] += 1;
114
104
  }
115
105
 
116
106
  delete this.indexes[id];
117
-
118
107
  return result;
119
108
  };
120
-
121
109
  /**
122
110
  * Traverses the container’s descendant nodes, calling callback
123
111
  * for each node.
@@ -139,26 +127,30 @@ var Container = function (_Node) {
139
127
  */
140
128
 
141
129
 
142
- Container.prototype.walk = function walk(callback) {
130
+ _proto.walk = function walk(callback) {
143
131
  return this.each(function (child, i) {
144
- var result = void 0;
132
+ var result;
133
+
145
134
  try {
146
135
  result = callback(child, i);
147
136
  } catch (e) {
148
137
  e.postcssNode = child;
138
+
149
139
  if (e.stack && child.source && /\n\s{4}at /.test(e.stack)) {
150
140
  var s = child.source;
151
- e.stack = e.stack.replace(/\n\s{4}at /, '$&' + s.input.from + ':' + s.start.line + ':' + s.start.column + '$&');
141
+ e.stack = e.stack.replace(/\n\s{4}at /, "$&" + s.input.from + ":" + s.start.line + ":" + s.start.column + "$&");
152
142
  }
143
+
153
144
  throw e;
154
145
  }
146
+
155
147
  if (result !== false && child.walk) {
156
148
  result = child.walk(callback);
157
149
  }
150
+
158
151
  return result;
159
152
  });
160
153
  };
161
-
162
154
  /**
163
155
  * Traverses the container’s descendant nodes, calling callback
164
156
  * for each declaration node.
@@ -190,7 +182,7 @@ var Container = function (_Node) {
190
182
  */
191
183
 
192
184
 
193
- Container.prototype.walkDecls = function walkDecls(prop, callback) {
185
+ _proto.walkDecls = function walkDecls(prop, callback) {
194
186
  if (!callback) {
195
187
  callback = prop;
196
188
  return this.walk(function (child, i) {
@@ -198,21 +190,22 @@ var Container = function (_Node) {
198
190
  return callback(child, i);
199
191
  }
200
192
  });
201
- } else if (prop instanceof RegExp) {
193
+ }
194
+
195
+ if (prop instanceof RegExp) {
202
196
  return this.walk(function (child, i) {
203
197
  if (child.type === 'decl' && prop.test(child.prop)) {
204
198
  return callback(child, i);
205
199
  }
206
200
  });
207
- } else {
208
- return this.walk(function (child, i) {
209
- if (child.type === 'decl' && child.prop === prop) {
210
- return callback(child, i);
211
- }
212
- });
213
201
  }
214
- };
215
202
 
203
+ return this.walk(function (child, i) {
204
+ if (child.type === 'decl' && child.prop === prop) {
205
+ return callback(child, i);
206
+ }
207
+ });
208
+ };
216
209
  /**
217
210
  * Traverses the container’s descendant nodes, calling callback
218
211
  * for each rule node.
@@ -238,30 +231,30 @@ var Container = function (_Node) {
238
231
  */
239
232
 
240
233
 
241
- Container.prototype.walkRules = function walkRules(selector, callback) {
234
+ _proto.walkRules = function walkRules(selector, callback) {
242
235
  if (!callback) {
243
236
  callback = selector;
244
-
245
237
  return this.walk(function (child, i) {
246
238
  if (child.type === 'rule') {
247
239
  return callback(child, i);
248
240
  }
249
241
  });
250
- } else if (selector instanceof RegExp) {
242
+ }
243
+
244
+ if (selector instanceof RegExp) {
251
245
  return this.walk(function (child, i) {
252
246
  if (child.type === 'rule' && selector.test(child.selector)) {
253
247
  return callback(child, i);
254
248
  }
255
249
  });
256
- } else {
257
- return this.walk(function (child, i) {
258
- if (child.type === 'rule' && child.selector === selector) {
259
- return callback(child, i);
260
- }
261
- });
262
250
  }
263
- };
264
251
 
252
+ return this.walk(function (child, i) {
253
+ if (child.type === 'rule' && child.selector === selector) {
254
+ return callback(child, i);
255
+ }
256
+ });
257
+ };
265
258
  /**
266
259
  * Traverses the container’s descendant nodes, calling callback
267
260
  * for each at-rule node.
@@ -294,7 +287,7 @@ var Container = function (_Node) {
294
287
  */
295
288
 
296
289
 
297
- Container.prototype.walkAtRules = function walkAtRules(name, callback) {
290
+ _proto.walkAtRules = function walkAtRules(name, callback) {
298
291
  if (!callback) {
299
292
  callback = name;
300
293
  return this.walk(function (child, i) {
@@ -302,21 +295,22 @@ var Container = function (_Node) {
302
295
  return callback(child, i);
303
296
  }
304
297
  });
305
- } else if (name instanceof RegExp) {
298
+ }
299
+
300
+ if (name instanceof RegExp) {
306
301
  return this.walk(function (child, i) {
307
302
  if (child.type === 'atrule' && name.test(child.name)) {
308
303
  return callback(child, i);
309
304
  }
310
305
  });
311
- } else {
312
- return this.walk(function (child, i) {
313
- if (child.type === 'atrule' && child.name === name) {
314
- return callback(child, i);
315
- }
316
- });
317
306
  }
318
- };
319
307
 
308
+ return this.walk(function (child, i) {
309
+ if (child.type === 'atrule' && child.name === name) {
310
+ return callback(child, i);
311
+ }
312
+ });
313
+ };
320
314
  /**
321
315
  * Traverses the container’s descendant nodes, calling callback
322
316
  * for each comment node.
@@ -335,14 +329,13 @@ var Container = function (_Node) {
335
329
  */
336
330
 
337
331
 
338
- Container.prototype.walkComments = function walkComments(callback) {
332
+ _proto.walkComments = function walkComments(callback) {
339
333
  return this.walk(function (child, i) {
340
334
  if (child.type === 'comment') {
341
335
  return callback(child, i);
342
336
  }
343
337
  });
344
338
  };
345
-
346
339
  /**
347
340
  * Inserts new nodes to the end of the container.
348
341
  *
@@ -365,45 +358,34 @@ var Container = function (_Node) {
365
358
  */
366
359
 
367
360
 
368
- Container.prototype.append = function append() {
369
- for (var _len = arguments.length, children = Array(_len), _key = 0; _key < _len; _key++) {
361
+ _proto.append = function append() {
362
+ for (var _len = arguments.length, children = new Array(_len), _key = 0; _key < _len; _key++) {
370
363
  children[_key] = arguments[_key];
371
364
  }
372
365
 
373
- for (var _iterator = children, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
374
- var _ref;
375
-
376
- if (_isArray) {
377
- if (_i >= _iterator.length) break;
378
- _ref = _iterator[_i++];
379
- } else {
380
- _i = _iterator.next();
381
- if (_i.done) break;
382
- _ref = _i.value;
383
- }
384
-
385
- var child = _ref;
386
-
366
+ for (var _i = 0; _i < children.length; _i++) {
367
+ var child = children[_i];
387
368
  var nodes = this.normalize(child, this.last);
388
- for (var _iterator2 = nodes, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {
389
- var _ref2;
390
369
 
391
- if (_isArray2) {
392
- if (_i2 >= _iterator2.length) break;
393
- _ref2 = _iterator2[_i2++];
370
+ for (var _iterator = nodes, _isArray = Array.isArray(_iterator), _i2 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
371
+ var _ref;
372
+
373
+ if (_isArray) {
374
+ if (_i2 >= _iterator.length) break;
375
+ _ref = _iterator[_i2++];
394
376
  } else {
395
- _i2 = _iterator2.next();
377
+ _i2 = _iterator.next();
396
378
  if (_i2.done) break;
397
- _ref2 = _i2.value;
379
+ _ref = _i2.value;
398
380
  }
399
381
 
400
- var node = _ref2;
382
+ var node = _ref;
401
383
  this.nodes.push(node);
402
384
  }
403
385
  }
386
+
404
387
  return this;
405
388
  };
406
-
407
389
  /**
408
390
  * Inserts new nodes to the start of the container.
409
391
  *
@@ -426,69 +408,73 @@ var Container = function (_Node) {
426
408
  */
427
409
 
428
410
 
429
- Container.prototype.prepend = function prepend() {
430
- for (var _len2 = arguments.length, children = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
411
+ _proto.prepend = function prepend() {
412
+ for (var _len2 = arguments.length, children = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
431
413
  children[_key2] = arguments[_key2];
432
414
  }
433
415
 
434
416
  children = children.reverse();
435
- for (var _iterator3 = children, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {
436
- var _ref3;
437
417
 
438
- if (_isArray3) {
439
- if (_i3 >= _iterator3.length) break;
440
- _ref3 = _iterator3[_i3++];
418
+ for (var _iterator2 = children, _isArray2 = Array.isArray(_iterator2), _i3 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {
419
+ var _ref2;
420
+
421
+ if (_isArray2) {
422
+ if (_i3 >= _iterator2.length) break;
423
+ _ref2 = _iterator2[_i3++];
441
424
  } else {
442
- _i3 = _iterator3.next();
425
+ _i3 = _iterator2.next();
443
426
  if (_i3.done) break;
444
- _ref3 = _i3.value;
427
+ _ref2 = _i3.value;
445
428
  }
446
429
 
447
- var child = _ref3;
448
-
430
+ var child = _ref2;
449
431
  var nodes = this.normalize(child, this.first, 'prepend').reverse();
450
- for (var _iterator4 = nodes, _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {
451
- var _ref4;
452
432
 
453
- if (_isArray4) {
454
- if (_i4 >= _iterator4.length) break;
455
- _ref4 = _iterator4[_i4++];
433
+ for (var _iterator3 = nodes, _isArray3 = Array.isArray(_iterator3), _i4 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {
434
+ var _ref3;
435
+
436
+ if (_isArray3) {
437
+ if (_i4 >= _iterator3.length) break;
438
+ _ref3 = _iterator3[_i4++];
456
439
  } else {
457
- _i4 = _iterator4.next();
440
+ _i4 = _iterator3.next();
458
441
  if (_i4.done) break;
459
- _ref4 = _i4.value;
442
+ _ref3 = _i4.value;
460
443
  }
461
444
 
462
- var node = _ref4;
445
+ var node = _ref3;
463
446
  this.nodes.unshift(node);
464
- }for (var id in this.indexes) {
447
+ }
448
+
449
+ for (var id in this.indexes) {
465
450
  this.indexes[id] = this.indexes[id] + nodes.length;
466
451
  }
467
452
  }
453
+
468
454
  return this;
469
455
  };
470
456
 
471
- Container.prototype.cleanRaws = function cleanRaws(keepBetween) {
457
+ _proto.cleanRaws = function cleanRaws(keepBetween) {
472
458
  _Node.prototype.cleanRaws.call(this, keepBetween);
459
+
473
460
  if (this.nodes) {
474
- for (var _iterator5 = this.nodes, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {
475
- var _ref5;
461
+ for (var _iterator4 = this.nodes, _isArray4 = Array.isArray(_iterator4), _i5 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {
462
+ var _ref4;
476
463
 
477
- if (_isArray5) {
478
- if (_i5 >= _iterator5.length) break;
479
- _ref5 = _iterator5[_i5++];
464
+ if (_isArray4) {
465
+ if (_i5 >= _iterator4.length) break;
466
+ _ref4 = _iterator4[_i5++];
480
467
  } else {
481
- _i5 = _iterator5.next();
468
+ _i5 = _iterator4.next();
482
469
  if (_i5.done) break;
483
- _ref5 = _i5.value;
470
+ _ref4 = _i5.value;
484
471
  }
485
472
 
486
- var node = _ref5;
473
+ var node = _ref4;
487
474
  node.cleanRaws(keepBetween);
488
475
  }
489
476
  }
490
477
  };
491
-
492
478
  /**
493
479
  * Insert new node before old node within the container.
494
480
  *
@@ -502,28 +488,32 @@ var Container = function (_Node) {
502
488
  */
503
489
 
504
490
 
505
- Container.prototype.insertBefore = function insertBefore(exist, add) {
491
+ _proto.insertBefore = function insertBefore(exist, add) {
506
492
  exist = this.index(exist);
507
-
508
493
  var type = exist === 0 ? 'prepend' : false;
509
494
  var nodes = this.normalize(add, this.nodes[exist], type).reverse();
510
- for (var _iterator6 = nodes, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {
511
- var _ref6;
512
495
 
513
- if (_isArray6) {
514
- if (_i6 >= _iterator6.length) break;
515
- _ref6 = _iterator6[_i6++];
496
+ for (var _iterator5 = nodes, _isArray5 = Array.isArray(_iterator5), _i6 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {
497
+ var _ref5;
498
+
499
+ if (_isArray5) {
500
+ if (_i6 >= _iterator5.length) break;
501
+ _ref5 = _iterator5[_i6++];
516
502
  } else {
517
- _i6 = _iterator6.next();
503
+ _i6 = _iterator5.next();
518
504
  if (_i6.done) break;
519
- _ref6 = _i6.value;
505
+ _ref5 = _i6.value;
520
506
  }
521
507
 
522
- var node = _ref6;
508
+ var node = _ref5;
523
509
  this.nodes.splice(exist, 0, node);
524
- }var index = void 0;
510
+ }
511
+
512
+ var index;
513
+
525
514
  for (var id in this.indexes) {
526
515
  index = this.indexes[id];
516
+
527
517
  if (exist <= index) {
528
518
  this.indexes[id] = index + nodes.length;
529
519
  }
@@ -531,7 +521,6 @@ var Container = function (_Node) {
531
521
 
532
522
  return this;
533
523
  };
534
-
535
524
  /**
536
525
  * Insert new node after old node within the container.
537
526
  *
@@ -542,27 +531,31 @@ var Container = function (_Node) {
542
531
  */
543
532
 
544
533
 
545
- Container.prototype.insertAfter = function insertAfter(exist, add) {
534
+ _proto.insertAfter = function insertAfter(exist, add) {
546
535
  exist = this.index(exist);
547
-
548
536
  var nodes = this.normalize(add, this.nodes[exist]).reverse();
549
- for (var _iterator7 = nodes, _isArray7 = Array.isArray(_iterator7), _i7 = 0, _iterator7 = _isArray7 ? _iterator7 : _iterator7[Symbol.iterator]();;) {
550
- var _ref7;
551
537
 
552
- if (_isArray7) {
553
- if (_i7 >= _iterator7.length) break;
554
- _ref7 = _iterator7[_i7++];
538
+ for (var _iterator6 = nodes, _isArray6 = Array.isArray(_iterator6), _i7 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {
539
+ var _ref6;
540
+
541
+ if (_isArray6) {
542
+ if (_i7 >= _iterator6.length) break;
543
+ _ref6 = _iterator6[_i7++];
555
544
  } else {
556
- _i7 = _iterator7.next();
545
+ _i7 = _iterator6.next();
557
546
  if (_i7.done) break;
558
- _ref7 = _i7.value;
547
+ _ref6 = _i7.value;
559
548
  }
560
549
 
561
- var node = _ref7;
550
+ var node = _ref6;
562
551
  this.nodes.splice(exist + 1, 0, node);
563
- }var index = void 0;
552
+ }
553
+
554
+ var index;
555
+
564
556
  for (var id in this.indexes) {
565
557
  index = this.indexes[id];
558
+
566
559
  if (exist < index) {
567
560
  this.indexes[id] = index + nodes.length;
568
561
  }
@@ -570,7 +563,6 @@ var Container = function (_Node) {
570
563
 
571
564
  return this;
572
565
  };
573
-
574
566
  /**
575
567
  * Removes node from the container and cleans the parent properties
576
568
  * from the node and its children.
@@ -587,14 +579,15 @@ var Container = function (_Node) {
587
579
  */
588
580
 
589
581
 
590
- Container.prototype.removeChild = function removeChild(child) {
582
+ _proto.removeChild = function removeChild(child) {
591
583
  child = this.index(child);
592
584
  this.nodes[child].parent = undefined;
593
585
  this.nodes.splice(child, 1);
586
+ var index;
594
587
 
595
- var index = void 0;
596
588
  for (var id in this.indexes) {
597
589
  index = this.indexes[id];
590
+
598
591
  if (index >= child) {
599
592
  this.indexes[id] = index - 1;
600
593
  }
@@ -602,7 +595,6 @@ var Container = function (_Node) {
602
595
 
603
596
  return this;
604
597
  };
605
-
606
598
  /**
607
599
  * Removes all children from the container
608
600
  * and cleans their parent properties.
@@ -615,25 +607,26 @@ var Container = function (_Node) {
615
607
  */
616
608
 
617
609
 
618
- Container.prototype.removeAll = function removeAll() {
619
- for (var _iterator8 = this.nodes, _isArray8 = Array.isArray(_iterator8), _i8 = 0, _iterator8 = _isArray8 ? _iterator8 : _iterator8[Symbol.iterator]();;) {
620
- var _ref8;
610
+ _proto.removeAll = function removeAll() {
611
+ for (var _iterator7 = this.nodes, _isArray7 = Array.isArray(_iterator7), _i8 = 0, _iterator7 = _isArray7 ? _iterator7 : _iterator7[Symbol.iterator]();;) {
612
+ var _ref7;
621
613
 
622
- if (_isArray8) {
623
- if (_i8 >= _iterator8.length) break;
624
- _ref8 = _iterator8[_i8++];
614
+ if (_isArray7) {
615
+ if (_i8 >= _iterator7.length) break;
616
+ _ref7 = _iterator7[_i8++];
625
617
  } else {
626
- _i8 = _iterator8.next();
618
+ _i8 = _iterator7.next();
627
619
  if (_i8.done) break;
628
- _ref8 = _i8.value;
620
+ _ref7 = _i8.value;
629
621
  }
630
622
 
631
- var node = _ref8;
623
+ var node = _ref7;
632
624
  node.parent = undefined;
633
- }this.nodes = [];
625
+ }
626
+
627
+ this.nodes = [];
634
628
  return this;
635
629
  };
636
-
637
630
  /**
638
631
  * Passes all declaration values within the container that match pattern
639
632
  * through callback, replacing those values with the returned result
@@ -662,7 +655,7 @@ var Container = function (_Node) {
662
655
  */
663
656
 
664
657
 
665
- Container.prototype.replaceValues = function replaceValues(pattern, opts, callback) {
658
+ _proto.replaceValues = function replaceValues(pattern, opts, callback) {
666
659
  if (!callback) {
667
660
  callback = opts;
668
661
  opts = {};
@@ -671,13 +664,10 @@ var Container = function (_Node) {
671
664
  this.walkDecls(function (decl) {
672
665
  if (opts.props && opts.props.indexOf(decl.prop) === -1) return;
673
666
  if (opts.fast && decl.value.indexOf(opts.fast) === -1) return;
674
-
675
667
  decl.value = decl.value.replace(pattern, callback);
676
668
  });
677
-
678
669
  return this;
679
670
  };
680
-
681
671
  /**
682
672
  * Returns `true` if callback returns `true`
683
673
  * for all of the container’s children.
@@ -691,10 +681,9 @@ var Container = function (_Node) {
691
681
  */
692
682
 
693
683
 
694
- Container.prototype.every = function every(condition) {
684
+ _proto.every = function every(condition) {
695
685
  return this.nodes.every(condition);
696
686
  };
697
-
698
687
  /**
699
688
  * Returns `true` if callback returns `true` for (at least) one
700
689
  * of the container’s children.
@@ -708,10 +697,9 @@ var Container = function (_Node) {
708
697
  */
709
698
 
710
699
 
711
- Container.prototype.some = function some(condition) {
700
+ _proto.some = function some(condition) {
712
701
  return this.nodes.some(condition);
713
702
  };
714
-
715
703
  /**
716
704
  * Returns a `child`’s index within the {@link Container#nodes} array.
717
705
  *
@@ -724,14 +712,13 @@ var Container = function (_Node) {
724
712
  */
725
713
 
726
714
 
727
- Container.prototype.index = function index(child) {
715
+ _proto.index = function index(child) {
728
716
  if (typeof child === 'number') {
729
717
  return child;
730
- } else {
731
- return this.nodes.indexOf(child);
732
718
  }
733
- };
734
719
 
720
+ return this.nodes.indexOf(child);
721
+ };
735
722
  /**
736
723
  * The container’s first child.
737
724
  *
@@ -742,47 +729,48 @@ var Container = function (_Node) {
742
729
  */
743
730
 
744
731
 
745
- Container.prototype.normalize = function normalize(nodes, sample) {
746
- var _this2 = this;
732
+ _proto.normalize = function normalize(nodes, sample) {
733
+ var _this = this;
747
734
 
748
735
  if (typeof nodes === 'string') {
749
736
  var parse = require('./parse');
737
+
750
738
  nodes = cleanSource(parse(nodes).nodes);
751
739
  } else if (Array.isArray(nodes)) {
752
740
  nodes = nodes.slice(0);
753
- for (var _iterator9 = nodes, _isArray9 = Array.isArray(_iterator9), _i9 = 0, _iterator9 = _isArray9 ? _iterator9 : _iterator9[Symbol.iterator]();;) {
754
- var _ref9;
755
741
 
756
- if (_isArray9) {
757
- if (_i9 >= _iterator9.length) break;
758
- _ref9 = _iterator9[_i9++];
742
+ for (var _iterator8 = nodes, _isArray8 = Array.isArray(_iterator8), _i9 = 0, _iterator8 = _isArray8 ? _iterator8 : _iterator8[Symbol.iterator]();;) {
743
+ var _ref8;
744
+
745
+ if (_isArray8) {
746
+ if (_i9 >= _iterator8.length) break;
747
+ _ref8 = _iterator8[_i9++];
759
748
  } else {
760
- _i9 = _iterator9.next();
749
+ _i9 = _iterator8.next();
761
750
  if (_i9.done) break;
762
- _ref9 = _i9.value;
751
+ _ref8 = _i9.value;
763
752
  }
764
753
 
765
- var i = _ref9;
766
-
754
+ var i = _ref8;
767
755
  if (i.parent) i.parent.removeChild(i, 'ignore');
768
756
  }
769
757
  } else if (nodes.type === 'root') {
770
758
  nodes = nodes.nodes.slice(0);
771
- for (var _iterator10 = nodes, _isArray10 = Array.isArray(_iterator10), _i11 = 0, _iterator10 = _isArray10 ? _iterator10 : _iterator10[Symbol.iterator]();;) {
772
- var _ref10;
773
759
 
774
- if (_isArray10) {
775
- if (_i11 >= _iterator10.length) break;
776
- _ref10 = _iterator10[_i11++];
760
+ for (var _iterator9 = nodes, _isArray9 = Array.isArray(_iterator9), _i10 = 0, _iterator9 = _isArray9 ? _iterator9 : _iterator9[Symbol.iterator]();;) {
761
+ var _ref9;
762
+
763
+ if (_isArray9) {
764
+ if (_i10 >= _iterator9.length) break;
765
+ _ref9 = _iterator9[_i10++];
777
766
  } else {
778
- _i11 = _iterator10.next();
779
- if (_i11.done) break;
780
- _ref10 = _i11.value;
767
+ _i10 = _iterator9.next();
768
+ if (_i10.done) break;
769
+ _ref9 = _i10.value;
781
770
  }
782
771
 
783
- var _i10 = _ref10;
784
-
785
- if (_i10.parent) _i10.parent.removeChild(_i10, 'ignore');
772
+ var _i11 = _ref9;
773
+ if (_i11.parent) _i11.parent.removeChild(_i11, 'ignore');
786
774
  }
787
775
  } else if (nodes.type) {
788
776
  nodes = [nodes];
@@ -792,33 +780,36 @@ var Container = function (_Node) {
792
780
  } else if (typeof nodes.value !== 'string') {
793
781
  nodes.value = String(nodes.value);
794
782
  }
795
- nodes = [new _declaration2.default(nodes)];
783
+
784
+ nodes = [new _declaration.default(nodes)];
796
785
  } else if (nodes.selector) {
797
786
  var Rule = require('./rule');
787
+
798
788
  nodes = [new Rule(nodes)];
799
789
  } else if (nodes.name) {
800
790
  var AtRule = require('./at-rule');
791
+
801
792
  nodes = [new AtRule(nodes)];
802
793
  } else if (nodes.text) {
803
- nodes = [new _comment2.default(nodes)];
794
+ nodes = [new _comment.default(nodes)];
804
795
  } else {
805
796
  throw new Error('Unknown node type in node creation');
806
797
  }
807
798
 
808
799
  var processed = nodes.map(function (i) {
809
800
  if (i.parent) i.parent.removeChild(i);
801
+
810
802
  if (typeof i.raws.before === 'undefined') {
811
803
  if (sample && typeof sample.raws.before !== 'undefined') {
812
804
  i.raws.before = sample.raws.before.replace(/[^\s]/g, '');
813
805
  }
814
806
  }
815
- i.parent = _this2;
807
+
808
+ i.parent = _this;
816
809
  return i;
817
810
  });
818
-
819
811
  return processed;
820
812
  };
821
-
822
813
  /**
823
814
  * @memberof Container#
824
815
  * @member {Node[]} nodes An array containing the container’s children.
@@ -832,12 +823,11 @@ var Container = function (_Node) {
832
823
 
833
824
 
834
825
  _createClass(Container, [{
835
- key: 'first',
826
+ key: "first",
836
827
  get: function get() {
837
828
  if (!this.nodes) return undefined;
838
829
  return this.nodes[0];
839
830
  }
840
-
841
831
  /**
842
832
  * The container’s last child.
843
833
  *
@@ -848,7 +838,7 @@ var Container = function (_Node) {
848
838
  */
849
839
 
850
840
  }, {
851
- key: 'last',
841
+ key: "last",
852
842
  get: function get() {
853
843
  if (!this.nodes) return undefined;
854
844
  return this.nodes[this.nodes.length - 1];
@@ -856,10 +846,9 @@ var Container = function (_Node) {
856
846
  }]);
857
847
 
858
848
  return Container;
859
- }(_node2.default);
860
-
861
- exports.default = Container;
849
+ }(_node.default);
862
850
 
851
+ var _default = Container;
863
852
  /**
864
853
  * @callback childCondition
865
854
  * @param {Node} node Container child.
@@ -875,5 +864,6 @@ exports.default = Container;
875
864
  * @return {false|undefined} Returning `false` will break iteration.
876
865
  */
877
866
 
878
- module.exports = exports['default'];
879
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["container.es6"],"names":["cleanSource","nodes","map","i","source","Container","push","child","parent","each","callback","lastEach","indexes","id","undefined","index","result","length","walk","e","postcssNode","stack","test","s","replace","input","from","start","line","column","walkDecls","prop","type","RegExp","walkRules","selector","walkAtRules","name","walkComments","append","children","normalize","last","node","prepend","reverse","first","unshift","cleanRaws","keepBetween","insertBefore","exist","add","splice","insertAfter","removeChild","removeAll","replaceValues","pattern","opts","props","indexOf","decl","fast","value","every","condition","some","sample","parse","require","Array","isArray","slice","Error","String","Declaration","Rule","AtRule","text","Comment","processed","raws","before","Node"],"mappings":"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","file":"container.js","sourcesContent":["import Declaration from './declaration'\nimport Comment from './comment'\nimport Node from './node'\n\nfunction cleanSource (nodes) {\n  return nodes.map(i => {\n    if (i.nodes) i.nodes = cleanSource(i.nodes)\n    delete i.source\n    return i\n  })\n}\n\n/**\n * The {@link Root}, {@link AtRule}, and {@link Rule} container nodes\n * inherit some common methods to help work with their children.\n *\n * Note that all containers can store any content. If you write a rule inside\n * a rule, PostCSS will parse it.\n *\n * @extends Node\n * @abstract\n */\nclass Container extends Node {\n  push (child) {\n    child.parent = this\n    this.nodes.push(child)\n    return this\n  }\n\n  /**\n   * Iterates through the container’s immediate children,\n   * calling `callback` for each child.\n   *\n   * Returning `false` in the callback will break iteration.\n   *\n   * This method only iterates through the container’s immediate children.\n   * If you need to recursively iterate through all the container’s descendant\n   * nodes, use {@link Container#walk}.\n   *\n   * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe\n   * if you are mutating the array of child nodes during iteration.\n   * PostCSS will adjust the current index to match the mutations.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * const root = postcss.parse('a { color: black; z-index: 1 }')\n   * const rule = root.first\n   *\n   * for (const decl of rule.nodes) {\n   *   decl.cloneBefore({ prop: '-webkit-' + decl.prop })\n   *   // Cycle will be infinite, because cloneBefore moves the current node\n   *   // to the next index\n   * }\n   *\n   * rule.each(decl => {\n   *   decl.cloneBefore({ prop: '-webkit-' + decl.prop })\n   *   // Will be executed only for color and z-index\n   * })\n   */\n  each (callback) {\n    if (!this.lastEach) this.lastEach = 0\n    if (!this.indexes) this.indexes = { }\n\n    this.lastEach += 1\n    let id = this.lastEach\n    this.indexes[id] = 0\n\n    if (!this.nodes) return undefined\n\n    let index, result\n    while (this.indexes[id] < this.nodes.length) {\n      index = this.indexes[id]\n      result = callback(this.nodes[index], index)\n      if (result === false) break\n\n      this.indexes[id] += 1\n    }\n\n    delete this.indexes[id]\n\n    return result\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each node.\n   *\n   * Like container.each(), this method is safe to use\n   * if you are mutating arrays during iteration.\n   *\n   * If you only need to iterate through the container’s immediate children,\n   * use {@link Container#each}.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walk(node => {\n   *   // Traverses all descendant nodes.\n   * })\n   */\n  walk (callback) {\n    return this.each((child, i) => {\n      let result\n      try {\n        result = callback(child, i)\n      } catch (e) {\n        e.postcssNode = child\n        if (e.stack && child.source && /\\n\\s{4}at /.test(e.stack)) {\n          let s = child.source\n          e.stack = e.stack.replace(/\\n\\s{4}at /,\n            `$&${ s.input.from }:${ s.start.line }:${ s.start.column }$&`)\n        }\n        throw e\n      }\n      if (result !== false && child.walk) {\n        result = child.walk(callback)\n      }\n      return result\n    })\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each declaration node.\n   *\n   * If you pass a filter, iteration will only happen over declarations\n   * with matching properties.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [prop]   String or regular expression\n   *                                 to filter declarations by property name.\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkDecls(decl => {\n   *   checkPropertySupport(decl.prop)\n   * })\n   *\n   * root.walkDecls('border-radius', decl => {\n   *   decl.remove()\n   * })\n   *\n   * root.walkDecls(/^background/, decl => {\n   *   decl.value = takeFirstColorFromGradient(decl.value)\n   * })\n   */\n  walkDecls (prop, callback) {\n    if (!callback) {\n      callback = prop\n      return this.walk((child, i) => {\n        if (child.type === 'decl') {\n          return callback(child, i)\n        }\n      })\n    } else if (prop instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'decl' && prop.test(child.prop)) {\n          return callback(child, i)\n        }\n      })\n    } else {\n      return this.walk((child, i) => {\n        if (child.type === 'decl' && child.prop === prop) {\n          return callback(child, i)\n        }\n      })\n    }\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each rule node.\n   *\n   * If you pass a filter, iteration will only happen over rules\n   * with matching selectors.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [selector] String or regular expression\n   *                                   to filter rules by selector.\n   * @param {childIterator} callback   Iterator receives each node and index.\n   *\n   * @return {false|undefined} returns `false` if iteration was broke.\n   *\n   * @example\n   * const selectors = []\n   * root.walkRules(rule => {\n   *   selectors.push(rule.selector)\n   * })\n   * console.log(`Your CSS uses ${ selectors.length } selectors`)\n   */\n  walkRules (selector, callback) {\n    if (!callback) {\n      callback = selector\n\n      return this.walk((child, i) => {\n        if (child.type === 'rule') {\n          return callback(child, i)\n        }\n      })\n    } else if (selector instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'rule' && selector.test(child.selector)) {\n          return callback(child, i)\n        }\n      })\n    } else {\n      return this.walk((child, i) => {\n        if (child.type === 'rule' && child.selector === selector) {\n          return callback(child, i)\n        }\n      })\n    }\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each at-rule node.\n   *\n   * If you pass a filter, iteration will only happen over at-rules\n   * that have matching names.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [name]   String or regular expression\n   *                                 to filter at-rules by name.\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkAtRules(rule => {\n   *   if (isOld(rule.name)) rule.remove()\n   * })\n   *\n   * let first = false\n   * root.walkAtRules('charset', rule => {\n   *   if (!first) {\n   *     first = true\n   *   } else {\n   *     rule.remove()\n   *   }\n   * })\n   */\n  walkAtRules (name, callback) {\n    if (!callback) {\n      callback = name\n      return this.walk((child, i) => {\n        if (child.type === 'atrule') {\n          return callback(child, i)\n        }\n      })\n    } else if (name instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'atrule' && name.test(child.name)) {\n          return callback(child, i)\n        }\n      })\n    } else {\n      return this.walk((child, i) => {\n        if (child.type === 'atrule' && child.name === name) {\n          return callback(child, i)\n        }\n      })\n    }\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each comment node.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkComments(comment => {\n   *   comment.remove()\n   * })\n   */\n  walkComments (callback) {\n    return this.walk((child, i) => {\n      if (child.type === 'comment') {\n        return callback(child, i)\n      }\n    })\n  }\n\n  /**\n   * Inserts new nodes to the end of the container.\n   *\n   * @param {...(Node|object|string|Node[])} children New nodes.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * const decl1 = postcss.decl({ prop: 'color', value: 'black' })\n   * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })\n   * rule.append(decl1, decl2)\n   *\n   * root.append({ name: 'charset', params: '\"UTF-8\"' })  // at-rule\n   * root.append({ selector: 'a' })                       // rule\n   * rule.append({ prop: 'color', value: 'black' })       // declaration\n   * rule.append({ text: 'Comment' })                     // comment\n   *\n   * root.append('a {}')\n   * root.first.append('color: black; z-index: 1')\n   */\n  append (...children) {\n    for (let child of children) {\n      let nodes = this.normalize(child, this.last)\n      for (let node of nodes) this.nodes.push(node)\n    }\n    return this\n  }\n\n  /**\n   * Inserts new nodes to the start of the container.\n   *\n   * @param {...(Node|object|string|Node[])} children New nodes.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * const decl1 = postcss.decl({ prop: 'color', value: 'black' })\n   * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })\n   * rule.prepend(decl1, decl2)\n   *\n   * root.append({ name: 'charset', params: '\"UTF-8\"' })  // at-rule\n   * root.append({ selector: 'a' })                       // rule\n   * rule.append({ prop: 'color', value: 'black' })       // declaration\n   * rule.append({ text: 'Comment' })                     // comment\n   *\n   * root.append('a {}')\n   * root.first.append('color: black; z-index: 1')\n   */\n  prepend (...children) {\n    children = children.reverse()\n    for (let child of children) {\n      let nodes = this.normalize(child, this.first, 'prepend').reverse()\n      for (let node of nodes) this.nodes.unshift(node)\n      for (let id in this.indexes) {\n        this.indexes[id] = this.indexes[id] + nodes.length\n      }\n    }\n    return this\n  }\n\n  cleanRaws (keepBetween) {\n    super.cleanRaws(keepBetween)\n    if (this.nodes) {\n      for (let node of this.nodes) node.cleanRaws(keepBetween)\n    }\n  }\n\n  /**\n   * Insert new node before old node within the container.\n   *\n   * @param {Node|number} exist             Child or child’s index.\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }))\n   */\n  insertBefore (exist, add) {\n    exist = this.index(exist)\n\n    let type = exist === 0 ? 'prepend' : false\n    let nodes = this.normalize(add, this.nodes[exist], type).reverse()\n    for (let node of nodes) this.nodes.splice(exist, 0, node)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (exist <= index) {\n        this.indexes[id] = index + nodes.length\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Insert new node after old node within the container.\n   *\n   * @param {Node|number} exist             Child or child’s index.\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   */\n  insertAfter (exist, add) {\n    exist = this.index(exist)\n\n    let nodes = this.normalize(add, this.nodes[exist]).reverse()\n    for (let node of nodes) this.nodes.splice(exist + 1, 0, node)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (exist < index) {\n        this.indexes[id] = index + nodes.length\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Removes node from the container and cleans the parent properties\n   * from the node and its children.\n   *\n   * @param {Node|number} child Child or child’s index.\n   *\n   * @return {Node} This node for methods chain\n   *\n   * @example\n   * rule.nodes.length  //=> 5\n   * rule.removeChild(decl)\n   * rule.nodes.length  //=> 4\n   * decl.parent        //=> undefined\n   */\n  removeChild (child) {\n    child = this.index(child)\n    this.nodes[child].parent = undefined\n    this.nodes.splice(child, 1)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (index >= child) {\n        this.indexes[id] = index - 1\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Removes all children from the container\n   * and cleans their parent properties.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * rule.removeAll()\n   * rule.nodes.length //=> 0\n   */\n  removeAll () {\n    for (let node of this.nodes) node.parent = undefined\n    this.nodes = []\n    return this\n  }\n\n  /**\n   * Passes all declaration values within the container that match pattern\n   * through callback, replacing those values with the returned result\n   * of callback.\n   *\n   * This method is useful if you are using a custom unit or function\n   * and need to iterate through all values.\n   *\n   * @param {string|RegExp} pattern      Replace pattern.\n   * @param {object} opts                Options to speed up the search.\n   * @param {string|string[]} opts.props An array of property names.\n   * @param {string} opts.fast           String that’s used to narrow down\n   *                                     values and speed up the regexp search.\n   * @param {function|string} callback   String to replace pattern or callback\n   *                                     that returns a new value. The callback\n   *                                     will receive the same arguments\n   *                                     as those passed to a function parameter\n   *                                     of `String#replace`.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * root.replaceValues(/\\d+rem/, { fast: 'rem' }, string => {\n   *   return 15 * parseInt(string) + 'px'\n   * })\n   */\n  replaceValues (pattern, opts, callback) {\n    if (!callback) {\n      callback = opts\n      opts = { }\n    }\n\n    this.walkDecls(decl => {\n      if (opts.props && opts.props.indexOf(decl.prop) === -1) return\n      if (opts.fast && decl.value.indexOf(opts.fast) === -1) return\n\n      decl.value = decl.value.replace(pattern, callback)\n    })\n\n    return this\n  }\n\n  /**\n   * Returns `true` if callback returns `true`\n   * for all of the container’s children.\n   *\n   * @param {childCondition} condition Iterator returns true or false.\n   *\n   * @return {boolean} Is every child pass condition.\n   *\n   * @example\n   * const noPrefixes = rule.every(i => i.prop[0] !== '-')\n   */\n  every (condition) {\n    return this.nodes.every(condition)\n  }\n\n  /**\n   * Returns `true` if callback returns `true` for (at least) one\n   * of the container’s children.\n   *\n   * @param {childCondition} condition Iterator returns true or false.\n   *\n   * @return {boolean} Is some child pass condition.\n   *\n   * @example\n   * const hasPrefix = rule.some(i => i.prop[0] === '-')\n   */\n  some (condition) {\n    return this.nodes.some(condition)\n  }\n\n  /**\n   * Returns a `child`’s index within the {@link Container#nodes} array.\n   *\n   * @param {Node} child Child of the current container.\n   *\n   * @return {number} Child index.\n   *\n   * @example\n   * rule.index( rule.nodes[2] ) //=> 2\n   */\n  index (child) {\n    if (typeof child === 'number') {\n      return child\n    } else {\n      return this.nodes.indexOf(child)\n    }\n  }\n\n  /**\n   * The container’s first child.\n   *\n   * @type {Node}\n   *\n   * @example\n   * rule.first === rules.nodes[0]\n   */\n  get first () {\n    if (!this.nodes) return undefined\n    return this.nodes[0]\n  }\n\n  /**\n   * The container’s last child.\n   *\n   * @type {Node}\n   *\n   * @example\n   * rule.last === rule.nodes[rule.nodes.length - 1]\n   */\n  get last () {\n    if (!this.nodes) return undefined\n    return this.nodes[this.nodes.length - 1]\n  }\n\n  normalize (nodes, sample) {\n    if (typeof nodes === 'string') {\n      let parse = require('./parse')\n      nodes = cleanSource(parse(nodes).nodes)\n    } else if (Array.isArray(nodes)) {\n      nodes = nodes.slice(0)\n      for (let i of nodes) {\n        if (i.parent) i.parent.removeChild(i, 'ignore')\n      }\n    } else if (nodes.type === 'root') {\n      nodes = nodes.nodes.slice(0)\n      for (let i of nodes) {\n        if (i.parent) i.parent.removeChild(i, 'ignore')\n      }\n    } else if (nodes.type) {\n      nodes = [nodes]\n    } else if (nodes.prop) {\n      if (typeof nodes.value === 'undefined') {\n        throw new Error('Value field is missed in node creation')\n      } else if (typeof nodes.value !== 'string') {\n        nodes.value = String(nodes.value)\n      }\n      nodes = [new Declaration(nodes)]\n    } else if (nodes.selector) {\n      let Rule = require('./rule')\n      nodes = [new Rule(nodes)]\n    } else if (nodes.name) {\n      let AtRule = require('./at-rule')\n      nodes = [new AtRule(nodes)]\n    } else if (nodes.text) {\n      nodes = [new Comment(nodes)]\n    } else {\n      throw new Error('Unknown node type in node creation')\n    }\n\n    let processed = nodes.map(i => {\n      if (i.parent) i.parent.removeChild(i)\n      if (typeof i.raws.before === 'undefined') {\n        if (sample && typeof sample.raws.before !== 'undefined') {\n          i.raws.before = sample.raws.before.replace(/[^\\s]/g, '')\n        }\n      }\n      i.parent = this\n      return i\n    })\n\n    return processed\n  }\n\n  /**\n   * @memberof Container#\n   * @member {Node[]} nodes An array containing the container’s children.\n   *\n   * @example\n   * const root = postcss.parse('a { color: black }')\n   * root.nodes.length           //=> 1\n   * root.nodes[0].selector      //=> 'a'\n   * root.nodes[0].nodes[0].prop //=> 'color'\n   */\n}\n\nexport default Container\n\n/**\n * @callback childCondition\n * @param {Node} node    Container child.\n * @param {number} index Child index.\n * @param {Node[]} nodes All container children.\n * @return {boolean}\n */\n\n/**\n * @callback childIterator\n * @param {Node} node    Container child.\n * @param {number} index Child index.\n * @return {false|undefined} Returning `false` will break iteration.\n */\n"]}
867
+ exports.default = _default;
868
+ module.exports = exports.default;
869
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["container.es6"],"names":["cleanSource","nodes","map","i","source","Container","push","child","parent","each","callback","lastEach","indexes","id","undefined","index","result","length","walk","e","postcssNode","stack","test","s","replace","input","from","start","line","column","walkDecls","prop","type","RegExp","walkRules","selector","walkAtRules","name","walkComments","append","children","normalize","last","node","prepend","reverse","first","unshift","cleanRaws","keepBetween","insertBefore","exist","add","splice","insertAfter","removeChild","removeAll","replaceValues","pattern","opts","decl","props","indexOf","fast","value","every","condition","some","sample","parse","require","Array","isArray","slice","Error","String","Declaration","Rule","AtRule","text","Comment","processed","raws","before","Node"],"mappings":"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","sourcesContent":["import Declaration from './declaration'\nimport Comment from './comment'\nimport Node from './node'\n\nfunction cleanSource (nodes) {\n  return nodes.map(i => {\n    if (i.nodes) i.nodes = cleanSource(i.nodes)\n    delete i.source\n    return i\n  })\n}\n\n/**\n * The {@link Root}, {@link AtRule}, and {@link Rule} container nodes\n * inherit some common methods to help work with their children.\n *\n * Note that all containers can store any content. If you write a rule inside\n * a rule, PostCSS will parse it.\n *\n * @extends Node\n * @abstract\n */\nclass Container extends Node {\n  push (child) {\n    child.parent = this\n    this.nodes.push(child)\n    return this\n  }\n\n  /**\n   * Iterates through the container’s immediate children,\n   * calling `callback` for each child.\n   *\n   * Returning `false` in the callback will break iteration.\n   *\n   * This method only iterates through the container’s immediate children.\n   * If you need to recursively iterate through all the container’s descendant\n   * nodes, use {@link Container#walk}.\n   *\n   * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe\n   * if you are mutating the array of child nodes during iteration.\n   * PostCSS will adjust the current index to match the mutations.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * const root = postcss.parse('a { color: black; z-index: 1 }')\n   * const rule = root.first\n   *\n   * for (const decl of rule.nodes) {\n   *   decl.cloneBefore({ prop: '-webkit-' + decl.prop })\n   *   // Cycle will be infinite, because cloneBefore moves the current node\n   *   // to the next index\n   * }\n   *\n   * rule.each(decl => {\n   *   decl.cloneBefore({ prop: '-webkit-' + decl.prop })\n   *   // Will be executed only for color and z-index\n   * })\n   */\n  each (callback) {\n    if (!this.lastEach) this.lastEach = 0\n    if (!this.indexes) this.indexes = { }\n\n    this.lastEach += 1\n    let id = this.lastEach\n    this.indexes[id] = 0\n\n    if (!this.nodes) return undefined\n\n    let index, result\n    while (this.indexes[id] < this.nodes.length) {\n      index = this.indexes[id]\n      result = callback(this.nodes[index], index)\n      if (result === false) break\n\n      this.indexes[id] += 1\n    }\n\n    delete this.indexes[id]\n\n    return result\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each node.\n   *\n   * Like container.each(), this method is safe to use\n   * if you are mutating arrays during iteration.\n   *\n   * If you only need to iterate through the container’s immediate children,\n   * use {@link Container#each}.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walk(node => {\n   *   // Traverses all descendant nodes.\n   * })\n   */\n  walk (callback) {\n    return this.each((child, i) => {\n      let result\n      try {\n        result = callback(child, i)\n      } catch (e) {\n        e.postcssNode = child\n        if (e.stack && child.source && /\\n\\s{4}at /.test(e.stack)) {\n          let s = child.source\n          e.stack = e.stack.replace(/\\n\\s{4}at /,\n            `$&${ s.input.from }:${ s.start.line }:${ s.start.column }$&`)\n        }\n        throw e\n      }\n      if (result !== false && child.walk) {\n        result = child.walk(callback)\n      }\n      return result\n    })\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each declaration node.\n   *\n   * If you pass a filter, iteration will only happen over declarations\n   * with matching properties.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [prop]   String or regular expression\n   *                                 to filter declarations by property name.\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkDecls(decl => {\n   *   checkPropertySupport(decl.prop)\n   * })\n   *\n   * root.walkDecls('border-radius', decl => {\n   *   decl.remove()\n   * })\n   *\n   * root.walkDecls(/^background/, decl => {\n   *   decl.value = takeFirstColorFromGradient(decl.value)\n   * })\n   */\n  walkDecls (prop, callback) {\n    if (!callback) {\n      callback = prop\n      return this.walk((child, i) => {\n        if (child.type === 'decl') {\n          return callback(child, i)\n        }\n      })\n    }\n    if (prop instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'decl' && prop.test(child.prop)) {\n          return callback(child, i)\n        }\n      })\n    }\n    return this.walk((child, i) => {\n      if (child.type === 'decl' && child.prop === prop) {\n        return callback(child, i)\n      }\n    })\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each rule node.\n   *\n   * If you pass a filter, iteration will only happen over rules\n   * with matching selectors.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [selector] String or regular expression\n   *                                   to filter rules by selector.\n   * @param {childIterator} callback   Iterator receives each node and index.\n   *\n   * @return {false|undefined} returns `false` if iteration was broke.\n   *\n   * @example\n   * const selectors = []\n   * root.walkRules(rule => {\n   *   selectors.push(rule.selector)\n   * })\n   * console.log(`Your CSS uses ${ selectors.length } selectors`)\n   */\n  walkRules (selector, callback) {\n    if (!callback) {\n      callback = selector\n\n      return this.walk((child, i) => {\n        if (child.type === 'rule') {\n          return callback(child, i)\n        }\n      })\n    }\n    if (selector instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'rule' && selector.test(child.selector)) {\n          return callback(child, i)\n        }\n      })\n    }\n    return this.walk((child, i) => {\n      if (child.type === 'rule' && child.selector === selector) {\n        return callback(child, i)\n      }\n    })\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each at-rule node.\n   *\n   * If you pass a filter, iteration will only happen over at-rules\n   * that have matching names.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {string|RegExp} [name]   String or regular expression\n   *                                 to filter at-rules by name.\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkAtRules(rule => {\n   *   if (isOld(rule.name)) rule.remove()\n   * })\n   *\n   * let first = false\n   * root.walkAtRules('charset', rule => {\n   *   if (!first) {\n   *     first = true\n   *   } else {\n   *     rule.remove()\n   *   }\n   * })\n   */\n  walkAtRules (name, callback) {\n    if (!callback) {\n      callback = name\n      return this.walk((child, i) => {\n        if (child.type === 'atrule') {\n          return callback(child, i)\n        }\n      })\n    }\n    if (name instanceof RegExp) {\n      return this.walk((child, i) => {\n        if (child.type === 'atrule' && name.test(child.name)) {\n          return callback(child, i)\n        }\n      })\n    }\n    return this.walk((child, i) => {\n      if (child.type === 'atrule' && child.name === name) {\n        return callback(child, i)\n      }\n    })\n  }\n\n  /**\n   * Traverses the container’s descendant nodes, calling callback\n   * for each comment node.\n   *\n   * Like {@link Container#each}, this method is safe\n   * to use if you are mutating arrays during iteration.\n   *\n   * @param {childIterator} callback Iterator receives each node and index.\n   *\n   * @return {false|undefined} Returns `false` if iteration was broke.\n   *\n   * @example\n   * root.walkComments(comment => {\n   *   comment.remove()\n   * })\n   */\n  walkComments (callback) {\n    return this.walk((child, i) => {\n      if (child.type === 'comment') {\n        return callback(child, i)\n      }\n    })\n  }\n\n  /**\n   * Inserts new nodes to the end of the container.\n   *\n   * @param {...(Node|object|string|Node[])} children New nodes.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * const decl1 = postcss.decl({ prop: 'color', value: 'black' })\n   * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })\n   * rule.append(decl1, decl2)\n   *\n   * root.append({ name: 'charset', params: '\"UTF-8\"' })  // at-rule\n   * root.append({ selector: 'a' })                       // rule\n   * rule.append({ prop: 'color', value: 'black' })       // declaration\n   * rule.append({ text: 'Comment' })                     // comment\n   *\n   * root.append('a {}')\n   * root.first.append('color: black; z-index: 1')\n   */\n  append (...children) {\n    for (let child of children) {\n      let nodes = this.normalize(child, this.last)\n      for (let node of nodes) this.nodes.push(node)\n    }\n    return this\n  }\n\n  /**\n   * Inserts new nodes to the start of the container.\n   *\n   * @param {...(Node|object|string|Node[])} children New nodes.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * const decl1 = postcss.decl({ prop: 'color', value: 'black' })\n   * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' })\n   * rule.prepend(decl1, decl2)\n   *\n   * root.append({ name: 'charset', params: '\"UTF-8\"' })  // at-rule\n   * root.append({ selector: 'a' })                       // rule\n   * rule.append({ prop: 'color', value: 'black' })       // declaration\n   * rule.append({ text: 'Comment' })                     // comment\n   *\n   * root.append('a {}')\n   * root.first.append('color: black; z-index: 1')\n   */\n  prepend (...children) {\n    children = children.reverse()\n    for (let child of children) {\n      let nodes = this.normalize(child, this.first, 'prepend').reverse()\n      for (let node of nodes) this.nodes.unshift(node)\n      for (let id in this.indexes) {\n        this.indexes[id] = this.indexes[id] + nodes.length\n      }\n    }\n    return this\n  }\n\n  cleanRaws (keepBetween) {\n    super.cleanRaws(keepBetween)\n    if (this.nodes) {\n      for (let node of this.nodes) node.cleanRaws(keepBetween)\n    }\n  }\n\n  /**\n   * Insert new node before old node within the container.\n   *\n   * @param {Node|number} exist             Child or child’s index.\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }))\n   */\n  insertBefore (exist, add) {\n    exist = this.index(exist)\n\n    let type = exist === 0 ? 'prepend' : false\n    let nodes = this.normalize(add, this.nodes[exist], type).reverse()\n    for (let node of nodes) this.nodes.splice(exist, 0, node)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (exist <= index) {\n        this.indexes[id] = index + nodes.length\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Insert new node after old node within the container.\n   *\n   * @param {Node|number} exist             Child or child’s index.\n   * @param {Node|object|string|Node[]} add New node.\n   *\n   * @return {Node} This node for methods chain.\n   */\n  insertAfter (exist, add) {\n    exist = this.index(exist)\n\n    let nodes = this.normalize(add, this.nodes[exist]).reverse()\n    for (let node of nodes) this.nodes.splice(exist + 1, 0, node)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (exist < index) {\n        this.indexes[id] = index + nodes.length\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Removes node from the container and cleans the parent properties\n   * from the node and its children.\n   *\n   * @param {Node|number} child Child or child’s index.\n   *\n   * @return {Node} This node for methods chain\n   *\n   * @example\n   * rule.nodes.length  //=> 5\n   * rule.removeChild(decl)\n   * rule.nodes.length  //=> 4\n   * decl.parent        //=> undefined\n   */\n  removeChild (child) {\n    child = this.index(child)\n    this.nodes[child].parent = undefined\n    this.nodes.splice(child, 1)\n\n    let index\n    for (let id in this.indexes) {\n      index = this.indexes[id]\n      if (index >= child) {\n        this.indexes[id] = index - 1\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * Removes all children from the container\n   * and cleans their parent properties.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * rule.removeAll()\n   * rule.nodes.length //=> 0\n   */\n  removeAll () {\n    for (let node of this.nodes) node.parent = undefined\n    this.nodes = []\n    return this\n  }\n\n  /**\n   * Passes all declaration values within the container that match pattern\n   * through callback, replacing those values with the returned result\n   * of callback.\n   *\n   * This method is useful if you are using a custom unit or function\n   * and need to iterate through all values.\n   *\n   * @param {string|RegExp} pattern      Replace pattern.\n   * @param {object} opts                Options to speed up the search.\n   * @param {string|string[]} opts.props An array of property names.\n   * @param {string} opts.fast           String that’s used to narrow down\n   *                                     values and speed up the regexp search.\n   * @param {function|string} callback   String to replace pattern or callback\n   *                                     that returns a new value. The callback\n   *                                     will receive the same arguments\n   *                                     as those passed to a function parameter\n   *                                     of `String#replace`.\n   *\n   * @return {Node} This node for methods chain.\n   *\n   * @example\n   * root.replaceValues(/\\d+rem/, { fast: 'rem' }, string => {\n   *   return 15 * parseInt(string) + 'px'\n   * })\n   */\n  replaceValues (pattern, opts, callback) {\n    if (!callback) {\n      callback = opts\n      opts = { }\n    }\n\n    this.walkDecls(decl => {\n      if (opts.props && opts.props.indexOf(decl.prop) === -1) return\n      if (opts.fast && decl.value.indexOf(opts.fast) === -1) return\n\n      decl.value = decl.value.replace(pattern, callback)\n    })\n\n    return this\n  }\n\n  /**\n   * Returns `true` if callback returns `true`\n   * for all of the container’s children.\n   *\n   * @param {childCondition} condition Iterator returns true or false.\n   *\n   * @return {boolean} Is every child pass condition.\n   *\n   * @example\n   * const noPrefixes = rule.every(i => i.prop[0] !== '-')\n   */\n  every (condition) {\n    return this.nodes.every(condition)\n  }\n\n  /**\n   * Returns `true` if callback returns `true` for (at least) one\n   * of the container’s children.\n   *\n   * @param {childCondition} condition Iterator returns true or false.\n   *\n   * @return {boolean} Is some child pass condition.\n   *\n   * @example\n   * const hasPrefix = rule.some(i => i.prop[0] === '-')\n   */\n  some (condition) {\n    return this.nodes.some(condition)\n  }\n\n  /**\n   * Returns a `child`’s index within the {@link Container#nodes} array.\n   *\n   * @param {Node} child Child of the current container.\n   *\n   * @return {number} Child index.\n   *\n   * @example\n   * rule.index( rule.nodes[2] ) //=> 2\n   */\n  index (child) {\n    if (typeof child === 'number') {\n      return child\n    }\n    return this.nodes.indexOf(child)\n  }\n\n  /**\n   * The container’s first child.\n   *\n   * @type {Node}\n   *\n   * @example\n   * rule.first === rules.nodes[0]\n   */\n  get first () {\n    if (!this.nodes) return undefined\n    return this.nodes[0]\n  }\n\n  /**\n   * The container’s last child.\n   *\n   * @type {Node}\n   *\n   * @example\n   * rule.last === rule.nodes[rule.nodes.length - 1]\n   */\n  get last () {\n    if (!this.nodes) return undefined\n    return this.nodes[this.nodes.length - 1]\n  }\n\n  normalize (nodes, sample) {\n    if (typeof nodes === 'string') {\n      let parse = require('./parse')\n      nodes = cleanSource(parse(nodes).nodes)\n    } else if (Array.isArray(nodes)) {\n      nodes = nodes.slice(0)\n      for (let i of nodes) {\n        if (i.parent) i.parent.removeChild(i, 'ignore')\n      }\n    } else if (nodes.type === 'root') {\n      nodes = nodes.nodes.slice(0)\n      for (let i of nodes) {\n        if (i.parent) i.parent.removeChild(i, 'ignore')\n      }\n    } else if (nodes.type) {\n      nodes = [nodes]\n    } else if (nodes.prop) {\n      if (typeof nodes.value === 'undefined') {\n        throw new Error('Value field is missed in node creation')\n      } else if (typeof nodes.value !== 'string') {\n        nodes.value = String(nodes.value)\n      }\n      nodes = [new Declaration(nodes)]\n    } else if (nodes.selector) {\n      let Rule = require('./rule')\n      nodes = [new Rule(nodes)]\n    } else if (nodes.name) {\n      let AtRule = require('./at-rule')\n      nodes = [new AtRule(nodes)]\n    } else if (nodes.text) {\n      nodes = [new Comment(nodes)]\n    } else {\n      throw new Error('Unknown node type in node creation')\n    }\n\n    let processed = nodes.map(i => {\n      if (i.parent) i.parent.removeChild(i)\n      if (typeof i.raws.before === 'undefined') {\n        if (sample && typeof sample.raws.before !== 'undefined') {\n          i.raws.before = sample.raws.before.replace(/[^\\s]/g, '')\n        }\n      }\n      i.parent = this\n      return i\n    })\n\n    return processed\n  }\n\n  /**\n   * @memberof Container#\n   * @member {Node[]} nodes An array containing the container’s children.\n   *\n   * @example\n   * const root = postcss.parse('a { color: black }')\n   * root.nodes.length           //=> 1\n   * root.nodes[0].selector      //=> 'a'\n   * root.nodes[0].nodes[0].prop //=> 'color'\n   */\n}\n\nexport default Container\n\n/**\n * @callback childCondition\n * @param {Node} node    Container child.\n * @param {number} index Child index.\n * @param {Node[]} nodes All container children.\n * @return {boolean}\n */\n\n/**\n * @callback childIterator\n * @param {Node} node    Container child.\n * @param {number} index Child index.\n * @return {false|undefined} Returning `false` will break iteration.\n */\n"],"file":"container.js"}