Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

abaabil.combobox

Package Overview
Dependencies
Maintainers
0
Versions
31
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

abaabil.combobox

  • 0.1.7
  • npm
  • Socket score

Version published
Weekly downloads
1
decreased by-50%
Maintainers
0
Weekly downloads
 
Created
Source

ComboBox Component

The ComboBox component is an accessible, customizable dropdown selection input that combines a button with a list of options.

Installation

npm install abaabil.temp.combobox

Importing

Import the ComboBox component from the package:

import ComboBox from 'abaabil.temp.combobox';

Basic Usage

<ComboBox
  options={[
    { key: 'option1', label: 'Option 1' },
    { key: 'option2', label: 'Option 2' },
  ]}
  onChange={(selectedOption) => console.log(selectedOption)}
  placeholder="Select an option"
/>

Examples

Standard ComboBox

<ComboBox
  options={[
    { key: 'apple', label: 'Apple' },
    { key: 'banana', label: 'Banana' },
    { key: 'cherry', label: 'Cherry' },
  ]}
  onChange={(selectedOption) => console.log(selectedOption)}
  placeholder="Select a fruit"
/>

ComboBox with Icons

<ComboBox
  icon="photo"
  actionIcon="chevron-down"
  options={[
    { key: 'apple', label: 'Apple', icon: 'apple' },
    { key: 'cherry', label: 'Cherry', icon: 'cherry' },
    { key: 'lemon', label: 'Lemon', icon: 'lemon' },
  ]}
  onChange={(selectedOption) => console.log(selectedOption)}
  placeholder="Select a fruit"
/>

ComboBox with Custom Styles

<ComboBox
  options={[
    { key: 'option1', label: 'Option 1' },
    { key: 'option2', label: 'Option 2' },
    { key: 'option3', label: 'Option 3' },
  ]}
  onChange={(selectedOption) => console.log(selectedOption)}
  placeholder="Custom style"
  buttonClassName="bg-amber-500 hover:bg-amber-600 focus:bg-amber-700 active:bg-amber-800"
  ulClassName="rounded-xl p-4 space-y-3"
  liClassName="rounded-xl"
/>

Properties

PropertyTypeDescriptionDefaultRequired
optionsArray<{ key: string, label: string, icon?: string }>Array of option objects to display in the dropdown-Yes
onChangefunctionFunction called when an option is selected-Yes
placeholderstringPlaceholder text when no option is selected-No
iconstringIcon ID to display at the start of the button-No
actionIconstringIcon ID to display at the end of the button-No
buttonClassNamestringAdditional CSS classes for the button element-No
ulClassNamestringAdditional CSS classes for the ComboBox container-No
liClassNamestringAdditional CSS classes for the list item elements-No

Styling

The ComboBox component uses default styling classes which can be customized using the buttonClassName, ulClassName, and liClassName props.

Accessibility

The ComboBox component enhances accessibility by:

  • Using proper ARIA roles, states, and properties for combobox, listbox, and option elements
  • Supporting full keyboard navigation (arrow keys, Enter, Escape, Tab)
  • Providing visual distinction and screen reader announcements for selected and highlighted options
  • Managing focus appropriately, including focus trapping within the dropdown when open
  • Offering clear labeling to convey the purpose of the ComboBox to all users
  • Ensuring compatibility with various assistive technologies

Notes

  • The component uses icons from the abaabil.temp.icon package. Ensure this dependency is available in your project.
  • The ComboBox is designed to be fully accessible, following W3C WAI-ARIA Authoring Practices guidelines.

Keywords

FAQs

Package last updated on 23 Aug 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc