Badge Component
A CSS implementation of the Sprout badge component.
Example
html
<div class="spr-inline-container-md spr-stack-md">
<div class="spr-badge spr-badge-success">
<span class="spr-badge-label">Standard positive badge</span>
</div>
<div class="spr-badge spr-badge-success spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-check-fill"></i>
<span class="spr-badge-label">Positive badge as button (both icons)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-success spr-badge-button">
<span class="spr-badge-label">Positive badge as button (right icon)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-success spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-check-fill"></i>
<span class="spr-badge-label">Positive badge as button (left icon)</span>
</div>
<div class="spr-badge spr-badge-success spr-badge-button">
<span class="spr-badge-label">Positive badge as button (no icon)</span>
</div>
<div class="spr-badge spr-badge-success spr-badge-button spr-badge-disabled">
<span class="spr-badge-label">Positive badge as button (disabled)</span>
</div>
</div>
<div class="spr-inline-container-md spr-stack-md">
<div class="spr-badge spr-badge-error">
<span class="spr-badge-label">Standard negative badge</span>
</div>
<div class="spr-badge spr-badge-error spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-alert-fill"></i>
<span class="spr-badge-label">Negative badge as button (both icons)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-error spr-badge-button">
<span class="spr-badge-label">Negative badge as button (right icon)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-error spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-alert-fill"></i>
<span class="spr-badge-label">Negative badge as button (left icon)</span>
</div>
<div class="spr-badge spr-badge-error spr-badge-button">
<span class="spr-badge-label">Negative badge as button (no icon)</span>
</div>
<div class="spr-badge spr-badge-error spr-badge-button spr-badge-disabled">
<span class="spr-badge-label">Negative badge as button (disabled)</span>
</div>
</div>
<div class="spr-inline-container-md spr-stack-md">
<div class="spr-badge spr-badge-neutral">
<span class="spr-badge-label">Standard neutral badge</span>
</div>
<div class="spr-badge spr-badge-neutral spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-info-fill"></i>
<span class="spr-badge-label">Neutral badge as button (both icons)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-neutral spr-badge-button">
<span class="spr-badge-label">Neutral badge as button (right icon)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-neutral spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-info-fill"></i>
<span class="spr-badge-label">Neutral badge as button (left icon)</span>
</div>
<div class="spr-badge spr-badge-neutral spr-badge-button">
<span class="spr-badge-label">Neutral badge as button (no icon)</span>
</div>
<div class="spr-badge spr-badge-neutral spr-badge-button spr-badge-disabled">
<span class="spr-badge-label">Neutral badge as button (disabled)</span>
</div>
</div>
<div class="spr-inline-container-md spr-stack-md">
<div class="spr-badge spr-badge-info">
<span class="spr-badge-label">Standard informative badge</span>
</div>
<div class="spr-badge spr-badge-info spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-info-fill"></i>
<span class="spr-badge-label">Informative badge as button (both icons)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-info spr-badge-button">
<span class="spr-badge-label">Informative badge as button (right icon)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-info spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-info-fill"></i>
<span class="spr-badge-label">Informative badge as button (left icon)</span>
</div>
<div class="spr-badge spr-badge-info spr-badge-button">
<span class="spr-badge-label">Informative badge as button (no icon)</span>
</div>
<div class="spr-badge spr-badge-info spr-badge-button spr-badge-disabled">
<span class="spr-badge-label">Informative badge as button (disabled)</span>
</div>
</div>
<div class="spr-inline-container-md spr-stack-md">
<div class="spr-badge spr-badge-warning">
<span class="spr-badge-label">Standard warning badge</span>
</div>
<div class="spr-badge spr-badge-warning spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-indeterminate-fill"></i>
<span class="spr-badge-label">Warning badge as button (both icons)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-warning spr-badge-button">
<span class="spr-badge-label">Warning badge as button (right icon)</span>
<i class="spr-badge-icon-right spr-icon spr-icon-help"></i>
</div>
<div class="spr-badge spr-badge-warning spr-badge-button">
<i class="spr-badge-icon-left spr-icon spr-icon-indeterminate-fill"></i>
<span class="spr-badge-label">Warning badge as button (left icon)</span>
</div>
<div class="spr-badge spr-badge-warning spr-badge-button">
<span class="spr-badge-label">Warning badge as button (no icon)</span>
</div>
<div class="spr-badge spr-badge-warning spr-badge-button spr-badge-disabled">
<span class="spr-badge-label">Warning badge as button (disabled)</span>
</div>
</div>
Compiled CSS
Example
scss
@import 'components/badge';
css
compiled
@keyframes openPopover {
from {
transform: scale(0.9);
}
to {
transform: scale(1);
}
}
.spr-icon-rotate-90 {
transform: rotate(90deg);
}
.spr-icon-rotate-180 {
transform: rotate(180deg);
}
.spr-icon-rotate-270 {
transform: rotate(270deg);
}
.spr-badge {
display: flex;
flex-direction: row;
justify-content: flex-start;
align-items: center;
padding: 0.25rem 0.5rem;
border-radius: 1rem;
}
.spr-badge > :not(:last-child) {
margin-right: 0.25rem;
}
.spr-badge.spr-badge-success {
background-color: rgba(4, 135, 103, 0.1);
color: #282f2c;
}
.spr-badge.spr-badge-success.spr-badge-button:not(.spr-badge-disabled) {
cursor: pointer;
}
.spr-badge.spr-badge-success.spr-badge-button:not(.spr-badge-disabled):hover {
background-color: rgba(4, 135, 103, 0.2);
}
.spr-badge.spr-badge-success.spr-badge-button.spr-badge-disabled {
cursor: default;
pointer-events: none;
opacity: 0.5;
}
.spr-badge.spr-badge-success .spr-badge-icon-left {
background-color: #048767;
}
.spr-badge.spr-badge-success .spr-badge-icon-right {
background-color: #282f2c;
}
.spr-badge.spr-badge-error {
background-color: rgba(180, 44, 1, 0.1);
color: #3b2e2c;
}
.spr-badge.spr-badge-error.spr-badge-button:not(.spr-badge-disabled) {
cursor: pointer;
}
.spr-badge.spr-badge-error.spr-badge-button:not(.spr-badge-disabled):hover {
background-color: rgba(180, 44, 1, 0.2);
}
.spr-badge.spr-badge-error.spr-badge-button.spr-badge-disabled {
cursor: default;
pointer-events: none;
opacity: 0.5;
}
.spr-badge.spr-badge-error .spr-badge-icon-left {
background-color: #b42c01;
}
.spr-badge.spr-badge-error .spr-badge-icon-right {
background-color: #3b2e2c;
}
.spr-badge.spr-badge-neutral {
background-color: rgba(83, 86, 90, 0.1);
color: #1a1a1a;
}
.spr-badge.spr-badge-neutral.spr-badge-button:not(.spr-badge-disabled) {
cursor: pointer;
}
.spr-badge.spr-badge-neutral.spr-badge-button:not(.spr-badge-disabled):hover {
background-color: rgba(83, 86, 90, 0.2);
}
.spr-badge.spr-badge-neutral.spr-badge-button.spr-badge-disabled {
cursor: default;
pointer-events: none;
opacity: 0.5;
}
.spr-badge.spr-badge-neutral .spr-badge-icon-left {
background-color: #53565a;
}
.spr-badge.spr-badge-neutral .spr-badge-icon-right {
background-color: #1a1a1a;
}
.spr-badge.spr-badge-info {
background-color: rgba(0, 111, 207, 0.1);
color: #00175a;
}
.spr-badge.spr-badge-info.spr-badge-button:not(.spr-badge-disabled) {
cursor: pointer;
}
.spr-badge.spr-badge-info.spr-badge-button:not(.spr-badge-disabled):hover {
background-color: rgba(0, 111, 207, 0.2);
}
.spr-badge.spr-badge-info.spr-badge-button.spr-badge-disabled {
cursor: default;
pointer-events: none;
opacity: 0.5;
}
.spr-badge.spr-badge-info .spr-badge-icon-left {
background-color: #006fcf;
}
.spr-badge.spr-badge-info .spr-badge-icon-right {
background-color: #00175a;
}
.spr-badge.spr-badge-warning {
background-color: rgba(234, 112, 10, 0.1);
color: #3c2528;
}
.spr-badge.spr-badge-warning.spr-badge-button:not(.spr-badge-disabled) {
cursor: pointer;
}
.spr-badge.spr-badge-warning.spr-badge-button:not(.spr-badge-disabled):hover {
background-color: rgba(234, 112, 10, 0.2);
}
.spr-badge.spr-badge-warning.spr-badge-button.spr-badge-disabled {
cursor: default;
pointer-events: none;
opacity: 0.5;
}
.spr-badge.spr-badge-warning .spr-badge-icon-left {
background-color: #ea700a;
}
.spr-badge.spr-badge-warning .spr-badge-icon-right {
background-color: #3c2528;
}
.spr-badge .spr-badge-label {
font-family: "BentonSansBook", "Helvetica Neue", Arial, sans-serif;
font-size: 0.75rem;
line-height: 1rem;
letter-spacing: 0;
font-weight: 400;
white-space: nowrap;
}
.spr-badge .spr-icon {
width: 1rem;
height: 1rem;
}