This is a library of icons with dynamic fill capabilities that can be used to show progress (similar to a traditional progress spinner or bar). These can be used to show health, battery life, etc.
Currently, we have icons available for:
- battery
- heart
- pie
- ups
To install the Brightlayer UI progress icons from NPM as a dependency for your project, you can run the following command in your project root:
yarn add @brightlayer-ui/react-progress-icons
The progress icon components can be imported and used like you would use any other component. You can manually set the desired color for the icon, otherwise it will inherit the text color of its parent container;
import {Battery, Heart, Pie} from '@brightlayer-ui/react-progress-icons';
...
<Battery percent={100} size={36} color={'green'} charging={true} outlined={true}/>
<Heart percent={50} size={18} color={'pink'} outlined={true}/>
<Pie percent={50} size={48} color={'blue'} ring={4} outlined={true}/>
These props are available on all of the progress icons in this package.
Prop Name | Description | Type | Required | Default |
---|---|---|---|---|
backgroundColor | Background color for the unfilled area | string |
no | |
color | The color used for the icon fill | string |
no | 'inherit' |
labelColor | Label text color | string |
no | |
labelPosition | Where to display the text label | 'top' | 'bottom' | 'center' | 'right' | 'left' |
no | center |
labelSize | Size of the label in px | number |
no | size/4 |
outlined | Whether to use the outlined style | boolean |
no | false |
percent | The amount to fill the icon (0-100) | number |
no | 100 |
showPercentLabel | Option to show percentage overlay | boolean |
no | false |
size | The size of the icon (in px) | number |
no | 24 |
Any other props supplied will be provided to the root element (svg
).
The battery supports all of the shared properties above and the following additional properties:
Prop Name | Description | Type | Required | Default |
---|---|---|---|---|
charging | Whether to show the charging indicator | boolean |
no | false |
The pie supports all of the shared properties above and the following additional properties:
Prop Name | Description | Type | Required | Default |
---|---|---|---|---|
ring | The thickness of the outer ring (1 = thin ring, 10 = full circle ) | number |
no | 10 |
These progress icons are currently created manually by modifying the svg files from the design folder with various clip paths and fill algorithms. They are then packaged up for distribution via npm.
The react icons are created as stateless functional components in individual files for each icon.
To create the /dist version of the icons:
cd /react
yarn build
And then to publish:
npm version patch
npm publish