-
Notifications
You must be signed in to change notification settings - Fork 161
Circular Progress Bar Specification
The Circular Progress Bar component provides the ability to display a determinate progress bar and its state changes. The value property determines the load state. The size of the filed-in part is calculated as percentage based on the current value vs the max value property. The default max value is 100. The circular progress bar shows percentage value, does not interact with the end-user and is read-only, i.e. the user could not change its state or value.
The circular progress bar component is a new Ignite UI JS Blocks component. It is providing minimal API for the most common use cases, leaving maximum flexibility in developer hands. It follows the mobile-first approach and should be suitable for hybrid applications.
As a citizen developer I want to be able to display certain progress for a concrete action so that the end-users know how much of a task has been completed. As a citizen developer I want to be able to implement determinate circular progress bar visual styles so that I can integrate it better with the overall look and feel of the application. As a citizen developer I want to be able to implement a circular progress bar with starting position at 12 o’clock that increases in clockwise direction.
<igx-circular-bar (onProgressChanged)="f($event)" [value]="currentValue">
</igx-circular-bar>
As an end user, I want to be given a visual representation of how much a task or an action has been completed, so that I can be better informed about its state. As an end user, I want to have circular progress bars, so that it matches the overall look and feel of the application.
- Have determinate circular progress bar that shows only increasing action.
- Have circular progressive bar that only increases in the clockwise direction starting from the position of 12 o’clock.
- The progress should support transition animation and must dynamically display the progress percentage.
- Value and Max must be configurable through the API.
- Text which shows the progress of the bar should be able to change its state to hidden.
The circular progress indicator should always fill from 0% to 100% in clockwise direction and never decrease in value.
Max
: Maximum value that can be passed.
Value
: Precise value between 0 and Max
Progress bar animation
: Transition (CSS)
TextVisibility
: Hide/Show the text.
Background-color
: styled through the CSS
The end user interface consists of:
- Value positioned in the middle of the circle showing the current state as percentage (between 0 and max)
- Clockwise increasing circle showing progress between 0% and 100%.
The end-user must not be able to change the circular progress bar value, max and size.
You should be able to configure the igx-linear-bar
and igx-circular-bar
by passing an Options object to it. It should be able to override methods of Options object.
-
max
- set maximum value that can be passed. Defaultmax
value is 100. -
value
- set value that indicates the completed bar position. -
animate
- animation on progress bar -
textVisibility
- Show/Hide the text.
-
animate
- returns if the animation is activated. -
max
- returns the max value. -
value
- returns passed value. -
valueInPercent
- returns passed value into percentage representation based on max value.
-
valueInPercent
- Converts passed value into percentage and put it in appropriate range between min and max values. -
animate
- Enable/Disabled the animation. -
max
- Sets maximum fill range of the progress bar. -
value
- Puts the value between min and max and update the progress bar indicator.
-
getValueInProperRange(value, max, min)
- validate passed value to to be in range between min(0) and max. -
convertInPercentage(value, max)
- converts value into percentage based on passed number and max value.
-
onProgressChanged
- exposed event, that could be handled to track progress changing
Roles:
- The circular bar has the
progressbar
role. https://www.w3.org/TR/wai-aria/roles#progressbar
Attributes:
The circular bar has the following attributes:
-
aria-valuemin
- https://www.w3.org/TR/wai-aria/states_and_properties#aria-valuemin -
aria-valuemax
- https://www.w3.org/TR/wai-aria/states_and_properties#aria-valuemax