Implement custom video controls with play/pause and seek functionality
This commit is contained in:
		@@ -116,6 +116,41 @@
 | 
				
			|||||||
		#video-overlay-container #back-button.button-hidden {
 | 
							#video-overlay-container #back-button.button-hidden {
 | 
				
			||||||
			opacity: 0; /* Class to hide the button */
 | 
								opacity: 0; /* Class to hide the button */
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							#custom-video-controls {
 | 
				
			||||||
 | 
								position: absolute;
 | 
				
			||||||
 | 
								bottom: 0;
 | 
				
			||||||
 | 
								left: 0;
 | 
				
			||||||
 | 
								width: 100%;
 | 
				
			||||||
 | 
								padding: 10px;
 | 
				
			||||||
 | 
								background-color: rgba(0, 0, 0, 0.5);
 | 
				
			||||||
 | 
								display: flex;
 | 
				
			||||||
 | 
								align-items: center;
 | 
				
			||||||
 | 
								z-index: 1; /* Above video, but below back button if it were in the same direct stacking context */
 | 
				
			||||||
 | 
								opacity: 1;
 | 
				
			||||||
 | 
								transition: opacity 0.3s ease-in-out;
 | 
				
			||||||
 | 
								box-sizing: border-box;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							#custom-video-controls.controls-hidden {
 | 
				
			||||||
 | 
								opacity: 0;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							#custom-play-pause-button {
 | 
				
			||||||
 | 
								background: none;
 | 
				
			||||||
 | 
								border: none;
 | 
				
			||||||
 | 
								color: white;
 | 
				
			||||||
 | 
								font-size: 1.5em; /* Adjust size as needed */
 | 
				
			||||||
 | 
								cursor: pointer;
 | 
				
			||||||
 | 
								padding: 5px 10px;
 | 
				
			||||||
 | 
								margin-right: 10px;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							#custom-seek-bar {
 | 
				
			||||||
 | 
								flex-grow: 1;
 | 
				
			||||||
 | 
								cursor: pointer;
 | 
				
			||||||
 | 
								accent-color: #3498db; /* Optional: color for the seek bar thumb and progress */
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	</style>
 | 
						</style>
 | 
				
			||||||
	<script>
 | 
						<script>
 | 
				
			||||||
		function hideLoader() {
 | 
							function hideLoader() {
 | 
				
			||||||
@@ -146,7 +181,7 @@
 | 
				
			|||||||
						let overlayContainer = $("<div id='video-overlay-container'></div>").appendTo("body");
 | 
											let overlayContainer = $("<div id='video-overlay-container'></div>").appendTo("body");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
						// Create video element and append to container
 | 
											// Create video element and append to container
 | 
				
			||||||
						let videoElement = $("<video controls autoplay class='video-player'></video>")
 | 
											let videoElement = $("<video autoplay class='video-player'></video>") // Removed 'controls' attribute
 | 
				
			||||||
											.attr("src", currentVideo.url)
 | 
																.attr("src", currentVideo.url)
 | 
				
			||||||
											.appendTo(overlayContainer)[0];
 | 
																.appendTo(overlayContainer)[0];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -154,22 +189,61 @@
 | 
				
			|||||||
						let backButton = $("<button id='back-button'>Back</button>")
 | 
											let backButton = $("<button id='back-button'>Back</button>")
 | 
				
			||||||
											.appendTo(overlayContainer);
 | 
																.appendTo(overlayContainer);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
						// Mouse inactivity logic for back button
 | 
											// Create custom video controls container
 | 
				
			||||||
 | 
											let customControls = $("<div id='custom-video-controls'></div>").appendTo(overlayContainer);
 | 
				
			||||||
 | 
											let playPauseButton = $("<button id='custom-play-pause-button'>❚❚</button>").appendTo(customControls); // Initial state: Pause icon
 | 
				
			||||||
 | 
											let seekBar = $("<input type='range' id='custom-seek-bar' value='0' />").appendTo(customControls);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
											// Mouse inactivity logic for back button, controls, and cursor
 | 
				
			||||||
						let inactivityTimer;
 | 
											let inactivityTimer;
 | 
				
			||||||
						function showButtonAndResetTimer() {
 | 
											function showControlsAndResetTimer() {
 | 
				
			||||||
							backButton.removeClass('button-hidden');
 | 
												backButton.removeClass('button-hidden');
 | 
				
			||||||
 | 
												customControls.removeClass('controls-hidden');
 | 
				
			||||||
							overlayContainer.css('cursor', 'default'); // Show cursor
 | 
												overlayContainer.css('cursor', 'default'); // Show cursor
 | 
				
			||||||
							clearTimeout(inactivityTimer);
 | 
												clearTimeout(inactivityTimer);
 | 
				
			||||||
							inactivityTimer = setTimeout(function() {
 | 
												inactivityTimer = setTimeout(function() {
 | 
				
			||||||
								backButton.addClass('button-hidden');
 | 
													backButton.addClass('button-hidden');
 | 
				
			||||||
 | 
													customControls.addClass('controls-hidden');
 | 
				
			||||||
								overlayContainer.css('cursor', 'none'); // Hide cursor
 | 
													overlayContainer.css('cursor', 'none'); // Hide cursor
 | 
				
			||||||
							}, 3000); // 3 seconds
 | 
												}, 3000); // 3 seconds
 | 
				
			||||||
						}
 | 
											}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
						overlayContainer.on('mousemove.inactivityControls', function() {
 | 
											overlayContainer.on('mousemove.inactivityControls', function() {
 | 
				
			||||||
							showButtonAndResetTimer();
 | 
												showControlsAndResetTimer();
 | 
				
			||||||
						});
 | 
											});
 | 
				
			||||||
						showButtonAndResetTimer(); // Initial call to show and start timer
 | 
											showControlsAndResetTimer(); // Initial call
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
											// Custom Controls Logic
 | 
				
			||||||
 | 
											// Play/Pause Button
 | 
				
			||||||
 | 
											playPauseButton.click(function() {
 | 
				
			||||||
 | 
												if (videoElement.paused) {
 | 
				
			||||||
 | 
													videoElement.play();
 | 
				
			||||||
 | 
												} else {
 | 
				
			||||||
 | 
													videoElement.pause();
 | 
				
			||||||
 | 
												}
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
											$(videoElement).on('play', function() {
 | 
				
			||||||
 | 
												playPauseButton.text('❚❚'); // Pause icon
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
											$(videoElement).on('pause', function() {
 | 
				
			||||||
 | 
												playPauseButton.text('►'); // Play icon
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
											// Seek Bar
 | 
				
			||||||
 | 
											$(videoElement).on('loadedmetadata', function() {
 | 
				
			||||||
 | 
												seekBar.attr('max', videoElement.duration);
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
											$(videoElement).on('timeupdate', function() {
 | 
				
			||||||
 | 
												seekBar.val(videoElement.currentTime);
 | 
				
			||||||
 | 
												// Optional: Update seek bar background to show progress
 | 
				
			||||||
 | 
												const percentage = (videoElement.currentTime / videoElement.duration) * 100;
 | 
				
			||||||
 | 
												seekBar.css('background', `linear-gradient(to right, #3498db ${percentage}%, #555 ${percentage}%)`);
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
											seekBar.on('input', function() {
 | 
				
			||||||
 | 
												videoElement.currentTime = $(this).val();
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
						// Request fullscreen on the container
 | 
											// Request fullscreen on the container
 | 
				
			||||||
						const containerEl = overlayContainer[0];
 | 
											const containerEl = overlayContainer[0];
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user