Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
react-query-assist
Advanced tools
A smart search bar for React that comes with built-in autocomplete and token visualization.
A token is a key-value in a search query that contains an attribute and a value separated by a colon. e.g. some_attribute:some_enumeration
$ npm install -S react-query-assist emotion react-emotion
emotion
is a peer dependency of this library to allow for easy custom styling.
import QueryAssist from 'react-query-assist'
const data = [
{
name: 'some_attribute',
type: 'string',
enumerations: ['enum1', 'enum2', 'enum3' /* ... */ ]
}
]
export default function () {
return (
<QueryAssist
data={data}
onSubmit={console.log} />
)
}
The data prop should have the full list of autocomplete values. The data structure should be an array of attributes, and each attribute should have a name, type and enumerations of available values:
[
{
name: String,
type: String,
enumerations: Array or null
}
]
name
The value of the attribute in the tokentype
The data type of the enumerations (this determines available operators)enumerations
A list of available attribute values in the tokenIf the attribute type is a string, there are two additional autocomplete values that may be suggested:
The autocomplete dropdown will automatically open when it detects a new word is being typed or an existing token is being edited. Note: Tokens are only valid if the attribute and value match an attribute and enumeration in the autocomplete data.
Each token in the query can have a number of operators, depending on the data type of the enumerations. They will change based on the type
of the active attribute. The operator buttons in the dropdown will automatically update as you type, but they can also be clicked to toggle/update the value.
NEGATE
-
int
or float
tokensGT
>
LT
<
GTE
>=
LTE
<=
The default styling is intentionally neutral so you can customize the look based on your own style guide. You can add custom styling to each specific element by using the inputProps, dropdownProps, selectorProps and listProps props. These objects will be merged into the props of each component. See the documentation for styled-system on how to customize styles with props.
A few extra props are accepted for further styling on inputProps
:
placeholderColor
The placeholder text color for the input fieldtokenColor
The highlight color of the valid tokensBy default, keyboard helpers for the dropdown are enabled. Meaning when the dropdown is open, pressing the following keys will result in action:
up
/down
Will navigate through the autocomplete valuesenter
Will select the currently highlighted value and insert into the queryescape
Will close the dropdownProp Name | Prop Type | Description | Default Value |
---|---|---|---|
data | object | Should return an array with the autocomplete data. | - |
onChange | function | Called with the updated value when the input changes. | - |
onSubmit | function | Called with the final value of the query when the enter key is pressed. Pressing enter will submit the query, but shift+enter will create a new line. | - |
defaultValue | string | The default value to pass to the input component. Will parse this value when mounted for any existing tokens. | - |
nameKey | string | The key to use for the attribute name in the data object. | name |
nameKeyIncludes | array | Keys to look at when determining a valid attribute name (e.g. if you want to display short names, but keep long names valid.) | ['name'] |
placeholder | string | The placeholder text to use for the input field. | Search |
collapseOnBlur | boolean | The input field automatically expands to fit the text, but if this is true , will collapse to one line when it is not in focus. | - |
keyboardHelpers | boolean | Whether to enable the keyboard helpers for the dropdown. | true |
inputProps | object | The props to use for the input component. See the themes section. | - |
dropdownProps | object | The props to use for the dropdown component. See the themes section. | - |
selectorProps | object | The props to use for the dropdown selector component. See the themes section. | - |
listProps | object | The props to use for the dropdown list component. See the themes section. | - |
footerComponent | function | Optionally append a footer component to the dropdown. Useful for adding a link to search documentation, etc. | - |
debug | boolean | Enables styling useful for debugging. | false |
FAQs
A smart search bar for React
The npm package react-query-assist receives a total of 12 weekly downloads. As such, react-query-assist popularity was classified as not popular.
We found that react-query-assist demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
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.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.