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.
		
		
		
		
		
			
		
			
				
					77 lines
				
				2.6 KiB
			
		
		
			
		
	
	
					77 lines
				
				2.6 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								"use strict";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								exports.__esModule = true;
							 | 
						||
| 
								 | 
							
								exports["default"] = between;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _getValueAndUnit5 = /*#__PURE__*/_interopRequireDefault( /*#__PURE__*/require("../helpers/getValueAndUnit"));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var _errors = /*#__PURE__*/_interopRequireDefault( /*#__PURE__*/require("../internalHelpers/_errors"));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Returns a CSS calc formula for linear interpolation of a property between two values. Accepts optional minScreen (defaults to '320px') and maxScreen (defaults to '1200px').
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @example
							 | 
						||
| 
								 | 
							
								 * // Styles as object usage
							 | 
						||
| 
								 | 
							
								 * const styles = {
							 | 
						||
| 
								 | 
							
								 *   fontSize: between('20px', '100px', '400px', '1000px'),
							 | 
						||
| 
								 | 
							
								 *   fontSize: between('20px', '100px')
							 | 
						||
| 
								 | 
							
								 * }
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * // styled-components usage
							 | 
						||
| 
								 | 
							
								 * const div = styled.div`
							 | 
						||
| 
								 | 
							
								 *   fontSize: ${between('20px', '100px', '400px', '1000px')};
							 | 
						||
| 
								 | 
							
								 *   fontSize: ${between('20px', '100px')}
							 | 
						||
| 
								 | 
							
								 * `
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * // CSS as JS Output
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * h1: {
							 | 
						||
| 
								 | 
							
								 *   'fontSize': 'calc(-33.33333333333334px + 13.333333333333334vw)',
							 | 
						||
| 
								 | 
							
								 *   'fontSize': 'calc(-9.090909090909093px + 9.090909090909092vw)'
							 | 
						||
| 
								 | 
							
								 * }
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								function between(fromSize, toSize, minScreen, maxScreen) {
							 | 
						||
| 
								 | 
							
								  if (minScreen === void 0) {
							 | 
						||
| 
								 | 
							
								    minScreen = '320px';
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  if (maxScreen === void 0) {
							 | 
						||
| 
								 | 
							
								    maxScreen = '1200px';
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var _getValueAndUnit = (0, _getValueAndUnit5["default"])(fromSize),
							 | 
						||
| 
								 | 
							
								      unitlessFromSize = _getValueAndUnit[0],
							 | 
						||
| 
								 | 
							
								      fromSizeUnit = _getValueAndUnit[1];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var _getValueAndUnit2 = (0, _getValueAndUnit5["default"])(toSize),
							 | 
						||
| 
								 | 
							
								      unitlessToSize = _getValueAndUnit2[0],
							 | 
						||
| 
								 | 
							
								      toSizeUnit = _getValueAndUnit2[1];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var _getValueAndUnit3 = (0, _getValueAndUnit5["default"])(minScreen),
							 | 
						||
| 
								 | 
							
								      unitlessMinScreen = _getValueAndUnit3[0],
							 | 
						||
| 
								 | 
							
								      minScreenUnit = _getValueAndUnit3[1];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var _getValueAndUnit4 = (0, _getValueAndUnit5["default"])(maxScreen),
							 | 
						||
| 
								 | 
							
								      unitlessMaxScreen = _getValueAndUnit4[0],
							 | 
						||
| 
								 | 
							
								      maxScreenUnit = _getValueAndUnit4[1];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  if (typeof unitlessMinScreen !== 'number' || typeof unitlessMaxScreen !== 'number' || !minScreenUnit || !maxScreenUnit || minScreenUnit !== maxScreenUnit) {
							 | 
						||
| 
								 | 
							
								    throw new _errors["default"](47);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  if (typeof unitlessFromSize !== 'number' || typeof unitlessToSize !== 'number' || fromSizeUnit !== toSizeUnit) {
							 | 
						||
| 
								 | 
							
								    throw new _errors["default"](48);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  if (fromSizeUnit !== minScreenUnit || toSizeUnit !== maxScreenUnit) {
							 | 
						||
| 
								 | 
							
								    throw new _errors["default"](75);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  var slope = (unitlessFromSize - unitlessToSize) / (unitlessMinScreen - unitlessMaxScreen);
							 | 
						||
| 
								 | 
							
								  var base = unitlessToSize - slope * unitlessMaxScreen;
							 | 
						||
| 
								 | 
							
								  return "calc(" + base.toFixed(2) + (fromSizeUnit || '') + " + " + (100 * slope).toFixed(2) + "vw)";
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								module.exports = exports.default;
							 |