Youtube auto jumper tutorial
https://youtu.be/2zfVeA279d0
From: 【歌回】響到什麼唱什麼|響Hibiki
Owner: @HibikiVtuber
This project is a Chrome extension designed to enhance YouTube's playlist management capabilities. The extension provides functionalities such as creating, editing, importing, exporting, and playing custom playlists directly within the YouTube interface.
- Dark Theme Detection: Automatically apply the correct CSS theme based on YouTube's dark or light theme.
- Playlist Management: Add, edit, and delete items in your custom playlists.
- Video Info Retrieval: Get the current video ID and playtime.
- State Management: Synchronize and update the playlist state with the background script.
- User Interaction: Enable editable text fields and handle drag-and-drop for playlist items.
- move sync to local
- Single Playback: Now you can play song separately and this also benefit you to edit playlist. (By the toggle switch or ctrl + left click)
- You can set the default add time now. (If the end time doesn't exist.)
Chrome store link
Firefox store link
- Clone the repository.
- Navigate to
chrome://extensions/
in your Chrome browser. - Enable "Developer mode".
- Click "Load unpacked" and select the cloned repository folder.
- Navigate to a YouTube video.
- Use the playlist management buttons to create and manage your playlists.
- Drag and drop items to rearrange them.
- Import or export playlists using the provided buttons to share your playlists with others.
Handles runtime messages and manages the state of the extension (on/off) and playlist initialization. It also handles messages to start playing the playlist.
- Functions:
handleRuntimeMessage(request, sender, sendResponse, context)
: Main function to process incoming messages and take appropriate actions.
Sends the current playlist state to the background script for persistence.
- Functions:
sendPlaylistStateToBackground(nowPlaylistState)
: Sends the current playlist state tobackground.js
.
Provides functions to retrieve information about the current YouTube video.
- Functions:
getCurrentVideoId()
: Retrieves the current video ID from the URL.getCurrentVideoTime()
: Retrieves the current playback time of the video and converts it to aTimeSlot
object.
Enables editing mode for playlist items and handles save and cancel actions.
- Functions:
enableEditMode(editableElement, playlistState, playlistTimeManager)
: Enables editing mode for a given element.handleBlur(editableElement, originalAttr, playlistState, playlistTimeManager)
: Handles actions when an editable element loses focus.handleKeydown(event, editableElement, originalText)
: Handles keydown events to save or cancel edits.
Applies the appropriate CSS theme based on YouTube's current theme.
- Functions:
isYouTubeDarkTheme()
: Checks if YouTube is in dark mode.applyTheme()
: Applies the dark or light theme CSS classes to the document body.
Contains data classes to manage playlist items and states.
- Classes:
TimeSlot
: Represents a time slot with hours, minutes, and seconds.PlaylistItem
: Represents a playlist item with start time, end time, and title.PlaylistState
: Manages the state of the playlist.
Handles drag-and-drop operations for playlist items.
- Classes:
MouseEventHandler
: Manages the drag-and-drop events and updates the playlist state.
Provides utility functions and classes for managing playlists and time slots.
- Classes:
PlaylistTimeManager
: Manages playlist time slots and ensures start times do not exceed end times.
- Functions:
equalsCheck(a, b)
: Checks if two objects are equal.getandUpdatePlaylistState(sharedState)
: Retrieves and updates the current playlist state.
Creates and manages UI components for the extension.
- Functions:
createPlaylistContainer(videoId)
: Creates a container for the playlist.createButtonContainer()
: Creates a container for action buttons.createImportExportContainer()
: Creates a container for import/export buttons.createPlaylistItemsContainer()
: Creates a container for playlist items.createTimeTextElements(startTime, endTime)
: Creates start and end time text elements.createAddToPlaylistButton()
: Creates an "Add to Playlist" button.createImportPlaylistButton(importPlaylistFromText)
: Creates an "Import Playlist" button.createExportPlaylistButton(exportPlaylist)
: Creates an "Export Playlist" button.createPlayButton()
: Creates a "Play Playlist" button.createPopupTextBox(title, onSave)
: Creates a popup text box for user input.
Controls the playback of the custom playlist.
- Functions:
playPlaylist(startIndex, sendResponse, tabId)
: Plays the playlist starting from the specified index.stopCurrentPlayback()
: Stops the current video playback.updateStyles(item, add)
: Updates the styles of the current playing item.
Manages the background operations of the extension, including communication with content scripts and handling state changes.
- Listeners:
chrome.runtime.onInstalled.addListener
: Initializes the extension state upon installation.chrome.action.onClicked.addListener
: Toggles the extension on/off state.chrome.runtime.onMessage.addListener
: Handles messages for updating playlist state and controlling playback.chrome.tabs.onUpdated.addListener
: Initializes the playlist when a YouTube tab is updated.chrome.tabs.onRemoved.addListener
: Cleans up state when a tab is closed.
Handles the content script operations, including injecting UI components, handling user interactions, and communicating with the background script.
- Modules Loaded:
dataclass.js
,playlistTool.js
,mouseEventHandler.js
,ui.js
,theme.js
,runtimeHandler.js
,editModule.js
,getVideoInfo.js
- Functions:
appstart()
: Starts the application by initializing UI components.initializePlaylist(sidebarElm)
: Initializes the playlist in the YouTube sidebar.addToPlaylist()
: Adds a new item to the playlist.createPlaylistItem(startTime, endTime, title)
: Creates a new playlist item element.playPlaylist(startIndex)
: Sends a message to start playing the playlist from a specified index.importPlaylistFromText()
: Imports a playlist from a text input.exportPlaylist()
: Exports the playlist to a text output.
Contributions are welcome! Please open an issue or submit a pull request with your changes.
This project is licensed under the MIT License. See the LICENSE file for details.