/trimtube

TrimTube is a web application which allows user to fetch video or a playlist using a YouTube video or playlist link. This app also features a media player that allows the user to trim and loop any portion of a YouTube video with ability to save the video(s) to a playlist(s).

Primary LanguageJavaScriptMIT LicenseMIT

TrimTube

TrimTube

GitHub Commitizen friendly

TrimTube is a web application which allows user to fetch video or a playlist using a YouTube video or playlist link. This app also features a media player that allows the user to trim and loop any portion of a YouTube video with ability to save the video(s) to a playlist(s).

πŸ‘€ Demo

https://trimtube.vercel.app/

πŸŽ‰ Features

TrimTube provides multiple features like:

  • Search: Search for a YouTube video or playlist by pasting the entire youtube video or playlist link or just the ID.
  • Video: Trim and loop a YouTube video with ability to share the URL as well as adding to playlist(s).
  • Playlist: View videos added to a playlist all at one place. Ability to save, share, and delete a playlist. Option to individually remove a video from the playlist.
  • Sync: Ability to sync a playlist with that of the YouTube playlist if the playlist was created locally in the app using the Search with playlist feature.
  • Sort: Sort a playlist created in the app based on the title or publishedDate of the videos.
  • Repeat: Repeat a single video or the entire playlist or just play through all the videos in the playlist once.

🧐 How to use TrimTube?

Search Video

There are multiple ways to search a video in the app.

  • Search with pasted YouTube Video URL or a YouTube Video ID to find the relevant YouTube video(s).
  • Visit https://trimtube.vercel.app/video?v=ID page replacing ID with YouTube Video ID to find the relevant YouTube video(s). ex - https://trimtube.vercel.app/video?v=a6Ur326zJtM

Watch Demo - Search Video

Trim Video

Click on Trim Video button on Video page and use the trim controls to input the Start and End times in Minutes and Seconds to Trim the video which will loop the video between this interval indefinitely.

Watch Demo - Trim Video

Create Playlist

There are multiple ways to create a playlist in the app.

  • Search with pasted YouTube Playlist URL or a YouTube Playlist ID to find the relevant YouTube video(s).

    Create a playlist in the app using the Create Playlist button with an ability to edit the name of the created playlist later.

  • On Video page, create a playlist in the modal when saving a video to a playlist.

Watch Demo - Create Playlist

Playlist Controls

  • Repeat a video or the playlist.
  • Shuffle the playlist
  • Sort the playlist based on the Title or Date.
  • Fetch the remote YouTube playlist and merge any new videos with the local playlist.
    Note: this option is available only on the playlists that were created using the YouTube playlist URL or ID

Watch Demo - Playlist Controls

Share

Share a trimmed Video or a created Playlist in the app on multiple platforms like Facebook, Twitter, LinkedIn and WhatsApp.

OR

You can simply Copy the URL to share on other platforms as well.

Watch Demo - Share

πŸ’» Quick start

  1. Clone the repository

    git clone https://github.com/iamsainikhil/trimtube.git
  2. Install the packages

    Install the packages using the command npm install

  3. Environment File

    Create an .env file in the root directory of the project. Add the following properties in it:

    YOUTUBE_API_V3=<your YouTube API key> (Required)
    
    NEXT_PUBLIC_GA_ID=<your Google Analytics tracking ID> (Optional)
    
    NEXT_PUBLIC_SITE_URL=<URL of the deployed app> (Optional)
    
    NEXT_PUBLIC_HOTJAR_ID=<your project Hotjar tracking ID> (Optional)
    
    NEXT_PUBLIC_HOTJAR_VERSION=<your project Hotjar tracking code version> (Optional)
  4. Start developing.

    Navigate into your new site’s directory and start it up.

    # Go to project directory
    cd <project-name>
    
    # start the application
    npm run dev
  5. Open the source code and start editing!

    Your site is now running at http://localhost:3000!

    Open the <project-name> directory in your code editor of choice and edit the contents. Save your changes and the browser will update in real time!

βš™οΈ Available Scripts


In the project directory, you can run:

  • npm run dev

    Runs the app in the development mode.Open [http://localhost:3000](http://localhost:3000/) to view it in the browser. The page will reload if you make edits. You will also see any lint or nextjs develop errors in the console.

  • npm run start

    Runs the app in the production mode.Open [http://localhost:3000](http://localhost:3000/) to view it in the browser. The page will reload if you make edits. You will also see any lint or nextjs develop errors in the console.

  • npm run build

    Builds the app for production to the build folder.It correctly bundles React in production mode and optimizes the build for the best performance.

    The build is minified and the filenames include the hashes. Your app is ready to be deployed!

    See the section about deployment for more information.

  • npm format

    Formats the app files like js, jsx, json, and md using Prettier. You can learn more about the format here.

Note: pwa-asset-generator tool is used to generate the below PWA assets. You can learn more about this tool here.

  • npx pwa-asset-generator ./public/logo.png ./public --icon-only --favicon --opaque false --maskable false --type png

    Generates favicons and place them in the public directory.

  • npx pwa-asset-generator ./public/logo.png ./public/light --splash-only --background lightgray --type jpeg --quality 80

    Generates splash images needed for apple devices with a light background and place them in the public/light directory.

  • npx pwa-asset-generator ./public/logo.png ./public/dark --splash-only --background 'rgba(51,51,51, 1)' --type jpeg --quality 80

    Generates splash images needed for apple devices with a dark background and place them in the public/dark directory.

πŸ™Œ Contribution

  • Open pull request with improvements.
  • If you have any new idea, check the feature request template to create a request.
  • If you found any issue or a bug, check the bug report template to create a report.

πŸ“ƒ License

Have a look at the license file for details

πŸ“§ Contact

Whether you’d like to discuss about this application or simply say β€œhello”, I’d love to hear from you.

Email: contact@iamsainikhil.com