# Input Components Components for user input in OpenTUI. ## Input Component Single-line text input field. ### Basic Usage ```tsx // React setValue(newValue)} placeholder="Enter text..." focused /> // Solid setValue(newValue)} placeholder="Enter text..." focused /> // Core const input = new InputRenderable(renderer, { id: "name", placeholder: "Enter text...", }) input.on(InputRenderableEvents.CHANGE, (value) => { console.log("Value:", value) }) input.focus() ``` ### Styling ```tsx ``` ### Events ```tsx // React console.log("Changed:", value)} onFocus={() => console.log("Focused")} onBlur={() => console.log("Blurred")} /> // Core input.on(InputRenderableEvents.CHANGE, (value) => {}) input.on(InputRenderableEvents.FOCUS, () => {}) input.on(InputRenderableEvents.BLUR, () => {}) ``` ### Controlled Input ```tsx // React function ControlledInput() { const [value, setValue] = useState("") return ( ) } // Solid function ControlledInput() { const [value, setValue] = createSignal("") return ( ) } ``` ## Textarea Component Multi-line text input field. ### Basic Usage ```tsx // React