Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@rmwc/chip
Advanced tools
Chips represent complex entities in small blocks, such as a contact.
<ChipSet>
<Chip selected label="Cookies" />
<Chip label="Pizza" />
<Chip label="Icecream" />
</ChipSet>
<ChipSet>
<Chip icon="favorite" label="Cookies" trailingIcon="close" />
</ChipSet>
function Example() {
const [selected, setSelected] = React.useState(false);
return (
<ChipSet>
<Chip
key="my-chip"
label="Click Me"
checkmark
selected={selected}
onRemove={(evt) => console.log('onRemove', evt.detail)}
onInteraction={(evt) => {
console.log('onInteraction', evt.detail);
setSelected(!selected);
}}
onTrailingIconInteraction={(evt) =>
console.log('onTrailingIconIteraction', evt.detail)
}
trailingIcon="close"
/>
</ChipSet>
);
}
You can specify a ChipSet
as either a filter
of choice
which slightly changes the visual styling of selected chips. While material-components-web
has some built in functionality for chip sets, it doesn't fit well with React's unidirectional data flow. It is recommended you use standard React patterns to store selected chips in your state and render them accordingly.
Clicking on the trailing close icon will trigger a close animation and put the chip in an exited state, but it is up to you to remove component out from rendering. The you use the onRemove
prop implement this behavior.
function Example() {
const [selected, setSelected] = React.useState({
cookies: false,
pizza: false,
icecream: false
});
const toggleSelected = (key) =>
setSelected({
...selected,
[key]: !selected[key]
});
return (
<ChipSet filter>
<Chip
selected={selected.cookies}
checkmark
onInteraction={() => toggleSelected('cookies')}
label="Cookies"
/>
<Chip
selected={selected.pizza}
checkmark
onInteraction={() => toggleSelected('pizza')}
icon="local_pizza"
label="Pizza"
/>
<Chip
selected={selected.icecream}
checkmark
onInteraction={() => toggleSelected('icecream')}
icon="favorite_border"
label="Icecream"
/>
</ChipSet>
);
}
function Example() {
const [selected, setSelected] = React.useState({
cookies: false,
pizza: false,
icecream: false
});
const toggleSelected = (key) =>
setSelected({
...selected,
[key]: !selected[key]
});
return (
<ChipSet choice>
<Chip
selected={selected.cookies}
onInteraction={() => toggleSelected('cookies')}
label="Cookies"
/>
<Chip
selected={selected.pizza}
onInteraction={() => toggleSelected('pizza')}
icon="local_pizza"
label="Pizza"
/>
<Chip
selected={selected.icecream}
onInteraction={() => toggleSelected('icecream')}
icon="favorite_border"
label="Icecream"
/>
</ChipSet>
);
}
A Chip component.
Name | Type | Description |
---|---|---|
checkmark | boolean | Includes an optional checkmark for the chips selected state. |
children | ReactNode | Additional children will be rendered in the text area. |
foundationRef | Ref<any> | Advanced: A reference to the MDCFoundation. |
icon | IconPropT | Instance of an Icon Component. |
id | string | An optional chip ID that will be included in callback evt.detail. If this is not passed, RMWC will attempt to use the "key" prop if present. |
label | ReactNode | Text for your Chip. |
onInteraction | (evt: ChipOnInteractionEventT) => void | A callback for click or enter key. This should be used over onClick for accessibility reasons. evt.detail = { chipId: string } |
onRemove | (evt: ChipOnRemoveEventT) => void | A callback that is fired once the chip is in an exited state from removing it. evt.detail = { chipId: string } |
onTrailingIconInteraction | (evt: ChipOnTrailingIconInteractionEventT) => void | A callback for click or enter key for the trailing icon. material-components-web always treats this as an intent to remove the chip. evt.detail = { chipId: string } |
selected | boolean | makes the Chip appear selected. |
trailingIcon | IconPropT | Instance of an Icon Component. |
trailingIconRemovesChip | boolean | Defaults to true. Set this to false if your trailing icon is something other than a remove button. |
A container for multiple chips.
Name | Type | Description |
---|---|---|
choice | boolean | Creates a choice chipset |
filter | boolean | Creates a filter chipset |
FAQs
RMWC Chip component
We found that @rmwc/chip demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 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
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.