Skip to content

Custom video player component built using React and the Wistia Player API. A playground (built using Next.js) is available for trying out and testing your different Wistia videos.

Notifications You must be signed in to change notification settings

philipstubbs13/wistia-video-player

Repository files navigation

Wistia Video Player

Project Link: https://wistia-video-player.vercel.app/

A custom video player component built using React and the Wistia JavaScript Player API. The React component itself and all the different props it accepts are documented in Storybook. If you would like to try out the video player with your own Wistia videos, head on over to the Wistia Player Playground.


Table of Contents

Acknowledgments

  • Wistia for their awesome video platform and API.
  • Next.js for the robust and flexible React framework.

About the Project

Built With

Features

  • Embed Wistia videos using their video IDs. You can pass any Wistia video id to the video player component via the videoId prop. When you provide the video id, the component loads the video and all the required assets from Wistia using the Wistia JavaScript Player API. All of this work is done by the component asynchronously when the page loads.

  • Responsive design for various screen sizes. There are no fixed width or height values. The component is responsive and dynamically adjusts to fit the width and height of its parent container.

  • Easy integration of the Wistia JavaScript Player API into any React application. The Wistia Player Playground site shows an example of how you can efficiently and effectively integrate the Wistia video player component in a Next.js application using the app router. Although just one example, it shows just how easy the Wistia JavaScript Player API is to work with and integrate as a React developer.

  • Quick access to Wistia video data. The video player component was designed in a way so that you have quick, easy access to the video player data that the Wistia API provides, such as video duration, video name, video stats, and more.

Getting Started

Follow these instructions to set up and run the project on your local machine.

Clone the project from GitHub.

  git clone https://github.com/philipstubbs13/wistia-video-player.git

Go to the project directory.

  cd wistia-video-player

Install dependencies.

  npm install

Start the Next.js development server.

  npm run dev

Open http://localhost:3000 with your browser to see the result.

You can start editing the page by modifying app/page.tsx. The page auto-updates as you edit the file.

This project uses next/font to automatically optimize and load Inter, a custom Google Font.

To learn more about Next.js, take a look at the following resources:

Wistia Player Playground

The Wistia Player Playground shows an example of how to integrate Wistia into a Next.js application using the app router.

To use the Wistia video player in the playground, provide the Wistia video ID using the videoId URL query parameter. For example:

https://wistia-video-player.vercel.app/?videoId=hv24s97rudm

Running Storybook

This project uses Storybook. Storybook is a frontend development tool for developing, testing, and documenting UI components in complete isolation from the applications in which they are used. In this Storybook, you will find a basic, working example of the video component, documentation on the various props the component accepts, and more.

To run Storybook for this project, run the following command in the root directory of this project.

  npm run storybook

The Storybook for this project is deployed to the following URL: https://66aa07fde316cf9b3445ce6d-wzfdwyrtml.chromatic.com/

Chromatic

For this project, Storybook is deployed via Chromatic. Chromatic catalogs the component library across commits and branches. If you plan to contribute to this project, it can help with reviewing the video player component online, see past versions of the component, and get feedback on any work in progress.

The Chromatic library is available at the following URL (mostly valuale only if you plan to contribute to this project):

https://www.chromatic.com/library?appId=66aa07fde316cf9b3445ce6d

Currently, When you push code to the main branch, a GitHub action is set up for this repository to automatically kick off a build in Chromatic. The Chromatic GitHub action is located in the .github/workflows directory of the repository. The CHROMATIC_PROJECT_TOKEN must be configured as a repository secret in the settings of this repository for this action to work.

When this action is run, a build will be kicked off. After the build is complete, you can review the component changes associated with that build and either accept or deny those changes from the Chromatic library.

Deployment

This app is deployed through the Vercel Platform. Deploys are set up to happen automatically when code is merged into the main branch.

Contributing

Contributions are welcome! Please open an issue or submit a pull request for any improvements or bug fixes.

Contact

Phil Stubbs - [email protected]

Issues and Requests

If you find an issue while using the application or have a request, log the issue or request here. These will be addressed in a future code update.

About

Custom video player component built using React and the Wistia Player API. A playground (built using Next.js) is available for trying out and testing your different Wistia videos.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published