116 lines
No EOL
4.6 KiB
JavaScript
116 lines
No EOL
4.6 KiB
JavaScript
|
|
// import { processForm } from "./formHandler.js";
|
|
import { basicElements } from "./getHtmlElements.js";
|
|
import { createMarker } from "./markerHandler.js";
|
|
|
|
|
|
export function initEvents(map) {
|
|
|
|
let editMode = false
|
|
let isTmpMarkerSet = false
|
|
let tmpMarkerSet = {}
|
|
|
|
|
|
const [addMarkerBtn, markerFormContainer, markerForm, noticeCoordsPicker, remainingForm] = basicElements()
|
|
|
|
markerForm.addEventListener("submit", processForm);
|
|
|
|
function setStyleForEditing(){
|
|
markerFormContainer.style.display = 'flex';
|
|
//Stile se stiamo inserendo il marker
|
|
noticeCoordsPicker.style.display = 'block'; //messaggio inserimento
|
|
remainingForm.style.display = 'none'; // form dati
|
|
// imposta una X rossa come icona pulsante, come icona cursore un marker e entra nella modalità inserimento.
|
|
document.getElementById("addMarkerBtn").innerHTML = '<img src="../img/xred20.png" alt="Button Image" />';
|
|
document.getElementById('map').style = 'cursor: url("https://unpkg.com/leaflet@1.9.4/dist/images/marker-icon.png") 13 41, auto;';
|
|
}
|
|
|
|
function setStyleNotEditing() {
|
|
markerForm.reset();
|
|
document.getElementById("addMarkerBtn").innerHTML = '<img src="../img/marker-icon18.png" alt="Button Image" />';
|
|
document.getElementById('map').style = 'cursor: auto;';
|
|
noticeCoordsPicker.style.display = 'none'; //messaggio inserimento
|
|
remainingForm.style.display = 'none'; // form dati
|
|
markerFormContainer.style.display = 'none';
|
|
}
|
|
|
|
addMarkerBtn.onclick = function (event) {
|
|
event.stopPropagation();
|
|
if (!editMode) {
|
|
setStyleForEditing()
|
|
editMode = true;
|
|
isTmpMarkerSet = false;
|
|
tmpMarkerSet = {};
|
|
} else {
|
|
setStyleNotEditing();
|
|
editMode = false;
|
|
map.removeLayer(tmpMarkerSet)
|
|
isTmpMarkerSet = false;
|
|
tmpMarkerSet = {};
|
|
}
|
|
};
|
|
|
|
|
|
//event listener onclick on map, display #remainingForm
|
|
map.on("click", function (e) {
|
|
if (editMode && !isTmpMarkerSet) {
|
|
let formInputCoordY = document.getElementById('formInputCoordY')
|
|
let formInputCoordX = document.getElementById('formInputCoordX')
|
|
formInputCoordY.value = e.latlng.lat
|
|
formInputCoordX.value = e.latlng.lng
|
|
noticeCoordsPicker.style.display = 'none';
|
|
remainingForm.style.display = 'block';
|
|
map.getContainer().style.cursor = 'auto';
|
|
const tmpMarker = {
|
|
coordinate: { x: formInputCoordX.value, y: formInputCoordY.value },
|
|
name: '',
|
|
description: '',
|
|
filename: '',
|
|
}
|
|
tmpMarkerSet = createMarker(tmpMarker, L, map, true)
|
|
isTmpMarkerSet = true
|
|
// Va creata la logica di eliminazione del marker tmp
|
|
//localStorage.setItem("tmpMarkerId", marker._leaflet_id);
|
|
}
|
|
})
|
|
|
|
function handleSentFormStyle() {
|
|
document.getElementById("addMarkerBtn").innerHTML = '<img src="../img/marker-icon18.png" alt="Button Image" />';
|
|
document.getElementById('map').style = 'cursor: auto;';
|
|
markerFormContainer.style.display = 'none'; //tutto
|
|
const remainingForm = document.getElementById("remainingForm")
|
|
remainingForm.style.display = 'none';
|
|
document.getElementById("addMarkerBtn").innerHTML = '<img src="../img/marker-icon18.png" alt="Button Image" />';
|
|
document.getElementById("markerFormContainer").style.display = 'none';
|
|
}
|
|
|
|
async function processForm(e) {
|
|
e.preventDefault();
|
|
handleSentFormStyle()
|
|
// imposta un marker come icona pulsante, icona cursore normale e esce dalla modalità inserimento.
|
|
editMode = false;
|
|
isTmpMarkerSet = false;
|
|
const markerForm = document.getElementById("markerForm")
|
|
const formData = new FormData(markerForm)
|
|
markerForm.reset();
|
|
|
|
// const tmpMarker = localStorage.getItem("tmpMarkerId");
|
|
// L.layerGroup().removeLayer(tmpMarker);
|
|
await fetch('/uploadMarker', {
|
|
method: 'POST',
|
|
body: formData,
|
|
}).then(async () => {
|
|
await map.fetchNewMarkers().then( () =>
|
|
map.removeLayer(tmpMarkerSet)
|
|
);
|
|
}
|
|
)
|
|
};
|
|
|
|
}
|
|
|
|
document.getElementById('file-input').addEventListener('change', function () {
|
|
const fileName = this.files[0] ? this.files[0].name : 'No file chosen';
|
|
const truncatedFileName = fileName.length > 21 ? fileName.slice(0, 21) + '...' : fileName;
|
|
document.querySelector('.file-chosen').textContent = truncatedFileName;
|
|
}); |