npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@vygruppen/spor-input-react

v1.3.6

Published

This package contains basic input fields, textareas and so forth.

Downloads

95

Readme

Input (React)

This package contains basic input fields, textareas and so forth.

Installation

$ npm install @vygruppen/spor-input-react

Usage

import {
  ChoiceChip,
  Input,
  InputGroup,
  InputLeftElement,
  InputRightElement,
  FormControl,
  FormErrorMessage,
  FormHelperText,
  FormLabel,
  InfoSelect,
  ListBox,
  PasswordInput,
  Radio,
  RadioGroup,
  Switch,
  Textarea,
} from "@vygruppen/spor-input-react";

There are a lot of imports here - luckily they're pretty intuitive to use, and you'll probably just use a few at a time.

Before we dive into each piece individually, here's a basic example:

<FormControl isInvalid={Boolean(errors.age)}>
  <Input label="Age" value={value} onChange={(e) => setValue(e.target.value)} />
  <FormErrorMessage>{errors.age}</FormErrorMessage>
  <FormHelperText>
    We'll use your age to choose the appropriate ticket
  </FormHelperText>
</FormControl>

FormControl

The FormControl component wraps most form inputs, and shares common properties like IDs, names, or whether or not a field is invalid.

By default, the FormControl component creates a unique ID for any inputs inside of it, and forwards it to any components that would require it.

<FormControl>
  <Input label="Name" />
</FormControl>

Input

The Input component works like a regular <input /> component, but it requires you to pass the label we want to display.

<Input label="Name" />

PasswordInput

The PasswordInput component works like a regular <Input /> component, but it has a button that lets you look at your password.

<PasswordInput label="Name" />

InputGroup, InputLeftElement and InputRightElement

If you want to add icons or buttons inside of your input field, you want to wrap your Input inside of an InputGroup component.

This is how you use it:

<FormControl>
  <InputGroup>
    <Input label="Search" type="search" />
    <InputRightElement>
      <IconButton
        type="submit"
        variant="ghost"
        aria-label="Search"
        icon={<SearchIcon />}
      />
    </InputRightElement>
  </InputGroup>
</FormControl>

If you want an icon up in front of your input field, you use the InputLeftElement in front of your Input element instead.

Textarea

Textareas work exactly like the Input component, but creates a resizable text area instead.

<FormControl>
  <Textarea label="Description" />
</FormControl>

Checkbox and CheckboxGroup

Checkboxes are great when you want users to answer yes or no to one or more questions.

You can use them by themselves, or place them inside of a CheckboxGroup.

<CheckboxGroup>
  <Checkbox value="terms">I accept the terms and conditions</Checkbox>
  <Checkbox value="marketing">I want to receive newsletters</Checkbox>
</CheckboxGroup>

You can also specify the direction of the checkboxes with the direction prop.

<CheckboxGroup direction="column">
  <Checkbox value="terms">I accept the terms and conditions</Checkbox>
  <Checkbox value="marketing">I want to receive newsletters</Checkbox>
</CheckboxGroup>

Radio and RadioGroup

Radio buttons are a great choice for when you want the user to select one out of several different options. You place your radio buttons inside of a radio button group, and give it a name.

Semantically, radio buttons should be enclosed in a <fieldset /> with a <legend /> tag asking the question you want the user to answer.

<Box as="fieldset">
  <Text as="legend">What is your favorite destination?</Text>
  <RadioGroup name="destination">
    <Radio value="oslo">Oslo</Radio>
    <Radio value="bergen">Bergen</Radio>
    <Radio value="trondheim">Trondheim</Radio>
  </RadioGroup>
</Box>

You can also specify the direction of the radio buttons with the direction prop.

<Box as="fieldset">
  <Text as="legend">What is your favorite destination?</Text>
  <RadioGroup name="destination" direction="column">
    <Radio value="oslo">Oslo</Radio>
    <Radio value="bergen">Bergen</Radio>
    <Radio value="trondheim">Trondheim</Radio>
  </RadioGroup>
</Box>

Switch

A switch lets you toggle between on and off, yes and no. It's an alternative to a checkbox.

You can use a Switch component inside of a FormControl with an associated FormLabel:

<FormControl>
  <FormLabel>Enable alerts?</FormLabel>
  <Switch />
</FormControl>

Switches are available in three different sizes - sm, md and lg. There are also two variants - solid and outline.

<FormControl>
  <FormLabel>Enable alerts?</FormLabel>
  <Switch variant="outline" size="lg" />
</FormControl>

ChoiceChip

Choice chips are checkboxes that look like selectable buttons.

Choice chips are available in three different sizes - sm, md and lg.

<Stack direction="row">
  <ChoiceChip size="lg">Bus</ChoiceChip>
  <ChoiceChip size="lg">Train</ChoiceChip>
</Stack>

You can add an icon as well, if you want to!

<Stack direction="row">
  <ChoiceChip size="lg" icon={<BusIcon />}>
    Bus
  </ChoiceChip>
  <ChoiceChip size="lg" icon={<TrainIcon />}>
    Train
  </ChoiceChip>
</Stack>

Select

Selects let you choose between several options

You should consider only using the Select component when you have more than 4 options. Otherwise, you should use the <Radio> component.

Select comes with its own optional label!

<Select label="Select level of luxury">
  <option>No luxury</option>
  <option>Some luxury</option>
  <option>Lots of luxury</option>
  <option>I'm rich</option>
</Select>

FormLabel

A neat looking label for a few different input types. Should be used inside of a FormControl, so it receives the correct IDs and attributes.

You don't need to use this label with the Input, Textarea, Checkbox or Radio components, as they come with one built in. You might want to use it with the Switch component, for instance.

<FormControl>
  <FormLabel>Enable alerts?</FormLabel>
  <Switch variant="outline" size="lg" />
</FormControl>

Yep, it's the same example as above - the docs author felt lazy. 😎

FormHelperText

If you want to add some descriptive text to your inputs, you should use the FormHelperText component. It adds some neat screen reader properties, and styles the text appropriately.

<FormControl>
  <Input label="age" />
  <FormHelperText>
    We'll use your age to choose the appropriate ticket
  </FormHelperText>
</FormControl>

FormErrorMessage

Shows an error message. Great for inline validation errors!

If you set the isInvalid prop on the surrounding FormControl component, the FormErrorMessage will only render if it's true.

<FormControl isInvalid={Boolean(errors.age)}>
  <Input label="age" />
  <FormErrorMessage>{errors.age?.message}</FormErrorMessage>
</FormControl>

Development

Please refer to the root readme for development notes.