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;
}