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.
		
		
		
		
		
			
		
			
				
					53 lines
				
				1.5 KiB
			
		
		
			
		
	
	
					53 lines
				
				1.5 KiB
			| 
											3 years ago
										 | import * as React from 'react'; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Takes an argument and if it's an array, returns the first item in the array, | ||
|  |  * otherwise returns the argument. Used for Preact compatibility. | ||
|  |  */ | ||
|  | export var unwrapArray = function unwrapArray(arg) { | ||
|  |   return Array.isArray(arg) ? arg[0] : arg; | ||
|  | }; | ||
|  | /** | ||
|  |  * Takes a maybe-undefined function and arbitrary args and invokes the function | ||
|  |  * only if it is defined. | ||
|  |  */ | ||
|  | 
 | ||
|  | export var safeInvoke = function safeInvoke(fn) { | ||
|  |   if (typeof fn === 'function') { | ||
|  |     for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { | ||
|  |       args[_key - 1] = arguments[_key]; | ||
|  |     } | ||
|  | 
 | ||
|  |     return fn.apply(void 0, args); | ||
|  |   } | ||
|  | }; | ||
|  | /** | ||
|  |  * Sets a ref using either a ref callback or a ref object | ||
|  |  */ | ||
|  | 
 | ||
|  | export var setRef = function setRef(ref, node) { | ||
|  |   // if its a function call it
 | ||
|  |   if (typeof ref === 'function') { | ||
|  |     return safeInvoke(ref, node); | ||
|  |   } // otherwise we should treat it as a ref object
 | ||
|  |   else if (ref != null) { | ||
|  |       ref.current = node; | ||
|  |     } | ||
|  | }; | ||
|  | /** | ||
|  |  * Simple ponyfill for Object.fromEntries | ||
|  |  */ | ||
|  | 
 | ||
|  | export var fromEntries = function fromEntries(entries) { | ||
|  |   return entries.reduce(function (acc, _ref) { | ||
|  |     var key = _ref[0], | ||
|  |         value = _ref[1]; | ||
|  |     acc[key] = value; | ||
|  |     return acc; | ||
|  |   }, {}); | ||
|  | }; | ||
|  | /** | ||
|  |  * Small wrapper around `useLayoutEffect` to get rid of the warning on SSR envs | ||
|  |  */ | ||
|  | 
 | ||
|  | export var useIsomorphicLayoutEffect = typeof window !== 'undefined' && window.document && window.document.createElement ? React.useLayoutEffect : React.useEffect; |