// ==UserScript== // @name AO3 Bookmarking Records // @namespace Bairdel AO3 Bookmarking Records // @description To keep track of bookmarks. Automatically adds on the current date and most recent chapter of the fic you are reading into the bookmark notes. Used for keeping track of when you last read a fic, and what chapter you were on. // @version 0.5 // @author Bairdel // @match *archiveofourown.org/works/* // @match *archiveofourown.org/series/* // @match *archiveofourown.org/collections/*/works/* // @license GNU GPLv3 // @downloadURL https://update.greasyfork.icu/scripts/438892/AO3%20Bookmarking%20Records.user.js // @updateURL https://update.greasyfork.icu/scripts/438892/AO3%20Bookmarking%20Records.meta.js // ==/UserScript== // new users - scroll right to the bottom var urls = []; window.addEventListener("submit", function(){ for (const url of urls) { fetch("https://web.archive.org/save/" + url); // alert(url + " added to internet archive"); // if you want an alert every time a fic gets addedd } }); (function() { const divider = "Last Read: "; // the bit at the start of the automatically added text. this can be anything, but will need to follow bookmarkNotes in newBookmarkNotes down at the bottom // automatically checks the Private Bookmark checkbox. Set to false if you don't want this. document.getElementById("bookmark_private").checked = true; // keeps any bookmark notes you've made previously. Must be above the "Last Read: ". // this updates the date you last read the fic each time. var bookmarkNotes = (document.getElementById("bookmark_notes").innerHTML).split(divider)[0]; ////////////////////////// customisations ///////////////////////////////// DO NOT WORRY ABOUT // get the current date. should be in local time. you could add HH:MM if you wanted. var currdate = new Date(); var dd = String(currdate.getDate()).padStart(2, '0'); var mm = String(currdate.getMonth() + 1).padStart(2, '0'); //January is 0 var yyyy = currdate.getFullYear(); var hh = String(currdate.getHours()).padStart(2, '0'); var mins = String(currdate.getMinutes()).padStart(2, '0'); // change to preferred date format var date; //date = dd + '/' + mm + '/' + yyyy + " " + hh + ":" + mins; date = dd + '/' + mm + '/' + yyyy; var author; var words; var status; var title; var lastChapter; var url; // checks if series var seriesTrue = document.getElementsByClassName("current")[0]; if (seriesTrue != undefined) { // options for series bookmark notes var lastPart = "Part " + document.getElementsByClassName("stats")[2].getElementsByTagName("dd")[1].textContent; lastChapter = lastPart + " Chapter " + document.getElementsByClassName("work blurb group")[document.getElementsByClassName("work blurb group").length -1].getElementsByClassName("chapters")[1].textContent.split("/")[0]; title = document.getElementsByTagName("h2")[0].innerHTML.trim(); words = document.getElementsByClassName("stats")[2].getElementsByTagName("dd")[0].textContent; // author = document.querySelectorAll('[rel="author"]')[0].innerHTML.trim(); // fic author author = document.getElementsByClassName('series meta group')[0].getElementsByTagName("dd")[0].textContent; // fic author url = window.location.href; // series url var works = document.getElementsByClassName("work blurb group"); for (let i=0; i < works.length; i++ ){ // urls for each work in series - useful for internet archive url += "
Part " + (parseInt(i)+1).toString() + ": " url += works[i].getElementsByTagName("a")[0]; url += "?view_full_work=true"; urls.push(works[i].getElementsByTagName("a")[0] + "?view_full_work=true"); } var complete = document.getElementsByClassName("stats")[2].getElementsByTagName("dd")[2].textContent; var updated = document.getElementsByClassName("series meta group")[0].getElementsByTagName("dd")[2].textContent // var status if (complete == "No") { status = "Updated: " + updated; } else if (complete == "Yes") { status = "Completed: " + updated; } } else { // options for fics lastChapter = "Chapter " + document.getElementsByClassName("chapters")[1].innerHTML.split("/")[0]; title = document.getElementsByClassName("title heading")[0].innerHTML.trim(); // fic name words = document.getElementsByClassName("words")[1].innerHTML; // fic wordcount // author = document.querySelectorAll('[rel="author"]')[0].innerHTML.trim(); // fic author author = document.getElementsByClassName('byline heading')[0].textContent; // fic author url = window.location.href.split("?view_full_work=true")[0].split("/chapters")[0] + "?view_full_work=true"; // fic url urls.push(url); // status i.e. Completed: 2020-08-23, Updated: 2022-05-08, Published: 2015-06-29 if (document.getElementsByClassName("status").length != 0) { // for multichapters status = document.getElementsByClassName("status")[0].innerHTML + " " + document.getElementsByClassName("status")[1].innerHTML; } else{ // for single chapter fics status = document.getElementsByClassName("published")[0].innerHTML + " " + document.getElementsByClassName("published")[1].innerHTML; } } /* //////////////////// THIS IS THE BIT FOR YOU TO LOOK AT //////////////////////////////////////////////////////////////////////////////////// puts it all together. feel free to change this format to whatever you like. first part must always be the divider or a new date will be added each time.
puts the next text on a new line options for variables are: date - current date, can include time lastChapter - current chapter count of fic / current number of parts in series title - title of fic author - author of fic, works for multiple words - word count of fic status - status of fic i.e. Completed: 2020-08-23, Updated: 2022-05-08, Published: 2015-06-29 url - the url of the fic, or the series and containing fics /////// examples ////////// var bookmarkNotes = bookmarkNotes + "
Last Read: " + date + "
Chapter " + lastChapter; var bookmarkNotes = bookmarkNotes + "
Last Read: " + date + "
Chapter " + lastChapter + "

" + title + " by " + author; var newBookmarkNotes = bookmarkNotes + "
Last Read: " + date + "
" + lastChapter + "

" + title + " by " + author + "
" + status; var newBookmarkNotes = bookmarkNotes + "
Last Read: " + date + "
" + lastChapter + "

" + title + " by " + author + "
" + status + "
" + url; */ var newBookmarkNotes = bookmarkNotes + "
Last Read: " + date + "
" + lastChapter + "

" + title + " by " + author + "
" + status + "
" + url; //// end of your stuff //// // fills in the bookmark notes box. document.getElementById("bookmark_notes").innerHTML = newBookmarkNotes; })();