react-progress-button
Version:
Simple react.js component for a inline progress indicator
177 lines (117 loc) • 4.97 kB
Markdown
//img.shields.io/travis/mathieudutour/react-progress-button/master.svg?style=flat-square)](https://travis-ci.org/mathieudutour/react-progress-button)
[](https://www.npmjs.com/package/react-progress-button)
[](https://david-dm.org/mathieudutour/react-progress-button)
[](https://david-dm.org/mathieudutour/react-progress-button#info=devDependencies)
> Simple [React](http://facebook.github.io/react/index.html) component for a circular Progress Button.
[](https://github.com/mathieudutour/react-progress-button/blob/master/example/index.html)
```bash
npm install react-progress-button --save
```
```javascript
import ProgressButton from 'react-progress-button'
const App = React.createClass({
getInitialState () {
return {
buttonState: ''
}
},
render () {
return (
<div>
<ProgressButton onClick={this.handleClick} state={this.state.buttonState}>
Go!
</ProgressButton>
</div>
)
},
handleClick () {
this.setState({buttonState: 'loading'})
// make asynchronous call
setTimeout(() => {
this.setState({buttonState: 'success'})
}, 3000)
}
})
```
[ ](https://github.com/mathieudutour/react-progress-button/blob/master/example/index.html)
If the function passed in via the `onClick` prop return a Promise or if a promise
is passed as an argument of the `loading` method,
the component will automatically transition to its success or error
states based on the outcome of the Promise without the need for
external manipulation of state using a ref.
```javascript
import ProgressButton from 'react-progress-button'
const App = React.createClass({
render () {
return (
<div>
<ProgressButton onClick={this.handleClick}>
Go!
</ProgressButton>
</div>
)
},
handleClick() {
return new Promise(function(resolve, reject) {
setTimeout(resolve, 3000)
})
}
});
```
[ ](https://github.com/mathieudutour/react-progress-button/blob/master/example/index-promises.html)
All props are optional. All props other than that will be passed to the top element.
Namespace for CSS classes, default is `pb-` i.e CSS classes are `pb-button`.
Duration (ms) before going back to normal state when an error occurs,
default is 1200
Duration (ms) before going back to normal state when an success occurs,
default is 500
Function to call when the button is clicked; if it returns a Promise
then the component will transition to the success/error state based on
the outcome of the Promise
Function to call when going back to the normal state after an error
Function to call when going back to the normal state after a success
State of the button if you do not want to use the functions. Can be `''`, `loading`, `success`, `error` or `disabled`.
Type of the button (can be 'submit' for example).
##### form
Id of the form to submit (useful if the button is not directly inside the form).
##### shouldAllowClickOnLoading
Whether click event should bubble when in loading state
### Methods
##### loading()
Put the button in the loading state.
##### disable()
Put the button in the disabled state.
##### notLoading(), enable()
Put the button in the normal state.
##### success([callback, dontGoBackToNormal])
Put the button in the success state. Call the callback or the onSuccess prop when going back to the normal state.
##### error([callback])
Put the button in the error state. Call the callback or the onError prop when going back to the normal state.
## Styles
Look at [react-progress-button.css](https://github.com/mathieudutour/react-progress-button/blob/master/react-progress-button.css) for an idea on how to style this component.
If you are using webpack, you'll need to have ```css-loader``` installed and include
```
{
test: /\.css$/,
loader: "style!css"
}
```
in your webpack config. In your jsx file you can then import the CSS with ```import "../node_modules/react-progress-button/react-progress-button.css";``` although the path depends on how deeply nested your jsx is. If you wish to theme it yourself, copy the CSS to a convenient location and point the import path at the copy, which is part of your repo, unlike the original in ```node_modules```.
MIT
[![build status](https: