AppyKit UI

Input

A text field for user input with optional placeholder and styling.

import { Button } from "@/components/ui/button";
import { Input } from "@/components/ui/input";
import { Text } from "@/components/ui/text";
import React from "react";
import { View } from "react-native";

export default function InputDemo() {
const [value, setValue] = React.useState("");

const onChangeText = (text: string) => {
setValue(text);
};
return (
<View className="flex-1   gap-6 justify-center items-start  p-5">
<View className="w-full gap-1">
<Text className="text-black font-semibold text-[16px]">Username</Text>
<Input
  className="bg-transparent border text-black border-black/50"
  placeholder="Appykit UI"
  value={value}
  onChangeText={onChangeText}
  aria-labelledby="inputLabel"
  aria-errormessage="inputError"
/>
<Text className="font-normal text-muted-foreground text-sm">
  This is your public display name.
</Text>
</View>
<Button className="bg-black">
<Text className="text-white">Submit</Text>
</Button>
</View>
);
}

Installation

npx appykit@latest add input

Create a folder named ui under component folder in your project and add the following code in a file named input.tsx:

import * as React from 'react';
import { TextInput, type TextInputProps } from 'react-native';
import { cn } from '@/lib/utils';

function Input({
  className,
  placeholderClassName,
  ...props
}: TextInputProps & {
  ref?: React.RefObject<TextInput>;
}) {
  return (
    <TextInput
      className={cn(
        'web:flex h-10 native:h-12 web:w-full rounded-lg border border-input bg-background px-3  web:py-2 text-base lg:text-sm native:text-[14px] native:leading-[1.25] text-foreground placeholder:text-muted-foreground web:ring-offset-background file:border-0 file:bg-transparent file:font-medium web:focus-visible:outline-none web:focus-visible:ring-2 web:focus-visible:ring-ring web:focus-visible:ring-offset-2',
        props.editable === false && 'opacity-50 web:cursor-not-allowed',
        className
      )}
      placeholderClassName={cn('text-muted-foreground', placeholderClassName)}
      {...props}
    />
  );
}

export { Input };

Update the import paths to match your project setup.

Usage

import { Input } from "@/components/ui/input";
 <Input
  className="w-full"
  placeholder="Appykit UI"
  value={value}
  onChangeText={onChangeText}
  aria-labelledby="inputLabel"
  aria-errormessage="inputError"
/>

On this page