UI for Zipcoin Blue

container.js 74KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908
  1. 'use strict';
  2. exports.__esModule = true;
  3. 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; }; }();
  4. var _declaration = require('./declaration');
  5. var _declaration2 = _interopRequireDefault(_declaration);
  6. var _comment = require('./comment');
  7. var _comment2 = _interopRequireDefault(_comment);
  8. var _node = require('./node');
  9. var _node2 = _interopRequireDefault(_node);
  10. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  11. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  12. 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; }
  13. 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; }
  14. function cleanSource(nodes) {
  15. return nodes.map(function (i) {
  16. if (i.nodes) i.nodes = cleanSource(i.nodes);
  17. delete i.source;
  18. return i;
  19. });
  20. }
  21. /**
  22. * The {@link Root}, {@link AtRule}, and {@link Rule} container nodes
  23. * inherit some common methods to help work with their children.
  24. *
  25. * Note that all containers can store any content. If you write a rule inside
  26. * a rule, PostCSS will parse it.
  27. *
  28. * @extends Node
  29. * @abstract
  30. */
  31. var Container = function (_Node) {
  32. _inherits(Container, _Node);
  33. function Container() {
  34. _classCallCheck(this, Container);
  35. return _possibleConstructorReturn(this, _Node.apply(this, arguments));
  36. }
  37. Container.prototype.push = function push(child) {
  38. child.parent = this;
  39. this.nodes.push(child);
  40. return this;
  41. };
  42. /**
  43. * Iterates through the container’s immediate children,
  44. * calling `callback` for each child.
  45. *
  46. * Returning `false` in the callback will break iteration.
  47. *
  48. * This method only iterates through the container’s immediate children.
  49. * If you need to recursively iterate through all the container’s descendant
  50. * nodes, use {@link Container#walk}.
  51. *
  52. * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe
  53. * if you are mutating the array of child nodes during iteration.
  54. * PostCSS will adjust the current index to match the mutations.
  55. *
  56. * @param {childIterator} callback - iterator receives each node and index
  57. *
  58. * @return {false|undefined} returns `false` if iteration was broke
  59. *
  60. * @example
  61. * const root = postcss.parse('a { color: black; z-index: 1 }');
  62. * const rule = root.first;
  63. *
  64. * for ( let decl of rule.nodes ) {
  65. * decl.cloneBefore({ prop: '-webkit-' + decl.prop });
  66. * // Cycle will be infinite, because cloneBefore moves the current node
  67. * // to the next index
  68. * }
  69. *
  70. * rule.each(decl => {
  71. * decl.cloneBefore({ prop: '-webkit-' + decl.prop });
  72. * // Will be executed only for color and z-index
  73. * });
  74. */
  75. Container.prototype.each = function each(callback) {
  76. if (!this.lastEach) this.lastEach = 0;
  77. if (!this.indexes) this.indexes = {};
  78. this.lastEach += 1;
  79. var id = this.lastEach;
  80. this.indexes[id] = 0;
  81. if (!this.nodes) return undefined;
  82. var index = void 0,
  83. result = void 0;
  84. while (this.indexes[id] < this.nodes.length) {
  85. index = this.indexes[id];
  86. result = callback(this.nodes[index], index);
  87. if (result === false) break;
  88. this.indexes[id] += 1;
  89. }
  90. delete this.indexes[id];
  91. return result;
  92. };
  93. /**
  94. * Traverses the container’s descendant nodes, calling callback
  95. * for each node.
  96. *
  97. * Like container.each(), this method is safe to use
  98. * if you are mutating arrays during iteration.
  99. *
  100. * If you only need to iterate through the container’s immediate children,
  101. * use {@link Container#each}.
  102. *
  103. * @param {childIterator} callback - iterator receives each node and index
  104. *
  105. * @return {false|undefined} returns `false` if iteration was broke
  106. *
  107. * @example
  108. * root.walk(node => {
  109. * // Traverses all descendant nodes.
  110. * });
  111. */
  112. Container.prototype.walk = function walk(callback) {
  113. return this.each(function (child, i) {
  114. var result = callback(child, i);
  115. if (result !== false && child.walk) {
  116. result = child.walk(callback);
  117. }
  118. return result;
  119. });
  120. };
  121. /**
  122. * Traverses the container’s descendant nodes, calling callback
  123. * for each declaration node.
  124. *
  125. * If you pass a filter, iteration will only happen over declarations
  126. * with matching properties.
  127. *
  128. * Like {@link Container#each}, this method is safe
  129. * to use if you are mutating arrays during iteration.
  130. *
  131. * @param {string|RegExp} [prop] - string or regular expression
  132. * to filter declarations by property name
  133. * @param {childIterator} callback - iterator receives each node and index
  134. *
  135. * @return {false|undefined} returns `false` if iteration was broke
  136. *
  137. * @example
  138. * root.walkDecls(decl => {
  139. * checkPropertySupport(decl.prop);
  140. * });
  141. *
  142. * root.walkDecls('border-radius', decl => {
  143. * decl.remove();
  144. * });
  145. *
  146. * root.walkDecls(/^background/, decl => {
  147. * decl.value = takeFirstColorFromGradient(decl.value);
  148. * });
  149. */
  150. Container.prototype.walkDecls = function walkDecls(prop, callback) {
  151. if (!callback) {
  152. callback = prop;
  153. return this.walk(function (child, i) {
  154. if (child.type === 'decl') {
  155. return callback(child, i);
  156. }
  157. });
  158. } else if (prop instanceof RegExp) {
  159. return this.walk(function (child, i) {
  160. if (child.type === 'decl' && prop.test(child.prop)) {
  161. return callback(child, i);
  162. }
  163. });
  164. } else {
  165. return this.walk(function (child, i) {
  166. if (child.type === 'decl' && child.prop === prop) {
  167. return callback(child, i);
  168. }
  169. });
  170. }
  171. };
  172. /**
  173. * Traverses the container’s descendant nodes, calling callback
  174. * for each rule node.
  175. *
  176. * If you pass a filter, iteration will only happen over rules
  177. * with matching selectors.
  178. *
  179. * Like {@link Container#each}, this method is safe
  180. * to use if you are mutating arrays during iteration.
  181. *
  182. * @param {string|RegExp} [selector] - string or regular expression
  183. * to filter rules by selector
  184. * @param {childIterator} callback - iterator receives each node and index
  185. *
  186. * @return {false|undefined} returns `false` if iteration was broke
  187. *
  188. * @example
  189. * const selectors = [];
  190. * root.walkRules(rule => {
  191. * selectors.push(rule.selector);
  192. * });
  193. * console.log(`Your CSS uses ${selectors.length} selectors`);
  194. */
  195. Container.prototype.walkRules = function walkRules(selector, callback) {
  196. if (!callback) {
  197. callback = selector;
  198. return this.walk(function (child, i) {
  199. if (child.type === 'rule') {
  200. return callback(child, i);
  201. }
  202. });
  203. } else if (selector instanceof RegExp) {
  204. return this.walk(function (child, i) {
  205. if (child.type === 'rule' && selector.test(child.selector)) {
  206. return callback(child, i);
  207. }
  208. });
  209. } else {
  210. return this.walk(function (child, i) {
  211. if (child.type === 'rule' && child.selector === selector) {
  212. return callback(child, i);
  213. }
  214. });
  215. }
  216. };
  217. /**
  218. * Traverses the container’s descendant nodes, calling callback
  219. * for each at-rule node.
  220. *
  221. * If you pass a filter, iteration will only happen over at-rules
  222. * that have matching names.
  223. *
  224. * Like {@link Container#each}, this method is safe
  225. * to use if you are mutating arrays during iteration.
  226. *
  227. * @param {string|RegExp} [name] - string or regular expression
  228. * to filter at-rules by name
  229. * @param {childIterator} callback - iterator receives each node and index
  230. *
  231. * @return {false|undefined} returns `false` if iteration was broke
  232. *
  233. * @example
  234. * root.walkAtRules(rule => {
  235. * if ( isOld(rule.name) ) rule.remove();
  236. * });
  237. *
  238. * let first = false;
  239. * root.walkAtRules('charset', rule => {
  240. * if ( !first ) {
  241. * first = true;
  242. * } else {
  243. * rule.remove();
  244. * }
  245. * });
  246. */
  247. Container.prototype.walkAtRules = function walkAtRules(name, callback) {
  248. if (!callback) {
  249. callback = name;
  250. return this.walk(function (child, i) {
  251. if (child.type === 'atrule') {
  252. return callback(child, i);
  253. }
  254. });
  255. } else if (name instanceof RegExp) {
  256. return this.walk(function (child, i) {
  257. if (child.type === 'atrule' && name.test(child.name)) {
  258. return callback(child, i);
  259. }
  260. });
  261. } else {
  262. return this.walk(function (child, i) {
  263. if (child.type === 'atrule' && child.name === name) {
  264. return callback(child, i);
  265. }
  266. });
  267. }
  268. };
  269. /**
  270. * Traverses the container’s descendant nodes, calling callback
  271. * for each comment node.
  272. *
  273. * Like {@link Container#each}, this method is safe
  274. * to use if you are mutating arrays during iteration.
  275. *
  276. * @param {childIterator} callback - iterator receives each node and index
  277. *
  278. * @return {false|undefined} returns `false` if iteration was broke
  279. *
  280. * @example
  281. * root.walkComments(comment => {
  282. * comment.remove();
  283. * });
  284. */
  285. Container.prototype.walkComments = function walkComments(callback) {
  286. return this.walk(function (child, i) {
  287. if (child.type === 'comment') {
  288. return callback(child, i);
  289. }
  290. });
  291. };
  292. /**
  293. * Inserts new nodes to the end of the container.
  294. *
  295. * @param {...(Node|object|string|Node[])} children - new nodes
  296. *
  297. * @return {Node} this node for methods chain
  298. *
  299. * @example
  300. * const decl1 = postcss.decl({ prop: 'color', value: 'black' });
  301. * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' });
  302. * rule.append(decl1, decl2);
  303. *
  304. * root.append({ name: 'charset', params: '"UTF-8"' }); // at-rule
  305. * root.append({ selector: 'a' }); // rule
  306. * rule.append({ prop: 'color', value: 'black' }); // declaration
  307. * rule.append({ text: 'Comment' }) // comment
  308. *
  309. * root.append('a {}');
  310. * root.first.append('color: black; z-index: 1');
  311. */
  312. Container.prototype.append = function append() {
  313. for (var _len = arguments.length, children = Array(_len), _key = 0; _key < _len; _key++) {
  314. children[_key] = arguments[_key];
  315. }
  316. for (var _iterator = children, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
  317. var _ref;
  318. if (_isArray) {
  319. if (_i >= _iterator.length) break;
  320. _ref = _iterator[_i++];
  321. } else {
  322. _i = _iterator.next();
  323. if (_i.done) break;
  324. _ref = _i.value;
  325. }
  326. var child = _ref;
  327. var nodes = this.normalize(child, this.last);
  328. for (var _iterator2 = nodes, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {
  329. var _ref2;
  330. if (_isArray2) {
  331. if (_i2 >= _iterator2.length) break;
  332. _ref2 = _iterator2[_i2++];
  333. } else {
  334. _i2 = _iterator2.next();
  335. if (_i2.done) break;
  336. _ref2 = _i2.value;
  337. }
  338. var node = _ref2;
  339. this.nodes.push(node);
  340. }
  341. }
  342. return this;
  343. };
  344. /**
  345. * Inserts new nodes to the start of the container.
  346. *
  347. * @param {...(Node|object|string|Node[])} children - new nodes
  348. *
  349. * @return {Node} this node for methods chain
  350. *
  351. * @example
  352. * const decl1 = postcss.decl({ prop: 'color', value: 'black' });
  353. * const decl2 = postcss.decl({ prop: 'background-color', value: 'white' });
  354. * rule.prepend(decl1, decl2);
  355. *
  356. * root.append({ name: 'charset', params: '"UTF-8"' }); // at-rule
  357. * root.append({ selector: 'a' }); // rule
  358. * rule.append({ prop: 'color', value: 'black' }); // declaration
  359. * rule.append({ text: 'Comment' }) // comment
  360. *
  361. * root.append('a {}');
  362. * root.first.append('color: black; z-index: 1');
  363. */
  364. Container.prototype.prepend = function prepend() {
  365. for (var _len2 = arguments.length, children = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
  366. children[_key2] = arguments[_key2];
  367. }
  368. children = children.reverse();
  369. for (var _iterator3 = children, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {
  370. var _ref3;
  371. if (_isArray3) {
  372. if (_i3 >= _iterator3.length) break;
  373. _ref3 = _iterator3[_i3++];
  374. } else {
  375. _i3 = _iterator3.next();
  376. if (_i3.done) break;
  377. _ref3 = _i3.value;
  378. }
  379. var child = _ref3;
  380. var nodes = this.normalize(child, this.first, 'prepend').reverse();
  381. for (var _iterator4 = nodes, _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {
  382. var _ref4;
  383. if (_isArray4) {
  384. if (_i4 >= _iterator4.length) break;
  385. _ref4 = _iterator4[_i4++];
  386. } else {
  387. _i4 = _iterator4.next();
  388. if (_i4.done) break;
  389. _ref4 = _i4.value;
  390. }
  391. var node = _ref4;
  392. this.nodes.unshift(node);
  393. }for (var id in this.indexes) {
  394. this.indexes[id] = this.indexes[id] + nodes.length;
  395. }
  396. }
  397. return this;
  398. };
  399. Container.prototype.cleanRaws = function cleanRaws(keepBetween) {
  400. _Node.prototype.cleanRaws.call(this, keepBetween);
  401. if (this.nodes) {
  402. for (var _iterator5 = this.nodes, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {
  403. var _ref5;
  404. if (_isArray5) {
  405. if (_i5 >= _iterator5.length) break;
  406. _ref5 = _iterator5[_i5++];
  407. } else {
  408. _i5 = _iterator5.next();
  409. if (_i5.done) break;
  410. _ref5 = _i5.value;
  411. }
  412. var node = _ref5;
  413. node.cleanRaws(keepBetween);
  414. }
  415. }
  416. };
  417. /**
  418. * Insert new node before old node within the container.
  419. *
  420. * @param {Node|number} exist - child or child’s index.
  421. * @param {Node|object|string|Node[]} add - new node
  422. *
  423. * @return {Node} this node for methods chain
  424. *
  425. * @example
  426. * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }));
  427. */
  428. Container.prototype.insertBefore = function insertBefore(exist, add) {
  429. exist = this.index(exist);
  430. var type = exist === 0 ? 'prepend' : false;
  431. var nodes = this.normalize(add, this.nodes[exist], type).reverse();
  432. for (var _iterator6 = nodes, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {
  433. var _ref6;
  434. if (_isArray6) {
  435. if (_i6 >= _iterator6.length) break;
  436. _ref6 = _iterator6[_i6++];
  437. } else {
  438. _i6 = _iterator6.next();
  439. if (_i6.done) break;
  440. _ref6 = _i6.value;
  441. }
  442. var node = _ref6;
  443. this.nodes.splice(exist, 0, node);
  444. }var index = void 0;
  445. for (var id in this.indexes) {
  446. index = this.indexes[id];
  447. if (exist <= index) {
  448. this.indexes[id] = index + nodes.length;
  449. }
  450. }
  451. return this;
  452. };
  453. /**
  454. * Insert new node after old node within the container.
  455. *
  456. * @param {Node|number} exist - child or child’s index
  457. * @param {Node|object|string|Node[]} add - new node
  458. *
  459. * @return {Node} this node for methods chain
  460. */
  461. Container.prototype.insertAfter = function insertAfter(exist, add) {
  462. exist = this.index(exist);
  463. var nodes = this.normalize(add, this.nodes[exist]).reverse();
  464. for (var _iterator7 = nodes, _isArray7 = Array.isArray(_iterator7), _i7 = 0, _iterator7 = _isArray7 ? _iterator7 : _iterator7[Symbol.iterator]();;) {
  465. var _ref7;
  466. if (_isArray7) {
  467. if (_i7 >= _iterator7.length) break;
  468. _ref7 = _iterator7[_i7++];
  469. } else {
  470. _i7 = _iterator7.next();
  471. if (_i7.done) break;
  472. _ref7 = _i7.value;
  473. }
  474. var node = _ref7;
  475. this.nodes.splice(exist + 1, 0, node);
  476. }var index = void 0;
  477. for (var id in this.indexes) {
  478. index = this.indexes[id];
  479. if (exist < index) {
  480. this.indexes[id] = index + nodes.length;
  481. }
  482. }
  483. return this;
  484. };
  485. /**
  486. * Removes node from the container and cleans the parent properties
  487. * from the node and its children.
  488. *
  489. * @param {Node|number} child - child or child’s index
  490. *
  491. * @return {Node} this node for methods chain
  492. *
  493. * @example
  494. * rule.nodes.length //=> 5
  495. * rule.removeChild(decl);
  496. * rule.nodes.length //=> 4
  497. * decl.parent //=> undefined
  498. */
  499. Container.prototype.removeChild = function removeChild(child) {
  500. child = this.index(child);
  501. this.nodes[child].parent = undefined;
  502. this.nodes.splice(child, 1);
  503. var index = void 0;
  504. for (var id in this.indexes) {
  505. index = this.indexes[id];
  506. if (index >= child) {
  507. this.indexes[id] = index - 1;
  508. }
  509. }
  510. return this;
  511. };
  512. /**
  513. * Removes all children from the container
  514. * and cleans their parent properties.
  515. *
  516. * @return {Node} this node for methods chain
  517. *
  518. * @example
  519. * rule.removeAll();
  520. * rule.nodes.length //=> 0
  521. */
  522. Container.prototype.removeAll = function removeAll() {
  523. for (var _iterator8 = this.nodes, _isArray8 = Array.isArray(_iterator8), _i8 = 0, _iterator8 = _isArray8 ? _iterator8 : _iterator8[Symbol.iterator]();;) {
  524. var _ref8;
  525. if (_isArray8) {
  526. if (_i8 >= _iterator8.length) break;
  527. _ref8 = _iterator8[_i8++];
  528. } else {
  529. _i8 = _iterator8.next();
  530. if (_i8.done) break;
  531. _ref8 = _i8.value;
  532. }
  533. var node = _ref8;
  534. node.parent = undefined;
  535. }this.nodes = [];
  536. return this;
  537. };
  538. /**
  539. * Passes all declaration values within the container that match pattern
  540. * through callback, replacing those values with the returned result
  541. * of callback.
  542. *
  543. * This method is useful if you are using a custom unit or function
  544. * and need to iterate through all values.
  545. *
  546. * @param {string|RegExp} pattern - replace pattern
  547. * @param {object} opts - options to speed up the search
  548. * @param {string|string[]} opts.props - an array of property names
  549. * @param {string} opts.fast - string that’s used
  550. * to narrow down values and speed up
  551. the regexp search
  552. * @param {function|string} callback - string to replace pattern
  553. * or callback that returns a new
  554. * value.
  555. * The callback will receive
  556. * the same arguments as those
  557. * passed to a function parameter
  558. * of `String#replace`.
  559. *
  560. * @return {Node} this node for methods chain
  561. *
  562. * @example
  563. * root.replaceValues(/\d+rem/, { fast: 'rem' }, string => {
  564. * return 15 * parseInt(string) + 'px';
  565. * });
  566. */
  567. Container.prototype.replaceValues = function replaceValues(pattern, opts, callback) {
  568. if (!callback) {
  569. callback = opts;
  570. opts = {};
  571. }
  572. this.walkDecls(function (decl) {
  573. if (opts.props && opts.props.indexOf(decl.prop) === -1) return;
  574. if (opts.fast && decl.value.indexOf(opts.fast) === -1) return;
  575. decl.value = decl.value.replace(pattern, callback);
  576. });
  577. return this;
  578. };
  579. /**
  580. * Returns `true` if callback returns `true`
  581. * for all of the container’s children.
  582. *
  583. * @param {childCondition} condition - iterator returns true or false.
  584. *
  585. * @return {boolean} is every child pass condition
  586. *
  587. * @example
  588. * const noPrefixes = rule.every(i => i.prop[0] !== '-');
  589. */
  590. Container.prototype.every = function every(condition) {
  591. return this.nodes.every(condition);
  592. };
  593. /**
  594. * Returns `true` if callback returns `true` for (at least) one
  595. * of the container’s children.
  596. *
  597. * @param {childCondition} condition - iterator returns true or false.
  598. *
  599. * @return {boolean} is some child pass condition
  600. *
  601. * @example
  602. * const hasPrefix = rule.some(i => i.prop[0] === '-');
  603. */
  604. Container.prototype.some = function some(condition) {
  605. return this.nodes.some(condition);
  606. };
  607. /**
  608. * Returns a `child`’s index within the {@link Container#nodes} array.
  609. *
  610. * @param {Node} child - child of the current container.
  611. *
  612. * @return {number} child index
  613. *
  614. * @example
  615. * rule.index( rule.nodes[2] ) //=> 2
  616. */
  617. Container.prototype.index = function index(child) {
  618. if (typeof child === 'number') {
  619. return child;
  620. } else {
  621. return this.nodes.indexOf(child);
  622. }
  623. };
  624. /**
  625. * The container’s first child.
  626. *
  627. * @type {Node}
  628. *
  629. * @example
  630. * rule.first == rules.nodes[0];
  631. */
  632. Container.prototype.normalize = function normalize(nodes, sample) {
  633. var _this2 = this;
  634. if (typeof nodes === 'string') {
  635. var parse = require('./parse');
  636. nodes = cleanSource(parse(nodes).nodes);
  637. } else if (Array.isArray(nodes)) {
  638. nodes = nodes.slice(0);
  639. for (var _iterator9 = nodes, _isArray9 = Array.isArray(_iterator9), _i9 = 0, _iterator9 = _isArray9 ? _iterator9 : _iterator9[Symbol.iterator]();;) {
  640. var _ref9;
  641. if (_isArray9) {
  642. if (_i9 >= _iterator9.length) break;
  643. _ref9 = _iterator9[_i9++];
  644. } else {
  645. _i9 = _iterator9.next();
  646. if (_i9.done) break;
  647. _ref9 = _i9.value;
  648. }
  649. var i = _ref9;
  650. if (i.parent) i.parent.removeChild(i, 'ignore');
  651. }
  652. } else if (nodes.type === 'root') {
  653. nodes = nodes.nodes.slice(0);
  654. for (var _iterator10 = nodes, _isArray10 = Array.isArray(_iterator10), _i11 = 0, _iterator10 = _isArray10 ? _iterator10 : _iterator10[Symbol.iterator]();;) {
  655. var _ref10;
  656. if (_isArray10) {
  657. if (_i11 >= _iterator10.length) break;
  658. _ref10 = _iterator10[_i11++];
  659. } else {
  660. _i11 = _iterator10.next();
  661. if (_i11.done) break;
  662. _ref10 = _i11.value;
  663. }
  664. var _i10 = _ref10;
  665. if (_i10.parent) _i10.parent.removeChild(_i10, 'ignore');
  666. }
  667. } else if (nodes.type) {
  668. nodes = [nodes];
  669. } else if (nodes.prop) {
  670. if (typeof nodes.value === 'undefined') {
  671. throw new Error('Value field is missed in node creation');
  672. } else if (typeof nodes.value !== 'string') {
  673. nodes.value = String(nodes.value);
  674. }
  675. nodes = [new _declaration2.default(nodes)];
  676. } else if (nodes.selector) {
  677. var Rule = require('./rule');
  678. nodes = [new Rule(nodes)];
  679. } else if (nodes.name) {
  680. var AtRule = require('./at-rule');
  681. nodes = [new AtRule(nodes)];
  682. } else if (nodes.text) {
  683. nodes = [new _comment2.default(nodes)];
  684. } else {
  685. throw new Error('Unknown node type in node creation');
  686. }
  687. var processed = nodes.map(function (i) {
  688. if (typeof i.before !== 'function') i = _this2.rebuild(i);
  689. if (i.parent) i.parent.removeChild(i);
  690. if (typeof i.raws.before === 'undefined') {
  691. if (sample && typeof sample.raws.before !== 'undefined') {
  692. i.raws.before = sample.raws.before.replace(/[^\s]/g, '');
  693. }
  694. }
  695. i.parent = _this2;
  696. return i;
  697. });
  698. return processed;
  699. };
  700. Container.prototype.rebuild = function rebuild(node, parent) {
  701. var _this3 = this;
  702. var fix = void 0;
  703. if (node.type === 'root') {
  704. var Root = require('./root');
  705. fix = new Root();
  706. } else if (node.type === 'atrule') {
  707. var AtRule = require('./at-rule');
  708. fix = new AtRule();
  709. } else if (node.type === 'rule') {
  710. var Rule = require('./rule');
  711. fix = new Rule();
  712. } else if (node.type === 'decl') {
  713. fix = new _declaration2.default();
  714. } else if (node.type === 'comment') {
  715. fix = new _comment2.default();
  716. }
  717. for (var i in node) {
  718. if (i === 'nodes') {
  719. fix.nodes = node.nodes.map(function (j) {
  720. return _this3.rebuild(j, fix);
  721. });
  722. } else if (i === 'parent' && parent) {
  723. fix.parent = parent;
  724. } else if (node.hasOwnProperty(i)) {
  725. fix[i] = node[i];
  726. }
  727. }
  728. return fix;
  729. };
  730. /**
  731. * @memberof Container#
  732. * @member {Node[]} nodes - an array containing the container’s children
  733. *
  734. * @example
  735. * const root = postcss.parse('a { color: black }');
  736. * root.nodes.length //=> 1
  737. * root.nodes[0].selector //=> 'a'
  738. * root.nodes[0].nodes[0].prop //=> 'color'
  739. */
  740. _createClass(Container, [{
  741. key: 'first',
  742. get: function get() {
  743. if (!this.nodes) return undefined;
  744. return this.nodes[0];
  745. }
  746. /**
  747. * The container’s last child.
  748. *
  749. * @type {Node}
  750. *
  751. * @example
  752. * rule.last == rule.nodes[rule.nodes.length - 1];
  753. */
  754. }, {
  755. key: 'last',
  756. get: function get() {
  757. if (!this.nodes) return undefined;
  758. return this.nodes[this.nodes.length - 1];
  759. }
  760. }]);
  761. return Container;
  762. }(_node2.default);
  763. exports.default = Container;
  764. /**
  765. * @callback childCondition
  766. * @param {Node} node - container child
  767. * @param {number} index - child index
  768. * @param {Node[]} nodes - all container children
  769. * @return {boolean}
  770. */
  771. /**
  772. * @callback childIterator
  773. * @param {Node} node - container child
  774. * @param {number} index - child index
  775. * @return {false|undefined} returning `false` will break iteration
  776. */
  777. module.exports = exports['default'];
  778. //# 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","walkDecls","prop","type","RegExp","test","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","replace","every","condition","some","sample","parse","require","Array","isArray","slice","Error","String","Declaration","Rule","AtRule","text","Comment","processed","before","rebuild","raws","fix","Root","j","hasOwnProperty","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\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 ( let 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 = callback(child, i);\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\n     *                                       to narrow down values and speed up\n                                             the regexp search\n     * @param {function|string} callback   - string to replace pattern\n     *                                       or callback that returns a new\n     *                                       value.\n     *                                       The callback will receive\n     *                                       the same arguments as those\n     *                                       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 ( typeof i.before !== 'function' ) i = this.rebuild(i);\n\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    rebuild(node, parent) {\n        let fix;\n        if ( node.type === 'root' ) {\n            let Root = require('./root');\n            fix = new Root();\n        } else if ( node.type === 'atrule' ) {\n            let AtRule = require('./at-rule');\n            fix = new AtRule();\n        } else if ( node.type === 'rule' ) {\n            let Rule = require('./rule');\n            fix = new Rule();\n        } else if ( node.type === 'decl' ) {\n            fix = new Declaration();\n        } else if ( node.type === 'comment' ) {\n            fix = new Comment();\n        }\n\n        for ( let i in node ) {\n            if ( i === 'nodes' ) {\n                fix.nodes = node.nodes.map( j => this.rebuild(j, fix) );\n            } else if ( i === 'parent' && parent ) {\n                fix.parent = parent;\n            } else if ( node.hasOwnProperty(i) ) {\n                fix[i] = node[i];\n            }\n        }\n\n        return fix;\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}\n\nexport default Container;\n\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"]}