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.
		
		
		
		
		
			
		
			
				
					
					
						
							57 lines
						
					
					
						
							1.7 KiB
						
					
					
				
			
		
		
	
	
							57 lines
						
					
					
						
							1.7 KiB
						
					
					
				| "use strict";
 | |
| 
 | |
| exports.__esModule = true;
 | |
| exports["default"] = transitions;
 | |
| 
 | |
| var _errors = /*#__PURE__*/_interopRequireDefault( /*#__PURE__*/require("../internalHelpers/_errors"));
 | |
| 
 | |
| function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
 | |
| 
 | |
| /**
 | |
|  * Accepts any number of transition values as parameters for creating a single transition statement. You may also pass an array of properties as the first parameter that you would like to apply the same transition values to (second parameter).
 | |
|  * @example
 | |
|  * // Styles as object usage
 | |
|  * const styles = {
 | |
|  *   ...transitions('opacity 1.0s ease-in 0s', 'width 2.0s ease-in 2s'),
 | |
|  *   ...transitions(['color', 'background-color'], '2.0s ease-in 2s')
 | |
|  * }
 | |
|  *
 | |
|  * // styled-components usage
 | |
|  * const div = styled.div`
 | |
|  *   ${transitions('opacity 1.0s ease-in 0s', 'width 2.0s ease-in 2s')};
 | |
|  *   ${transitions(['color', 'background-color'], '2.0s ease-in 2s'),};
 | |
|  * `
 | |
|  *
 | |
|  * // CSS as JS Output
 | |
|  *
 | |
|  * div {
 | |
|  *   'transition': 'opacity 1.0s ease-in 0s, width 2.0s ease-in 2s'
 | |
|  *   'transition': 'color 2.0s ease-in 2s, background-color 2.0s ease-in 2s',
 | |
|  * }
 | |
|  */
 | |
| function transitions() {
 | |
|   for (var _len = arguments.length, properties = new Array(_len), _key = 0; _key < _len; _key++) {
 | |
|     properties[_key] = arguments[_key];
 | |
|   }
 | |
| 
 | |
|   if (Array.isArray(properties[0]) && properties.length === 2) {
 | |
|     var value = properties[1];
 | |
| 
 | |
|     if (typeof value !== 'string') {
 | |
|       throw new _errors["default"](61);
 | |
|     }
 | |
| 
 | |
|     var transitionsString = properties[0].map(function (property) {
 | |
|       return property + " " + value;
 | |
|     }).join(', ');
 | |
|     return {
 | |
|       transition: transitionsString
 | |
|     };
 | |
|   } else {
 | |
|     return {
 | |
|       transition: properties.join(', ')
 | |
|     };
 | |
|   }
 | |
| }
 | |
| 
 | |
| module.exports = exports.default; |