lettera.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. // Oggetto che raccoglie le info necessarie per la pagina
  2. pageInfo = {};
  3. // Inizializzazione della pagina
  4. initPage();
  5. // Def. funzione di inizializzazione
  6. async function initPage(){
  7. pageInfo = await getPageInfo();
  8. updatePage();
  9. }
  10. // Esegue le queries, restituisce un oggetto con tutte le info per completare la pagina
  11. async function getPageInfo(){
  12. var out = {};
  13. try{
  14. out.query1 = await doJsonQuery(query1, true);
  15. out.query2 = await doJsonQuery(query2, true);
  16. out.titolo = await doJsonQuery(queryTitolo, true);
  17. out.segnatura = await doJsonQuery(querySegnatura, true);
  18. out.sigla = await doJsonQuery(querySiglaOVI, true);
  19. out.areaLinguistica = await doJsonQuery(queryAreaLinguistica, true);
  20. out.descrizione = await doJsonQuery(queryDescrizione, true);
  21. out.testo = await doJsonQuery(queryTestoLemmatizzato, true);
  22. out.edizione = await doJsonQuery(queryEdizione, true);
  23. out.toponimi = await doJsonQuery(queryToponimi);
  24. out.antroponimi = await doJsonQuery(queryAntroponimi);
  25. // out.tipo = await doJsonQuery(queryTipo);
  26. // out.siglaOVI = await doJsonQuery(querySiglaOVI);
  27. // out.raccolta = await doJsonQuery(queryRaccolta);
  28. } catch(err){
  29. console.log(err);
  30. }
  31. console.log('out', out)
  32. return out;
  33. }
  34. // Aggiorna la pagina usando l'oggetto-info passato come parametro
  35. function updatePage(){
  36. if(pageInfo.titolo) document.getElementById("title").innerHTML = pageInfo.titolo.titolo.value;
  37. if(pageInfo.query1) {
  38. if(pageInfo.query1.hasOwnProperty('mittente')) document.getElementById("mittente_id").innerHTML = pageInfo.query1.mittente.value;
  39. if(pageInfo.query1.hasOwnProperty('destinatario')) document.getElementById("destinatario_id").innerHTML = pageInfo.query1.destinatario.value;
  40. if(pageInfo.query1.hasOwnProperty('luogo_partenza')) document.getElementById("luogo_partenza_id").innerHTML = pageInfo.query1.luogo_partenza.value;
  41. if(pageInfo.query1.hasOwnProperty('uriLuogoPartenza')) document.getElementById("luogo_partenza_btn").innerHTML = createButton("fa fa-map", "Vedi mappa", "schedaMappa('LUOGO')".replace("LUOGO", pageInfo.query1.uriLuogoPartenza.value));
  42. if(pageInfo.query1.hasOwnProperty('luogo_arrivo')) document.getElementById("luogo_arrivo_id").innerHTML = pageInfo.query1.luogo_arrivo.value;
  43. if(pageInfo.query1.hasOwnProperty('uriLuogoArrivo')) document.getElementById("luogo_arrivo_btn").innerHTML = createButton("fa fa-map", "Vedi mappa", "schedaMappa('LUOGO')".replace("LUOGO", pageInfo.query1.uriLuogoArrivo.value));
  44. if(pageInfo.query1.hasOwnProperty('data_partenza')) document.getElementById("data_partenza_id").innerHTML = pageInfo.query1.data_partenza.value;
  45. if(pageInfo.query1.hasOwnProperty('data_arrivo')) document.getElementById("data_arrivo_id").innerHTML = pageInfo.query1.data_arrivo.value;
  46. }
  47. /*if(pageInfo.query1){
  48. document.getElementById("mittente_id").innerHTML = pageInfo.query1.mittente.value;
  49. //document.getElementById("mittente_btn").innerHTML = createButton("fa fa-user", "Scheda persona", "schedaPersona('PERS')".replace("PERS", pageInfo.query1.mittente.value));
  50. }
  51. if(pageInfo.query1){
  52. document.getElementById("destinatario_id").innerHTML = pageInfo.query1.destinatario.value;
  53. //document.getElementById("destinatario_btn").innerHTML = createButton("fa fa-user", "Scheda persona", "schedaPersona('PERS')".replace("PERS", pageInfo.query1.destinatario.value));
  54. }
  55. if(pageInfo.query1){
  56. document.getElementById("imageASPO").innerHTML = createEmbed(pageInfo.query1.subject.value);
  57. }
  58. if(pageInfo.query1){
  59. document.getElementById("luogo_partenza_id").innerHTML = pageInfo.query1.luogo_partenza.value;
  60. document.getElementById("luogo_partenza_btn").innerHTML = createButton("fa fa-map", "Vedi mappa", "schedaMappa('LUOGO')".replace("LUOGO", pageInfo.query1.uriLuogoPartenza.value));
  61. }
  62. if(pageInfo.query1){
  63. document.getElementById("luogo_arrivo_id").innerHTML = pageInfo.query1.luogo_arrivo.value;
  64. document.getElementById("luogo_arrivo_btn").innerHTML = createButton("fa fa-map", "Vedi mappa", "schedaMappa('LUOGO')".replace("LUOGO", pageInfo.query1.uriLuogoArrivo.value));
  65. }
  66. if(pageInfo.query1) document.getElementById("data_partenza_id").innerHTML = pageInfo.query1.data_partenza.value;
  67. if(pageInfo.query1) document.getElementById("data_arrivo_id").innerHTML = pageInfo.query1.data_arrivo.value;
  68. */
  69. if(pageInfo.descrizione) document.getElementById("descrizione_id").innerHTML = pageInfo.descrizione.descrizione.value;
  70. if(pageInfo.areaLinguistica) document.getElementById("lingua_id").innerHTML = pageInfo.areaLinguistica.lingua.value;
  71. if(pageInfo.areaLinguistica) document.getElementById("area_linguistica_id").innerHTML = pageInfo.areaLinguistica.area_linguistica.value;
  72. if(pageInfo.sigla) document.getElementById("sigla_OVI").innerHTML = pageInfo.sigla.sigla_OVI.value;
  73. if(pageInfo.segnatura){
  74. document.getElementById("segnatura_id").innerHTML = pageInfo.segnatura.segnatura_OVI.value;
  75. document.getElementById("segnatura_btn").innerHTML = createButton("fa fa-link", "Link ASPO", "schedaASPO('SEGN')".replace("SEGN", thisUrlParams.link));
  76. }
  77. if(pageInfo.edizione){
  78. document.getElementById("edizione_id").innerHTML = pageInfo.edizione.edizione.value;
  79. document.getElementById("edizione_btn").innerHTML = createButton("fa fa-comments", "Cita Edizione", "schedaEdizione('EDIZ')".replace("EDIZ", pageInfo.edizione.edizione.value));
  80. }
  81. if(pageInfo.testo) document.getElementById("trascrizione_id").innerHTML = pageInfo.testo.testo_lemmatizzato.value;
  82. //
  83. if(pageInfo.antroponimi && pageInfo.antroponimi.length){
  84. const listaAntroponimi = pageInfo.antroponimi.map(elem => elem.antroponimo.value);
  85. document.getElementById("antroponimi").innerHTML = formatListAsLi(listaAntroponimi);
  86. }
  87. if(pageInfo.toponimi && pageInfo.toponimi.length){
  88. const listaToponimi = pageInfo.toponimi.map(elem => elem.toponimo.value);
  89. document.getElementById("toponimi").innerHTML = formatListAsLi(listaToponimi);
  90. }
  91. if(pageInfo.query2) {
  92. if(pageInfo.query2.hasOwnProperty('mittente')) document.getElementById("mittente_id_ASPO").innerHTML = pageInfo.query2.mittente.value;
  93. if(pageInfo.query2.hasOwnProperty('uriSender')) document.getElementById("mittente_btn_ASPO").innerHTML = createButton("fa fa-user", "Scheda persona", "schedaPersona('PERS')".replace("PERS", pageInfo.query2.uriSender.value));
  94. if(pageInfo.query2.hasOwnProperty('destinatario')) document.getElementById("destinatario_id_ASPO").innerHTML = pageInfo.query2.destinatario.value;
  95. if(pageInfo.query2.hasOwnProperty('uriReceiver')) document.getElementById("destinatario_btn_ASPO").innerHTML = createButton("fa fa-user", "Scheda persona", "schedaPersona('PERS')".replace("PERS", pageInfo.query2.uriReceiver.value));
  96. if(pageInfo.query2.hasOwnProperty('placeSend')) document.getElementById("luogo_partenza_id_ASPO").innerHTML = pageInfo.query2.placeSend.value;
  97. if(pageInfo.query2.hasOwnProperty('placeReceive')) document.getElementById("luogo_arrivo_id_ASPO").innerHTML = pageInfo.query2.placeReceive.value;
  98. if(pageInfo.query2.hasOwnProperty('timeSpanSend')) document.getElementById("data_partenza_id_ASPO").innerHTML = pageInfo.query2.timeSpanSend.value;
  99. if(pageInfo.query2.hasOwnProperty('timeSpanReceive')) document.getElementById("data_arrivo_id_ASPO").innerHTML = pageInfo.query2.timeSpanReceive.value;
  100. if(pageInfo.query2.hasOwnProperty('material')) document.getElementById("consistenzaASPO").innerHTML = pageInfo.query2.material.value;
  101. if(pageInfo.query2.hasOwnProperty('dimension')) document.getElementById("dimensioneASPO").innerHTML = pageInfo.query2.dimension.value;
  102. if(pageInfo.query2.hasOwnProperty('identifier')) document.getElementById("segnatura_id_ASPO").innerHTML = pageInfo.query2.identifier.value;
  103. if(pageInfo.query2.hasOwnProperty('currentLocation')) document.getElementById("ownerASPO").innerHTML = pageInfo.query2.currentLocation.value;
  104. }
  105. if(pageInfo.sigla){
  106. document.getElementById("evt_button").innerHTML = createButtonEVT(pageInfo.sigla.sigla_OVI.value);
  107. }
  108. if(pageInfo.query1){
  109. document.getElementById("imageASPO").innerHTML = createEmbed(pageInfo.query1.subject.value);
  110. }
  111. }
  112. // Mini-utility per formattare liste
  113. function formatListAsLi(thisList){
  114. toRet = "";
  115. thisList.forEach(value => toRet += "<li>" + value + "</li>");
  116. return toRet;
  117. }
  118. // Buttons
  119. function createButton(buttonClass, text, onClickFunction){
  120. htmlCode = '\
  121. <button class="btn btn-default" type="button" onclick="<FUNCTION>">\
  122. <i class="<CLASS>" aria-hidden="true">\
  123. <p class="btn-text"><TEXT></p>\
  124. </i>\
  125. </button>\
  126. '.replace("<CLASS>", buttonClass).replace("<TEXT>", text).replace("<FUNCTION>", onClickFunction);
  127. return htmlCode;
  128. }
  129. function createButtonEVT(sigla){
  130. htmlCode = '\
  131. <button type="button" class="btn btn-secondary" onclick="loadPageEVT(\'<SIGLA>\')">\
  132. Button EVT</button>\
  133. '.replace("<SIGLA>", sigla);
  134. return htmlCode;
  135. }
  136. //<button type="button" class="btn btn-secondary" onclick="loadPageLOD()">Button LOD</button>
  137. function loadPageEVT(sigla)
  138. {
  139. window.location="http://restore.ovi.cnr.it/mockup/evt/#/imageText?p=" + sigla + "_01&el=diplomatic";
  140. }
  141. function createEmbed(link) {
  142. image = link.replace("scheda", "imageView") + "/#main";
  143. htmlCode = '\
  144. <embed id="imageEmb" src="<LINK>"> \
  145. '.replace("<LINK", image);
  146. return htmlCode;
  147. }
  148. function schedaPersona(info){
  149. window.open("Persona.html?link="+info);
  150. }
  151. function schedaMappa(info){
  152. window.open("Luogo.html?link="+info);
  153. }
  154. function schedaASPO(info){
  155. window.open(info);
  156. }
  157. function schedaEdizione(info){
  158. $("#myModal").empty();
  159. $("#myModal").css("display", "block");
  160. $('#myModal').append("<div class='modal-content'><span class='close'>&times;</span><div id='myInput'>" +
  161. info + "</div><button id='copy_btn' class='btn btn-primary btn-lg' onclick='myFunction()'>Copia</button>");
  162. }
  163. function show_OVI(){
  164. document.getElementById("OVI_info").style.display = "block";
  165. document.getElementById("ASPO_info").style.display = "none";
  166. }
  167. function show_ASPO(){
  168. document.getElementById("OVI_info").style.display = "none";
  169. document.getElementById("ASPO_info").style.display = "block";
  170. }
  171. var header = document.getElementById("choice_buttons");
  172. var btns = header.getElementsByClassName("btn");
  173. for (var i = 0; i < btns.length; i++) {
  174. btns[i].addEventListener("click", function() {
  175. var current = document.getElementsByClassName("active");
  176. current[0].className = current[0].className.replace(" active", "");
  177. this.className += " active";
  178. });
  179. }
  180. $(document).on("click", ".close", function (ev) {
  181. var link = this.id;
  182. //alert(nome_autore);
  183. //$('#myModal').text("");
  184. $("#myModal").css("display", "none");
  185. });
  186. function copyToClipboard(text) {
  187. var sampleTextarea = document.createElement("textarea");
  188. document.body.appendChild(sampleTextarea);
  189. sampleTextarea.value = text; //save main text in it
  190. sampleTextarea.select(); //select textarea contenrs
  191. document.execCommand("copy");
  192. document.body.removeChild(sampleTextarea);
  193. }
  194. function myFunction(){
  195. var copy = document.getElementById("myInput");
  196. copyText = copy.textContent;
  197. copyToClipboard(copyText);
  198. //copyToClipboard(copyText.value);
  199. }