Last active
June 16, 2024 16:40
-
-
Save ttscoff/5834741 to your computer and use it in GitHub Desktop.
Create a bookmark and paste the code from `grab links.bookmarklet` into the url. Trigger it on a page containing links you want to save and then click the section of the page containing the links. A Markdown list of all links will be generated, and clicking the resulting list will select all for copying.
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
javascript:(function(){var p=document.createElement("p");p.innerHTML="<strong>Loading…</strong>";p.id="loadingp";p.style.padding="20px";p.style.background="#fff";p.style.left="20px";p.style.top=0;p.style.position="fixed";p.style.zIndex="9999999";p.style.opacity=".85";document.body.appendChild(p);document.body.appendChild(document.createElement("script")).src="https://gist.github.com/ttscoff/5834741/raw/grablinks.js?x="+(Math.random());})(); |
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
// version 2.2 | |
// Updated jQuery to stable head | |
// removed padding changes on hover, too messy | |
// avoid Tweet This, ADN and Facebook Share links | |
// version 2.1 | |
// | |
// Fixed jQuery injection | |
// version 2.0 | |
// | |
// no repeated urls | |
// handle relative links and local hashes better | |
// better handling of title attributes | |
// add origin link at top of output | |
// don't force selection on click, allow copying individual parts | |
// add a close button | |
// truncate long titles at 50 chars | |
// Do a better job of incrementing/decrementing padding | |
(function () { | |
function callback() { | |
(function ($) { | |
var jQuery = $; | |
$("#loadingp").fadeOut("fast", function () { | |
$(this).remove(); | |
}); | |
var selectLinks = function () { | |
var doc = document, | |
text = doc.getElementById("linkoutput"), | |
range, selection; | |
if (doc.body.createTextRange) { | |
range = doc.body.createTextRange(); | |
range.moveToElementText(text); | |
range.select(); | |
} else if (window.getSelection) { | |
selection = window.getSelection(); | |
range = doc.createRange(); | |
range.selectNodeContents(text); | |
selection.removeAllRanges(); | |
selection.addRange(range); | |
} | |
}, collection = []; | |
$("div,table,article,section,aside").on("mouseover mouseout click", function (a) { | |
a.stopPropagation(); | |
a.type === "mouseover" ? $(this).css({ | |
outline: "1px solid rgb(194, 130, 148)" | |
}).addClass("mkhovered") : $("div,table,article,section,aside").css({ | |
outline: "none" | |
}).removeClass("mkhovered"); | |
if (a.type === "click") { | |
a.preventDefault(); | |
$(".mkhovered").css({ | |
outline: "none" | |
}).removeClass("mkhovered"); | |
var i, url, linkText, norepeat = [], | |
linkage = $(this).find("a"), | |
avoidUrls = ["twitter\\.com\\/intent","www\\.facebook\\.com\\/dialog","alpha\\.app\\.net\\/intent"]; | |
linkage.each(function (i, link) { | |
var $link = $(link); | |
var parser = document.createElement("a"); | |
parser.href = $link.attr("href"); | |
for (i in avoidUrls) { | |
var re = new RegExp(avoidUrls[i]); | |
if (re.test(parser.href)) { | |
return false; | |
} | |
} | |
if ($.inArray(parser.href, norepeat) === -1) { | |
console.log(parser.href); | |
norepeat.push(parser.href); | |
if ($link.attr("title") && $link.attr("title").length > 3) { | |
linkText = $link.attr("title"); | |
} else { | |
if ($link.text() === undefined || $link.text().length < 4) { | |
if (document.location.hostname === parser.hostname && parser.hash !== "") { | |
linkText = parser.hash; | |
} else { | |
linkText = parser.href; | |
} | |
} else { | |
linkText = $link.text(); | |
} | |
} | |
collection.push(["- [" + linkText.replace(/[\n\r\s]+/g, " ").replace(/(^\s*|\s*$)/g, "").slice(0, 50).replace(/[\[\]\|]+/g, "") + "](" + parser.href + ")"]); | |
} | |
}); | |
$("<div>").css({ | |
position: "fixed", | |
top: "0", | |
left: "0", | |
right: "0", | |
bottom: "0", | |
overflow: "auto", | |
backgroundColor: "#efefef", | |
color: "#333", | |
zIndex: "99999", | |
fontFamily: "menlo, courier, monospace" | |
}).append($("<pre id=linkoutput>").css({ | |
padding: "20px", | |
margin: "40px", | |
textAlign: "left" | |
}).text("Collected from: [" + document.title.replace(/[\r\n]+/, "") + "](" + document.location.href + ")\n\n\n" + collection.join("\n"))).append($("<a href=#>Click here to close</a>").css({ | |
display: "block", | |
padding: "10px", | |
color: "#fff", | |
fontSize: "16px", | |
background: "rgba(194, 56, 96, 1)", | |
margin: "0 auto", | |
width: "220px", | |
textAlign: "center", | |
borderRadius: "10px", | |
fontFamily: "Helvetica, Arial, sans-serif", | |
fontWeight: "bold", | |
}).click(function (ev) { | |
$(this).closest("div").remove(); | |
$("div,table,article,section,aside").unbind(); | |
})).appendTo("body"); | |
selectLinks(); | |
return false; | |
} | |
}) | |
})(jQuery.noConflict(true)) | |
} | |
var s = document.createElement("script"); | |
s.src = "https://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"; | |
if (s.addEventListener) { | |
s.addEventListener("load", callback, false) | |
} else if (s.readyState) { | |
s.onreadystatechange = callback | |
} | |
document.body.appendChild(s); | |
})() |
Is not working on youtube.
Tried to grap some link out of the video description section.
https://www.youtube.com/watch?v=pZT-FZqfxZA for testing.
Under Chrome + Mac 10.10.5
Hope issue is reproducible.
This doesnt appear to be working on https://sgpokemap.com/quest.html? any work around to grab the google maps links from this google embeddded map?
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Unfortunately the bookmarklet does not work as expected with https://www.youtube.com/channel/UCltBAWC_VcLQp9ySf7dHyDQ/feed# (with Safari): all link titles are empty!