basic impl

This commit is contained in:
setop 2024-10-24 14:16:52 +02:00
commit 876a5b5928
4 changed files with 74 additions and 0 deletions

24
README.md Normal file
View File

@ -0,0 +1,24 @@
This is a Firefox Addon that allows to create a ["Text Fragment"](https://developer.mozilla.org/en-US/docs/Web/URI/Fragment/Text_fragments#:%7E:text=Text%20fragments%20allow%20linking%20directly%20to%20a%20specific%20portion%20of%20text%20in%20a%20web%20document) link for the context menu.
# installation
* git clone or export this repo
* go to page "about:debugging#/runtime/this-firefox" (or "about:debugging" then click "This Firefox")
* click on "Load Temporary Add-on…"
* select "manifest.json" file
# usage
* select a text in a document,
* right clic to have contextual menu,
* choose "text fragment" entry
* paste the link in an address bar or in a mail or in a chat
# limitation
* not packaged, only debug mode yet
* on the plus side, the code is so simple that you can see it won't stab you in the back
* tested only on Firefox
* the other, most popular, web browser is on the evil side for a long time now

20
background.js Normal file
View File

@ -0,0 +1,20 @@
browser.contextMenus.create({
id: "text-fragment",
title: "Text Fragment",
contexts: ["selection"]
});
browser.contextMenus.onClicked.addListener((info) => {
if (info.menuItemId === "text-fragment") {
const selectedText = encodeURIComponent(info.selectionText);
const pageUrl = info.pageUrl.split('#')[0]; // Remove existing fragment, if any
const textToCopy = `${pageUrl}#:~:text=${selectedText}`;
navigator.clipboard.writeText(textToCopy).then(() => {
console.log("Text copied to clipboard");
}).catch(err => {
console.error("Could not copy text: ", err);
});
}
});

10
icon.svg Normal file
View File

@ -0,0 +1,10 @@
<svg xmlns="http://www.w3.org/2000/svg" width="128" height="128" viewBox="0 0 16 16" fill="#0a84ff" opacity="0.98">
<g transform="rotate(90 8 8)">
<rect x="7" y="3.286" width="2" height="9.429" rx="1" ry="1" transform="rotate(-45 8 8)"/>
<path d="M2.354 4.522L4.485 2.39a.5.5 0 0 1 .711 0l3.19 3.19.014-.015a2 2 0 0 0 0-2.821L6.272.616a2 2 0 0 0-2.821 0L.616 3.451a2 2 0 0 0 0 2.821L2.744 8.4a1.993 1.993 0 0 0 2.8.02l-3.19-3.186a.5.5 0 0 1 0-.712z"/>
<path d="M15.416 9.759L13.287 7.63a2 2 0 0 0-2.821 0l-.015.015 3.189 3.189a.5.5 0 0 1 0 .711l-2.132 2.132a.5.5 0 0 1-.711 0L7.61 10.49a1.993 1.993 0 0 0 .02 2.8l2.128 2.128a2 2 0 0 0 2.821 0l2.835-2.835a2 2 0 0 0 .002-2.824z"/>
</g>
<g stroke="#737373" stroke-width="4" transform="scale(0.5) translate(18 18)">
<path transform="scale(0.667)" d="M10 19H12M12 19H14M12 19V5M12 5H6V6M12 5H18V6" stroke-linecap="round"/>
</g>
</svg>

After

Width:  |  Height:  |  Size: 929 B

20
manifest.json Normal file
View File

@ -0,0 +1,20 @@
{
"manifest_version": 2,
"name": "Text Fragment Copier",
"version": "1.0",
"permissions": [
"contextMenus",
"clipboardWrite",
"activeTab"
],
"background": {
"scripts": ["background.js"]
},
"icons": {
"32": "icon.svg",
"48": "icon.svg",
"64": "icon.svg",
"96": "icon.svg",
"128": "icon.svg"
}
}