10
0
mirror of https://github.com/LCPQ/QUESTDB_website.git synced 2025-01-12 22:18:29 +01:00

Dynamic data loading for select depending on previous selects selection

This commit is contained in:
Mickaël Véril 2020-01-28 11:41:06 +01:00
parent f1d04d4f29
commit ed403e92f9

View File

@ -85,7 +85,7 @@ draft: false
window.defaultDats = window.defaultDats.concat(sub) window.defaultDats = window.defaultDats.concat(sub)
} }
processingIndicator.isActive = false processingIndicator.isActive = false
await reloadSelect() reloadCustomFiles()
} }
async function reloadCustomFiles() { async function reloadCustomFiles() {
window.dats = window.defaultDats; window.dats = window.defaultDats;
@ -98,41 +98,78 @@ draft: false
} }
} }
} }
reloadSelect("DOI")
} }
async function clearSelect() { async function clearSelect(BeforeName = null) {
$('#form_dat > fieldset > div > select,#sel_ref').each(function () { var selects = ((BeforeName == null) ? getAllSelect() : getAllSelectAfter(BeforeName, true))
selects.add($('#sel_ref'))
selects.each(function () {
$(this).empty() $(this).empty()
}) })
} }
async function reloadSelect() {
reloadCustomFiles() function getAllSelect() {
clearSelect() return $('#form_dat > fieldset > div > select')
$('#form_dat > fieldset > div > select').each(async function () {
const vals = uniq(window.dats.map((d) => {
switch ($(this).attr("name")) {
case "method":
return d.method.name
break;
case "basis":
return d.method.basis
case "DOI":
return d.DOI.string
default:
return d[$(this).attr("name")]
break;
} }
}))
var sets = await getSets() function getAllSelectAfter(Name, include=false) {
const selects=getAllSelect()
var index = selects.index($(`[name="${Name}"]`))
if (!include) {
index++
}
return selects.slice(index)
}
function getAllSelectBefore(Name, include = false) {
const selects=getAllSelect()
var index = selects.index($(`[name="${Name}"]`))
if (include) {
index++
}
return selects.slice(0, index)
}
async function reloadNextSelect(e) {
const afters=getAllSelectAfter(e.target.name)
const isLast=afters.length==0
if (!isLast) {
await reloadSelect(afters.prop("name"))
}
var submit=$(e.target.form).find(':submit')
submit.prop("disabled",!isLast)
}
async function reloadSelect(name) {
clearSelect(name)
var selects = getAllSelectBefore(name, true)
var currentselect = selects.last()
selects = selects.slice(0,selects.length-1)
const vals = uniq(window.dats.filter(d => {
return Array.from(selects).every((el)=>{
return $(el).val().includes(getSelectValue(d, el.name))
})
}).map((d) => getSelectValue(d, name)))
const sets=(name==="DOI") ? await getSets() : undefined
for (const val of vals) { for (const val of vals) {
if (val !== null) { if (val !== null) {
$("<option/>", { $("<option/>", {
value: JSON.stringify(val) value: val
}).text(($(this).attr("name") === "DOI" && sets.has(val)) ? sets.get(val) : val.toString()).appendTo(this) }).text((name === "DOI" && sets.has(val)) ? sets.get(val) : val.toString()).appendTo(currentselect)
} }
} }
}) }
$('#form_dat > input[type="submit"').prop('disabled', false); function getSelectValue(data, name) {
processingIndicator.isActive = false switch (name) {
case "method":
return data.method.name
break;
case "basis":
return data.method.basis
case "DOI":
return data.DOI.string
default:
return data[name]
break;
}
} }
async function reloadStat() { async function reloadStat() {
processingIndicator.isActive = true processingIndicator.isActive = true
@ -253,22 +290,7 @@ draft: false
if (typeof values == "undefined" || values == null) { if (typeof values == "undefined" || values == null) {
return false return false
} }
var val = null return values.includes(getSelectValue(d,prop))
switch (prop) {
case "method":
val = d.method.name
break;
case "basis":
val = d.method.basis
break;
case "DOI":
val = d.DOI.string
break;
default:
val = d[prop]
break;
}
return values.includes(JSON.stringify(val))
delete (val) delete (val)
}) })
}) })
@ -428,34 +450,34 @@ draft: false
<legend>Import custom files</legend> <legend>Import custom files</legend>
<div> <div>
<label for="absFiles_input">Add custom absorption data files</label> <label for="absFiles_input">Add custom absorption data files</label>
<input type="file" multiple onchange="reloadSelect()" id="absFiles_input" name="file_abs"></input> <input type="file" multiple onchange="reloadCustomFiles()" id="absFiles_input" name="file_abs"></input>
</div> </div>
<div> <div>
<label for="fluoFiles_input">Add custom fluorescence data files</label> <label for="fluoFiles_input">Add custom fluorescence data files</label>
<input type="file" multiple onchange="reloadSelect()" id="fluoFiles_input" name="file_fluo"></input> <input type="file" multiple onchange="reloadCustomFiles()" id="fluoFiles_input" name="file_fluo"></input>
</div> </div>
</fieldset> </fieldset>
<fieldset class="table"> <fieldset class="table">
<div style="display: inline-block;"> <div style="display: inline-block;">
<label for="DOI_select">Sets</label> <label for="DOI_select">Sets</label>
<button class="SelectAll" type="button" onclick="selectSelectAll_click(event)">Select all</button> <button class="SelectAll" type="button" onclick="selectSelectAll_click(event)">Select all</button>
<select multiple id="DOI_select" name="DOI"></select> <select multiple id="DOI_select" name="DOI" onchange="reloadNextSelect(event)"></select>
</div> </div>
<div style="display:inline-block"> <div style="display:inline-block">
<label for="mol_select">Molecules</label> <label for="mol_select">Molecules</label>
<button class="SelectAll" type="button" onclick="selectSelectAll_click(event)">Select all</button> <button class="SelectAll" type="button" onclick="selectSelectAll_click(event)">Select all</button>
<select multiple id="mol_select" name="molecule"></select> <select multiple id="mol_select" name="molecule" onchange="reloadNextSelect(event)"></select>
</div> </div>
<br /> <br />
<div style="display: inline-block;"> <div style="display: inline-block;">
<label for="method_select">Methods</label> <label for="method_select">Methods</label>
<button class="SelectAll" type="button" onclick="selectSelectAll_click(event)">Select all</button> <button class="SelectAll" type="button" onclick="selectSelectAll_click(event)">Select all</button>
<select multiple id="method_select" name="method"></select> <select multiple id="method_select" name="method" onchange="reloadNextSelect(event)"></select>
</div> </div>
<div style="display: inline-block;"> <div style="display: inline-block;">
<label for="basis_select">Basis sets</label> <label for="basis_select">Basis sets</label>
<button class="SelectAll" type="button" onclick="selectSelectAll_click(event)">Select all</button> <button class="SelectAll" type="button" onclick="selectSelectAll_click(event)">Select all</button>
<select multiple id="basis_select" name="basis"></select> <select multiple id="basis_select" name="basis" onchange="reloadNextSelect(event)"></select>
</div> </div>
</fieldset> </fieldset>
<fieldset> <fieldset>