
Security News
Risky Biz Podcast: Making Reachability Analysis Work in Real-World Codebases
This episode explores the hard problem of reachability analysis, from static analysis limits to handling dynamic languages and massive dependency trees.
@rmwc/badge
Advanced tools
RMWC ADDON
Badges are small status descriptors for UI elements. A badge consists of a small circle, typically containing a number or other short set of characters, that appears in proximity to another object.
<Badge align="inline" />
<>
<Badge align="inline" label={20} />
<Badge align="inline" label="99+" />
<Badge align="inline" label="New" />
</>
<>
<Badge theme={['primaryBg', 'onPrimary']} align="inline" />
<Badge style={{ background: 'hotpink' }} align="inline" />
<Badge
theme={['secondaryBg', 'onSecondary']}
align="inline"
label="Theme"
/>
</>
The badge component has been designed to play well with the majority of components in RMWC. You can place it inside of any component that accepts children and its default position will be absolute to the top end corner.
Because passing a Badge as a child doesn't always work (for things like overflow: hidden
elements), you can use the BadgeAnchor
component. This is really just a div with position: relative
and some other sensible layout properties set on it, so you can use this or your own CSS to achieve the same result. Additionally, exact positioning is highly dependent on your design and shape of your components. Badges provide an inset
property that allows you to adjust the positioning of the Badge as necessary.
<>
<BadgeAnchor>
<Button raised label="Button" />
<Badge />
</BadgeAnchor>
<BadgeAnchor>
<Button
raised
label="Button"
theme={['secondaryBg', 'onSecondary']}
/>
<Badge style={{ background: 'hotpink' }} label="Hello" />
</BadgeAnchor>
</>
<BadgeAnchor>
<IconButton icon="notifications" />
<Badge inset="0.75rem" />
</BadgeAnchor>
<>
<BadgeAnchor>
<Avatar
src="images/avatars/ironman.png"
size="large"
name="Tony Stark"
/>
<Badge inset="5px" />
</BadgeAnchor>
<BadgeAnchor>
<Avatar
src="images/avatars/blackwidow.png"
size="large"
name="Natalia Alianovna Romanova"
square
/>
<Badge />
</BadgeAnchor>
</>
Badges can be aligned to the start, end, or use inline alignment. They are also RTL aware. They default to align end.
<>
<BadgeAnchor>
<Button raised label="Align Start" />
<Badge align="start" />
</BadgeAnchor>
<BadgeAnchor>
<Button raised label="Align End" />
<Badge align="end" />
</BadgeAnchor>
</>
You can transition between the standalone indicator and a badge with content. The badge will consider any label
other than null or undefined as valid content.
function Example() {
const [label, setLabel] = React.useState(undefined);
React.useEffect(() => {
const timeout = setTimeout(() => {
switch (label) {
case '99+':
setLabel(undefined);
break;
case '':
setLabel('99+');
break;
case undefined:
setLabel('');
break;
}
}, 1800);
return () => clearTimeout(timeout);
}, [label]);
return (
<BadgeAnchor>
<Button raised label="Button" />
<Badge label={label} exited={label === undefined} />
</BadgeAnchor>
);
}
A Badge component for indicating alerts or counts.
Name | Type | Description |
---|---|---|
align | "end" | "start" | "inline" | How to align the badge. |
exited | undefined | false | true | Animates the badge out of view. When this class is removed, the badge will return to view. |
inset | string | number | A value to inset the badge alignment by, useful for positioning the badge on different shaped components. |
label | React.ReactNode | number | A label or count for the badge. |
An anchor component for badges.
FAQs
Badges are small status descriptors for UI elements. A badge consists of a small circle, typically containing a number or other short set of characters, that appears in proximity to another object.
The npm package @rmwc/badge receives a total of 469 weekly downloads. As such, @rmwc/badge popularity was classified as not popular.
We found that @rmwc/badge demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer 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
This episode explores the hard problem of reachability analysis, from static analysis limits to handling dynamic languages and massive dependency trees.
Security News
/Research
Malicious Nx npm versions stole secrets and wallet info using AI CLI tools; Socket’s AI scanner detected the supply chain attack and flagged the malware.
Security News
CISA’s 2025 draft SBOM guidance adds new fields like hashes, licenses, and tool metadata to make software inventories more actionable.