-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathApplyAnnotations.user.js
89 lines (86 loc) · 4.31 KB
/
ApplyAnnotations.user.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// ==UserScript==
// @name ApplyAnnotations
// @description Extremely simple Web Annotation client
// @author David M. Weigl
// @homepageURL https://github.com/musicog/ApplyAnnotations
// @version 1
// @run-at document-idle
// @include http://yasgui.org/*
// @include https://yasgui.org/*
// @include http://linkeddata.uni-muenster.de:7200/sparql
// @require http://www.verovio.org/javascript/latest/verovio-toolkit.js
// ==/UserScript==
function fetchAndApply() {
const theUri = document.getElementById('__applyannotations_userscript_url_input').value;
// GET the content at the specified URI, as JSON-LD
fetch(theUri, { headers: { "Accept": "application/ld+json"} }).then((response) => {
// read out the json inside
response.json().then( (annotations) => {
// for each annotation we find
annotations.map( (anno) => {
// assuming it has at least one target (it ought to...)
if("http://www.w3.org/ns/oa#hasTarget" in anno) {
// iterate over each target
anno["http://www.w3.org/ns/oa#hasTarget"].map((target) => {
// motivation tells us what to do with the target
const motivations = anno["http://www.w3.org/ns/oa#motivatedBy"] || [];
// expect the target ID to end in a fragment identifier (e.g. #note-12345)
const targetId = target["@id"]
const fragment = targetId.substr(targetId.lastIndexOf("#"))
// any annotation bodies... (might be none)
const bodies = anno["http://www.w3.org/ns/oa#hasBody"] || [];
// the target DOM element
const element = document.querySelector(fragment);
motivations.map((motivation) => {
// now do stuff to the target element, according to the annotation's motivation
switch(motivation["@id"]) {
case "http://www.w3.org/ns/oa#highlighting":
// fill in the element
console.log("HIGHLIGHTING: ", anno);
element.style.fill = "darkorange";
break;
case "http://www.w3.org/ns/oa#linking":
console.log("LINKING: ", anno);
// assuming there is at least one body attached to the annotation...
if(bodies.length) {
// make the target clickable, linking to the (first) body URI
element.addEventListener("click", function() {
window.open(bodies[0]["@id"], "_blank")
}, true);
// and turn the cursor into a pointer as a hint that it's clickable
element.style.pointer = "cursor";
}
break;
case "http://www.w3.org/ns/oa#describing":
console.log("DESCRIBING: ", anno);
// assuming there is at least one body attached to the annotation...
if(bodies.length) {
if("@value" in bodies[0]) {
// SVG uses title elements, not attributes like HTML
// so create a new title node in the SVG namespace:
const title = document.createElementNS("http://www.w3.org/2000/svg", "title")
// Enter the annotation text into this title node
title.innerHTML = bodies[0]["@value"]
// and slot it in under the note
element.insertBefore(title, element.firstChild);
}
}
break;
default:
console.log("sorry, don't know what to do for this annotation ", anno, " with motivation ", motivation);
}
});
})
}
})
})
});
}
let annoUrlBox = document.createElement("span");
annoUrlBox.innerHTML = "Apply Web Annotation: <input type='text' name='anno' id='__applyannotations_userscript_url_input'/> ";
let applyButton = document.createElement("input");
applyButton.setAttribute("type", "button");
applyButton.setAttribute("value", "Apply");
applyButton.addEventListener("click", fetchAndApply, true );
document.body.insertBefore(applyButton, document.body.firstChild);
document.body.insertBefore(annoUrlBox, document.body.firstChild);