Dashboard sipadu mbip
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

animate.js 3.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. exports.__esModule = true;
  4. exports.default = void 0;
  5. var _hyphenate = _interopRequireDefault(require("../util/hyphenate"));
  6. var _style = _interopRequireDefault(require("../style"));
  7. var _on = _interopRequireDefault(require("../events/on"));
  8. var _off = _interopRequireDefault(require("../events/off"));
  9. var _properties = _interopRequireDefault(require("./properties"));
  10. var _isTransform = _interopRequireDefault(require("./isTransform"));
  11. var reset = {};
  12. reset[_properties.default.property] = reset[_properties.default.duration] = reset[_properties.default.delay] = reset[_properties.default.timing] = ''; // super lean animate function for transitions
  13. // doesn't support all translations to keep it matching the jquery API
  14. /**
  15. * code in part from: Zepto 1.1.4 | zeptojs.com/license
  16. */
  17. function _animate(_ref) {
  18. var node = _ref.node,
  19. properties = _ref.properties,
  20. _ref$duration = _ref.duration,
  21. duration = _ref$duration === void 0 ? 200 : _ref$duration,
  22. easing = _ref.easing,
  23. callback = _ref.callback;
  24. var cssProperties = [],
  25. fakeEvent = {
  26. target: node,
  27. currentTarget: node
  28. },
  29. cssValues = {},
  30. transforms = '',
  31. fired;
  32. if (!_properties.default.end) duration = 0;
  33. Object.keys(properties).forEach(function (key) {
  34. if ((0, _isTransform.default)(key)) transforms += key + "(" + properties[key] + ") ";else {
  35. cssValues[key] = properties[key];
  36. cssProperties.push((0, _hyphenate.default)(key));
  37. }
  38. });
  39. if (transforms) {
  40. cssValues[_properties.default.transform] = transforms;
  41. cssProperties.push(_properties.default.transform);
  42. }
  43. if (duration > 0) {
  44. cssValues[_properties.default.property] = cssProperties.join(', ');
  45. cssValues[_properties.default.duration] = duration / 1000 + 's';
  46. cssValues[_properties.default.delay] = 0 + 's';
  47. cssValues[_properties.default.timing] = easing || 'linear';
  48. (0, _on.default)(node, _properties.default.end, done);
  49. setTimeout(function () {
  50. if (!fired) done(fakeEvent);
  51. }, duration + 500);
  52. } //eslint-disable-next-line no-unused-expressions
  53. node.clientLeft; // trigger page reflow
  54. (0, _style.default)(node, cssValues);
  55. if (duration <= 0) setTimeout(done.bind(null, fakeEvent), 0);
  56. return {
  57. cancel: function cancel() {
  58. if (fired) return;
  59. fired = true;
  60. (0, _off.default)(node, _properties.default.end, done);
  61. (0, _style.default)(node, reset);
  62. }
  63. };
  64. function done(event) {
  65. if (event.target !== event.currentTarget) return;
  66. fired = true;
  67. (0, _off.default)(event.target, _properties.default.end, done);
  68. (0, _style.default)(node, reset);
  69. callback && callback.call(this);
  70. }
  71. }
  72. function animate(node, properties, duration, easing, callback) {
  73. if (arguments.length === 1 && typeof node === 'object') {
  74. return _animate(node);
  75. }
  76. if (typeof easing === 'function') {
  77. callback = easing;
  78. easing = null;
  79. }
  80. return _animate({
  81. node: node,
  82. properties: properties,
  83. duration: duration,
  84. easing: easing,
  85. callback: callback
  86. });
  87. }
  88. var _default = animate;
  89. exports.default = _default;
  90. module.exports = exports["default"];