people.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531
  1. // Raccatto i parametri dall'URL -- mi aspetto un parametro di nome 'link'!
  2. thisUrlParams = {};
  3. window.location.href.replace(/[?&]+([^=&]+)=([^&]*)/gi, function(m,key,value) {
  4. thisUrlParams[key] = value;
  5. });
  6. console.log('URL get params: ', thisUrlParams);
  7. // Funzioni per eseguire le queries
  8. function prepareQueryURL(query){
  9. sparqlEndpoint = 'http://dev.restore.ovi.cnr.it:8890/sparql/';
  10. sparqlUrlParams = '?default-graph-uri=&query=' + encodeURIComponent(query) + '&output=json&callback=?';
  11. return sparqlEndpoint + sparqlUrlParams;
  12. }
  13. function doJsonQuery(query){
  14. queryURL = prepareQueryURL(query);
  15. response = $.ajax({//OGGETTO
  16. url: queryURL,
  17. dataType: "json",
  18. success: function (data){},
  19. error: function (e) {}
  20. });
  21. return response;
  22. }
  23. // Funzioni per raccattare + stringhificare l'output
  24. queryStringOutput = "";
  25. function stringifyResponse(val){
  26. resultArray = val['results']['bindings'];
  27. out = "";
  28. for(i = 0; i < resultArray.length; i++){
  29. out = out + JSON.stringify(resultArray[i])
  30. }
  31. queryStringOutput = (queryStringOutput + out).replace("}{",",");
  32. }
  33. prefixes = "PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#> \
  34. PREFIX rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> \
  35. PREFIX crm: <http://www.cidoc-crm.org/cidoc-crm/> \
  36. PREFIX owl: <http://www.w3.org/2002/07/owl#>"
  37. query = prefixes + " SELECT DISTINCT ?place ?label ?coordinates \
  38. WHERE { \
  39. {?pc crm:P02_has_range <" + thisUrlParams.link + "> . \
  40. ?event_from crm:P01_has_domain ?pc ; \
  41. rdf:type crm:EL3_Receive_Letter; \
  42. crm:P26_moved_to ?place_from . \
  43. ?place_from rdf:type crm:E53_Place ; \
  44. owl:sameAs ?place . \
  45. ?place rdfs:label ?label ; \
  46. crm:P168_place_is_defined_by ?coordinates . \
  47. } UNION { \
  48. ?pc crm:P02_has_range <" + thisUrlParams.link + "> . \
  49. ?event_from crm:P01_has_domain ?pc ; \
  50. rdf:type crm:EL2_Send_Letter; \
  51. crm:P27_moved_from ?place_from . \
  52. ?place_from rdf:type crm:E53_Place ; \
  53. owl:sameAs ?place . \
  54. ?place rdfs:label ?label ; \
  55. crm:P168_place_is_defined_by ?coordinates . \
  56. } \
  57. }"
  58. queryInfo = prefixes + " SELECT DISTINCT ?graph ?label \
  59. WHERE { \
  60. GRAPH ?graph {<" + thisUrlParams.link + "> rdfs:label ?label} \
  61. }"
  62. queryLetters = prefixes + " SELECT DISTINCT ?type ?document_uri ?document_name \
  63. WHERE {?pc crm:P02_has_range <" + thisUrlParams.link + "> . \
  64. ?ev_send crm:P01_has_domain ?pc ; \
  65. rdfs:label ?type ; \
  66. rdfs:subClassOf ?event . \
  67. ?document_uri crm:P25i_moved_by ?event ; \
  68. rdfs:label ?document_name . \
  69. }"
  70. queryNetwork = prefixes + " SELECT DISTINCT ?uri ?label ?uri2 ?label2 \
  71. WHERE { \
  72. {?event rdf:type crm:EL1_Exchange_Letters . \
  73. ?event_to rdfs:subClassOf ?event; \
  74. rdf:type crm:EL2_Send_Letter ; \
  75. crm:P01_has_domain ?pc_to . \
  76. ?pc_to crm:P02_has_range ?uri . \
  77. ?uri rdfs:label ?label . \
  78. ?event_from rdfs:subClassOf ?event; \
  79. rdf:type crm:EL3_Receive_Letter; \
  80. crm:P01_has_domain ?pc_from . \
  81. ?pc_from crm:P02_has_range ?uri2 . \
  82. ?uri2 rdfs:label ?label2 . \
  83. FILTER (?uri = <" + thisUrlParams.link + ">) \
  84. } UNION { \
  85. ?event rdf:type crm:EL1_Exchange_Letters . \
  86. ?event_to rdfs:subClassOf ?event; \
  87. rdf:type crm:EL3_Receive_Letter ; \
  88. crm:P01_has_domain ?pc_from . \
  89. ?pc_from crm:P02_has_range ?uri . \
  90. ?uri rdfs:label ?label . \
  91. ?event_from rdfs:subClassOf ?event; \
  92. rdf:type crm:EL2_Send_Letter; \
  93. crm:P01_has_domain ?pc_to . \
  94. ?pc_to crm:P02_has_range ?uri2 . \
  95. ?uri2 rdfs:label ?label2 . \
  96. FILTER (?uri = <" + thisUrlParams.link + ">) \
  97. } \
  98. } LIMIT 30"
  99. queryURL = prepareQueryURL(query);
  100. queryNet = prepareQueryURL(queryNetwork);
  101. query = prepareQueryURL(queryInfo);
  102. queryEx = prepareQueryURL(queryLetters);
  103. response = $.ajax({
  104. url: query,
  105. dataType: "json",
  106. success: function (data){
  107. handle_data(data);
  108. },
  109. error: function (e) {}
  110. });
  111. response = $.ajax({
  112. url: queryURL,
  113. dataType: "json",
  114. success: function (data){
  115. handle_map(data);
  116. },
  117. error: function (e) {}
  118. });
  119. responseNet = $.ajax({
  120. url: queryNet,
  121. dataType: "json",
  122. success: function (data){
  123. handle_network(data);
  124. },
  125. error: function (e) {}
  126. });
  127. responseLet = $.ajax({
  128. url: queryEx,
  129. dataType: "json",
  130. success: function (data){
  131. handle_Letters(data);
  132. },
  133. error: function (e) {}
  134. });
  135. function handle_data(json) {
  136. console.log(json);
  137. var graph = "";
  138. var label = "";
  139. $.each(
  140. json['results']['bindings'],
  141. function (index, value) {
  142. var graph = value['graph']['value'];
  143. var label = value['label']['value'];
  144. document.getElementById("grafo").innerHTML = graph;
  145. document.getElementById("nome_persona").innerHTML = label;
  146. document.getElementById("nome1").innerHTML = label;
  147. document.getElementById("nome2").innerHTML = label;
  148. document.getElementById("nome_au").innerHTML = label;
  149. document.getElementById("nome_ap").innerHTML = label;
  150. document.getElementById("nome_al").innerHTML = label;
  151. });
  152. }
  153. function handle_Letters(json) {
  154. console.log(json);
  155. const send = {};
  156. const receive = {};
  157. var i=0;
  158. var j=0;
  159. $.each(
  160. json['results']['bindings'],
  161. function (index, value) {
  162. type = value['type']['value'];
  163. uri = value['document_uri']['value'];
  164. title = value['document_name']['value'];
  165. if (type == "Invio") {
  166. send[uri] = title;
  167. i++;
  168. } else {
  169. receive[uri] = title;
  170. j++;
  171. }
  172. });
  173. var Send_Letters = "";
  174. var Receive_Letters = "";
  175. for (var key in send) {
  176. Send_Letters += "<div class='row'><div class='col-10'>" + send[key] + "</div><div class='col'><a href='" + key + "'><i class='fas fa-external-link-alt' aria-hidden='true'></i></a></div></div>";
  177. }
  178. for (var key in receive) {
  179. Receive_Letters += "<div class='row'><div class='col-10'>" + receive[key] + "</div><div class='col'><a href='" + key + "'><i class='fas fa-external-link-alt' aria-hidden='true'></i></a></div></div>";
  180. }
  181. document.getElementById("l_send").innerHTML = i;
  182. document.getElementById("l_receive").innerHTML = j;
  183. document.getElementById("letters_send").innerHTML = Send_Letters;
  184. document.getElementById("letters_receive").innerHTML = Receive_Letters;
  185. if (i==0) {
  186. var messaggio = "<p>Nessun risultato trovato</p>";
  187. document.getElementById("letters_send").innerHTML = messaggio;
  188. }
  189. if (j==0) {
  190. var messaggio = "<p>Nessun risultato trovato</p>";
  191. document.getElementById("letters_receive").innerHTML = messaggio;
  192. }
  193. }
  194. function handle_map(json) {
  195. console.log(json);
  196. const locations = [];
  197. const place_names = [];
  198. var lat = 0;
  199. var long = 0;
  200. var i=0;
  201. var myPlaces = "";
  202. $.each(
  203. json['results']['bindings'],
  204. function (index, value) {
  205. const loc = []
  206. var uri = value['place']['value'];
  207. var label = value['label']['value'];
  208. var coord = value['coordinates']['value'];
  209. const coordinates = coord.split(", ");
  210. loc.push(label);
  211. myPlaces += "<div class='row'><div class='col-10'>" + label + "</div><div class='luogo col' id='" +
  212. uri + "'><i class='far fa-map'></i></div></div>";
  213. loc.push(coordinates[0]);
  214. lat += parseInt(coordinates[0]);
  215. loc.push(coordinates[1]);
  216. long += parseInt(coordinates[1].replace(/^(\.)/,"0.").replace("-.", "-0."));
  217. locations.push(loc);
  218. i++;
  219. });
  220. var latitude = lat/i;
  221. var longitude = long/i;
  222. document.getElementById("list_places_person").innerHTML = myPlaces;
  223. var cloudmadeUrl = 'http://{s}.tile.cloudmade.com/BC9A493B41014CAABB98F0471D759707/997/256/{z}/{x}/{y}.png',
  224. cloudmadeAttribution = 'Map data &copy; 2011 OpenStreetMap contributors, Imagery &copy; 2011 CloudMade, Points &copy 2012 LINZ',
  225. cloudmade = new L.TileLayer(cloudmadeUrl, {maxZoom: 17, attribution: cloudmadeAttribution}),
  226. latlng = new L.LatLng(latitude, longitude);
  227. var map = new L.Map('map', {center: latlng, zoom: 5, layers: [cloudmade]});
  228. mapLink = '<a href="http://openstreetmap.org">OpenStreetMap</a>';
  229. var markers = new L.MarkerClusterGroup();
  230. var markerList = [];
  231. var geo = new L.tileLayer(
  232. 'http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
  233. attribution: '&copy; ' + mapLink + ' Contributors',
  234. maxZoom: 18,
  235. }).addTo(map);
  236. function populate() {
  237. for (var i = 0; i < locations.length; i++) {
  238. var a = locations[i];
  239. var title = a[0];
  240. var marker = new L.Marker(new L.LatLng(a[1], a[2]), { title: title });
  241. marker.bindPopup(title);
  242. markers.addLayer(marker);
  243. markerList.push(marker);
  244. }
  245. }
  246. populate();
  247. map.addLayer(markers);
  248. document.getElementById('doit').onclick = function () {
  249. var m = markerList[Math.floor(Math.random() * markerList.length)];
  250. markers.zoomToShowLayer(m, function () {
  251. m.openPopup();
  252. });
  253. };
  254. }
  255. //out = "";
  256. //for(i = 0; i < resultArray.length; i++){
  257. // out = out + JSON.stringify(resultArray[i])
  258. //}
  259. //queryStringOutput = (queryStringOutput + out).replace("}{",",");
  260. /*
  261. var locations = [
  262. ["LOCATION_1", 11.8166, 122.0942],
  263. ["LOCATION_2", 11.9804, 121.9189],
  264. ["LOCATION_3", 10.7202, 122.5621],
  265. ["LOCATION_4", 11.3889, 122.6277],
  266. ["LOCATION_5", 10.5929, 122.6325]
  267. ];
  268. var map = L.map('map').setView([11.206051, 122.447886], 8);
  269. mapLink =
  270. '<a href="http://openstreetmap.org">OpenStreetMap</a>';
  271. L.tileLayer(
  272. 'http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
  273. attribution: '&copy; ' + mapLink + ' Contributors',
  274. maxZoom: 18,
  275. }).addTo(map);
  276. for (var i = 0; i < locations.length; i++) {
  277. marker = new L.marker([locations[i][1], locations[i][2]])
  278. .bindPopup(locations[i][0])
  279. .addTo(map);
  280. }
  281. */
  282. function handle_network(json) {
  283. console.log(json);
  284. const myArray = {};
  285. const myLinks = [];
  286. var listNodes = "";
  287. var listLinks = "";
  288. var ArrayNames = "";
  289. var max = 0;
  290. $.each(
  291. json['results']['bindings'],
  292. function (index, value) {
  293. const topo = [];
  294. var id = value['uri']['value'];
  295. var name = value['label']['value'];
  296. var id2 = value['uri2']['value'];
  297. var name2 = value['label2']['value'];
  298. ArrayNames += "<div class='row'><div class='col-9'>" +
  299. name2 + "</div><div class='col'><a target='_blank' href='" +
  300. id2 + "'><i class='fas fa-external-link-alt' aria-hidden='true'></i></a></div><div class='persona col' id='" +
  301. id2 + "'><i class='fa fa-user'></i></div></div></div>";
  302. myArray[id] = name;
  303. myArray[id2] = name2;
  304. myLinks.push([id, id2]);
  305. });
  306. document.getElementById("list_person_network").innerHTML = ArrayNames;
  307. for (var key in myArray) {
  308. listNodes += '{ "id": \"' + key + '\", "name": \"' + myArray[key] + '\"},';
  309. }
  310. for (var i in myLinks) {
  311. var source = myLinks[i][0]
  312. var target = myLinks[i][1]
  313. listLinks += '{ "source": \"' + source + '\", "target": \"' + target + '\"},';
  314. }
  315. console.log(myLinks);
  316. let listN = ('[' + listNodes + ']').replace(',]', ']');
  317. let listL = ('[' + listLinks + ']').replace(',]', ']');
  318. const nodes = JSON.parse(listN);
  319. const links = JSON.parse(listL);
  320. console.log(nodes);
  321. console.log(links);
  322. var svg = d3.select("svg"),
  323. width = +svg.attr("width"),
  324. height = +svg.attr("height");
  325. var simulation = d3.forceSimulation()
  326. .force("link", d3.forceLink().id(function(d) { return d.id; }))
  327. //.force("charge", d3.forceManyBody().strength(-200))
  328. .force('charge', d3.forceManyBody()
  329. .strength(-500)
  330. .theta(0.8)
  331. .distanceMax(300)
  332. )
  333. // .force('collide', d3.forceCollide()
  334. // .radius(d => 40)
  335. // .iterations(2)
  336. // )
  337. .force("center", d3.forceCenter(width / 4, height / 3));
  338. links.forEach(function(d){
  339. // d.source = d.source_id;
  340. // d.target = d.target_id;
  341. });
  342. var link = svg.append("g")
  343. .style("stroke", "#aaa")
  344. .selectAll("line")
  345. .data(links)
  346. .enter().append("line");
  347. var node = svg.append("g")
  348. .attr("class", "nodes")
  349. .selectAll("circle")
  350. .data(nodes)
  351. .enter().append("circle")
  352. .attr("r", 2)
  353. .attr("id", function (d) { return d.id; })
  354. .call(d3.drag()
  355. .on("start", dragstarted)
  356. .on("drag", dragged)
  357. .on("end", dragended));
  358. var label = svg.append("g")
  359. .attr("class", "labels")
  360. .selectAll("text")
  361. .data(nodes)
  362. .enter().append("text")
  363. .attr("class", "label")
  364. .call(d3.drag()
  365. .on("start", dragstarted)
  366. .on("drag", dragged)
  367. .on("end", dragended))
  368. .text(function(d) { return d.name; });
  369. simulation
  370. .nodes(nodes)
  371. .on("tick", ticked);
  372. simulation.force("link")
  373. .links(links);
  374. function ticked() {
  375. link
  376. .attr("x1", function(d) { return d.source.x; })
  377. .attr("y1", function(d) { return d.source.y; })
  378. .attr("x2", function(d) { return d.target.x; })
  379. .attr("y2", function(d) { return d.target.y; });
  380. node
  381. .attr("r", 5)
  382. .style("fill", "#efefef")
  383. .style("stroke", "#424242")
  384. .style("stroke-width", "1px")
  385. .attr("cx", function (d) { return d.x+5; })
  386. .attr("cy", function(d) { return d.y-3; });
  387. label
  388. .attr("x", function(d) { return d.x+12; })
  389. .attr("y", function (d) { return d.y+1; })
  390. .style("font-size", "10px").style("fill", "#333");
  391. }
  392. function dragstarted(d) {
  393. if (!d3.event.active) simulation.alphaTarget(0.3).restart()
  394. d.fx = d.x
  395. d.fy = d.y
  396. // simulation.fix(d);
  397. }
  398. function dragged(d) {
  399. d.fx = d3.event.x
  400. d.fy = d3.event.y
  401. // simulation.fix(d, d3.event.x, d3.event.y);
  402. }
  403. function dragended(d) {
  404. d.fx = d3.event.x
  405. d.fy = d3.event.y
  406. if (!d3.event.active) simulation.alphaTarget(0);
  407. //simulation.unfix(d);
  408. }
  409. }
  410. $(document).on("click", ".luogo", function (ev) {
  411. var link = this.id;
  412. //alert(nome_autore);
  413. //$('#myModal').text("");
  414. window.open("Luogo.html?link="+this.id);
  415. });
  416. $(document).on("click", ".persona", function (ev) {
  417. var link = this.id;
  418. //alert(nome_autore);
  419. //$('#myModal').text("");
  420. window.open("Persona.html?link="+this.id);
  421. });