mirror of
				https://github.com/anna-sara/filament_inventory
				synced 2025-10-26 20:37:13 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			30 lines
		
	
	
	
		
			746 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
	
		
			746 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { forwardRef, useEffect, useImperativeHandle, useRef } from 'react';
 | |
| 
 | |
| export default forwardRef(function TextInput(
 | |
|     { type = 'text', className = '', isFocused = false, ...props },
 | |
|     ref,
 | |
| ) {
 | |
|     const localRef = useRef(null);
 | |
| 
 | |
|     useImperativeHandle(ref, () => ({
 | |
|         focus: () => localRef.current?.focus(),
 | |
|     }));
 | |
| 
 | |
|     useEffect(() => {
 | |
|         if (isFocused) {
 | |
|             localRef.current?.focus();
 | |
|         }
 | |
|     }, [isFocused]);
 | |
| 
 | |
|     return (
 | |
|         <input
 | |
|             {...props}
 | |
|             type={type}
 | |
|             className={
 | |
|                 'rounded-md border-gray-300 shadow-sm focus:border-indigo-500 focus:ring-indigo-500 ' +
 | |
|                 className
 | |
|             }
 | |
|             ref={localRef}
 | |
|         />
 | |
|     );
 | |
| });
 |