diff --git a/webgis/js/components/SiteSheet.js b/webgis/js/components/SiteSheet.js
index a423ede..be0d0ef 100644
--- a/webgis/js/components/SiteSheet.js
+++ b/webgis/js/components/SiteSheet.js
@@ -3,13 +3,21 @@
* @class SiteSheet
*/
export class SiteSheet {
+ biblioElements = [];
+ /*
+ constructor(data) {
+ this._siteData = data;
+ }
+ */
/**
* @param {object} data
*/
set siteData(data) {
this._siteData = data;
}
-
+ /**
+ * @returns {string} HTML
+ */
render() {
return `
@@ -33,6 +41,13 @@ export class SiteSheet {
Anno di ritrovamento | ${this._siteData.finding} |
Materiali rinvenuti | ${this._siteData.materials} |
Luogo custodia materiali | ${this._siteData.conservationPlace} |
+ Bibliografia |
+
+
+ ${this.biblio()}
+
+ |
+
Descrizione |
${this._siteData.description} |
@@ -60,6 +75,13 @@ export class SiteSheet {
Località generica: ${this._siteData.genericPlace}
+
+
+
+
+ Bibliografia: ${this.biblio()}
+
+
${this._siteData.shortDescription}
@@ -68,4 +90,36 @@ export class SiteSheet {
`;
}
+
+ biblio() {
+ let citations = '';
+
+ if (this._siteData.bibliography.length) {
+ this._siteData.bibliography.forEach(record => {
+ citations += `
+
+ ${record.citation.toLowerCase()},
+ ${record.pages};
+ `;
+
+ this.biblioElements.push(`
+
+ `
+ );
+ });
+ }
+
+ return citations.trim().slice(0, -1);
+ }
+
+ getReference(id) {
+ return this.biblioElements.find(ref => {
+ let regex = new RegExp('ref-'+id+'"');
+ return ref.match(regex);
+ });
+ }
}
\ No newline at end of file
diff --git a/webgis/js/controllers/biblio_controller.js b/webgis/js/controllers/biblio_controller.js
index ff78870..cfb05b2 100644
--- a/webgis/js/controllers/biblio_controller.js
+++ b/webgis/js/controllers/biblio_controller.js
@@ -5,11 +5,16 @@ export default class extends Controller {
open(event) {
const biblio = window.Biblio;
- const target = event.currentTarget;
- const id = target.id.replace('cit-', '');
-
- this.biblioTarget.innerHTML = '
';
- this.biblioTarget.innerHTML += biblio.getReference(id);
+ this.trigger = event.currentTarget;
+ const id = this.trigger.id.replace('cit-', '');
+ this.ref = this.biblioTarget;
+
+ if (this.trigger.parentElement.nodeName === 'TD') {
+ this.ref = this.biblioTargets.find(t => t.id === 'biblio-detail');
+ }
+
+ this.ref.innerHTML = '
';
+ this.ref.innerHTML += biblio.getReference(id);
this.showBiblio();
}
@@ -19,11 +24,12 @@ export default class extends Controller {
}
showBiblio() {
- this.biblioTarget.classList.remove('is-hidden');
- this.biblioTarget.scrollIntoView({behavior: 'smooth'});
+ this.ref.classList.remove('is-hidden');
+ this.ref.scrollIntoView({behavior: 'smooth'});
}
hideBiblio() {
- this.biblioTarget.classList.add('is-hidden');
+ this.ref.classList.add('is-hidden');
+ this.trigger.parentElement.scrollIntoView({behavior: 'smooth'});
}
}
diff --git a/webgis/js/controllers/menu_controller.js b/webgis/js/controllers/menu_controller.js
index 183e79d..44b0d4e 100644
--- a/webgis/js/controllers/menu_controller.js
+++ b/webgis/js/controllers/menu_controller.js
@@ -4,15 +4,7 @@ export default class extends Controller {
static targets = ['list', 'menu', 'icon'];
toggleMenu() {
- /*
- const target = event.currentTarget;
- const id = target.getAttribute('data-id');
- const icon = this.iconTargets.find(i => i.getAttribute('data-id') === id);
- */
-
this.menuTarget.classList.toggle('is-hidden');
- //this.toggleIcon(icon);
- //this.openList(`#${id}-list`);
}
close() {
diff --git a/webgis/js/ui.js b/webgis/js/ui.js
index 60f5dd1..9415541 100644
--- a/webgis/js/ui.js
+++ b/webgis/js/ui.js
@@ -108,6 +108,7 @@ UI.openSiteModal = async function (data, selector) {
}
let siteSheet = new SiteSheet();
siteSheet.siteData = data;
+ window.Biblio = siteSheet;
modal.querySelector('#short-sheet').innerHTML = siteSheet.renderShort();
if (data.description) {