nopaque/web/app/static/js/nopaque.callbacks.js

124 lines
5.4 KiB
JavaScript
Raw Normal View History

2020-06-26 10:04:54 +02:00
// This callback is called on a socket.on "corpus_analysis_send_meta_data".
// Handels incoming corpus metadata
function recvMetaData(payload) {
results.metaData.init(payload)
console.log(results.metaData);
}
2020-06-26 10:04:54 +02:00
// This callback is called in socket.on "corpus_analysis_inspect_match" but
// only if the response.type is "sub-results".
// Saves the incoming inspect match results into results.subResultsData.
2020-06-25 10:51:51 +02:00
function saveSubResultsChoices(response) {
console.log("Recieve match with context");
results.subResultsData.init();
results.subResultsData.matches.push(...response.payload.matches);
results.subResultsData.addData(response.payload.cpos_lookup, "cpos_lookup");
results.subResultsData.addData(response.payload.text_lookup, "text_lookup");
results.subResultsData.addData(results.metaData);
results.subResultsData.query = results.data.query;
results.subResultsData.corpus_type = "sub-results";
results.subResultsData.match_count = [...response.payload.matches].length;
results.subResultsData.cpos_ranges = response.payload.cpos_ranges;
console.log(results.subResultsData);
subResultsCreateElement.getElementsByClassName("button-icon-spinner")[0].remove();
subResultsCreateElement.getElementsByTagName("i")[0].classList.remove("hide");
subResultsCreateElement.firstElementChild.classList.add("disabled");
2020-06-25 17:44:55 +02:00
subResultsExportElement.classList.remove("disabled", "btn-flat");
subResultsExportElement.classList.add("pulse", "btn-small");
setTimeout(() => {
subResultsExportElement.classList.remove("pulse", "btn-small");
subResultsExportElement.classList.add("btn-flat");
clearTimeout();
}, 3000)
}
2020-06-26 10:04:54 +02:00
// This callback is called on socket.on "query".
// Does some hiding, showing disabling etc.
2020-03-31 10:17:04 +02:00
function querySetup(payload) {
2020-04-09 10:17:04 +02:00
// some hiding and resetting
2020-06-25 10:51:51 +02:00
let textarea = subResultsIdListElement.getElementsByTagName("textarea")[0];
textarea.innerText = "";
M.textareaAutoResize(textarea);
2020-06-29 11:09:12 +02:00
nrMarkedMatches.innerText = 0;
2020-06-25 10:51:51 +02:00
results.jsList.addToSubResultsStatus = {};
results.jsList.addToSubResultsIdsToShow = new Set();
2020-04-01 13:44:06 +02:00
queryResultsExportElement.classList.add("disabled");
2020-06-25 10:51:51 +02:00
addToSubResultsElement.setAttribute("disabled", "");
2020-03-31 10:17:04 +02:00
queryResultsDeterminateElement.style.width = "0%";
2020-03-31 10:27:26 +02:00
queryResultsProgressElement.classList.remove("hide");
2020-04-01 13:44:06 +02:00
queryResultsUserFeedbackElement.classList.remove("hide");
2020-04-08 11:37:34 +02:00
// some initial values
2020-04-01 13:44:06 +02:00
receivedMatchCountElement.innerText = "0";
textLookupCountElement.innerText = "0";
matchCountElement.innerText = payload.match_count;
2020-06-19 12:30:05 +02:00
textTitlesElement.innterText = "";
2020-04-01 13:44:06 +02:00
// always re initializes results to delete old results from it
2020-04-08 11:37:34 +02:00
// this has to be done here again because the last chunk from old results was still being recieved
2020-04-09 10:17:04 +02:00
results.clearAll()
2020-04-07 13:13:48 +02:00
// Get query string again
results.data.getQueryStr(queryFormElement);
results.data.match_count = payload.match_count;
2020-03-31 10:17:04 +02:00
}
2020-06-26 10:04:54 +02:00
// This callback is called on socket.on "query_results"
// this handels the incoming result chunks
function queryRenderResults(payload, imported=false) {
2020-04-08 11:37:34 +02:00
let resultItems; // array of built html result items row element
2020-04-01 13:44:06 +02:00
// This is called when results are transmitted and being recieved
console.log("Current recieved chunk:", payload.chunk);
2020-04-02 14:22:03 +02:00
if (payload.chunk.cpos_ranges == true) {
results.data["cpos_ranges"] = true;
2020-04-02 14:22:03 +02:00
} else {
results.data["cpos_ranges"] = false;
2020-04-02 14:22:03 +02:00
}
2020-04-01 13:44:06 +02:00
// update progress bar
2020-03-31 10:17:04 +02:00
queryResultsDeterminateElement.style.width = `${payload.progress}%`;
2020-04-01 13:44:06 +02:00
// building the result list js list from incoming chunk
resultItems = []; // list for holding every row item
// get infos for full match row
for (let [index, match] of payload.chunk.matches.entries()) {
resultItems.push({...match, ...{"index": index + results.data.matches.length}});
2020-04-01 13:44:06 +02:00
}
results.jsList.add(resultItems, (items) => {
2020-04-01 13:44:06 +02:00
for (let item of items) {
item.elm = results.jsList.createResultRowElement(item, payload.chunk);
2020-04-01 13:44:06 +02:00
}
results.jsList.update();
results.jsList.changeContext(); // sets lr context on first result load
2020-04-01 13:44:06 +02:00
});
2020-03-31 10:17:04 +02:00
// incorporating new chunk results into full results
results.data.matches.push(...payload.chunk.matches);
Object.assign(results.data.cpos_lookup, payload.chunk.cpos_lookup);
Object.assign(results.data.text_lookup, payload.chunk.text_lookup);
2020-04-01 13:44:06 +02:00
// show user current and total match count
receivedMatchCountElement.innerText = `${results.data.matches.length}`;
textLookupCountElement.innerText = `${Object.keys(results.data.text_lookup).length}`;
2020-06-19 12:30:05 +02:00
let titles = new Array();
for (let [key, value] of Object.entries(results.data.text_lookup)) {
titles.push(`${value.title} (${value.publishing_year})`);
};
textTitlesElement.innerText = `${titles.join(", ")}`;
console.log("Results recieved:", results.data);
2020-04-06 12:41:23 +02:00
// upate progress status
progress = payload.progress; // global declaration
if (progress === 100 && !imported) {
2020-04-06 12:41:23 +02:00
queryResultsProgressElement.classList.add("hide");
queryResultsUserFeedbackElement.classList.add("hide");
queryResultsExportElement.classList.remove("disabled");
2020-06-25 10:51:51 +02:00
addToSubResultsElement.removeAttribute("disabled");
// inital expert mode check and sub results activation
results.jsList.activateInspect();
2020-06-25 10:51:51 +02:00
if (addToSubResultsElement.checked) {
results.jsList.activateAddToSubResults();
2020-06-19 12:30:05 +02:00
}
if (expertModeSwitchElement.checked) {
results.jsList.expertModeOn("query-display");
}
} else if (imported) {
results.jsList.activateInspect();
if (expertModeSwitchElement.checked) {
results.jsList.expertModeOn("query-display");
}
2020-04-06 12:52:26 +02:00
}
2020-03-31 10:17:04 +02:00
}