Skip to content

Constructor-io/constructorio-ui-autocomplete

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

constructor logo

Autocomplete UI

Lightweight, minimalistic, and fully customizable autocomplete component for fast, accessible, and flexible search experiences with Constructor.io's autosuggest services. πŸš€

Read The Docs


minzipped size NPM Version MIT licensed

Autocomplete UI demonstration

πŸ“Œ Table of Contents

Features

  • πŸ”Œ Easy Integration – Quickly integrate with your app as a plug-and-play React component
  • ⚑ Lightweight & Fast – Tiny bundle size, optimized for speed
  • 🎨 Customizable UI – With minmal styles, and supports for custom markup
  • ⌨️ Keyboard Navigation – Fully supports accessible keyboard naviagation
  • β™Ώ Accessible (a11y) – Built-in ARIA support for screen readers
  • πŸ›‘ Written in TypeScript with type safety

React

⚑ Installation & Quick Start

Install the library

npm i @constructor-io/constructorio-ui-autocomplete

Import and use the CioAutocomplete component

import { CioAutocomplete } from '@constructor-io/constructorio-ui-autocomplete';
import '@constructor-io/constructorio-ui-autocomplete/styles.css';

function YourComponent() {
  return (
    <div>
      <CioAutocomplete
        apiKey="key_M57QS8SMPdLdLx4x"
        onSubmit={(e) => {console.log(e)}}
    </div>
  );

Shopify

⚑ Installation & Quick Start

The Constructor autocomplete component is available as part of the Constructor.io Shopify App

After installing the app, you can use the Constructor autocomplete component by clicking 'Add Section' in your theme editor and adding the Constructor autocomplete liquid component

installation gif

For more in depth instructions, check out the Shopify documentation.

Bundle (Vanilla JS)

This is a framework agnostic method that can be used in any JavaScript project. The CioAutocomplete function provides a simple interface to inject an entire Autocomplete UI into the provided selector. In addition to Autocomplete component props, this function also accepts a selector and includeCSS.

⚑ Installation & Quick Start

Install the library

npm i @constructor-io/constructorio-ui-autocomplete

Import and use the CioAutocomplete component

import CioAutocomplete from '@constructor-io/constructorio-ui-autocomplete/constructorio-ui-autocomplete-bundled';

CioAutocomplete({
  selector: '#autocomplete-container',
  includeCSS: true, // Include the default CSS styles. Defaults to true.
  apiKey: 'key_M57QS8SMPdLdLx4x',
  onSubmit: (submitEvent) => console.dir(submitEvent),
  // ... additional arguments
});
</script>

πŸ’‘ Code Examples

Ready-to-use, copy-paste examples with explanations.

πŸ”Ή For more examples check the full examples

🎨 Customization

CSS styles are not imported by default. Add this to your code to import basic styles

import '@constructor-io/constructorio-ui-autocomplete/styles.css';

All styles are scoped under .cio-autocomplete. You can extend them by targeting that selector.

/* Custom Style Sheet */
.cio-autocomplete .cio-submit-btn {
  border-radius: 10px;
  border: 1px solid red;
}

If you'd like to override or extend the base className, you can do so with the autocompleteClassName argument

import { CioAutocomplete } from '@constructor-io/constructorio-ui-autocomplete';
import '@constructor-io/constructorio-ui-autocomplete/styles.css';

function YourComponent() {
  return (
    <div>
      <CioAutocomplete
        apiKey="key_M57QS8SMPdLdLx4x"
        onSubmit={(e) => { console.log(e)}}
        autocompleteClassName="cio-autocomplete custom-autocomplete-container"
      />
    </div>
  );

Then you can modify styles like so

/* Custom Style Sheet */
.cio-autocomplete.custom-autocomplete-styles .cio-input {
  font-weight: bold;
}

πŸš€ Advanced Features

πŸ”Ή For more advanced use cases check the full documentation

πŸ›  Troubleshooting

Common issues and solutions.

Problem Description Solution
Older JavaScript environments The library provides two different builds. CommonJS (cjs) and ECMAScript Modules (mjs)

For ECMAScript Modules (mjs) build, the JavaScript version is ESNext which might not be supported by your environment. If that's the case and your environment is using an older Javascript version like ES6 (ES2015), you might get this error.

Module parse failed: Unexpected token (15:32) You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file
To solve this you can import the CommonJS (cjs) build which supports ES6 (ES2015) syntax:

import CioAutocomplete from '@constructor-io/constructorio-ui-autocomplete/cjs'
ESLint There is a known issue with ESLint where it fails to resolve the paths exposed in the exports statement of NPM packages.

For ECMAScript Modules (mjs) build. The Javascript version is ESNext which might not be supported by your environment. If that's the case and your environment is using an older Javascript version like ES6 (ES2015), you might get this error.

Unable to resolve path to module '@constructor-io/constructorio-ui-autocomplete/styles.css'

Relevant open issues:
If you are receiving the following error, you can safely disable ESLint using // eslint-disable-line for that line.
Peer Dependencies The library requires a couple of peer dependencies to be installed, so ensure they're installed if not already.

  1. constructorio-client-javascript
  2. downshift
Run npm i downshift @constructor-io/constructorio-client-javascript

πŸ’¬ Need help? Join our GitHub Discussions

πŸ“– API Reference

  • Full API docs: Click here

πŸ”— Complementary Resources

🀝 Contributing

  1. Fork the repo & create a new branch.
  2. Run npm install to install dependencies.
  3. After making the desired changes, run npm run tests && npm run lint locally.
  4. Submit a PR for review.

πŸ“œ License

MIT License

Copyright (c) 2022-present Constructor.io Corporation