Intermediate push

This commit is contained in:
Stephan Porada 2020-09-09 16:01:12 +02:00
parent 9ae74cc9de
commit 1e316d6852
4 changed files with 77 additions and 169 deletions

View File

@ -90,7 +90,7 @@ def query_result(query_result_id):
@login_required @login_required
def inspect_query_result(query_result_id): def inspect_query_result(query_result_id):
''' '''
View to inspect one importe result file in a corpus analysis like interface View to inspect imported result file in a corpus analysis like interface
''' '''
query_result = QueryResult.query.get_or_404(query_result_id) query_result = QueryResult.query.get_or_404(query_result_id)
query_metadata = query_result.query_metadata query_metadata = query_result.query_metadata

View File

@ -28,7 +28,7 @@ function prepareQueryData() {
/** /**
* This callbacks saves the incoming query data chunks into the model results. * This callbacks saves the incoming query data chunks into the model results.
*/ */
function saveQueryData(args) { function saveQueryData() {
let [payload, client, results, rest] = arguments; let [payload, client, results, rest] = arguments;
// get data matches length before new chun kdata is being inserted // get data matches length before new chun kdata is being inserted
let dataLength = results.data.matches.length; let dataLength = results.data.matches.length;
@ -51,14 +51,14 @@ function saveQueryData(args) {
} }
} }
function getResultsData(args) { function getResultsData() {
let [resultsType, dataIndexes, client, results, rest] = arguments; let [resultsType, dataIndexes, client, results, rest] = arguments;
client.isBusy = true; client.isBusy = true;
client.notifyView('results-data-recieving'); client.notifyView('results-data-recieving');
client.getResultsData(resultsType, dataIndexes, results); client.getResultsData(resultsType, dataIndexes, results);
} }
function saveResultsData(args) { function saveResultsData() {
let [payload, type, client, results, rest] = arguments; let [payload, type, client, results, rest] = arguments;
let objectKey = ''; let objectKey = '';
if (type === 'full-results') { if (type === 'full-results') {

View File

@ -75,11 +75,11 @@ function recieveMetaData(type, client) {
* Also prepares the result.jsList for the incoming data. * Also prepares the result.jsList for the incoming data.
*/ */
function recieveQueryStatus(type, client) { function recieveQueryStatus(type, client) {
client.socket.on(type, (response) => {
/** /**
* Check if request for session was OK. * Check if request for session was OK.
* If OK execute registered callbacks and notify View. * If OK execute registered callbacks and notify View.
*/ */
client.socket.on(type, (response) => {
if (response.code === 200) { if (response.code === 200) {
console.group('corpus_analysis_query: Client recieving query process', console.group('corpus_analysis_query: Client recieving query process',
'status via socket.on'); 'status via socket.on');
@ -109,7 +109,6 @@ function recieveQueryData(type, client) {
* Check if request for session was OK. * Check if request for session was OK.
* If OK execute registered callbacks and notify View. * If OK execute registered callbacks and notify View.
*/ */
if (client.dynamicMode) {
client.socket.on(type, (response) => { client.socket.on(type, (response) => {
if (response.code === 200) { if (response.code === 200) {
console.group('corpus_analysis_query_results: Recieveing query data') console.group('corpus_analysis_query_results: Recieveing query data')
@ -129,13 +128,6 @@ function recieveQueryData(type, client) {
console.groupEnd(); console.groupEnd();
} }
}); });
} else {
console.group('corpus_analysis_query_results: Loading query data.');
console.info('Client loading imported query data from database.');
// executing the registered callbacks
client.eventListeners[type].executeCallbacks();
console.groupEnd();
}
} }
/** /**

View File

@ -57,166 +57,82 @@
<script type="module"> <script type="module">
/** /**
* First Phase: * First Phase:
* document content is loaded and scripts are being imported and executed * Document content is loaded and scripts are being imported and executed.
*/ */
import {
CorpusAnalysisClient, // Import Client classes. Client handles the server client communication.
CorpusAnalysisDisplay, import {
SocketEventListener, Client,
ClientEventListener,
ListenerCallback, ListenerCallback,
} from '../../static/js/modules/nopaque.CorpusAnalysisClient.js'; } from '../../static/js/modules/corpus_analysis/client/Client.js';
import { /**
recieveSession, * Import Client listener functions which will listen for defined socket or
* javascript events.
*/
import {
recieveQueryStatus, recieveQueryStatus,
recieveQueryData, recieveQueryData,
} from '../../static/js/modules/nopaque.listenerFunctions.js'; } from '../../static/js/modules/corpus_analysis/client/listeners.js';
import { // Import client listener callbacks so they can be registered to the listeners.
querySetup, import {
queryRenderResults, prepareQueryData,
} from '../../static/js/modules/nopaque.listenerCallbacks.js' saveQueryData,
import { } from '../../static/js/modules/corpus_analysis/client/callbacks.js';
// Import Results class which will be used to save results data of a query etc.
import {
Results, Results,
Data, } from '../../static/js/modules/corpus_analysis/model/Results.js';
MetaData, /**
} from '../../static/js/nopaque.Results.js'; * Import the ResultsList which can be understood as a View class that handles
import { * how the data from Results is represented to the user. The ViewEventListener
* is used to register listener functions which listen for events emitred by
* the Client.
*/
import {
ResultsList, ResultsList,
} from '../../static/js/nopaque.lists.js'; ViewEventListener,
import { } from '../../static/js/modules/corpus_analysis/view/ResultsView.js';
import {
scrollToTop, scrollToTop,
} from '../../static/js/modules/nopaque.scrollToTop.js'; } from '../../static/js/modules/corpus_analysis/view/scrollToTop.js'
/** /**
* Second Phase: * Second Phase:
* Asynchronus and event driven code * Asynchronus and event driven code.
*/ */
document.addEventListener("DOMContentLoaded", () => { document.addEventListener("DOMContentLoaded", () => {
// Initialize the CorpusAnalysisClient with dynamicMode as false // Initialize the client with dynamicMode set to false.
const client = new CorpusAnalysisClient({'logging': true, const client = new Client({'logging': true,
'dynamicMode': false}); 'dynamicMode': false});
console.info("CorpusAnalysisClient created as client:", client);
// Set up display elements which hare show depending on the client status
client.getHTMLElements(['#query-display']);
const queryDisplay = new CorpusAnalysisDisplay(client.queryDisplay);
// Register those display elements to client
client.setDisplay("query", queryDisplay);
/** /**
* Initializing the results object holding all the data of a query. * Initializing the results object as a model holding all the data of a
* Also holds the metadata of one query. * query. Also holds the metadata of one query and results data.
* Lastly it contains the object ResultsList which is a list.js * After that initialize the ResultsList object as the View handeling the
* subclass which handles the visual representation of the query data. * representation of the data for the user.
*/ */
let displayOptionsData = ResultsList.getDisplayOptions('display-options-form'); let results = new Results();
ResultsList.options.page = displayOptionsData["resultsPerPage"]; let resultsList = new ResultsList('result-list', ResultsList.options);
let data = new Data(); // Import results data from json file.
let resultsList = new ResultsList("result-list", ResultsList.options); const resultsJson = {{ query_result_file_content|tojson|safe }};
let resultsMetaData = new MetaData();
let results = new Results(data, resultsList, resultsMetaData);
// make results part of the client
client.results = results;
// inits some object keys and values
client.results.clearAll();
console.info('Initialized the Results object.')
// init some modals
let deleteOverlay = () => {
let overlay = document.getElementsByClassName("modal-overlay")[0];
overlay.remove();
};
client.getHTMLElements(['#meta-data-modal'])
client.metaDataModal = M.Modal.init(client.metaDataModal,
{'preventScrolling': false,
'opacity': 0.0,
'dismissible': false,
'onOpenEnd': deleteOverlay});
// saving imported data into client object
const payload = {{ query_result_file_content|tojson|safe }};
/** /**
* Register listeners and their callbacks. Because we are using the client * Register needed listeners and their callbacks. But we will
* not in dynamic mode we will not load the listeners. We just call the * just call the attached callbacks manually. Because dynamicMode is false.
* callbacks of the listeners manually. This is done to keep the setup of
* the client in dynamic or not dynamic mode similarish.
*/ */
const listenForQueryStatus = new SocketEventListener('corpus_analysis_query', const listenForQueryStatus = new ClientEventListener('corpus_analysis_query',
recieveQueryStatus); recieveQueryStatus);
const queryStatusCallback = new ListenerCallback('corpus_analysis_query', const queryStatusCallback = new ListenerCallback('corpus_analysis_query',
querySetup); prepareQueryData,
[client, results]);
listenForQueryStatus.setCallbacks([queryStatusCallback]); listenForQueryStatus.setCallbacks([queryStatusCallback]);
const listenForQueryData = new SocketEventListener('corpus_analysis_query_results', const listenForQueryData = new ClientEventListener('corpus_analysis_query_results',
recieveQueryData); recieveQueryData);
const queryDataCallback = new ListenerCallback('corpus_analysis_query_results', const queryDataCallback = new ListenerCallback('corpus_analysis_query_results',
queryRenderResults); saveQueryData,
[client, results]);
listenForQueryData.setCallbacks([queryDataCallback]); listenForQueryData.setCallbacks([queryDataCallback]);
// TODO: execute callbacks manually with right input
// // Enable scroll to Top functionality.
// // Initialization of interactionElemnts scrollToTop('#headline', '#menu-scroll-to-top-div');
// // An interactionElement is an object identifing a switch or button via
// // htmlID. Callbacks are set for these elements which will be triggered on
// // a pagination interaction by the user or if the status of the element has
// // been altered. (Like the switche has ben turned on or off).
// interactionElements = new InteractionElements();
// let expertModeInteraction = new InteractionElement("display-options-form-expert_mode");
// expertModeInteraction.setCallback("on",
// results.jsList.expertModeOn,
// results.jsList,
// ["query-display"])
// expertModeInteraction.setCallback("off",
// results.jsList.expertModeOff,
// results.jsList,
// ["query-display"])
//
// let activateInspectInteraction = new InteractionElement("inspect",
// false);
// activateInspectInteraction.setCallback("noCheck",
// results.jsList.activateInspect,
// results.jsList);
//
// let changeContextInteraction = new InteractionElement("display-options-form-results_per_page",
// false);
// changeContextInteraction.setCallback("noCheck",
// results.jsList.changeContext,
// results.jsList)
// interactionElements.addInteractions([expertModeInteraction, activateInspectInteraction, changeContextInteraction]);
//
// // checks if a change for every interactionElement happens and executes
// // the callbacks accordingly
// interactionElements.onChangeExecute();
//
// // eventListener if pagination is used to apply new context size to new page
// // and also activate inspect match if progress is 100
// // also adds more interaction buttons like add to sub results
// for (let element of paginationElements) {
// element.addEventListener("click", (event) => {
// results.jsList.pageChangeEventInteractionHandler(interactionElements);
// });
// }
//
// render results directly with callbacks because we are not in dynamic mode
listenForQueryStatus.listenerCallbacks['corpus_analysis_query'].callbackFunction(payload, client);
listenForQueryData.listenerCallbacks['corpus_analysis_query_results'].callbackFunction(payload, client);
// // ### Show corpus Metadata
// showMetaDataButton.onclick = () => {
// metaDataModal.open();
// };
//
// // live update of hits per page if hits per page value is changed
// let changeHitsPerPageBind = results.jsList.changeHitsPerPage.bind(results.jsList);
// hitsPerPageInputElement.onchange = changeHitsPerPageBind;
//
// // live update of lr context per item if context value is changed
// contextPerItemElement.onchange = results.jsList.changeContext;
//
// // new insepct event listener makeing use of javascript bubbleing
// let resultsTable = document.getElementById("query-results");
// resultsTable.addEventListener("click", (event) => {
// if (event.target.classList.contains("inspect-btn")) {
// const dataIndex = event.target.closest("tr").dataset.index;
// const fakeResponse = results.jsList.createFakeResponse();
// results.jsList.showMatchContext(fakeResponse);
// }
// });
//
// Add scrollToTop functionality
scrollToTop();
}); });
</script> </script>
{% endblock %} {% endblock %}