Created
March 31, 2024 23:25
-
-
Save auchenberg/d5347fa4c9833ede4b3f2032855e9583 to your computer and use it in GitHub Desktop.
Script to delete all Google Photos from console (2024)
This file contains 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="Delete"]'; | |
const confirmationButtonSelector = '#yDmH0d > div.VfPpkd-Sx9Kwc.cC1eCc.UDxLd.PzCPDd.V639qd.bvQPzd.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(); |
Thanks working selection
Works great! Before using this script, I recommend going to site settings and blocking images from loading to improve performance.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
This should be the new confirmationButton selecor in line 6:
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";