Created
          July 21, 2024 08:24 
        
      - 
      
- 
        Save zhiephie/9a3363d63ccc5d06cc326478a1697a09 to your computer and use it in GitHub Desktop. 
    Delete all Google Photos from console
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | const maxCount = 500; | |
| const counterSelector = '.rtExYb'; | |
| const checkboxSelector = '.ckGgle[aria-checked=false]'; | |
| const photoDivSelector = ".yDSiEe.uGCjIb.zcLWac.eejsDc.TWmIyd"; | |
| const deleteButtonSelector = 'button[aria-label="Hapus"]'; | |
| const confirmationButtonSelector = "#yDmH0d > div.VfPpkd-Sx9Kwc.cC1eCc.UDxLd.PzCPDd.V639qd.oEOLpc.A9Uzve.VfPpkd-Sx9Kwc-OWXEXe-FNFY6c > div.VfPpkd-wzTsW.O4g5Md.iWO5td > div > div.VfPpkd-cnG4Wd.m5OsGf > div > div.VfPpkd-T0kwCb.IdSMxc > button.VfPpkd-LgbsSe.VfPpkd-LgbsSe-OWXEXe-k8QpJ.nCP5yc.AjY5Oe.LQeN7.kDryjd"; | |
| async function deleteGooglePhotos() { | |
| // Retrieves the current count of selected photos | |
| const getCount = () => { | |
| const counterElement = document.querySelector(counterSelector); | |
| return counterElement ? parseInt(counterElement.textContent) || 0 : 0; | |
| }; | |
| // Waits for a specified time | |
| const wait = (milliseconds) => new Promise(resolve => setTimeout(resolve, milliseconds)); | |
| // Scrolls the photo list down | |
| const scrollPhotoList = async () => { | |
| let photoDiv = document.querySelector(photoDivSelector) | |
| let top = photoDiv.scrollTop; | |
| await waitUntil(() => { | |
| photoDiv.scrollBy(0, photoDiv.clientHeight); | |
| return photoDiv.scrollTop > top; | |
| }); | |
| }; | |
| // Scrolls the photo list to the top | |
| const scrollPhotoListTo = (top = 0) => { | |
| document.querySelector(photoDivSelector).scrollTop = top; | |
| }; | |
| // Scrolls the photo list to the top | |
| const scrollPhotoListBy = async (height = 0) => { | |
| const photoDiv = document.querySelector(photoDivSelector); | |
| await waitUntil(() => { | |
| const top = photoDiv.scrollTop; | |
| photoDiv.scrollBy(0, height); | |
| return waitUntil(() => document.querySelector(checkboxSelector), 500).catch(() => null) | |
| }); | |
| }; | |
| // Waits until a specific condition is met, then returns the result | |
| const waitUntil = async (resultFunction, timeout = 600000) => { | |
| let startTime = Date.now(); | |
| while (Date.now() - startTime < timeout) { | |
| let result = await resultFunction(); | |
| if (result) return result; | |
| await wait(300); | |
| } | |
| throw new Error("Timeout reached"); | |
| }; | |
| // Handles the deletion of selected photos | |
| const deleteSelected = async () => { | |
| let count = getCount(); | |
| if (count <= 0) return; | |
| console.log("Deleting " + count); | |
| const deleteButton = document.querySelector(deleteButtonSelector); | |
| deleteButton.click(); | |
| const confirmation_button = await waitUntil(() => document.querySelector(confirmationButtonSelector)); | |
| confirmation_button.click(); | |
| await waitUntil(() => getCount() === 0); | |
| scrollPhotoListTo(0); | |
| }; | |
| // Main loop to select and delete photos | |
| while (true) { | |
| try { | |
| const checkboxes = await waitUntil( | |
| () => { | |
| const selectors = document.querySelectorAll(checkboxSelector) | |
| return selectors.length > 0 ? [...document.querySelectorAll(checkboxSelector)] : null | |
| } | |
| ); | |
| let count = getCount(); | |
| let targetCheckboxes = checkboxes.slice(0, maxCount - count); | |
| targetCheckboxes.forEach(x => x.click()); | |
| await wait(200); | |
| count = getCount(); | |
| console.log("Selected " + count); | |
| if (count >= maxCount) { | |
| await deleteSelected(); | |
| } else { | |
| let rect = targetCheckboxes[targetCheckboxes.length - 1].getBoundingClientRect(); | |
| let height = rect.top; | |
| await scrollPhotoListBy(height); | |
| } | |
| } catch (e) { | |
| console.log(e); | |
| break; // Break out of the loop if a timeout occurs | |
| } | |
| } | |
| // Final deletion for any remaining photos | |
| await deleteSelected(); | |
| console.log('End of deletion process'); | |
| } | |
| await deleteGooglePhotos(); | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
English
change this
const deleteButtonSelector = 'button[aria-label="Hapus"]';toconst deleteButtonSelector = 'button[aria-label="Delete"]';