Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/AbreezaSaleem/react-voice-recorder-player
Voice Recorder Component for React
https://github.com/AbreezaSaleem/react-voice-recorder-player
audio-player audio-recorder mediarecorder-api react reactjs recording voice voice-recorder
Last synced: about 2 months ago
JSON representation
Voice Recorder Component for React
- Host: GitHub
- URL: https://github.com/AbreezaSaleem/react-voice-recorder-player
- Owner: AbreezaSaleem
- License: mit
- Created: 2023-04-03T22:22:50.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-04-23T20:01:16.000Z (9 months ago)
- Last Synced: 2024-04-24T20:58:27.802Z (9 months ago)
- Topics: audio-player, audio-recorder, mediarecorder-api, react, reactjs, recording, voice, voice-recorder
- Language: TypeScript
- Homepage:
- Size: 641 KB
- Stars: 19
- Watchers: 3
- Forks: 5
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- my-awesome-list - react-voice-recorder-player
README
## react-voice-recorder-player
Say goodbye to boring audio elments and hello to interactive voice recording! `react-voice-recorder-player` is a React component that lets users record and playback their voice directly in the browser. It even includes a waveform graph that shows the audio being captured and played back in real-time.
`react-voice-recorder-player` is an ultra light-weight component. The package size is only around `160 kB` meaning it won't add unnecessary bulk to your application. And the best part is, its completely customizable! You can easily change the appearance of the component to fit your application's unique design and trigger your own code on our custom events.
## Installation
The package can be installed via [npm](https://github.com/npm/cli):
```
npm install react-voice-recorder-player --save
```Or via [yarn](https://github.com/yarnpkg/yarn):
```
yarn add react-voice-recorder-player
```## See it in action!
Check out the [CodePen demo](https://codesandbox.io/s/react-voice-recorder-player-example-gtod60) to see the `VoiceRecorder` component in action. This demo is a great starting point for customizing the component to fit your application's unique design.
## Getting Started
Using the VoiceRecorder component is a breeze. Simply import it into your React application like so:
```js
import React from 'react';
import { VoiceRecorder } from 'react-voice-recorder-player';function App() {
return (
React Voice Recorder
);
}export default App;
```The `VoiceRecorder` component will provide your users with an intuitive MP3-like interface, complete with record, play, pause, and stop buttons.
## Points to note
- The `VoiceRecorder` component uses the [MediaRecorder API](https://developer.mozilla.org/en-US/docs/Web/API/MediaRecorder) to record audio. This means that the component will only work in browsers that support this API. You can check out the [browser compatibility table](https://developer.mozilla.org/en-US/docs/Web/API/MediaRecorder#browser_compatibility) to see which browsers support this API.
- There is no limit to the length of the audio that can be recorded. However, the longer the audio, the thinner the waveform graph will be. You can adjust this by increasing the width of the component.
- And after you're done recording you'll see a download button that lets your users download the audio file to their computer. If you want to disable this feature, simply pass in `false` to the `downloadable` prop. If you'd like to obtain the audio file link programmatically, you can pass in a callback function to the `onAudioDownload` prop. This callback function will be called with the audio file blob as an argument.## Props
| Prop name | Description | Type |
|-------------------------|--------------------------------------------------------------------------------------------------|---------------|
| `mainContainerStyle` | Style object for the container of the whole component. | `CSSProperties` |
| `height` | Height of the component. | `number,string` |
| `width` | Width of the component. | `number,string` |
| `controllerContainerStyle` | Style object for the container of the controller buttons. | `CSSProperties` |
| `controllerStyle` | Style object for the controller buttons. | `CSSProperties` |
| `waveContainerStyle` | Style object for the container of the waveform graph. | `CSSProperties` |
| `graphColor` | Color of the waveform graph. | `string` |
| `graphShaded` | Boolean value indicating if the waveform graph should be shaded according to the amplitude of the audio. `true` by default. | `boolean` |
| `downloadable` | Boolean value indicating if the download button should be displayed to the user when they're done recording. `true` by default. | `boolean` |
| `uploadAudioFile` | Boolean value indicating if the upload button should be displayed to the user. `true` by default. | `boolean` |
| `onAudioDownload` | A callback function that'll get called as soon as the `Blob` is available. | `Function` |
------------------------------------------------------------------------------------------------------------------------------------------## Custom Events
In addition to the props mentioned above, you can also use our custom callback events to trigger specific actions in your application. Here's a list of the custom events that are available:| Prop name | Description | Type |
|------------------|-------------------------------------------|-------------|
| `onRecordingStart` | Event triggered when recording starts | `function` |
| `onRecordingEnd` | Event fired when recording ends | `function` |
| `onPlayStart` | Event triggered when playback starts | `function` |
| `onPlayEnd` | Event fired when playback ends | `function` |
| `onRecordingPause` | Event triggered when recording is paused | `function` |
| `onPlayPause` | Event fired when playback is paused | `function` |## Customization
Want to make the `VoiceRecorder` component even more personalized? No problem! You can customize the appearance of the component by passing in your own style objects. Here's an example:
```js
import React from 'react';
import { VoiceRecorder } from 'react-voice-recorder-player';function MyComponent() {
const styles = {
mainContainerStyle: {
backgroundColor: 'gray',
border: '1px solid black',
borderRadius: '5px',
padding: '10px'
},
controllerContainerStyle: {
display: 'flex',
justifyContent: 'space-between',
marginTop: '10px'
},
controllerStyle: {
backgroundColor: 'white',
border: '1px solid black',
borderRadius: '5px',
cursor: 'pointer',
padding: '5px'
},
waveContainerStyle: {
height: '100px',
marginTop: '10px',
width: '100%'
}
};return (
);
}```
## Troubleshooting
This section provides solutions for known issues related to browser compatibility:
- ~~Issue: Playback option not working on iOS devices~~
- ~~Due to browser limitations on iOS devices, the playback option may not work as expected. In the meantime, consider testing on other browsers or devices for full functionality.~~ (fixed [here](https://github.com/AbreezaSaleem/react-voice-recorder-player/commit/f6b42448d9c8372a74bc41a025b6974fbc1b8a4c))
- Issue: Playback option not working on Mac Safari in Codesandbox
- Codesandbox is unable to play the recorded audio on Safari Mac. More details of the issue can be found here https://github.com/AbreezaSaleem/react-voice-recorder-player/issues/1Please note that this list may be updated as new issues are identified and resolved. Contributions from the community are welcome in identifying and fixing any bugs. We appreciate your help in making this project better!
## Contributing
We welcome contributions to improve `react-voice-recorder-player`. To contribute, please follow these steps:1. Fork the repository and clone it to your local machine.
2. Install the package dependencies by running npm install.
3. Commit your changes with a descriptive commit message.
4. Push your changes to your forked repository.
5. Submit a pull request to the main branch of the original repository.## Issues
If you encounter any issues while using `react-voice-recorder-player`, please feel free to [open an issue](https://github.com/AbreezaSaleem/react-voice-recorder-player/issues) on the project's GitHub repository. We welcome bug reports, feature requests, and other contributions from the community.
## License
`react-voice-recorder-player` is licensed under the MIT License. See the [LICENSE](https://github.com/AbreezaSaleem/react-voice-recorder-player/blob/main/LICENSE) file for more information.
## Author
Abreeza Saleem
[email protected]
https://abreeza.tech