2020-07-15 21:30:37 +00:00
# Progress Bar
[component-header:sl-progress-bar]
2020-11-25 21:20:15 +00:00
Progress bars are used to show the status of an ongoing operation.
2020-07-15 21:30:37 +00:00
```html preview
< sl-progress-bar percentage = "50" > < / sl-progress-bar >
```
## Examples
### Custom Height
Use the `--height` custom property to set the progress bar's height.
```html preview
< sl-progress-bar percentage = "50" style = "--height: 6px;" > < / sl-progress-bar >
```
### Labels
Use the default slot to show a label.
```html preview
< sl-progress-bar percentage = "50" class = "progress-bar-labels" > 50%< / sl-progress-bar >
< br >
< sl-button circle > < sl-icon name = "dash" > < / sl-icon > < / sl-button >
< sl-button circle > < sl-icon name = "plus" > < / sl-icon > < / sl-button >
< script >
const progressBar = document.querySelector('.progress-bar-labels');
const subtractButton = progressBar.nextElementSibling.nextElementSibling;
const addButton = subtractButton.nextElementSibling;
addButton.addEventListener('click', () => {
const percentage = Math.min(100, progressBar.percentage + 10);
progressBar.percentage = percentage;
progressBar.textContent = `${percentage}%` ;
});
subtractButton.addEventListener('click', () => {
const percentage = Math.max(0, progressBar.percentage - 10)
progressBar.percentage = percentage;
progressBar.textContent = `${percentage}%` ;
});
< / script >
```
2020-11-25 21:20:15 +00:00
### Indeterminate
The `indeterminate` attribute can be used to inform the user that the operation is pending, but its status cannot currently be determined. In this state, `percentage` is ignored and the label, if present, will not be shown.
```html preview
< sl-progress-bar indeterminate > < / sl-progress-bar >
```
2020-07-15 21:30:37 +00:00
[component-metadata:sl-progress-bar]