2020-04-27 16:16:57 +02:00
|
|
|
function recvMetaData(payload) {
|
2020-04-30 15:21:55 +02:00
|
|
|
results.metaData.init(payload)
|
|
|
|
console.log(results.metaData);
|
2020-04-27 16:16:57 +02:00
|
|
|
}
|
|
|
|
|
2020-06-19 15:49:11 +02:00
|
|
|
function saveSubSubcorpusChoices(payload) {
|
|
|
|
console.log("SAVE");
|
|
|
|
console.log(payload);
|
|
|
|
}
|
|
|
|
|
2020-03-31 10:17:04 +02:00
|
|
|
function querySetup(payload) {
|
|
|
|
// This is called when a query was successfull
|
2020-04-09 10:17:04 +02:00
|
|
|
// some hiding and resetting
|
2020-04-01 13:44:06 +02:00
|
|
|
queryResultsExportElement.classList.add("disabled");
|
2020-06-19 12:30:05 +02:00
|
|
|
addToSubSubcorpusElement.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
|
2020-04-30 15:21:55 +02:00
|
|
|
results.data.getQueryStr(queryFormElement);
|
|
|
|
results.data.match_count = payload.match_count;
|
2020-03-31 10:17:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function queryRenderResults(payload) {
|
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) {
|
2020-04-30 15:21:55 +02:00
|
|
|
results.data["cpos_ranges"] = true;
|
2020-04-02 14:22:03 +02:00
|
|
|
} else {
|
2020-04-30 15:21:55 +02:00
|
|
|
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()) {
|
2020-04-30 15:21:55 +02:00
|
|
|
resultItems.push({...match, ...{"index": index + results.data.matches.length}});
|
2020-04-01 13:44:06 +02:00
|
|
|
}
|
2020-04-30 15:21:55 +02:00
|
|
|
results.jsList.add(resultItems, (items) => {
|
2020-04-01 13:44:06 +02:00
|
|
|
for (let item of items) {
|
2020-04-30 15:21:55 +02:00
|
|
|
item.elm = results.jsList.createResultRowElement(item, payload.chunk);
|
2020-04-01 13:44:06 +02:00
|
|
|
}
|
2020-04-30 15:21:55 +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
|
2020-04-30 15:21:55 +02:00
|
|
|
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
|
2020-04-30 15:21:55 +02:00
|
|
|
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(", ")}`;
|
2020-04-30 15:21:55 +02:00
|
|
|
console.log("Results recieved:", results.data);
|
2020-04-06 12:41:23 +02:00
|
|
|
// upate progress status
|
2020-04-06 15:27:25 +02:00
|
|
|
progress = payload.progress; // global declaration
|
|
|
|
if (progress === 100) {
|
2020-04-06 12:41:23 +02:00
|
|
|
queryResultsProgressElement.classList.add("hide");
|
|
|
|
queryResultsUserFeedbackElement.classList.add("hide");
|
|
|
|
queryResultsExportElement.classList.remove("disabled");
|
2020-06-19 12:30:05 +02:00
|
|
|
addToSubSubcorpusElement.removeAttribute("disabled");
|
2020-04-30 15:21:55 +02:00
|
|
|
results.jsList.activateInspect();
|
2020-06-19 12:30:05 +02:00
|
|
|
// inital expert mode check and sub subcorpus activation
|
|
|
|
if (addToSubSubcorpusElement.checked) {
|
|
|
|
results.jsList.activateAddToSubSubcorpus();
|
|
|
|
}
|
|
|
|
if (expertModeSwitchElement.checked) {
|
|
|
|
results.jsList.expertModeOn("query-display");
|
|
|
|
}
|
2020-04-06 12:52:26 +02:00
|
|
|
}
|
2020-03-31 10:17:04 +02:00
|
|
|
}
|