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.
		
		
		
		
		
			
		
			
				
					60 lines
				
				1.5 KiB
			
		
		
			
		
	
	
					60 lines
				
				1.5 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								// @flow strict
							 | 
						||
| 
								 | 
							
								import * as React from 'react';
							 | 
						||
| 
								 | 
							
								import { type Ref } from './RefTypes';
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * 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 const unwrapArray = (arg: *): * => (Array.isArray(arg) ? arg[0] : arg);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Takes a maybe-undefined function and arbitrary args and invokes the function
							 | 
						||
| 
								 | 
							
								 * only if it is defined.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								export const safeInvoke = <F: Function>(
							 | 
						||
| 
								 | 
							
								  fn: ?F,
							 | 
						||
| 
								 | 
							
								  ...args: Array<mixed>
							 | 
						||
| 
								 | 
							
								): $Call<F> => {
							 | 
						||
| 
								 | 
							
								  if (typeof fn === 'function') {
							 | 
						||
| 
								 | 
							
								    return fn(...args);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Sets a ref using either a ref callback or a ref object
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								export const setRef = (ref: ?Ref, node: ?HTMLElement): void => {
							 | 
						||
| 
								 | 
							
								  // 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 const fromEntries = (
							 | 
						||
| 
								 | 
							
								  entries: Array<[string, any]>
							 | 
						||
| 
								 | 
							
								): { [key: string]: any } =>
							 | 
						||
| 
								 | 
							
								  entries.reduce((acc, [key, value]) => {
							 | 
						||
| 
								 | 
							
								    acc[key] = value;
							 | 
						||
| 
								 | 
							
								    return acc;
							 | 
						||
| 
								 | 
							
								  }, {});
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Small wrapper around `useLayoutEffect` to get rid of the warning on SSR envs
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								export const useIsomorphicLayoutEffect:
							 | 
						||
| 
								 | 
							
								  | typeof React.useEffect
							 | 
						||
| 
								 | 
							
								  | typeof React.useLayoutEffect =
							 | 
						||
| 
								 | 
							
								  typeof window !== 'undefined' &&
							 | 
						||
| 
								 | 
							
								  window.document &&
							 | 
						||
| 
								 | 
							
								  window.document.createElement
							 | 
						||
| 
								 | 
							
								    ? React.useLayoutEffect
							 | 
						||
| 
								 | 
							
								    : React.useEffect;
							 |