keyframes.js 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. "use strict";
  2. exports.__esModule = true;
  3. var _postcssValueParser = require("postcss-value-parser");
  4. var _postcssValueParser2 = _interopRequireDefault(_postcssValueParser);
  5. var _cache = require("./cache");
  6. var _cache2 = _interopRequireDefault(_cache);
  7. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  8. var RESERVED_KEYWORDS = ["none", "inherit", "initial", "unset"];
  9. var cache = {};
  10. var atRules = [];
  11. var decls = [];
  12. exports.default = {
  13. collect: function collect(node, encoder) {
  14. var name = node.name,
  15. prop = node.prop,
  16. type = node.type;
  17. if (type === 'atrule' && /keyframes/.test(name) && RESERVED_KEYWORDS.indexOf(node.params) === -1) {
  18. (0, _cache2.default)(node.params, encoder, cache);
  19. atRules.push(node);
  20. }
  21. if (type === 'decl' && /animation/.test(prop)) {
  22. decls.push(node);
  23. }
  24. },
  25. transform: function transform() {
  26. // Iterate each property and change their names
  27. decls.forEach(function (decl) {
  28. decl.value = (0, _postcssValueParser2.default)(decl.value).walk(function (node) {
  29. if (node.type === 'word' && node.value in cache) {
  30. cache[node.value].count++;
  31. node.value = cache[node.value].ident;
  32. } else if (node.type === 'space') {
  33. node.value = ' ';
  34. } else if (node.type === 'div') {
  35. node.before = node.after = '';
  36. }
  37. }).toString();
  38. });
  39. // Iterate each at rule and change their name if references to them have been found
  40. atRules.forEach(function (rule) {
  41. var cached = cache[rule.params];
  42. if (cached && cached.count > 0) {
  43. rule.params = cached.ident;
  44. }
  45. });
  46. // reset cache after transform
  47. cache = {};
  48. atRules = [];
  49. decls = [];
  50. }
  51. };
  52. module.exports = exports["default"];