sp-meter

Examples API

Attributes and Properties #

Property Attribute Type Default Description
dir dir 'ltr' | 'rtl' 'ltr'
label label string ''
negative negative boolean false
notice notice boolean false
overBackground over-background boolean false
positive positive boolean false
progress progress number 0
sideLabel side-label boolean false
size size ElementSize

Slots #

Name Description
default slot text labeling the Meter

CSS Custom Properties #

Name Default
--spectrum-fieldlabel-m-side-padding-right var(--spectrum-global-dimension-size-150)
--spectrum-fieldlabel-m-text-color var(--spectrum-alias-label-text-color)
--spectrum-meter-m-negative-track-fill-color var(--spectrum-semantic-negative-status-color)
--spectrum-meter-m-notice-track-fill-color var(--spectrum-semantic-notice-status-color)
--spectrum-meter-m-positive-track-fill-color var(--spectrum-semantic-positive-status-color)
--spectrum-progressbar-l-border-radius var(--spectrum-global-dimension-size-50)
--spectrum-progressbar-l-height var(--spectrum-global-dimension-size-100)
--spectrum-progressbar-l-indeterminate-duration var(--spectrum-global-animation-duration-2000)
--spectrum-progressbar-l-indeterminate-fill-width var(--spectrum-global-dimension-static-percent-70)
--spectrum-progressbar-l-value-gap-y 0px
--spectrum-progressbar-l-width var(--spectrum-global-dimension-static-size-2500)
--spectrum-progressbar-m-border-radius undefined
--spectrum-progressbar-m-height var(--spectrum-global-dimension-size-75)
--spectrum-progressbar-m-indeterminate-duration var(--spectrum-global-animation-duration-2000)
--spectrum-progressbar-m-indeterminate-fill-width var(--spectrum-global-dimension-static-percent-70)
--spectrum-progressbar-m-overbackground-track-color var(--spectrum-alias-track-color-overbackground)
--spectrum-progressbar-m-overbackground-track-fill-color var(--spectrum-alias-track-fill-color-overbackground)
--spectrum-progressbar-m-track-color var(--spectrum-alias-track-color-default)
--spectrum-progressbar-m-track-fill-color var(--spectrum-semantic-informative-color-default)
--spectrum-progressbar-m-value-gap-y 0px
--spectrum-progressbar-m-width var(--spectrum-global-dimension-static-size-2400)
--spectrum-progressbar-s-border-radius undefined
--spectrum-progressbar-s-height var(--spectrum-global-dimension-size-50)
--spectrum-progressbar-s-indeterminate-duration var(--spectrum-global-animation-duration-2000)
--spectrum-progressbar-s-indeterminate-fill-width var(--spectrum-global-dimension-static-percent-70)
--spectrum-progressbar-s-value-gap-y 0px
--spectrum-progressbar-s-width var(--spectrum-global-dimension-static-size-2400)
--spectrum-progressbar-xl-border-radius undefined
--spectrum-progressbar-xl-height var(--spectrum-global-dimension-size-125)
--spectrum-progressbar-xl-indeterminate-duration var(--spectrum-global-animation-duration-2000)
--spectrum-progressbar-xl-indeterminate-fill-width var(--spectrum-global-dimension-static-percent-70)
--spectrum-progressbar-xl-value-gap-y 0px
--spectrum-progressbar-xl-width var(--spectrum-global-dimension-static-size-2800)

Description #

An <sp-meter> is a visual representation of a quantity or achievement. The meter's progress is determined by user actions, rather than system actions.

Installation #

See it on NPM! How big is this package in your project? Try it on webcomponents.dev

yarn add @spectrum-web-components/meter

Import the side-effectful registration of <sp-meter> via:

import '@spectrum-web-components/meter/sp-meter.js';

When looking to leverage the Meter base class as a type and/or for extension purposes, do so via:

import { Meter } from '@spectrum-web-components/meter';

Sizes #

Small
<sp-meter size="s" progress="71">Tasks Completed</sp-meter>
Medium
<sp-meter size="m" progress="71">Tasks Completed</sp-meter>
Large
<sp-meter size="l" progress="71">Tasks Completed</sp-meter>
Extra Large
<sp-meter size="xl" progress="71">Tasks Completed</sp-meter>

Variants #

Over Background #

When a loader needs to be placed on top of a colored background, use the over background loader as signified by [over-background]. This loader uses a white opaque color no matter the background. Make sure the background offers enough contrast for the loader to be legible.

<div
style="width: var(--spectrum-global-dimension-size-3000); height: var(--spectrum-global-dimension-size-2000); display: flex; flex-direction: column; align-items: center; justify-content: space-around; background-color: var(--spectrum-alias-background-color-modal-overlay);"
>

<sp-meter progress="42" over-background>Tasks Completed</sp-meter>
</div>

Side Label #

A meter can be delivered with its labeling displayed above its visual indicator or to either side. Use the boolean [side-label] attribute to define where this content should appear.

<sp-meter side-label>Side Label</sp-meter>