Update findings + menu layout (WIP)

This commit is contained in:
2024-11-25 18:30:28 +01:00
parent 08711db11a
commit e3fe2f1b94
9 changed files with 267 additions and 51 deletions

View File

@@ -2,11 +2,14 @@
* @class Finding
*/
export class Finding {
biblioElements = [];
images = null;
set data(data) {
this._data = data;
}
render() {
async render() {
return `
<div class="container px-4 pt-4">
<p class="p-2">
@@ -36,6 +39,13 @@ export class Finding {
<p class="p-2">
<strong>Luogo di conservazione</strong> ${this._data.conservationPlace}
</p>
<p class="mt-4 pl-2 pr-5">
<span class="icon has-text-link">
<i class="fa fa-book"></i>
</span>
<strong>Bibliografia:</strong> ${await this.biblio(this._data.id)}
</p>
<div class="notification is-light mx-3 mt-4 mb-0 p-2 is-hidden" id="biblio"></div>
<p class="mt-4 pl-2 pr-5">
<strong class="pb-3">Descrizione</strong></br>
${this._data.description}
@@ -45,4 +55,70 @@ export class Finding {
</p>
</div>`;
}
renderImages() {
let content = `<div class="content has-text-centered">
<p class="is-size-5 mt-3">Immagini</p>`;
content += `
<div style="max-width: 70%; margin: 0 auto">
<p class="is-size-6 has-text-centered">Cliccare sull'immagine per aprire la gallery</p>
<figure class="is-relative is-clickable has-text-centered" id="finding-gallery">
<img src="img/${this.images[0].filename}" width="300"/>
<div class="icon overlay is-flex is-justify-content-center is-align-items-center">
<i class="is-flex fa fa-2x fa-play-circle"></i>
</div>
</figure>
</div>
</div>
`;
return content;
}
async setImages() {
let record = await this.fetchData(`${window.API_URL}/finding/${this._data.id}`)
if (record.images.length) {
this.images = record.images;
}
}
/**
* @param {number} recordId
*/
async biblio(recordId) {
let record = await this.fetchData(`${window.API_URL}/finding/${recordId}`);
let citations = '';
if (record.bibliography.length) {
record.bibliography.forEach(record => {
citations += `
<span class="is-clickable is-capitalized has-text-link"
id="cit-${record.id}">
${record.citation.toLowerCase()},
</span> ${record.pages};
`;
this.biblioElements.push(`
<div class="p-2 mt-2" id="ref-${record.id}">
<p>${record.reference}</p>
</div>
`
);
});
}
return citations.trim().slice(0, -1);
}
getReference(id) {
return this.biblioElements.find(ref => {
let regex = new RegExp('ref-'+id+'"');
return ref.match(regex);
});
}
async fetchData(url) {
return await fetch(url).then(res => res.json());
}
}

View File

@@ -42,8 +42,7 @@ export class NotConservedSheet {
</span>
<strong>Bibliografia:</strong> ${await this.biblio(this._data.id)}
</p>
<div class="notification is-light mx-3 mt-4 mb-0 p-2 is-hidden" id="biblio">
</div>
<div class="notification is-light mx-3 mt-4 mb-0 p-2 is-hidden" id="biblio"></div>
<p class="p-2 mb-4">
<strong>Autore scheda:</strong> ${this._data.author}
</p>