This tutorial is based on Livepeer React version 3.9 or earlier, which is now
deprecated. Please ensure that you use Livepeer React version 4 or later, with
the new Livepeer JavaScript SDK. The integration process may appear different,
but the underlying concepts remain same.
Prerequisites
Before you start with this tutorial, make sure you have the following tools
installed on your machine:
Setting up Next.js App
First, let’s create a directory for your project and initialize a Next.js app
using the following command in your terminal:
This will create a new Next.js app in the current directory and install all the
necessary dependencies.
Next, let”s install the @livepeer/react, library which we will use to
integrate Livepeer:
npm install @livepeer/react dotenv
Adding TailwindCSS
Tailwind CSS is a utility-first CSS framework that enables you to rapidly build
user interfaces. We will use it to style our app. First, we need to install the
tailwindcss, postcss, and autoprefixerdependencies. These dependencies are
necessary for TailwindCSS to work properly in a Next.js app.
Run the following command to install them:
npm install --dev tailwindcss postcss autoprefixer
tailwind.config.js and
postcss.config.js. These files contain the configuration for Tailwind CSS and
PostCSS, respectively. Next, open the tailwind.config.js file in code editor
of your choice and replace its contents with the following code:
module.exports = {
  content: ["./pages//.{js,ts,jsx,tsx}", "./components//.{js,ts,jsx,tsx}"],
  theme: {
    extend: {},
  },
  plugins: [],
};
./styles/globals.css
file.
@tailwind base;
@tailwind components;
@tailwind utilities;
pages/index.js file, with below code.
<div className="flex flex-col justify-center items-center h-screen font-poppins">
  <h1 className="text-9xl font-bold text-slate-900 text-transparent bg-clip-text bg-gradient-to-r from-[#00A660] to-[#28CE88]">
    Livepeer x IPFS
  </h1>
  <h3 className="text-xl mt-6 text-slate-800 w-[50%] text-center">
    Upload, stream, and transcode video on the decentralized web with Livepeer
    and IPFS.
  </h3>
</div>
npm run dev to start the next.js app.
Integrating Livepeer
Livepeer is a decentralized video platform that allows users to upload,
transcode, and serve video content. The Livepeer React SDK provides a set of
ready-to-use hooks that make it easy to integrate Livepeer into a project.
To get started, navigate to
https://livepeer.studio/register and create
a new account on Livepeer Studio. This will give you access to your Livepeer
dashboard, where you can manage your account and access your API keys.
Once you have created an account, in the dashboard, click on the Developers on
the sidebar.
Then, click on Create API Key, give a name to your key and then copy it as we
will need it later.
To use Livepeer React in your project, create a new directory named clientin
the root directory, and add the following code to index.js
import { createReactClient, studioProvider } from "@livepeer/react";
const LivepeerClient = createReactClient({
  provider: studioProvider({ apiKey: "YOUR_API_KEY" }),
});
export default LivepeerClient;
YOUR_API_KEY with the key which you just copied from
the Livepeer dashboard. And also replace the code inside of _app.js in the
page directory with the below code.
import { LivepeerConfig } from "@livepeer/react";
import LivepeerClient from "../client";
import "../styles/globals.css";
function MyApp({ Component, pageProps }) {
  return (
    <LivepeerConfig client={LivepeerClient}>
      <Component {...pageProps} />
    </LivepeerConfig>
  );
}
export default MyApp;
Create IPFS Bucket
We will be first using 4everland to upload videos to Arweave and then playback
the transcoded version using Livepeer’s Player.
The Livepeer player automatically triggers video transcoding to ensure smooth
playback.
This can be useful for ensuring that your videos are of high quality and that
they are accessible to a wide range of viewers, regardless of their device or
connection speed.
Head to the 4everland website and sign up for an account. Once you’ve created
your account, navigate to the “buckets” section in the sidebar and click on
“create bucket”. Give your bucket a name and select IPFS as the storage option.
You can then use the 4everland dashboard or the API to upload your videos to
IPFS.
Then you can either use the 4everland dashboard to upload your videos to IPFS or
the API.
Playback Videos from IPFS
Once you have uploaded the video, you can add Livepeer Player to playback the
video from the IPFS.
{
  arweaveId && (
    <div className="mt-6 w-1/2">
      <Player.Root src={"IPFS_CID"}>
        <Player.Container>
          <Player.Video />
        </Player.Container>
      </Player.Root>
    </div>
  );
}