function extractFilename(url) try const urlObj = new URL(url); let filename = urlObj.pathname.split('/').pop(); if (!filename.includes('.')) filename += '.mp4'; if (filename.length > 50) filename = filename.substring(0, 50) + '.mp4'; return decodeURIComponent(filename); catch(e) return 'sharepoint_video.mp4';
); ); );
<!DOCTYPE html> <html> <head> <style> body width: 350px; padding: 15px; font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; h3 margin: 0 0 10px 0; color: #0078d4; button background: #0078d4; color: white; border: none; padding: 10px; width: 100%; cursor: pointer; border-radius: 4px; font-size: 14px; margin: 5px 0; button:hover background: #005a9e; #videoList max-height: 300px; overflow-y: auto; margin: 10px 0; .video-item background: #f3f2f1; margin: 5px 0; padding: 8px; border-radius: 4px; font-size: 12px; word-break: break-all; .download-btn background: #107c10; margin-top: 5px; padding: 5px; font-size: 11px; .status font-size: 12px; color: #666; margin: 5px 0; </style> </head> <body> <h3>📹 SharePoint Video Downloader</h3> <button id="scanVideos">🔍 Scan for Videos</button> <div id="videoList"></div> <div id="status" class="status"></div> <script src="popup.js"></script> </body> </html> 3. popup.js document.getElementById('scanVideos').addEventListener('click', () => const statusDiv = document.getElementById('status'); statusDiv.textContent = 'Scanning for videos...'; chrome.tabs.query(active: true, currentWindow: true, (tabs) => chrome.tabs.sendMessage(tabs[0].id, action: "scanVideos", (response) => if (response && response.videos) displayVideos(response.videos); statusDiv.textContent = Found $response.videos.length video(s) ; else statusDiv.textContent = 'No videos found on this page'; download sharepoint video chrome extension
// Monitor network requests for video files const observer = new PerformanceObserver((list) => list.getEntries().forEach((entry) => entry.name.includes('video')) console.log('Video detected:', entry.name); ); ); observer.observe(entryTypes: ['resource']); This extension provides a solid foundation for downloading SharePoint videos. Remember to respect copyright and your organization's policies when downloading content. // Method 3: Find video links in iframes
// Method 3: Find video links in iframes const iframes = document.querySelectorAll('iframe'); iframes.forEach(iframe => iframe.src.includes('streaming'))) videos.push( url: iframe.src, filename: 'sharepoint_stream_video.mp4' ); filename: 'sharepoint_stream_video.mp4' )
// Add download event listeners document.querySelectorAll('.download-btn').forEach(btn => btn.addEventListener('click', (e) => ); );