fixed fields
This commit is contained in:
@@ -97,6 +97,31 @@ if (!$template) {
|
||||
<ul id="associationsList" class="list-group border p-3"></ul>
|
||||
</div>
|
||||
|
||||
<!-- Default Values (Fixed fields) -->
|
||||
<div class="mt-4">
|
||||
<h5>Default Values (Fixed fields)</h5>
|
||||
|
||||
<div class="row g-3">
|
||||
<div class="col-md-6">
|
||||
<label class="form-label">MoltiplicatorePrezzo (default)</label>
|
||||
<select id="defaultMoltiplicatorePrezzo" class="form-select">
|
||||
<option value="">Loading...</option>
|
||||
</select>
|
||||
<small class="text-muted">Loaded from API: get_moltiplicatoreprezzo.php</small>
|
||||
</div>
|
||||
|
||||
<div class="col-md-6">
|
||||
<label class="form-label">ConsegnaRichiesta (default)</label>
|
||||
<input type="date" id="defaultConsegnaRichiesta" class="form-control">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="mt-3">
|
||||
<button class="btn btn-success" id="saveDefaultsBtn">💾 Save defaults</button>
|
||||
<span id="defaultsStatus" class="ms-2 text-muted"></span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Save Button -->
|
||||
<div class="mt-4 text-end">
|
||||
<a href="templates_dashboard.php" class="btn btn-primary">⬅ Back to Template Dashboard</a>
|
||||
@@ -273,7 +298,7 @@ if (!$template) {
|
||||
}
|
||||
})
|
||||
.catch(error => console.error('Error loading table columns:', error));
|
||||
*/
|
||||
*/
|
||||
/** =======================
|
||||
* CARICAMENTO MAPPATURE GIÀ ESISTENTI
|
||||
* ======================= */
|
||||
@@ -441,6 +466,97 @@ if (!$template) {
|
||||
})
|
||||
.catch(error => console.error("❌ Fetch error:", error));
|
||||
}
|
||||
|
||||
/** =======================
|
||||
* DEFAULTS (Fixed fields)
|
||||
* - stored in localStorage for now
|
||||
* ======================= */
|
||||
|
||||
const defaultsKey = "tpl_defaults_" + templateId;
|
||||
|
||||
function loadDefaultsFromLocal() {
|
||||
try {
|
||||
const raw = localStorage.getItem(defaultsKey);
|
||||
if (!raw) return;
|
||||
const saved = JSON.parse(raw);
|
||||
|
||||
if (saved && typeof saved === "object") {
|
||||
if (saved.moltiplicatore_prezzo_id !== undefined) {
|
||||
document.getElementById('defaultMoltiplicatorePrezzo').value = saved.moltiplicatore_prezzo_id || "";
|
||||
}
|
||||
if (saved.consegna_richiesta !== undefined) {
|
||||
document.getElementById('defaultConsegnaRichiesta').value = saved.consegna_richiesta || "";
|
||||
}
|
||||
}
|
||||
} catch (e) {
|
||||
console.warn("⚠️ Cannot parse saved defaults:", e);
|
||||
}
|
||||
}
|
||||
|
||||
function saveDefaultsToLocal() {
|
||||
const moltiplicatoreId = document.getElementById('defaultMoltiplicatorePrezzo').value || "";
|
||||
const consegna = document.getElementById('defaultConsegnaRichiesta').value || "";
|
||||
|
||||
const payload = {
|
||||
moltiplicatore_prezzo_id: moltiplicatoreId,
|
||||
consegna_richiesta: consegna
|
||||
};
|
||||
|
||||
localStorage.setItem(defaultsKey, JSON.stringify(payload));
|
||||
|
||||
const status = document.getElementById('defaultsStatus');
|
||||
status.textContent = "✅ Defaults saved for this template (local)";
|
||||
setTimeout(() => status.textContent = "", 2500);
|
||||
}
|
||||
|
||||
function loadMoltiplicatoriPrezzo() {
|
||||
const select = document.getElementById('defaultMoltiplicatorePrezzo');
|
||||
select.innerHTML = `<option value="">-- Select --</option>`;
|
||||
|
||||
fetch('get_moltiplicatoreprezzo.php')
|
||||
.then(r => r.json())
|
||||
.then(data => {
|
||||
// OData tipico: { value: [...] }
|
||||
const rows = Array.isArray(data?.value) ? data.value : (Array.isArray(data) ? data : []);
|
||||
if (!rows.length) {
|
||||
select.innerHTML = `<option value="">(No data)</option>`;
|
||||
return;
|
||||
}
|
||||
|
||||
rows.forEach(item => {
|
||||
// ⚠️ Qui i nomi campi dipendono dal JSON reale:
|
||||
// - id: item.Id / item.ID / item.idMoltiplicatorePrezzo
|
||||
// - label: item.Descrizione / item.Nome / item.Codice
|
||||
const id = item.IdMoltiplicatorePrezzo;
|
||||
const label = `${item.Descrizione} (x${item.Fattore})`;
|
||||
|
||||
|
||||
if (id === undefined || id === null) return;
|
||||
|
||||
const opt = document.createElement('option');
|
||||
opt.value = String(id);
|
||||
opt.textContent = String(label);
|
||||
select.appendChild(opt);
|
||||
});
|
||||
|
||||
// dopo aver popolato, prova a rimettere il valore salvato
|
||||
loadDefaultsFromLocal();
|
||||
})
|
||||
.catch(err => {
|
||||
console.error("❌ Error loading MoltiplicatorePrezzo:", err);
|
||||
select.innerHTML = `<option value="">(Load error)</option>`;
|
||||
});
|
||||
}
|
||||
|
||||
// Events
|
||||
document.getElementById('saveDefaultsBtn').addEventListener('click', function() {
|
||||
saveDefaultsToLocal();
|
||||
});
|
||||
|
||||
// Init
|
||||
loadMoltiplicatoriPrezzo();
|
||||
loadDefaultsFromLocal();
|
||||
|
||||
});
|
||||
</script>
|
||||
</body>
|
||||
|
||||
Reference in New Issue
Block a user