search.js 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813
  1. var Parole = "";
  2. let mmoQueries = 0;
  3. let infQueries = 0;
  4. let perQueries = 0;
  5. let lgQueries = 0;
  6. $(document).ready(function () {
  7. //#######################################
  8. populateOption();
  9. var search_name = "";
  10. var Label = "";
  11. var object_Label = "";
  12. var id_label = "";
  13. var name_per = "";
  14. var note_per = "";
  15. var occupation_per = "";
  16. var place_search = "";
  17. var testo = "";
  18. $('#ClipArt1').on("click", function () {
  19. $('#Man-Made_Object').text("");
  20. $('#n_mmo').text("0");
  21. $('#Information_Object').text("");
  22. $('#n_io').text("0");
  23. $('#Person').text("");
  24. $('#n_ps').text("0");
  25. $('#Place').text("");
  26. $('#n_pl').text("0");
  27. testo = $('input#TextArea1').val();
  28. Parole = testo;
  29. //questo era il contenuto di results_retrieveData()
  30. mmoQueries = 0;
  31. infQueries = 0;
  32. perQueries = 0;
  33. lgQueries = 0;
  34. $("#mmoLoader").css("display", "block");
  35. $("#infLoader").css("display", "block");
  36. $("#perLoader").css("display", "block");
  37. $("#lgLoader").css("display", "block");
  38. $('#wb_Image1').text("");
  39. $('.results').css("display", "none");
  40. next_text = testo.split(" ");
  41. search_name = "\"'" + next_text[0] + "'";
  42. if (next_text.length > 1) {
  43. for (var i=1; i<next_text.length; i++) {
  44. search_name = search_name + " AND '" + next_text[i] + "'";
  45. }
  46. }
  47. search_name = search_name + "\"";
  48. if (testo != "") {
  49. Label = " ?label bif:contains "+ search_name + " . ";
  50. object_Label = " ?object_Label bif:contains "+ search_name + " . ";
  51. id_label = " ?id bif:contains "+ search_name + " . ";
  52. name_per = "?name bif:contains "+ search_name + " . ";
  53. note_per = " ?note bif:contains " + search_name + " . ";
  54. occupation_per = " ?occupation bif:contains " + search_name + " . ";
  55. place_search = " ?label bif:contains" + search_name + " . ";
  56. }
  57. else {
  58. Label = "";
  59. object_Label = "";
  60. id_label = "";
  61. name_per = "";
  62. note_per = " ?note bif:contains 'NNNNNN' . ";;
  63. place_search = "";
  64. occupation_per = " ?occupation bif:contains 'NNNNN' . ";;
  65. }
  66. var g = document.getElementById("graph_selector");
  67. var g2 = document.getElementById("graph_selector2");
  68. var graph1 = g.value;
  69. var graph2 = g2.value;
  70. if (graph1 == 'MPP') {
  71. object_Label = " ?object_Label bif:contains 'NNNNNNNN' . ";
  72. }
  73. var search_graph = getGraph(graph1, graph2);
  74. var pref = queryManager['prefixes']['all'];
  75. var query1 = pref + (queryManager['queryMMO']['queryLabel']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', Label);
  76. var query2 = pref + (queryManager['queryMMO']['queryArte']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', Label);
  77. var query3 = pref + (queryManager['queryMMO']['queryIdentificatore']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', testo);
  78. var query4 = pref + (queryManager['queryINF']['queryContenuti1']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', object_Label);
  79. var query5 = pref + (queryManager['queryINF']['queryContenuti2']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', object_Label);
  80. var query6 = pref + (queryManager['queryINF']['queryContenuti3']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', object_Label);
  81. var query7 = pref + (queryManager['queryPER']['queryNome']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', name_per);
  82. var query8 = pref + (queryManager['queryPER']['queryNote']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', note_per);
  83. var query9 = pref + (queryManager['queryPER']['queryOccupazione']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', occupation_per);
  84. var query10 = pref + (queryManager['queryLG']['queryLuoghi']).replace('<{GRAPH}>', search_graph).replace('<{WORD}>', place_search);
  85. // la funzione doJsonQuery restituisce direttamente l'oggetto della chiamata ajax in json.
  86. // Una volta effettuata la chiamata, il risultato è passato alla funzione manage...
  87. doJsonQuery(query1).done(function(r) { manageMMO(r); });
  88. doJsonQuery(query2).done(function(r) { manageMMO(r); });
  89. doJsonQuery(query3).done(function(r) { manageMMO(r); });
  90. doJsonQuery(query4).done(function(r) { manageINF(r); });
  91. doJsonQuery(query5).done(function(r) { manageINF(r); });
  92. doJsonQuery(query6).done(function(r) { manageINF(r); });
  93. doJsonQuery(query7).done(function(r) { managePER(r); });
  94. doJsonQuery(query8).done(function(r) { managePER(r); });
  95. doJsonQuery(query9).done(function(r) { managePER(r); });
  96. doJsonQuery(query10).done(function(r) { manageLG(r); });
  97. });
  98. $('input#TextArea1').keypress(function(e) {
  99. var key = e.which;
  100. if (key == 13) // the enter key code
  101. {
  102. $('#ClipArt1').click();
  103. return false;
  104. }
  105. });
  106. });
  107. function checkEmpty() {
  108. if ($("#Man-Made_Object").is(':empty')) {
  109. var message = '<p class="no-results">Nessun <span>Oggetto Fisico</span> trovato</p>';
  110. $('#Man-Made_Object').append(message);
  111. }
  112. if ($("#Information_Object").is(':empty')) {
  113. var message = '<p class="no-results">Nessun <span>Oggetto Informativo</span> trovato</p>';
  114. $('#Information_Object').append(message);
  115. }
  116. if ($("#Person").is(':empty')) {
  117. var message = '<p class="no-results">Nessuna <span>Persona</span> trovata</p>';
  118. $('#Person').append(message);
  119. }
  120. if ($("#Place").is(':empty')) {
  121. var message = '<p class="no-results">Nessun <span>Luogo</span> trovato</p>';
  122. $('#Place').append(message);
  123. }
  124. }
  125. function rewrite_graph(graph) {
  126. var graph_name = ""
  127. if (graph == "http://dev.restore.ovi.cnr.it:8890/aspo/datini") {
  128. graph_name = "Archivio di Stato di Prato - Fondo Datini";
  129. }
  130. else if (graph == "http://dev.restore.ovi.cnr.it:8890/aspo/ospedale") {
  131. graph_name = "Archivio di Stato di Prato - Fondo Ospedale Misericordia e Dolce";
  132. }
  133. else if (graph == "http://dev.restore.ovi.cnr.it:8890/aspo/marcovaldi") {
  134. graph_name = "Archivio di Stato di Prato - Fondo Marcolvaldi";
  135. }
  136. else if (graph == "http://dev.restore.ovi.cnr.it:8890/aspo/gettatelli") {
  137. graph_name = "Archivio di Stato di Prato - Fondo Ospedale Misericordia e Dolce";
  138. }
  139. else if (graph == "http://dev.restore.ovi.cnr.it:8890/aspo/actors") {
  140. graph_name = "Archivio di Stato di Prato";
  141. }
  142. else if (graph == "http://dev.restore.ovi.cnr.it:8890/mpp/martini") {
  143. graph_name = "Museo di Palazzo Pretorio di Prato";
  144. }
  145. else if (graph == "http://dev.restore.ovi.cnr.it:8890/mpp/ospedale") {
  146. graph_name = "Museo di Palazzo Pretorio di Prato";
  147. }
  148. else if (graph == "http://dev.restore.ovi.cnr.it:8890/mpp/datini") {
  149. graph_name = "Museo di Palazzo Pretorio di Prato";
  150. }
  151. else if (graph == "http://dev.restore.ovi.cnr.it:8890/mpp/authors") {
  152. graph_name = "Museo di Palazzo Pretorio di Prato";
  153. }
  154. else if (graph == "http://dev.restore.ovi.cnr.it:8890/ovi/datini") {
  155. graph_name = "Opera del Vocabolario Italiano";
  156. }
  157. else if (graph == "http://dev.restore.ovi.cnr.it:8890/ovi/datini/trascr") {
  158. graph_name = "Opera del Vocabolario Italiano";
  159. }
  160. else if (graph == "http://dev.restore.ovi.cnr.it:8890/places") {
  161. graph_name = "Luoghi";
  162. }
  163. else if (graph == "http://dev.restore.ovi.cnr.it:8890/mpp/places") {
  164. graph_name = "Museo di Palazzo Pretorio di Prato";
  165. }
  166. else if (graph == "http://dev.restore.ovi.cnr.it:8890/label/toponimi") {
  167. graph_name = "Toponimi Archivio di Stato di Prato";
  168. }
  169. else if (graph == "http://dev.restore.ovi.cnr.it:8890/aspo/onomastica") {
  170. graph_name = "Archivio di Stato di Prato - Onomatica Datini";
  171. }
  172. else if (graph == "http://dev.restore.ovi.cnr.it:8890/aspo/gettatelli/newdataset") {
  173. graph_name = "Archivio di Stato di Prato - Fondo Ospedale Misericordia e Dolce";
  174. }
  175. else if (graph == "http://dev.restore.ovi.cnr.it:8890/aspo/onomastica/gruppi") {
  176. graph_name = "Archivio di Stato di Prato - Onomastica Datini";
  177. }
  178. else if (graph == "http://dev.restore.ovi.cnr.it:8890/mpp/autori") {
  179. graph_name = "Museo di Palazzo Pretorio";
  180. }
  181. else {graph_name = graph;
  182. }
  183. return graph_name;
  184. }
  185. function MMO_handle_json(json) {
  186. // console.log(json);
  187. mmoQueries = mmoQueries+1;
  188. if(mmoQueries==3){
  189. $('#mmoLoader').css("display", "none");
  190. }
  191. $('#wb_Shape1').text("");
  192. $(".results").css("display", "block");
  193. var n_mmo = $('#n_mmo').text();
  194. var b = parseInt(n_mmo);
  195. var i = 0;
  196. $.each(
  197. json['results']['bindings'],
  198. function (index, value) {
  199. var object = ""; /*Inserisci VALUE TIPOLOGIA*/
  200. var graph = value['graph']['value'];
  201. var graph_name = rewrite_graph(graph);
  202. var mmoType = "";
  203. var mmoId = "";
  204. var object_button = "";
  205. var object_type = "";
  206. if (value.hasOwnProperty('type')) {
  207. mmoType = value['type']['value'];
  208. }
  209. if (value.hasOwnProperty('identifier')) {
  210. mmoId = value['identifier']['value'];
  211. }
  212. if (mmoType.includes("Opera d'Arte")) {
  213. object_type = "artwork";
  214. object_button += '<button type="button" id="' + value['subject']['value'] +
  215. '" class="artwork btn btn-default" alt="opera d\'arte" title="' + value['label']['value'] +
  216. '"><i class="fas fa-paint-brush"></i><p class="btn-text">Scheda Opera d\'Arte</p></button>';
  217. } else {
  218. object_type = "object";
  219. object_button += '<button type="button" id="' + value['subject']['value'] +
  220. '" class="object btn btn-default" alt="oggetto" title="' + value['label']['value'] +
  221. '"><i class="fa fa-book"></i><p class="btn-text">Scheda Oggetto</p></button>';
  222. }
  223. object += /*INIZIO DIV*/ '<div class="row res"><div class="col-8">' + graph_name + '<br />' +
  224. '<span id="' + value['subject']['value'] + '" class="title_doc ' + object_type +'">' + value['label']['value'] + '</span><br />' +
  225. '<i>' + mmoType + ' ' + mmoId + '</i></div>' +
  226. '<div class="col d-flex align-items-start justify-content-end">' + object_button +
  227. '<button type="button" value="' + object_type + '" id="' + value['subject']['value'] + '" class="cit btn btn-default" alt="scheda" title="Info"><i class="fa fa-quote-right"></i><p class="btn-text">Citazione</p></button>' +
  228. /*DA QUI HYPERLINK ->*/'<button type="button" value="' + object_type + '" id="' + value['subject']['value'] + '" class="hyp btn btn-default" alt="scheda" title="Info"><i class="fa fa-link"></i><p class="btn-text">Hyperlink</p></button>' +
  229. /*DA QUI LOD ->*/'<a href="http://dev.restore.ovi.cnr.it/lodlive/?' + value['subject']['value'] + '" target="_blank"><button type="button" class="btn btn-default info" alt="LOD"><i class="fa fa-share-alt"></i><p class="btn-text">Lod</p></button></a></div></div>';
  230. i++;
  231. /*onclick=copy__Text("' + value['link']['value'] + '")*/
  232. $('#Man-Made_Object').append(object);
  233. });
  234. var n_oggetto = b + i;
  235. $('#n_mmo').text("");
  236. $('#n_mmo').append(n_oggetto);
  237. if (n_oggetto == 0) {
  238. $('#Man-Made_Object').text("");
  239. var message = '<p id="no_mmo" class="no-results">Nessun <span>Oggetto Fisico</span> trovato</p>';
  240. $('#Man-Made_Object').append(message);
  241. } else {
  242. $('#no_mmo').remove("");
  243. }
  244. }
  245. function InfObj_handle_json(json) {
  246. // console.log(json);
  247. infQueries = infQueries+1;
  248. if(infQueries==3){
  249. $('#infLoader').css("display", "none");
  250. }
  251. var n_io = $('#n_io').text();
  252. var b = parseInt(n_io);
  253. var i = 0;
  254. $.each(
  255. json['results']['bindings'],
  256. function (index, value) {
  257. var information = ""; /*Inserisci VALUE TIPOLOGIA*/
  258. var graph = value['graph']['value'];
  259. var graph_name = rewrite_graph(graph);
  260. var tipo = "";
  261. var id = "";
  262. var infObject_button = "";
  263. if (value['text']['type'] != 'uri') {
  264. var myString = value['text']['value'];
  265. var str = myString.replace(/<[^>]*>?/gm, '');
  266. let string_text = str.toLowerCase();
  267. let string_len = str.length;
  268. var word = Parole;
  269. let ind = string_text.indexOf(word);
  270. let length = word.length;
  271. var wl = ind + length;
  272. var resource_type = "";
  273. var link_type = "";
  274. /*var start = 0;
  275. var end = 0
  276. var bb = pp - 50;
  277. var ee = pp + length + 150;*/
  278. var pp = ind;
  279. before = str.substring(0, ind);
  280. after = str.substring(wl, string_len);
  281. let bb = before.lastIndexOf(".");
  282. let point = bb + pp;
  283. let ee = str.indexOf(".", point);
  284. if (bb < 0) {
  285. start = 0;
  286. } else {
  287. start = bb+1;
  288. }
  289. if (ee < 0) {
  290. end = string_len;
  291. } else {
  292. end = ee;
  293. }
  294. first_chunk = str.substring(start, ind);
  295. highlight = str.substring(ind, wl);
  296. second_chunk = str.substring(wl, end);
  297. var snippet = first_chunk + highlight + second_chunk ;
  298. //var snippet = first_chunk + "<span class='sharp'>" + highlight + "</span>" + second_chunk ;
  299. if (value.hasOwnProperty('types')) {
  300. tipo = value['types']['value'];
  301. }
  302. if (value.hasOwnProperty('id')) {
  303. id = " (" + value['id']['value'] + ")";
  304. }
  305. if (tipo.includes("lettera")) {
  306. link_name = value['subject']['value'];
  307. resource_type = "lettera";
  308. link_type = "lettera";
  309. infObject_button += '<button type="button" id="' + value['subject']['value'] +
  310. '" class="lettera btn btn-default" alt="lettera" title="' + value['label']['value'] +
  311. '"><i class="fa fa-envelope"></i><p class="btn-text">Scheda Lettera</p></button>';
  312. } else {
  313. link_name = value['Physical_Object']['value'];
  314. resource_type = "object";
  315. link_type = "object";
  316. infObject_button += '<button type="button" id="' + value['Physical_Object']['value'] +
  317. '" class="object btn btn-default" alt="oggetto" title="' + value['label']['value'] +
  318. '"><i class="fa fa-book"></i><p class="btn-text">Scheda Oggetto</p></button>';
  319. }
  320. //'<div class="row res"><div class="col-8"><p>' + graph_name + '<br />' +
  321. //'<span id="' + value['subject']['value'] + '" class="title_doc luogo">' + value['label']['value'] + '</span></p></div>'
  322. information += /*INIZIO DIV*/ '<div class="row res"><div class="col-8"><p>'+ snippet+'</p>' +
  323. 'In: ' + graph_name + ';<br />' +
  324. '<span id="' + link_name + '" class="title_doc ' + link_type + '">' + value['label']['value'] + id +
  325. '</span>;<br /><i>' + tipo + '</i><br /></div>' +
  326. '<div class="col d-flex align-items-start justify-content-end">' + infObject_button +
  327. '<button type="button" value="' + resource_type + '" id="' + value['subject']['value'] + '" class="cit btn btn-default" alt="scheda" title="Info"><i class="fa fa-quote-right"></i><p class="btn-text">Citazione</p></button>' +
  328. /*DA QUI HYPERLINK ->*/'<button type="button" value="' + resource_type + '" id="' + value['subject']['value'] + '" class="hyp btn btn-default" alt="scheda" title="Info"><i class="fa fa-link"></i><p class="btn-text">Hyperlink</p></button>' +
  329. /*DA QUI LOD ->*/'<a href="http://dev.restore.ovi.cnr.it/lodlive/?' + value['subject']['value'] + '" target="_blank"><button type="button" class="btn btn-default info" alt="LOD"><i class="fa fa-share-alt"></i><p class="btn-text">Lod</p></button></a></div></div>';
  330. i++;
  331. /*onclick=copy__Text("' + value['link']['value'] + '")*/
  332. $('#Information_Object').append(information);
  333. }
  334. });
  335. var n_oggetto = b + i;
  336. $('#n_io').text("");
  337. $('#n_io').append(n_oggetto);
  338. if (n_oggetto == 0) {
  339. $('#Information_Object').text("");
  340. var message = '<p id="no_io" class="no-results">Nessun <span>Testo</span> trovato</p>';
  341. $('#Information_Object').append(message);
  342. } else {
  343. $('#no_io').remove("");
  344. }
  345. }
  346. function Person_handle_json(json) {
  347. console.log(json);
  348. perQueries = perQueries+1;
  349. if(perQueries==3){
  350. $('#perLoader').css("display", "none");
  351. }
  352. var n_ps = $('#n_ps').text();
  353. var b = parseInt(n_ps);
  354. var i = 0;
  355. $.each(
  356. json['results']['bindings'],
  357. function (index, value) {
  358. var person = ""; /*Inserisci VALUE TIPOLOGIA*/
  359. var graph = value['graph']['value'];
  360. var graph_name = rewrite_graph(graph);
  361. person += /*INIZIO DIV*/ '<div class="row res"><div class="col-8"><p>' + graph_name + '<br />' +
  362. '<span id="' + value['subject']['value'] + '" class="title_doc persona">' + value['name']['value'] + '</span></p></div>' +
  363. '<div class="col d-flex align-items-start justify-content-end"><button type="button" id="' + value['subject']['value'] + '" class="persona btn btn-default" alt="persona" title="' +
  364. value['name']['value'] + '"><i class="fa fa-user"></i><p class="btn-text">Scheda Persona</p></button>' +
  365. '<button type="button" value="Persona" id="' + value['subject']['value'] + '" class="cit btn btn-default" alt="scheda" title="Info"><i class="fa fa-quote-right"></i><p class="btn-text">Citazione</p></button>' +
  366. /*DA QUI HYPERLINK ->*/'<button type="button" value="Persona" id="' + value['subject']['value'] + '" class="hyp btn btn-default" alt="scheda" title="Info"><i class="fa fa-link"></i><p class="btn-text">Hyperlink</p></button>' +
  367. /*DA QUI LOD ->*/'<a href="http://dev.restore.ovi.cnr.it/lodlive/?' + value['subject']['value'] + '" target="_blank"><button type="button" class="btn btn-default info" alt="LOD"><i class="fa fa-share-alt"></i><p class="btn-text">Lod</p></button></a></div></div>';
  368. i++;
  369. /*onclick=copy__Text("' + value['link']['value'] + '")*/
  370. $('#Person').append(person);
  371. });
  372. var n_oggetto = b + i;
  373. $('#n_ps').text("");
  374. $('#n_ps').append(n_oggetto);
  375. if (n_oggetto == 0) {
  376. $('#Person').text("");
  377. var message = '<p id="no_ps" class="no-results">Nessun <span>Persona</span> trovata</p>';
  378. $('#Person').append(message);
  379. } else {
  380. $('#no_ps').remove("");
  381. }
  382. }
  383. function Place_handle_json(json) {
  384. // console.log(json);
  385. lgQueries = lgQueries+1;
  386. if(lgQueries==1){
  387. $('#lgLoader').css("display", "none");
  388. }
  389. var n_pl = $('#n_pl').text();
  390. var b = parseInt(n_pl);
  391. var i = 0;
  392. $.each(
  393. json['results']['bindings'],
  394. function (index, value) {
  395. var place = ""; /*Inserisci VALUE TIPOLOGIA*/
  396. var graph = value['graph']['value'];
  397. var graph_name = rewrite_graph(graph);
  398. place += /*INIZIO DIV*/ '<div class="row res"><div class="col-8"><p>' + graph_name + '<br />' +
  399. '<span id="' + value['subject']['value'] + '" class="title_doc luogo">' + value['label']['value'] + '</span></p></div>' +
  400. '<div class="col d-flex align-items-start justify-content-end"><button type="button" id="' + value['subject']['value'] + '" class="luogo btn btn-default" alt="luogo" title="' +
  401. value['label']['value'] + '"><i class="fa fa-map"></i><p class="btn-text">Scheda Luogo</p></button>' +
  402. '<button type="button" value="Luogo" id="' + value['subject']['value'] + '" class="cit btn btn-default" alt="scheda" title="Info"><i class="fa fa-quote-right"></i><p class="btn-text">Citazione</p></button>' +
  403. /*DA QUI HYPERLINK ->*/'<button type="button" value="Luogo" id="' + value['subject']['value'] + '" class="hyp btn btn-default" alt="scheda" title="Info"><i class="fa fa-link"></i><p class="btn-text">Hyperlink</p></button>' +
  404. /*DA QUI LOD ->*/'<a href="http://dev.restore.ovi.cnr.it/lodlive/?' + value['subject']['value'] + '" target="_blank"><button type="button" class="btn btn-default info" alt="LOD"><i class="fa fa-share-alt"></i><p class="btn-text">Lod</p></button></a></div></div>';
  405. i++;
  406. /*onclick=copy__Text("' + value['link']['value'] + '")*/
  407. $('#Place').append(place);
  408. });
  409. var n_oggetto = b + i;
  410. $('#n_pl').text("");
  411. $('#n_pl').append(n_oggetto);
  412. if (n_oggetto == 0) {
  413. $('#Place').text("");
  414. var message = '<p id="no_pl" class="no-results">Nessun <span>Luogo</span> trovato</p>';
  415. $('#Place').append(message);
  416. } else {
  417. $('#no_pl').remove("");
  418. }
  419. }
  420. //onlick hyperlink button
  421. $(document).on("click", ".hyp", function (ev) {
  422. var baseurl = window.location.origin+window.location.pathname;
  423. let slash = baseurl.lastIndexOf("/");
  424. var type = $(this).val() + '.html';
  425. var link = this.id;
  426. var url = baseurl.substr(0, slash+1) + type + "?link="+link;
  427. var link = this.id;
  428. $("#myModal").empty();
  429. $("#myModal").css("display", "block");
  430. $('#myModal').append("<div class='modal-content'><div class='modal-close'><span class='close'>&times;</span></div><div id='myInput'>" +
  431. url + "</div><button id='copy_btn' class='btn btn-theme-primary btn-md' onclick='myFunction()'>Copia</button>");
  432. });
  433. $(document).on("click", ".lettera", function (ev) {
  434. var link = this.id;
  435. //alert(nome_autore);
  436. //$('#myModal').text("");
  437. window.open("lettera.html?link="+this.id);
  438. });
  439. $(document).on("click", ".object", function (ev) {
  440. var link = this.id;
  441. //alert(nome_autore);
  442. //$('#myModal').text("");
  443. window.open("object.html?link="+this.id);
  444. });
  445. $(document).on("click", ".artwork", function (ev) {
  446. var link = this.id;
  447. //alert(nome_autore);
  448. //$('#myModal').text("");
  449. window.open("OA.html?link="+this.id);
  450. });
  451. $(document).on("click", ".persona", function (ev) {
  452. var link = this.id;
  453. //alert(nome_autore);
  454. //$('#myModal').text("");
  455. window.open("Persona.html?link="+this.id);
  456. });
  457. $(document).on("click", ".luogo", function (ev) {
  458. var link = this.id;
  459. //alert(nome_autore);
  460. //$('#myModal').text("");
  461. window.open("Luogo.html?link="+this.id);
  462. });
  463. $(document).on("click", ".close", function (ev) {
  464. var link = this.id;
  465. //alert(nome_autore);
  466. //$('#myModal').text("");
  467. $("#myModal").css("display", "none");
  468. });
  469. $(document).on("click", ".back", function (ev) {
  470. $("#myTab").css("display", "none");
  471. });
  472. $(document).on("click", ".cit", function (ev) {
  473. var author ="RESTORE. smart access to digital heritage and memory"
  474. var year = new Date().getFullYear()
  475. var today = new Date();
  476. var dd = String(today.getDate()).padStart(2, '0');
  477. var mm = String(today.getMonth() + 1).padStart(2, '0'); //January is 0!
  478. var yyyy = today.getFullYear();
  479. today = dd + '/' + mm + '/' + yyyy;
  480. var baseurl = window.location.origin+window.location.pathname;
  481. let slash = baseurl.lastIndexOf("/");
  482. var type = $(this).val() + '.html';
  483. var link = this.id;
  484. var url = baseurl.substr(0, slash+1) + type + "?link="+link;
  485. //alert(nome_autore);
  486. //$('#myModal').text("");
  487. $("#myModal").empty();
  488. $("#myModal").css("display", "block");
  489. $('#myModal').append("<div class='modal-content'><div class='modal-close'><span class='close'>&times;</span></div><div id='myInput'>" +
  490. author + " " + year + ", accesso effettuato: " + today + ", &lt;" + url + "&gt;</div><button id='copy_btn' class='btn btn-theme-primary btn-md' onclick='myFunction()'>Copia</button>");
  491. });
  492. //#######################################
  493. function prepareQueryURL(query){
  494. sparqlEndpoint = 'http://dev.restore.ovi.cnr.it:8890/sparql/';
  495. sparqlUrlParams = '?default-graph-uri=&query=' + encodeURIComponent(query) + '&output=json&callback=?';
  496. return sparqlEndpoint + sparqlUrlParams;
  497. }
  498. // Esegue una query sull'endpoint SPARQL il cui testo completo deve essere fornito nel parametro-stringa 'query'
  499. // Restituisce una lista di oggetti json nel formato di Virtuoso
  500. // Il parametro opzionale 'isUnique', se messo a 'true' controlla che ci sia un unico risultato (un array di
  501. // lunghezza 1) e se non è così restituisce un errore.
  502. //restituisce direttamente l'oggetto della chiamata ajax
  503. function doJsonQuery(query) {
  504. queryURL = prepareQueryURL(query);
  505. return $.ajax({
  506. url: queryURL,
  507. dataType: "json",
  508. type: 'GET'
  509. });
  510. }
  511. //funzione che prende il risultato della chiamata ajax e fa tutto quello che serve dopo
  512. function manageMMO(result){
  513. // console.log(result);
  514. MMO_handle_json(result);
  515. }
  516. function manageINF(result){
  517. // console.log(result);
  518. InfObj_handle_json(result);
  519. }
  520. function managePER(result){
  521. // console.log(result);
  522. Person_handle_json(result);
  523. }
  524. function manageLG(result){
  525. // console.log(result);
  526. Place_handle_json(result);
  527. }
  528. function populateOption() {
  529. const graph_selector = document.getElementById("graph_selector");
  530. const graph_selector2 = document.getElementById("graph_selector2");
  531. const createOption = (graph_selector, text, value) => {
  532. const opt = document.createElement('option');
  533. opt.value = value;
  534. opt.text = text;
  535. graph_selector.options.add(opt);
  536. }
  537. const configureDropDownLists = (graph_selector, graph_selector2) => {
  538. const ASPO = [
  539. ['Tutti Fondi', ''],
  540. ['Fondo Datini', 'aspo_datini'],
  541. ['Fondo Ospedale Misericordia e Dolce', 'aspo_ospedale'],
  542. ['Fondo Marcovaldi', 'aspo_marcovaldi'],
  543. ['Fondo Gettatelli', 'aspo_gettatelli']
  544. ];
  545. const MPP = [
  546. ['Tutte', ''],
  547. ['Galleria Martini', 'mpp_martini'],
  548. ['Opere provenienti dall’Ospedale', 'mpp_ospedale'],
  549. ['Iconografia Datini', 'mpp_datini']
  550. ];
  551. const OVI = [
  552. ['Tutte le risorse', ''],
  553. ['Lettere', 'ovi_lettere']
  554. ];
  555. graph_selector2.options.length = 0
  556. switch (graph_selector.value) {
  557. case 'ASPO':
  558. for (const c of ASPO) {
  559. createOption(graph_selector2, c[0], c[1]);
  560. }
  561. break;
  562. case 'MPP':
  563. for (const s of MPP) {
  564. createOption(graph_selector2, s[0], s[1]);
  565. }
  566. break;
  567. case 'OVI':
  568. for (const n of OVI) {
  569. createOption(graph_selector2, n[0], n[1]);
  570. }
  571. break;
  572. default:
  573. break;
  574. }
  575. }
  576. graph_selector.addEventListener('change', () => {
  577. $("#graph_selector2").css("display", "block");
  578. configureDropDownLists(graph_selector, graph_selector2)
  579. });
  580. }
  581. function getGraph(graph1, graph2) {
  582. var search_graph = "";
  583. if ((graph1 == '') && (graph2 == '')) {
  584. search_graph = "";
  585. }
  586. else if ((graph1 != '') && (graph2 == '')) {
  587. if (graph1 == "ASPO") {
  588. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/aspo/datini> \
  589. <http://dev.restore.ovi.cnr.it:8890/aspo/ospedale> \
  590. <http://dev.restore.ovi.cnr.it:8890/aspo/marcovaldi> \
  591. <http://dev.restore.ovi.cnr.it:8890/aspo/gettatelli>}";
  592. }
  593. if (graph1 == "MPP") {
  594. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/mpp/martini> \
  595. <http://dev.restore.ovi.cnr.it:8890/mpp/ospedale> \
  596. <http://dev.restore.ovi.cnr.it:8890/mpp/datini> \
  597. <http://dev.restore.ovi.cnr.it:8890/mpp/autori> }";
  598. }
  599. if (graph1 == "OVI") {
  600. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/ovi/datini>}";
  601. }
  602. }
  603. else if (graph2 != '') {
  604. if (graph2 == "aspo_datini") {
  605. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/aspo/datini>}";
  606. }
  607. if (graph2 == "aspo_ospedale") {
  608. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/aspo/ospedale>}";
  609. }
  610. if (graph2 == "aspo_marcovaldi") {
  611. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/aspo/marcovaldi>}";
  612. }
  613. if (graph2 == "aspo_gettatelli") {
  614. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/aspo/gettatelli>}";
  615. }
  616. if (graph2 == "mpp_martini") {
  617. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/mpp/martini>}";
  618. }
  619. if (graph2 == "mpp_ospedale") {
  620. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/mpp/ospedale>}";
  621. }
  622. if (graph2 == "mpp_datini") {
  623. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/mpp/datini>}";
  624. }
  625. if (graph2 == "ovi_lettere") {
  626. search_graph = "VALUES ?g {<http://dev.restore.ovi.cnr.it:8890/ovi/datini>}";
  627. }
  628. } else {
  629. search_graph = "";
  630. }
  631. return search_graph;
  632. }
  633. function copyToClipboard(text) {
  634. var sampleTextarea = document.createElement("textarea");
  635. document.body.appendChild(sampleTextarea);
  636. sampleTextarea.value = text; //save main text in it
  637. sampleTextarea.select(); //select textarea contenrs
  638. document.execCommand("copy");
  639. document.body.removeChild(sampleTextarea);
  640. }
  641. function myFunction(){
  642. var copy = document.getElementById("myInput");
  643. copyText = copy.textContent;
  644. copyToClipboard(copyText);
  645. //copyToClipboard(copyText.value);
  646. }