test: browsing dei canti aggiunto a NikBrowseSearchCombined
This commit is contained in:
parent
3f64175b54
commit
87e3205f58
File diff suppressed because it is too large
Load Diff
|
@ -221,7 +221,7 @@ p{
|
||||||
.minimap_container {
|
.minimap_container {
|
||||||
position: fixed;
|
position: fixed;
|
||||||
top: 100px;
|
top: 100px;
|
||||||
left: 1000px;
|
left: 900px;
|
||||||
min-width: 20px;
|
min-width: 20px;
|
||||||
z-index: 100;
|
z-index: 100;
|
||||||
|
|
||||||
|
@ -250,6 +250,7 @@ p{
|
||||||
z-index: 100;
|
z-index: 100;
|
||||||
|
|
||||||
border: 1px solid #0000009a;
|
border: 1px solid #0000009a;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.minimap_content {
|
.minimap_content {
|
||||||
|
|
|
@ -18,19 +18,22 @@ $(document).ready(function() {
|
||||||
$(this).attr("style", 'display:none');
|
$(this).attr("style", 'display:none');
|
||||||
});
|
});
|
||||||
hideListaCanti()
|
hideListaCanti()
|
||||||
|
$( ".minimap_container" ).remove();
|
||||||
activateMenuItem('#cantica1')
|
activateMenuItem('#cantica1')
|
||||||
if (!(primaCanticaLoaded)) {
|
if (!(primaCanticaLoaded)) {
|
||||||
|
|
||||||
jsonQuery = versiCantica("Inferno");
|
jsonQuery = versiCantica("Inferno");
|
||||||
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
||||||
executeQueryVersi(execQuery);
|
executeQueryVersi(execQuery);
|
||||||
primaCanticaLoaded = true;
|
primaCanticaLoaded = true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$("#InfernoCanto_1").attr('style', 'display:block')
|
//$("#InfernoCanto_1").attr('style', 'display:block')
|
||||||
$("#CantiInferno").attr('style', 'display:block')
|
$("#CantiInferno").attr('style', 'display:block')
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -40,16 +43,17 @@ $(document).ready(function() {
|
||||||
$(this).attr("style", 'display:none');
|
$(this).attr("style", 'display:none');
|
||||||
});
|
});
|
||||||
hideListaCanti()
|
hideListaCanti()
|
||||||
|
$( ".minimap_container" ).remove();
|
||||||
activateMenuItem('#cantica2')
|
activateMenuItem('#cantica2')
|
||||||
if (!(secondaCanticaLoaded)) {
|
if (!(secondaCanticaLoaded)) {
|
||||||
|
|
||||||
jsonQuery = versiCantica("Purgatorio");
|
jsonQuery = versiCantica("Purgatorio");
|
||||||
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
||||||
executeQueryVersi(execQuery);
|
executeQueryVersi(execQuery);
|
||||||
secondaCanticaLoaded = true;
|
secondaCanticaLoaded = true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$("#PurgatorioCanto_1").attr('style', 'display:block')
|
//$("#PurgatorioCanto_1").attr('style', 'display:block')
|
||||||
$("#CantiPurgatorio").attr('style', 'display:block')
|
$("#CantiPurgatorio").attr('style', 'display:block')
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -62,16 +66,17 @@ $(document).ready(function() {
|
||||||
$(this).attr("style", 'display:none');
|
$(this).attr("style", 'display:none');
|
||||||
});
|
});
|
||||||
hideListaCanti()
|
hideListaCanti()
|
||||||
|
$( ".minimap_container" ).remove();
|
||||||
activateMenuItem('#cantica3')
|
activateMenuItem('#cantica3')
|
||||||
if (!(terzaCanticaLoaded)) {
|
if (!(terzaCanticaLoaded)) {
|
||||||
|
|
||||||
jsonQuery = versiCantica("Paradiso");
|
jsonQuery = versiCantica("Paradiso");
|
||||||
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
||||||
executeQueryVersi(execQuery);
|
executeQueryVersi(execQuery);
|
||||||
terzaCanticaLoaded = true;
|
terzaCanticaLoaded = true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$("#ParadisoCanto_1").attr('style', 'display:block')
|
//$("#ParadisoCanto_1").attr('style', 'display:block')
|
||||||
$("#CantiParadiso").attr('style', 'display:block')
|
$("#CantiParadiso").attr('style', 'display:block')
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -136,6 +141,7 @@ $(document).ready(function() {
|
||||||
minimap.className = 'minimap_container'
|
minimap.className = 'minimap_container'
|
||||||
minimapSize.className = 'minimap_size'
|
minimapSize.className = 'minimap_size'
|
||||||
viewer.className = 'minimap_viewer'
|
viewer.className = 'minimap_viewer'
|
||||||
|
viewer.id='minimapviewer'
|
||||||
minimapContent.className = 'minimap_content'
|
minimapContent.className = 'minimap_content'
|
||||||
|
|
||||||
minimap.append(minimapSize, viewer, minimapContent);
|
minimap.append(minimapSize, viewer, minimapContent);
|
||||||
|
@ -143,7 +149,7 @@ $(document).ready(function() {
|
||||||
document.body.appendChild(minimap)
|
document.body.appendChild(minimap)
|
||||||
|
|
||||||
let html = document.getElementById(element).innerHTML
|
let html = document.getElementById(element).innerHTML
|
||||||
console.log(html)
|
//console.log(html)
|
||||||
|
|
||||||
let iFrameDoc = minimapContent.contentWindow.document;
|
let iFrameDoc = minimapContent.contentWindow.document;
|
||||||
iFrameDoc.open();
|
iFrameDoc.open();
|
||||||
|
@ -261,18 +267,5 @@ $(document).ready(function() {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
// scroll function
|
|
||||||
/*
|
|
||||||
$(window).scroll(function(e){
|
|
||||||
var $el = $('.blog-masthead');
|
|
||||||
var isPositionFixed = ($el.css('position') == 'fixed');
|
|
||||||
if ($(this).scrollTop() > 10 && !isPositionFixed){
|
|
||||||
$el.css({'position': 'fixed', 'top': '0px'});
|
|
||||||
}
|
|
||||||
if ($(this).scrollTop() < 10 && isPositionFixed){
|
|
||||||
$el.css({'position': 'static', 'top': '0px'});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
*/
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
|
@ -0,0 +1,274 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
$(document).ready(function() {
|
||||||
|
|
||||||
|
|
||||||
|
const sparqlGenerator = sparqljs.Generator;
|
||||||
|
const myEngine = new Comunica.QueryEngine();
|
||||||
|
const sparqlEndpoint = "https://hdnlab1.isti.cnr.it/fuseki/commediaontosintgra/query";
|
||||||
|
var primaCanticaLoaded = false;
|
||||||
|
var secondaCanticaLoaded = false;
|
||||||
|
var terzaCanticaLoaded = false;
|
||||||
|
var listaVersi = new Set()
|
||||||
|
|
||||||
|
//caricamento prima cantica
|
||||||
|
$('#cantica1').on('click', function() {
|
||||||
|
$('.canto').each(function() {
|
||||||
|
$(this).attr("style", 'display:none');
|
||||||
|
});
|
||||||
|
hideListaCanti()
|
||||||
|
$( ".minimap_container" ).remove();
|
||||||
|
//activateMenuItem('#cantica1')
|
||||||
|
if (!(primaCanticaLoaded)) {
|
||||||
|
|
||||||
|
jsonQuery = versiCantica("Inferno");
|
||||||
|
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
||||||
|
executeQueryVersi(execQuery);
|
||||||
|
primaCanticaLoaded = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
//$("#InfernoCanto_1").attr('style', 'display:block')
|
||||||
|
$("#CantiInferno").attr('style', 'display:block')
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
//caricamento seconda cantica
|
||||||
|
$('#cantica2').on('click', function() {
|
||||||
|
$('.canto').each(function() {
|
||||||
|
$(this).attr("style", 'display:none');
|
||||||
|
});
|
||||||
|
hideListaCanti()
|
||||||
|
$( ".minimap_container" ).remove();
|
||||||
|
//activateMenuItem('#cantica2')
|
||||||
|
if (!(secondaCanticaLoaded)) {
|
||||||
|
|
||||||
|
jsonQuery = versiCantica("Purgatorio");
|
||||||
|
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
||||||
|
executeQueryVersi(execQuery);
|
||||||
|
secondaCanticaLoaded = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
//$("#PurgatorioCanto_1").attr('style', 'display:block')
|
||||||
|
$("#CantiPurgatorio").attr('style', 'display:block')
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
//caricamento terza cantica
|
||||||
|
$('#cantica3').on('click', function() {
|
||||||
|
$('.canto').each(function() {
|
||||||
|
$(this).attr("style", 'display:none');
|
||||||
|
});
|
||||||
|
hideListaCanti()
|
||||||
|
$( ".minimap_container" ).remove();
|
||||||
|
//activateMenuItem('#cantica3')
|
||||||
|
if (!(terzaCanticaLoaded)) {
|
||||||
|
|
||||||
|
jsonQuery = versiCantica("Paradiso");
|
||||||
|
execQuery = new sparqlGenerator().stringify(jsonQuery);
|
||||||
|
executeQueryVersi(execQuery);
|
||||||
|
terzaCanticaLoaded = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
//$("#ParadisoCanto_1").attr('style', 'display:block')
|
||||||
|
$("#CantiParadiso").attr('style', 'display:block')
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
jQuery(document).delegate('.navig-canto', 'click', function(e) {
|
||||||
|
$('.canto').each(function() {
|
||||||
|
$(this).attr("style", 'display:none');
|
||||||
|
});
|
||||||
|
$("#" + $(this).attr('name').replace(" ", "_")).attr('style', 'display:block')
|
||||||
|
showMinimap($(this).attr('name').replace(" ", "_"))
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
//Utility functions
|
||||||
|
|
||||||
|
//activate navigation menu items
|
||||||
|
|
||||||
|
function activateMenuItem(menuItem) {
|
||||||
|
$('.blog-nav-item').each(function() {
|
||||||
|
$(this).attr("class", $(this).attr("class").replace(' active', ''));
|
||||||
|
});
|
||||||
|
$(menuItem).attr("class", $(menuItem).attr("class") + ' active');
|
||||||
|
}
|
||||||
|
|
||||||
|
//hides liste canti
|
||||||
|
|
||||||
|
function hideListaCanti() {
|
||||||
|
$("#CantiInferno").attr('style', 'display:none')
|
||||||
|
$("#CantiPurgatorio").attr('style', 'display:none')
|
||||||
|
$("#CantiParadiso").attr('style', 'display:none')
|
||||||
|
}
|
||||||
|
|
||||||
|
// utils
|
||||||
|
function managePunctuation(stringa) {
|
||||||
|
var tempstringa=stringa.replaceAll(" ,", ",")
|
||||||
|
tempstringa=tempstringa.replaceAll(" .", ".")
|
||||||
|
tempstringa=tempstringa.replaceAll(" :", ":")
|
||||||
|
tempstringa=tempstringa.replaceAll(" !", "!")
|
||||||
|
tempstringa=tempstringa.replaceAll(" ?", "?")
|
||||||
|
tempstringa=tempstringa.replaceAll(" ;", ";")
|
||||||
|
return tempstringa
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//minimap management
|
||||||
|
let minimap = document.createElement('div');
|
||||||
|
let minimapSize = document.createElement('div');
|
||||||
|
let viewer = document.createElement('div');
|
||||||
|
let minimapContent = document.createElement('iframe');
|
||||||
|
let scale=0.1;
|
||||||
|
let realScale;
|
||||||
|
|
||||||
|
function showMinimap(element) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
minimap.className = 'minimap_container'
|
||||||
|
minimapSize.className = 'minimap_size'
|
||||||
|
viewer.className = 'minimap_viewer'
|
||||||
|
viewer.id='minimapviewer'
|
||||||
|
minimapContent.className = 'minimap_content'
|
||||||
|
|
||||||
|
minimap.append(minimapSize, viewer, minimapContent);
|
||||||
|
|
||||||
|
document.body.appendChild(minimap)
|
||||||
|
|
||||||
|
let html = document.getElementById(element).innerHTML
|
||||||
|
//console.log(html)
|
||||||
|
|
||||||
|
let iFrameDoc = minimapContent.contentWindow.document;
|
||||||
|
iFrameDoc.open();
|
||||||
|
iFrameDoc.write(html);
|
||||||
|
iFrameDoc.close();
|
||||||
|
|
||||||
|
getDimensions()
|
||||||
|
window.addEventListener('scroll', trackScroll)
|
||||||
|
window.addEventListener('resize', getDimensions)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function getDimensions(){
|
||||||
|
|
||||||
|
let bodyWidth = document.body.clientWidth;
|
||||||
|
let bodyRatio = document.body.clientHeight / bodyWidth;
|
||||||
|
let winRatio = window.innerHeight / window.innerWidth;
|
||||||
|
|
||||||
|
minimap.style.width = '10%';
|
||||||
|
|
||||||
|
realScale = minimap.clientWidth / (bodyWidth);
|
||||||
|
|
||||||
|
minimapSize.style.paddingTop = `${bodyRatio * 100}%`
|
||||||
|
viewer.style.paddingTop = `${winRatio * 100}%`;
|
||||||
|
|
||||||
|
minimapContent.style.transform = `scale(${realScale})`;
|
||||||
|
minimapContent.style.width = `${(100 / realScale)}%`
|
||||||
|
minimapContent.style.height = `${(100 / realScale)}%`
|
||||||
|
}
|
||||||
|
|
||||||
|
function trackScroll(){
|
||||||
|
viewer.style.transform=`translateY(${window.scrollY * realScale}px)`
|
||||||
|
}
|
||||||
|
|
||||||
|
//end minimap management
|
||||||
|
|
||||||
|
async function executeQueryVersi(query) {
|
||||||
|
bindingsStream = await myEngine.queryBindings(query, { sources: [{ type: 'sparql', value: sparqlEndpoint },], });
|
||||||
|
alert(query)
|
||||||
|
try {
|
||||||
|
var listaCanti = new Set()
|
||||||
|
listaVersi = new Set()
|
||||||
|
let cantica = 0;
|
||||||
|
bindingsStream.on('data', (binding) => {
|
||||||
|
//cantica
|
||||||
|
cantica = binding.get('Cantica').value;
|
||||||
|
//la lista dei canti
|
||||||
|
listaCanti.add(binding.get('Canto').value)
|
||||||
|
//la lista dei versi
|
||||||
|
var obj = new Object();
|
||||||
|
obj.numverso = binding.get('NumeroVerso').value;
|
||||||
|
obj.verso = binding.get('Verso').value;
|
||||||
|
obj.canto = binding.get('Canto').value;
|
||||||
|
obj.from = binding.get('from').value;
|
||||||
|
obj.to = binding.get('to').value;
|
||||||
|
listaVersi.add(obj)
|
||||||
|
|
||||||
|
});
|
||||||
|
bindingsStream.on('end', () => {
|
||||||
|
|
||||||
|
var orderedListaCanti = Array.from(listaCanti)
|
||||||
|
orderedListaCanti = orderedListaCanti.sort((a, b) => {
|
||||||
|
if (parseInt(a.split(" ")[1]) < parseInt(b.split(" ")[1])) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
var orderedListaVersi = Array.from(listaVersi)
|
||||||
|
orderedListaVersi = orderedListaVersi.sort((a, b) => {
|
||||||
|
if (parseInt(a.numverso) < parseInt(b.numverso)) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
var divListaCanti = $('<DIV id="Canti' + cantica + '" />')
|
||||||
|
for (canto of orderedListaCanti) {
|
||||||
|
var licanto = $('<li class="navig-canto"/>')
|
||||||
|
/*
|
||||||
|
licanto.attr('name', cantica + canto)
|
||||||
|
licanto.attr('href', "#")
|
||||||
|
licanto.attr("style", "line-height: 1.2em")
|
||||||
|
licanto.append(canto)
|
||||||
|
|
||||||
|
|
||||||
|
licanto.appendTo(divListaCanti)
|
||||||
|
*/
|
||||||
|
var divcanto = $('<div />')
|
||||||
|
var titolocanto = $('<div class="measure f3 lh-copy text-primary font-weight-lighter titolo-canto" />')
|
||||||
|
//<div class="measure f6 lh-copy text-secondary font-weight-lighter labelCanto">
|
||||||
|
titolocanto.append(canto)
|
||||||
|
divcanto.attr('class', 'canto f6 font-weight-lighter')
|
||||||
|
divcanto.attr('style', 'display:none')
|
||||||
|
divcanto.attr('id', (cantica + canto).replace(" ", "_"))
|
||||||
|
titolocanto.appendTo(divcanto)
|
||||||
|
divcanto.appendTo(' .areacanti')
|
||||||
|
}
|
||||||
|
//divListaCanti.appendTo('#listacanti')
|
||||||
|
|
||||||
|
for (verso of orderedListaVersi) {
|
||||||
|
|
||||||
|
|
||||||
|
var elementoverso = $('<p />')
|
||||||
|
elementoverso.append(verso.numverso + ". " + managePunctuation(verso.verso))
|
||||||
|
elementoverso.attr("style", "line-height: 0.5em")
|
||||||
|
elementoverso.attr('class', 'f6 font-weight-lighter')
|
||||||
|
elementoverso.appendTo('#' + cantica + verso.canto.replace(" ", "_"))
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
console.log(err.message);
|
||||||
|
$("#loader").hide();
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
});
|
Loading…
Reference in New Issue