src/components/sq-progress-bar/sq-progress-bar.component.ts
Represents a progress bar component for displaying progress visually.
Look the link about the component in original framework and the appearance
See https://css.squidit.com.br/components/progress-bar
<sq-progress-bar [value]="50" [striped]="true"></sq-progress-bar>
selector | sq-progress-bar |
styleUrls | ./sq-progress-bar.component.scss |
templateUrl | ./sq-progress-bar.component.html |
Properties |
Inputs |
animated | |
Type : boolean
|
|
Default value : false
|
|
Indicates whether the progress bar should have an animation. |
color | |
Type : string
|
|
Default value : 'black'
|
|
The color of the progress bar. |
hasLabel | |
Type : boolean
|
|
Default value : false
|
|
Indicates whether to display a label on the progress bar. |
height | |
Type : string
|
|
Default value : '1rem'
|
|
The height of the progress bar. |
striped | |
Type : boolean
|
|
Default value : true
|
|
Indicates whether to display stripes on the progress bar. |
value | |
Type : string | number
|
|
Default value : 0
|
|
The value of the progress bar (can be a string or number). |
roundValue |
Default value : useMemo((value: string | number) => {
return Math.round(Number(value))
})
|
The rounded value of the progress (rounded to the nearest integer). |
import { Component, Input } from '@angular/core'
import { useMemo } from '../../helpers/memo.helper'
/**
* Represents a progress bar component for displaying progress visually.
*
* Look the link about the component in original framework and the appearance
*
* @see {@link https://css.squidit.com.br/components/progress-bar}
*
* <div class="progress my-3">
* <div
* class="progress-bar background-dashed animate-bar"
* role="progressbar"
* aria-valuemin="0"
* aria-valuemax="100"
* ></div>
* </div>
*
* @example
* <sq-progress-bar [value]="50" [striped]="true"></sq-progress-bar>
*
*/
@Component({
selector: 'sq-progress-bar',
templateUrl: './sq-progress-bar.component.html',
styleUrls: ['./sq-progress-bar.component.scss'],
})
export class SqProgressBarComponent {
/**
* The color of the progress bar.
*/
@Input() color = 'black'
/**
* Indicates whether to display a label on the progress bar.
*/
@Input() hasLabel = false
/**
* The value of the progress bar (can be a string or number).
*/
@Input() value: string | number = 0
/**
* The height of the progress bar.
*/
@Input() height = '1rem'
/**
* Indicates whether to display stripes on the progress bar.
*/
@Input() striped = true
/**
* Indicates whether the progress bar should have an animation.
*/
@Input() animated = false
/**
* The rounded value of the progress (rounded to the nearest integer).
*/
roundValue = useMemo((value: string | number) => {
return Math.round(Number(value))
})
}
<div class="progress" style="height: 14px">
<div
class="progress-bar background-{{ color }}"
role="progressbar"
aria-valuemin="0"
aria-valuemax="100"
[ngClass]="{
'background-dashed': striped,
'animate-bar': animated
}"
[ngStyle]="{
width: value + '%',
height: height,
'backgroud-color': color
}"
style="font-size: 0.86rem"
>
{{ hasLabel ? roundValue(value) + '%' : null }}
</div>
</div>
./sq-progress-bar.component.scss
.progress {
width: 100%;
}
:host {
display: inline-block;
width: 100%;
}