You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
74 lines
1.8 KiB
74 lines
1.8 KiB
"use strict";
|
|
|
|
exports.__esModule = true;
|
|
exports["default"] = animation;
|
|
|
|
var _errors = /*#__PURE__*/_interopRequireDefault( /*#__PURE__*/require("../internalHelpers/_errors"));
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
|
|
/**
|
|
* Shorthand for easily setting the animation property. Allows either multiple arrays with animations
|
|
* or a single animation spread over the arguments.
|
|
* @example
|
|
* // Styles as object usage
|
|
* const styles = {
|
|
* ...animation(['rotate', '1s', 'ease-in-out'], ['colorchange', '2s'])
|
|
* }
|
|
*
|
|
* // styled-components usage
|
|
* const div = styled.div`
|
|
* ${animation(['rotate', '1s', 'ease-in-out'], ['colorchange', '2s'])}
|
|
* `
|
|
*
|
|
* // CSS as JS Output
|
|
*
|
|
* div {
|
|
* 'animation': 'rotate 1s ease-in-out, colorchange 2s'
|
|
* }
|
|
* @example
|
|
* // Styles as object usage
|
|
* const styles = {
|
|
* ...animation('rotate', '1s', 'ease-in-out')
|
|
* }
|
|
*
|
|
* // styled-components usage
|
|
* const div = styled.div`
|
|
* ${animation('rotate', '1s', 'ease-in-out')}
|
|
* `
|
|
*
|
|
* // CSS as JS Output
|
|
*
|
|
* div {
|
|
* 'animation': 'rotate 1s ease-in-out'
|
|
* }
|
|
*/
|
|
function animation() {
|
|
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
args[_key] = arguments[_key];
|
|
}
|
|
|
|
// Allow single or multiple animations passed
|
|
var multiMode = Array.isArray(args[0]);
|
|
|
|
if (!multiMode && args.length > 8) {
|
|
throw new _errors["default"](64);
|
|
}
|
|
|
|
var code = args.map(function (arg) {
|
|
if (multiMode && !Array.isArray(arg) || !multiMode && Array.isArray(arg)) {
|
|
throw new _errors["default"](65);
|
|
}
|
|
|
|
if (Array.isArray(arg) && arg.length > 8) {
|
|
throw new _errors["default"](66);
|
|
}
|
|
|
|
return Array.isArray(arg) ? arg.join(' ') : arg;
|
|
}).join(', ');
|
|
return {
|
|
animation: code
|
|
};
|
|
}
|
|
|
|
module.exports = exports.default; |