Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Audio Duplication with ReactPlayer in Next.js using --turbo Flag #1895

Open
l-Nuril-l opened this issue Oct 23, 2024 · 2 comments
Open

Audio Duplication with ReactPlayer in Next.js using --turbo Flag #1895

l-Nuril-l opened this issue Oct 23, 2024 · 2 comments

Comments

@l-Nuril-l
Copy link

l-Nuril-l commented Oct 23, 2024

Current Behavior

When using ReactPlayer in a Next.js project with the --turbo flag enabled, audio is duplicated starting from version 2.14 up to 2.16 of react-player. The issue does not occur in earlier versions (e.g., 2.13). This happens when toggling the ReactPlayer component based on state and occurs only the first time after the page loads.

Expected Behavior

Audio should play without duplication when ReactPlayer is triggered, and the sound should play as expected without overlapping.

Steps to Reproduce

  1. Use Next.js with the --turbo flag ("dev": "next dev --turbo").
  2. Include the ReactPlayer component that streams video from a local or remote source.
  3. Toggle the player using a button to initiate playback.
  4. Observe that, starting from react-player versions 2.14 - 2.16, the sound is duplicated.

Environment

  • Browser: Chrome 129
  • Operating system: Windows 11

Code Example

"use client"
import React, { useState } from 'react';
import ReactPlayer from 'react-player';

export default function page() {
    const [state, setState] = useState(false);
    return (
        <div>
            <button onClick={() => setState(true)}>click</button>
            {state && <ReactPlayer url='https://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4' playing={true} />}
        </div>
    );
}
@Deamoner
Copy link

I have this same issue. Any update?

@Deamoner
Copy link

Pretty sure this has to do with react strict mode in nextjs. In prod doesn't happen and seems to be temporary fixable with nextjs config change:
module.exports = {
// Only do this for testing - don't commit this change
reactStrictMode: false,
// ... other config
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants