Skip to content

Commit

Permalink
feat: added error and success status to AutocompleteInput
Browse files Browse the repository at this point in the history
  • Loading branch information
AssisrMatheus committed Aug 22, 2022
1 parent 7f7a62f commit b8599b3
Show file tree
Hide file tree
Showing 5 changed files with 87 additions and 4 deletions.
6 changes: 6 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

### Fixed

## [7.7.0] 2022-08-22

### Changes

- Added error and success status to `AutocompleteInput`

## [7.6.0] 2022-08-22

### Changes
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@perimetre/ui",
"description": "A component library made by @perimetre",
"version": "7.6.0",
"version": "7.7.0",
"repository": {
"type": "git",
"url": "git+https://github.com/perimetre/ui.git"
Expand Down
10 changes: 10 additions & 0 deletions src/components/AutocompleteInput/AutocompleteInput.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,16 @@ InitialText.args = {
defaultValue: 'Option 999'
};

export const WithHelp = Template.bind({});
WithHelp.args = {
help: 'You can also have a help text'
};

export const WithError = Template.bind({});
WithError.args = {
error: 'Input is required'
};

/**
* A story that displays an Autocomplete example
*
Expand Down
45 changes: 42 additions & 3 deletions src/components/AutocompleteInput/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,22 @@ export type AutocompleteInputProps<Item> =
* @default false
*/
displayRegardlessIfSearching?: boolean;
/**
* If provided, displays a help text under the input
*/
help?: string;
/**
* The error text to replace the help text with
*/
error?: string;
/**
* Shows a success status
*/
success?: boolean;
/**
* The classname string prepended to the input container className
*/
containerClassName?: string;
/**
* Whether or not should always show the result list regardless if the input is focused or not
* (Only relevant when using TAB to focus the input)
Expand Down Expand Up @@ -111,6 +127,10 @@ type DownshiftAutocompleteContentProps<Item> = ControllerStateAndHelpers<Item> &
* @param props.options The options that should be displayed in the dropdown
* @param props.initialSelectedItem The initial selected item
* @param props.displayRegardlessIfSearching Whether or not should always show the result list regardless if the user is searching or not.
* @param props.help If provided, displays a help text under the input
* @param props.error The error text to replace the help text with
* @param props.success Shows a success status
* @param props.containerClassName The classname string prepended to the input container className
* @param props.onItemToggle A callback that is called every time the user selects or unselects an item
* @param props.defaultValue The input defaultValue property
* @param props.ignoreFilter Whether or not the options should be filtered based on user's input
Expand Down Expand Up @@ -196,6 +216,10 @@ const DownshiftAutocompleteContent = <Item extends { id: string | number }>({
setItemCount,
setState,
unsetItemCount,
containerClassName,
error,
success,
help,

...props
}: DownshiftAutocompleteContentProps<Item> &
Expand Down Expand Up @@ -251,17 +275,30 @@ const DownshiftAutocompleteContent = <Item extends { id: string | number }>({
);

return (
<>
<div>
{label && <label {...getLabelProps({ className: 'pui-label-input' })}>{label}</label>}
{/* Render the combo container for the input and the results */}
<div className="pui-dropdown-input-container">
<div
className={classnames('pui-dropdown-input-container', {
error: !!error,
success: success
})}
>
{/* <span
className={classnames(containerClassName, {
'pui-text-input-error': !!error,
'pui-text-input-success': success,
'pui-text-input-loading': loading
})}
> */}
<input
{...getInputProps({
className: classnames('pui-text-input', className),
...props
})}
onClick={() => !isOpen && toggleMenu()}
/>
{/* </span> */}
{/* <button aria-label={'toggle menu'} className="p-2" type="button" {...getToggleButtonProps()}></button> */}

{/* The container for the results must be in the DOM at all times for accessibility reasons */}
Expand Down Expand Up @@ -332,7 +369,9 @@ const DownshiftAutocompleteContent = <Item extends { id: string | number }>({
))}
</ul>
</div>
</>
{help && !error && <p className="pui-help-text-input">{help}</p>}
{error && <p className="pui-animate-fadeDown pui-help-text-input text-pui-error">{error}</p>}
</div>
);
};

Expand Down
28 changes: 28 additions & 0 deletions src/components/DropdownInput/index.css
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,34 @@
@apply z-20;
}

&.error {
@apply pui-icon-attention;

/* First child = input */
:first-child {
@apply border-pui-error;
}

&::after {
/* By setting the bg color, the color of the icon itself is set */
@apply bg-pui-error;
}
}

&.success {
@apply pui-icon-check;

/* First child = input */
:first-child {
@apply border-pui-success;
}

&::after {
/* By setting the bg color, the color of the icon itself is set */
@apply bg-pui-success;
}
}

/* On open */
&.open {
/* First child = input */
Expand Down

0 comments on commit b8599b3

Please sign in to comment.