class CorpusAnalysisClient { constructor(corpusId, socket) { this.callbacks = {}; this.corpusId = corpusId; this.displays = {}; this.socket = socket; socket.on("pj_corpus_analysis_init", (response) => { var errorText; if (response.code === 200) { console.log(`pj_corpus_analysis_init: ${response.code} - ${response.msg}`); if (this.callbacks.init != undefined) {this.callbacks.init(response.payload);} if (this.displays.init != undefined) {this.displays.init.setVisibilityByStatus("success");} } else { errorText = `Error ${response.code} - ${response.msg}`; if (this.displays.init.errorContainer != undefined) {this.displays.init.errorContainer.innerHTML = `
error ${errorText}
`;} if (this.displays.init != undefined) {this.displays.init.setVisibilityByStatus("error");} console.error(`pj_corpus_analysis_init: ${errorText}`); } }); socket.on("pj_corpus_analysis_query", (response) => { var errorText; if (response.code === 200) { console.log(`pj_corpus_analysis_query: ${response.code} - ${response.msg}`); if (this.callbacks.query != undefined) {this.callbacks.query(response.payload);} if (this.displays.query != undefined) {this.displays.query.setVisibilityByStatus("success");} } else { errorText = `Error ${response.payload.code} - ${response.payload.msg}`; nopaque.flash("error", errorText); if (this.displays.query.errorContainer != undefined) {this.displays.query.errorContainer.innerHTML = `error ${errorText}
`;} if (this.displays.query != undefined) {this.displays.query.setVisibilityByStatus("error");} console.error(`pj_corpus_analysis_query: ${errorText}`); } }); socket.on("pj_corpus_analysis_query_results", (response) => { if (this.callbacks.query_results != undefined) {this.callbacks.query_results(response.payload);} }); } init() { if (this.displays.init.errorContainer != undefined) {this.displays.init.errorContainer.innerHTML == "";} if (this.displays.init != undefined) {this.displays.init.setVisibilityByStatus("waiting");} this.socket.emit("pj_corpus_analysis_init", this.corpusId); } query(queryStr) { if (this.displays.query.errorContainer != undefined) {this.displays.query.errorContainer.innerHTML == "";} if (this.displays.query != undefined) {this.displays.query.setVisibilityByStatus("waiting");} nopaque.socket.emit("pj_corpus_analysis_query", queryStr); } getQueryStr(queryFormElement) { // gets query let queryFormData; let queryStr; queryFormData = new FormData(queryFormElement); queryStr = queryFormData.get("query-form-query"); return queryStr } setCallback(type, callback) { // saves callback functions into an object. Key is function type, callback // is the callback function this.callbacks[type] = callback; } setDisplay(type, display) { this.displays[type] = display; } } class CorpusAnalysisDisplay { constructor(element) { this.element = element; this.errorContainer = element.querySelector(".error-container"); this.showOnError = element.querySelectorAll(".show-on-error"); this.showOnSuccess = element.querySelectorAll(".show-on-success"); this.showWhileWaiting = element.querySelectorAll(".show-while-waiting"); } setVisibilityByStatus(status) { switch (status) { case "error": for (let element of this.showOnError) {element.classList.remove("hide");} for (let element of this.showOnSuccess) {element.classList.add("hide");} for (let element of this.showWhileWaiting) {element.classList.add("hide");} break; case "success": for (let element of this.showOnError) {element.classList.add("hide");} for (let element of this.showOnSuccess) {element.classList.remove("hide");} for (let element of this.showWhileWaiting) {element.classList.add("hide");} break; case "waiting": for (let element of this.showOnError) {element.classList.add("hide");} for (let element of this.showOnSuccess) {element.classList.add("hide");} for (let element of this.showWhileWaiting) {element.classList.remove("hide");} break; default: // Hide all for (let element of this.showOnError) {element.classList.add("hide");} for (let element of this.showOnSuccess) {element.classList.add("hide");} for (let element of this.showWhileWaiting) {element.classList.add("hide");} } } }