nopaque/app/static/js/CorpusAnalysis/QueryBuilder.js

960 lines
38 KiB
JavaScript
Raw Normal View History

2022-07-13 14:06:22 +02:00
class ConcordanceQueryBuilder {
2022-09-07 09:06:21 +02:00
constructor() {
2022-08-03 16:21:11 +02:00
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
this.elements = {
counter: 0,
yourQueryContent: [],
queryContent:[],
concordanceQueryBuilder: document.querySelector("#concordance-query-builder"),
concordanceQueryBuilderButton: document.querySelector("#concordance-query-builder-button"),
closeQueryBuilder: document.querySelector("#close-query-builder"),
queryBuilderTutorialModal: document.querySelector('#query-builder-tutorial-modal'),
//#region QueryBuilder Elements
positionalAttrButton: document.querySelector('#positional-attr-button'),
positionalAttrArea: document.querySelector('#positional-attr'),
positionalAttr: document.querySelector("#token-attr"),
structuralAttrButton: document.querySelector('#structural-attr-button'),
structuralAttrArea: document.querySelector("#structural-attr"),
queryContainer: document.querySelector('#query-container'),
buttonPreparer: document.querySelector("#button-preparer"),
yourQuery: document.querySelector("#your-query"),
insertQueryButton: document.querySelector("#insert-query-button"),
queryPreview: document.querySelector('#query-preview'),
tokenQuery: document.querySelector("#token-query"),
tokenBuilderContent: document.querySelector("#token-builder-content"),
tokenSubmitButton: document.querySelector("#token-submit"),
extFormQuery: document.querySelector('#concordance-extension-form-query'),
dropButton: "",
queryBuilderTutorialInfoIcon: document.querySelector('#query-builder-tutorial-info-icon'),
tokenTutorialInfoIcon: document.querySelector("#token-tutorial-info-icon"),
editTokenTutorialInfoIcon: document.querySelector('#edit-options-tutorial-info-icon'),
structuralAttributeTutorialInfoIcon: document.querySelector('#add-structural-attribute-tutorial-info-icon'),
generalOptionsQueryBuilderTutorialInfoIcon: document.querySelector('#general-options-query-builder-tutorial-info-icon'),
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
//#endregion QueryBuilder Elements
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
//#region Strucutral Attributes
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
sentence:document.querySelector("#sentence"),
entity: document.querySelector("#entity"),
textAnnotation: document.querySelector("#text-annotation"),
entityBuilder: document.querySelector("#entity-builder"),
englishEntType: document.querySelector("#english-ent-type"),
germanEntType: document.querySelector("#german-ent-type"),
emptyEntity: document.querySelector("#empty-entity"),
entityAnyType: false,
textAnnotationBuilder: document.querySelector("#text-annotation-builder"),
textAnnotationOptions: document.querySelector("#text-annotation-options"),
textAnnotationInput: document.querySelector("#text-annotation-input"),
textAnnotationSubmit: document.querySelector("#text-annotation-submit"),
noValueMetadataMessage: document.querySelector('#no-value-metadata-message'),
//#endregion Structural Attributes
//#region Token Attributes
tokenQueryFilled: false,
lemma: document.querySelector("#lemma"),
emptyToken: document.querySelector("#empty-token"),
word: document.querySelector("#word"),
lemma: document.querySelector("#lemma"),
pos: document.querySelector("#pos"),
simplePosButton: document.querySelector("#simple-pos-button"),
incidenceModifiers: document.querySelector("[data-target='incidence-modifiers']"),
or: document.querySelector("#or"),
and: document.querySelector("#and"),
//#region Word and Lemma Elements
wordBuilder: document.querySelector("#word-builder"),
lemmaBuilder: document.querySelector("#lemma-builder"),
inputOptions: document.querySelector("#input-options"),
incidenceModifiersButton: document.querySelector("#incidence-modifiers-button"),
conditionContainer: document.querySelector('#condition-container'),
wordInput: document.querySelector("#word-input"),
lemmaInput: document.querySelector("#lemma-input"),
ignoreCaseCheckbox : document.querySelector("#ignore-case-checkbox"),
ignoreCase: document.querySelector("input[type='checkbox']"),
wildcardChar: document.querySelector("#wildcard-char"),
optionGroup: document.querySelector("#option-group"),
//#endregion Word and Lemma Elements
//#region posBuilder Elements
englishPosBuilder: document.querySelector("#english-pos-builder"),
englishPos: document.querySelector("#english-pos"),
germanPosBuilder: document.querySelector("#german-pos-builder"),
germanPos: document.querySelector("#german-pos"),
//#endregion posBuilder Elements
//#region simple_posBuilder Elements
simplePosBuilder: document.querySelector("#simplepos-builder"),
simplePos: document.querySelector("#simple-pos"),
//#endregion simple_posBuilder Elements
//#region incidence modifiers
oneOrMore: document.querySelector("#one-or-more"),
zeroOrMore: document.querySelector("#zero-or-more"),
zeroOrOne: document.querySelector("#zero-or-one"),
exactlyN: document.querySelector("#exactlyN"),
betweenNM: document.querySelector("#betweenNM"),
nInput: document.querySelector("#n-input"),
nSubmit: document.querySelector("#n-submit"),
nmInput: document.querySelector("#n-m-input"),
mInput: document.querySelector("#m-input"),
nmSubmit: document.querySelector("#n-m-submit"),
//#endregion incidence modifiers
cancelBool: false,
noValueMessage: document.querySelector('#no-value-message'),
//#endregion Token Attributes
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
this.elements.closeQueryBuilder.addEventListener("click", () => {this.closeQueryBuilderModal(this.elements.concordanceQueryBuilder);});
this.elements.concordanceQueryBuilderButton.addEventListener("click", () => {this.clearAll();});
this.elements.insertQueryButton.addEventListener("click", () => {this.insertQuery();});
this.elements.positionalAttrButton.addEventListener("click", () => {this.showPositionalAttrArea();});
this.elements.structuralAttrButton.addEventListener("click", () => {this.showStructuralAttrArea();});
//#region Structural Attribute Event Listeners
this.elements.sentence.addEventListener("click", () => {this.addSentence();});
this.elements.entity.addEventListener("click", () => {this.addEntity();});
this.elements.textAnnotation.addEventListener("click", () => {this.addTextAnnotation();});
this.elements.englishEntType.addEventListener("change", () => {this.englishEntTypeHandler();});
this.elements.germanEntType.addEventListener("change", () => {this.germanEntTypeHandler();});
this.elements.emptyEntity.addEventListener("click", () => {this.emptyEntityButton();});
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
this.elements.textAnnotationSubmit.addEventListener("click", () => {this.textAnnotationSubmitHandler();});
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
//#endregion
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
//#region Token Attribute Event Listeners
this.elements.queryBuilderTutorialInfoIcon.addEventListener("click", () => {this.tutorialIconHandler('#query-builder-tutorial-start');});
this.elements.tokenTutorialInfoIcon.addEventListener("click", () => {this.tutorialIconHandler('#add-new-token-tutorial');});
this.elements.editTokenTutorialInfoIcon.addEventListener("click", () => {this.tutorialIconHandler('#edit-options-tutorial');});
this.elements.structuralAttributeTutorialInfoIcon.addEventListener("click", () => {this.tutorialIconHandler('#add-structural-attribute-tutorial');});
this.elements.generalOptionsQueryBuilderTutorialInfoIcon.addEventListener("click", () => {this.tutorialIconHandler('#general-options-query-builder');});
this.elements.positionalAttr.addEventListener("change", () => {this.tokenTypeSelector();});
this.elements.tokenSubmitButton.addEventListener("click", () => {this.addToken();});
this.elements.ignoreCase.addEventListener("change", () => {this.inputOptionHandler(this.elements.ignoreCase);});
this.elements.wildcardChar.addEventListener("click", () => {this.inputOptionHandler(this.elements.wildcardChar);});
this.elements.optionGroup.addEventListener("click", () => {this.inputOptionHandler(this.elements.optionGroup);});
this.elements.oneOrMore.addEventListener("click", () => {this.incidenceModifiersHandler(this.elements.oneOrMore);});
this.elements.zeroOrMore.addEventListener("click", () => {this.incidenceModifiersHandler(this.elements.zeroOrMore);});
this.elements.zeroOrOne.addEventListener("click", () => {this.incidenceModifiersHandler(this.elements.zeroOrOne);});
this.elements.nSubmit.addEventListener("click", () => {this.nSubmitHandler();});
this.elements.nmSubmit.addEventListener("click", () => {this.nmSubmitHandler();});
this.elements.or.addEventListener("click", () => {this.orHandler();});
this.elements.and.addEventListener("click", () => {this.andHandler();});
//#endregion Token Attribute Event Listeners
}
//#region General Functions
closeQueryBuilderModal(closeInstance){
let instance = M.Modal.getInstance(closeInstance);
instance.close();
}
showPositionalAttrArea(){
this.elements.positionalAttrArea.classList.remove('hide');
this.elements.wordBuilder.classList.remove("hide");
this.elements.inputOptions.classList.remove("hide");
this.elements.incidenceModifiersButton.classList.remove('hide');
this.elements.conditionContainer.classList.remove("hide");
this.elements.ignoreCaseCheckbox.classList.remove("hide");
this.elements.structuralAttrArea.classList.add('hide');
this.elements.lemmaBuilder.classList.add('hide');
this.elements.englishPosBuilder.classList.add('hide');
this.elements.germanPosBuilder.classList.add('hide');
this.elements.simplePosBuilder.classList.add('hide');
this.elements.tokenQueryFilled = false;
window.location.href = "#token-builder-content";
// Resets materialize select field to default value
let SelectInstance = M.FormSelect.getInstance(this.elements.positionalAttr);
SelectInstance.input.value = "word";
this.elements.positionalAttr.value = "word";
}
showStructuralAttrArea(){
this.elements.positionalAttrArea.classList.add('hide');
this.elements.structuralAttrArea.classList.remove('hide');
}
buttonfactory(dataType, prettyText, queryText) {
window.location.href = "#query-container";
this.elements.counter += 1;
queryText = encodeURI(queryText);
let chipColor = 'style="background-color:#';
// Sets chip color, depending on the type of element
if (dataType === 'start-sentence' || dataType === 'end-sentence'){
chipColor += 'FD9720';
}else if (dataType === "start-empty-entity" || dataType === "start-entity" || dataType === "end-entity"){
chipColor += 'A6E22D';
}else if (dataType === "text-annotation"){
chipColor += '2FBBAB';
}else if (dataType === "token"){
chipColor += '28B3D1';
}else {
chipColor = '';
}
// Creates a chip with the previously selected element. Is first created in the "BuilderElement" and populated with an EventListener, then moved to "yourQuery".
let builderElement = document.createElement('div');
builderElement.innerHTML +=`
<div class="chip" ${chipColor}" data-type="${dataType}" data-query="${queryText}" draggable="true" style="cursor:pointer;" ondragstart="concordanceQueryBuilder.dragStartHandler(event)" ondragend="concordanceQueryBuilder.dragEndHandler(event)">
${prettyText}
<i class="material-icons close">close</i>
</div>
`.trim();
let buttonElement = builderElement.firstElementChild;
buttonElement.addEventListener("click", () => {this.deleteAttr(buttonElement);});
// Ensures that metadata is always at the end of the query:
if(this.elements.yourQuery.lastChild === null || this.elements.yourQuery.lastChild.dataset.type !== "text-annotation"){
this.elements.yourQuery.appendChild(buttonElement);
}else if (this.elements.yourQuery.lastChild.dataset.type === "text-annotation"){
this.elements.yourQuery.insertBefore(buttonElement, this.elements.yourQuery.lastChild);
}
this.elements.queryContainer.classList.remove("hide");
this.queryPreviewBuilder();
// Opens a hint about the possible functions for editing the query when the first chip is added. It is displayed for 5 seconds and then deleted.
if (this.elements.yourQuery.classList.contains("tooltipped")){
let tooltipInstance = M.Tooltip.getInstance(this.elements.yourQuery);
tooltipInstance.tooltipEl.style.background = "#98ACD2";
tooltipInstance.tooltipEl.style.borderTop = "solid 4px #0064A3"
tooltipInstance.tooltipEl.style.padding = "10px";
tooltipInstance.tooltipEl.style.color = "black";
if (tooltipInstance !== undefined){
setTimeout(() => {
tooltipInstance.open();
setTimeout(() => {
tooltipInstance.destroy();
}, 5000);
}, 500);
}
this.elements.yourQuery.classList.remove("tooltipped");
}
}
2022-09-07 14:47:42 +02:00
//#region Drag&Drop Events
2022-09-07 09:06:21 +02:00
dragStartHandler(event){
this.elements.dropButton = event.target;
let targetChip = `
<div class="chip target" ondragover="concordanceQueryBuilder.dragOverHandler(event)" ondragenter="concordanceQueryBuilder.dragEnterHandler(event)" ondragleave="concordanceQueryBuilder.dragLeaveHandler(event)" ondrop="concordanceQueryBuilder.dropHandler(event)">
Drop here
</div>
`.trim();
let childNodes = this.elements.yourQuery.querySelectorAll("div:not(.target)");
setTimeout(() => {
for (let element of childNodes){
if(element === event.target){
continue;
}else if (element === event.target.nextSibling){
continue;
}else {
element.insertAdjacentHTML("beforebegin", targetChip)
2022-07-13 14:06:22 +02:00
}
2022-09-07 09:06:21 +02:00
}
childNodes[childNodes.length-1].insertAdjacentHTML("afterend", targetChip);
},0);
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
dragOverHandler(event){
event.preventDefault();
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
dragEnterHandler(event){
event.preventDefault();
event.target.style.borderStyle = "solid dotted";
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
dragLeaveHandler(event){
event.preventDefault();
event.target.style.borderStyle = "hidden";
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
dragEndHandler(event){
let targets = document.querySelectorAll('.target');
for (let target of targets){
target.remove();
2022-07-13 14:06:22 +02:00
}
2022-09-07 09:06:21 +02:00
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
dropHandler(event){
let dropzone = event.target;
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
for (let i = 0; i < dropzone.parentElement.childNodes.length; i++){
if (dropzone === dropzone.parentElement.childNodes[i]){
nodeIndex = i;
}
2022-07-13 14:06:22 +02:00
}
2022-09-07 09:06:21 +02:00
for (let i = 0; i < dropzone.parentElement.childNodes.length; i++){
if (this.elements.dropButton === dropzone.parentElement.childNodes[i]){
draggedElementIndex = i;
}
2022-08-01 10:00:12 +02:00
}
2022-09-07 09:06:21 +02:00
dropzone.parentElement.replaceChild(this.elements.dropButton, dropzone);
this.queryPreviewBuilder();
}
2022-09-07 14:47:42 +02:00
//#endregion Drag&Drop Events
2022-08-01 10:00:12 +02:00
2022-09-07 09:06:21 +02:00
queryPreviewBuilder(){
this.elements.yourQueryContent = [];
2022-08-01 10:00:12 +02:00
2022-09-07 09:06:21 +02:00
for (let element of this.elements.yourQuery.childNodes) {
let queryElement = decodeURI(element.dataset.query);
if (queryElement.includes("<")){
queryElement = queryElement.replace("<", "&#60;");
}
if (queryElement.includes(">")){
queryElement = queryElement.replace(">", "&#62;");
}
if (queryElement !== "undefined") {
this.elements.yourQueryContent.push(queryElement);
}
2022-08-01 10:00:12 +02:00
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
let queryString = this.elements.yourQueryContent.join(' ');
queryString += ";";
this.elements.queryPreview.innerHTML = queryString;
}
2022-07-13 14:06:22 +02:00
2022-08-01 10:00:12 +02:00
2022-09-07 09:06:21 +02:00
deleteAttr(attr) {
this.elements.yourQuery.removeChild(attr);
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
this.elements.counter -= 1;
if(this.elements.counter === 0){
this.elements.queryContainer.classList.add("hide");
2022-07-13 14:06:22 +02:00
}
2022-09-07 09:06:21 +02:00
this.queryPreviewBuilder();
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
insertQuery() {
this.elements.yourQueryContent = [];
2022-08-01 10:00:12 +02:00
2022-09-07 09:06:21 +02:00
for (let element of this.elements.yourQuery.childNodes) {
let queryElement = decodeURI(element.dataset.query);
if (queryElement !== "undefined"){
this.elements.yourQueryContent.push(queryElement);
2022-07-13 14:06:22 +02:00
}
}
2022-09-07 09:06:21 +02:00
let queryString = this.elements.yourQueryContent.join(' ');
queryString += ";";
2022-08-01 10:00:12 +02:00
2022-09-07 09:06:21 +02:00
this.elements.concordanceQueryBuilder.classList.add('modal-close');
this.elements.extFormQuery.value = queryString;
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
clearAll() {
// Everything is reset. After 5 seconds for 5 seconds (with "instance"), a message is displayed indicating that further information can be obtained via the question mark icon
let instance = M.Tooltip.getInstance(this.elements.queryBuilderTutorialInfoIcon);
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
this.hideEverything();
this.elements.counter = 0;
this.elements.concordanceQueryBuilder.classList.remove('modal-close');
this.elements.positionalAttrArea.classList.add('hide');
this.elements.structuralAttrArea.classList.add('hide');
this.elements.yourQuery.innerHTML = '';
this.elements.queryContainer.classList.add('hide');
instance.tooltipEl.style.background = '#98ACD2';
instance.tooltipEl.style.borderTop = 'solid 4px #0064A3';
instance.tooltipEl.style.padding = '10px';
instance.tooltipEl.style.color = 'black';
setTimeout(() => {
instance.open();
setTimeout(() => {
2022-08-03 16:21:11 +02:00
instance.close();
2022-09-07 09:06:21 +02:00
}, 5000);
}, 5000);
}
tutorialIconHandler(id) {
setTimeout(() => {
window.location.href= id;
}, 0);
}
//#endregion General Functions
//#region Token Attribute Builder Functions
//#region General functions of the Token Builder
tokenTypeSelector() {
this.hideEverything();
switch (this.elements.positionalAttr.value) {
case "word":
this.wordBuilder();
break;
case "lemma":
this.lemmaBuilder();
break;
case "english-pos":
this.englishPosHandler();
break;
case "german-pos":
this.germanPosHandler();
break;
case "simple-pos-button":
this.simplePosBuilder();
break;
case "empty-token":
this.emptyTokenHandler();
break;
default:
this.wordBuilder();
break;
}
}
hideEverything(){
this.elements.wordBuilder.classList.add("hide");
this.elements.lemmaBuilder.classList.add("hide");
this.elements.ignoreCaseCheckbox.classList.add("hide");
this.elements.inputOptions.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
this.elements.conditionContainer.classList.add("hide");
this.elements.englishPosBuilder.classList.add("hide");
this.elements.germanPosBuilder.classList.add("hide");
this.elements.simplePosBuilder.classList.add("hide");
this.elements.entityBuilder.classList.add("hide");
this.elements.textAnnotationBuilder.classList.add("hide");
}
tokenButtonfactory(prettyText, tokenText) {
tokenText = encodeURI(tokenText);
let builderElement;
let buttonElement;
builderElement = document.createElement('div');
builderElement.innerHTML = `
<div class="chip col s2 l2" style="margin-top:20px;" data-tokentext="${tokenText}">
${prettyText}
<i class="material-icons close">close</i>
</div>`;
buttonElement = builderElement.firstElementChild;
buttonElement.addEventListener("click", () => {this.deleteTokenAttr(buttonElement);});
this.elements.tokenQuery.appendChild(buttonElement);
}
deleteTokenAttr(attr){
// let tokenQuery = this.elements.tokenQuery.childNodes;
// console.log(tokenQuery);
// console.log(this.elements.tokenQuery);
console.log(this.elements.tokenQuery.childNodes.length);
if (this.elements.tokenQuery.childNodes.length < 2) {
this.elements.tokenQuery.removeChild(attr);
this.wordBuilder();
} else {
this.elements.tokenQuery.removeChild(attr);
}
}
addToken() {
let c;
let tokenQueryContent = ""; //for ButtonFactory(prettyText)
let tokenQueryText = ""; //for ButtonFactory(queryText)
this.elements.cancelBool = false;
let emptyTokenCheck = false;
if (this.elements.ignoreCase.checked){
c = ' %c';
}else{
c = '';
}
for (let element of this.elements.tokenQuery.childNodes){
tokenQueryContent += ' ' + element.firstChild.data + ' ';
tokenQueryText += decodeURI(element.dataset.tokentext);
if (element.innerText.indexOf("empty token") !== -1){
emptyTokenCheck = true;
}
2022-08-03 16:21:11 +02:00
}
2022-09-07 09:06:21 +02:00
if (this.elements.tokenQueryFilled === false){
switch (this.elements.positionalAttr.value) {
case "word":
if (this.elements.wordInput.value === "") {
this.disableTokenSubmit();
} else {
tokenQueryContent += `word=${this.elements.wordInput.value}${c}`;
tokenQueryText += `word="${this.elements.wordInput.value}"${c}`;
this.elements.wordInput.value = '';
}
break;
case "lemma":
if (this.elements.lemmaInput.value === "") {
this.disableTokenSubmit();
} else {
tokenQueryContent += `lemma=${this.elements.lemmaInput.value}${c}`;
tokenQueryText += `lemma="${this.elements.lemmaInput.value}"${c}`;
this.elements.lemmaInput.value = '';
}
break;
case "english-pos":
if (this.elements.englishPos.value === "default") {
this.disableTokenSubmit();
} else {
tokenQueryContent += `pos=${this.elements.englishPos.value}`;
tokenQueryText += `pos="${this.elements.englishPos.value}"`;
this.elements.englishPos.value = '';
}
break;
case "german-pos":
if (this.elements.germanPos.value === "default") {
this.disableTokenSubmit();
} else {
tokenQueryContent += `pos=${this.elements.germanPos.value}`;
tokenQueryText += `pos="${this.elements.germanPos.value}"`;
this.elements.germanPos.value = '';
}
break;
case "simple-pos-button":
if (this.elements.simplePos.value === "default") {
this.disableTokenSubmit();
} else {
tokenQueryContent += `simple_pos=${this.elements.simplePos.value}`;
tokenQueryText += `simple_pos="${this.elements.simplePos.value}"`;
this.elements.simplePos.value = '';
}
break;
default:
this.wordBuilder();
break;
}
2022-07-13 14:06:22 +02:00
}
2022-09-07 09:06:21 +02:00
// cancelBool looks in disableTokenSubmit() whether a value is passed. If the input fields/dropdowns are empty (cancelBool === true), no token is added.
if (this.elements.cancelBool === false){
// Square brackets are added only if it is not an empty token (where they are already present).
if (emptyTokenCheck === false) {
tokenQueryText = '[' + tokenQueryText + ']';
}
this.buttonfactory('token', tokenQueryContent, tokenQueryText);
this.hideEverything();
this.elements.positionalAttrArea.classList.add('hide');
this.elements.tokenQuery.innerHTML = "";
}
}
disableTokenSubmit() {
this.elements.cancelBool = true;
this.elements.tokenSubmitButton.classList.add("red");
this.elements.noValueMessage.classList.remove('hide');
setTimeout(() => {
this.elements.tokenSubmitButton.classList.remove("red");
}, 500);
setTimeout(() => {
this.elements.noValueMessage.classList.add('hide');
}, 3000);
}
//#endregion General functions of the Token Builder
//#region Dropdown Select Handler
wordBuilder() {
this.hideEverything();
this.elements.wordInput.value = "";
this.elements.wordBuilder.classList.remove("hide");
this.elements.inputOptions.classList.remove("hide");
this.elements.incidenceModifiersButton.classList.remove('hide');
this.elements.conditionContainer.classList.remove("hide");
this.elements.ignoreCaseCheckbox.classList.remove("hide");
// Resets materialize select field to default value
let SelectInstance = M.FormSelect.getInstance(this.elements.positionalAttr);
SelectInstance.input.value = "word";
this.elements.positionalAttr.value = "word";
}
lemmaBuilder() {
this.hideEverything();
this.elements.lemmaBuilder.classList.remove("hide");
this.elements.inputOptions.classList.remove("hide");
this.elements.incidenceModifiersButton.classList.remove('hide');
this.elements.conditionContainer.classList.remove("hide");
this.elements.ignoreCaseCheckbox.classList.remove("hide");
}
englishPosHandler() {
this.hideEverything();
this.elements.englishPosBuilder.classList.remove("hide");
this.elements.incidenceModifiersButton.classList.remove('hide');
this.elements.conditionContainer.classList.remove("hide");
// Resets materialize select dropdown
let selectInstance = M.FormSelect.getInstance(this.elements.englishPos);
selectInstance.input.value = "English pos tagset";
this.elements.englishPos.value = "default";
}
germanPosHandler() {
this.hideEverything();
this.elements.germanPosBuilder.classList.remove("hide");
this.elements.incidenceModifiersButton.classList.remove('hide');
this.elements.conditionContainer.classList.remove("hide");
// Resets materialize select dropdown
let selectInstance = M.FormSelect.getInstance(this.elements.germanPos);
selectInstance.input.value = "German pos tagset";
this.elements.germanPos.value = "default";
}
simplePosBuilder() {
this.hideEverything();
this.elements.simplePosBuilder.classList.remove("hide");
this.elements.incidenceModifiersButton.classList.remove('hide');
this.elements.conditionContainer.classList.remove("hide");
this.elements.simplePos.selectedIndex = 0;
// Resets materialize select dropdown
let selectInstance = M.FormSelect.getInstance(this.elements.simplePos);
selectInstance.input.value = "simple_pos tagset";
this.elements.simplePos.value = "default";
}
emptyTokenHandler() {
this.tokenButtonfactory("empty token", "[]");
this.elements.tokenQueryFilled = true;
this.hideEverything();
this.elements.incidenceModifiersButton.classList.remove('hide');
}
//#endregion Dropdown Select Handler
//#region Options to edit your token - Wildcard Charakter, Option Group, Incidence Modifiers, Ignore Case, "and", "or"
inputOptionHandler(elem) {
let input;
if (this.elements.wordBuilder.classList.contains('hide') === false) {
input = this.elements.wordInput;
} else {
input = this.elements.lemmaInput;
}
if (elem === this.elements.optionGroup) {
input.value += '( option1 | option2 )';
let firstIndex = input.value.indexOf('option1');
let lastIndex = firstIndex + 'option1'.length;
input.focus();
input.setSelectionRange(firstIndex, lastIndex);
} else if (elem === this.elements.wildcardChar) {
input.value += '.';
}
}
nSubmitHandler() {
let instance = M.Modal.getInstance(this.elements.exactlyN);
instance.close();
switch (this.elements.positionalAttr.value) {
case "word":
this.elements.wordInput.value += " {" + this.elements.nInput.value + "}";
break;
case "lemma":
this.elements.lemmaInput.value += " {" + this.elements.nInput.value + "}";
break;
case "english-pos":
this.elements.tokenQueryFilled = true;
this.tokenButtonfactory(`pos=${this.elements.englishPos.value}`, `pos="${this.elements.englishPos.value}"`);
this.tokenButtonfactory("{" + this.elements.nInput.value + "}", "{" + this.elements.nInput.value + "}");
this.elements.englishPosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
break;
case "german-pos":
this.elements.tokenQueryFilled = true;
this.tokenButtonfactory(`pos=${this.elements.germanPos.value}`, `pos="${this.elements.germanPos.value}"`);
this.tokenButtonfactory("{" + this.elements.nInput.value + "}", "{" + this.elements.nInput.value + "}");
this.elements.germanPosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
break;
case "simple-pos-button":
this.elements.tokenQueryFilled = true;
this.tokenButtonfactory(`simple_pos=${this.elements.simplePos.value}`, `simple_pos="${this.elements.simplePos.value}"`);
this.tokenButtonfactory("{" + this.elements.nInput.value + "}", "{" + this.elements.nInput.value + "}");
this.elements.simplePosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
break;
case "empty-token":
this.tokenButtonfactory("{" + this.elements.nInput.value + "}", "{" + this.elements.nInput.value + "}");
break;
default:
break;
}
}
nmSubmitHandler() {
let instance = M.Modal.getInstance(this.elements.betweenNM);
instance.close();
2022-09-07 14:22:59 +02:00
switch (this.elements.positionalAttr.value) {
case "word":
this.elements.wordInput.value += `{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`;
break;
case "lemma":
this.elements.lemmaInput.value += `{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`;
break;
case "english-pos":
this.elements.tokenQueryFilled = true;
this.tokenButtonfactory(`pos=${this.elements.englishPos.value}`, `pos="${this.elements.englishPos.value}"`);
this.tokenButtonfactory(`{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`, `{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`);
this.elements.englishPosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
break;
case "german-pos":
this.elements.tokenQueryFilled = true;
this.tokenButtonfactory(`pos=${this.elements.germanPos.value}`, `pos="${this.elements.germanPos.value}"`);
this.tokenButtonfactory(`{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`, `{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`);
this.elements.germanPosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
break;
case "simple-pos-button":
this.elements.tokenQueryFilled = true;
this.tokenButtonfactory(`simple_pos=${this.elements.simplePos.value}`, `simple_pos="${this.elements.simplePos.value}"`);
this.tokenButtonfactory(`{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`, `{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`);
this.elements.simplePosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
break;
case "empty-token":
this.tokenButtonfactory(`{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`, `{${this.elements.nmInput.value}, ${this.elements.mInput.value}}`);
break;
default:
break;
}
2022-09-07 09:06:21 +02:00
}
incidenceModifiersHandler(elem) {
// For word and lemma, the incidence modifiers are inserted in the input field. For the others, one or two chips are created which contain the respective value of the token and the incidence modifier.
if (this.elements.positionalAttr.value === "empty-token") {
this.tokenButtonfactory(elem.innerText, elem.dataset.token);
} else if (this.elements.positionalAttr.value === "english-pos") {
this.tokenButtonfactory(`pos=${this.elements.englishPos.value}`, `pos="${this.elements.englishPos.value}"`);
this.tokenButtonfactory(elem.innerText, elem.dataset.token);
this.elements.englishPosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
this.elements.tokenQueryFilled = true;
} else if (this.elements.positionalAttr.value === "german-pos") {
this.tokenButtonfactory(`pos=${this.elements.germanPos.value}`, `pos="${this.elements.germanPos.value}"`);
this.tokenButtonfactory(elem.innerText, elem.dataset.token);
this.elements.germanPosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
this.elements.tokenQueryFilled = true;
} else if (this.elements.positionalAttr.value === "simple-pos-button") {
this.tokenButtonfactory(`simple_pos=${this.elements.simplePos.value}`, `simple_pos="${this.elements.simplePos.value}"`);
this.tokenButtonfactory(elem.innerText, elem.dataset.token);
this.elements.simplePosBuilder.classList.add("hide");
this.elements.incidenceModifiersButton.classList.add("hide");
this.elements.tokenQueryFilled = true;
} else {
let input;
if (this.elements.wordBuilder.classList.contains('hide') === false) {
input = this.elements.wordInput;
} else {
input = this.elements.lemmaInput;
}
2022-07-13 14:06:22 +02:00
2022-09-07 09:06:21 +02:00
input.value += ' ' + elem.dataset.token;
}
}
orHandler() {
this.conditionHandler("or", " | ");
}
andHandler() {
this.conditionHandler("and", " & ");
}
conditionHandler(conditionText, conditionQueryContent) {
this.hideEverything();
let tokenQueryContent;
let tokenQueryText;
let c;
if (this.elements.ignoreCase.checked){
c = ' %c';
}else{
c = '';
}
switch (this.elements.positionalAttr.value) {
case "word":
tokenQueryContent = `word=${this.elements.wordInput.value}${c}`;
tokenQueryText = `word="${this.elements.wordInput.value}"${c}`;
this.elements.wordInput.value = '';
break;
case "lemma":
tokenQueryContent = `lemma=${this.elements.lemmaInput.value}${c}`;
tokenQueryText = `word="${this.elements.lemmaInput.value}"${c}`;
this.elements.lemmaInput.value = '';
break;
case "english-pos":
tokenQueryContent = `pos=${this.elements.englishPos.value}`;
tokenQueryText = `pos="${this.elements.englishPos.value}"`;
this.elements.englishPos.value = '';
break;
case "german-pos":
tokenQueryContent = `pos=${this.elements.germanPos.value}`;
tokenQueryText = `pos="${this.elements.germanPos.value}"`;
this.elements.germanPos.value = '';
break;
case "simple-pos-button":
tokenQueryContent = `simple_pos=${this.elements.simplePos.value}`;
tokenQueryText = `simple_pos="${this.elements.simplePos.value}"`;
this.elements.simplePos.value = '';
break;
default:
this.wordBuilder();
break;
}
this.tokenButtonfactory(tokenQueryContent, tokenQueryText);
this.tokenButtonfactory(conditionText, conditionQueryContent);
this.wordBuilder();
}
//#endregion Options to edit your token - Wildcard Charakter, Option Group, Incidence Modifiers, Ignore Case, "and", "or"
//#endregion Token Attribute Builder Functions
//#region Structural Attribute Builder Functions
addSentence() {
this.hideEverything();
if(this.elements.sentence.text === 'End Sentence') {
this.buttonfactory('end-sentence', 'Sentence End', '</s>');
this.elements.sentence.innerHTML = 'Sentence';
} else {
this.buttonfactory('start-sentence', 'Sentence Start', '<s>');
this.elements.queryContent.push('sentence');
this.elements.sentence.innerHTML = 'End Sentence';
}
}
addEntity() {
if (this.elements.entity.text === 'End Entity') {
let queryText;
if (this.elements.entityAnyType === false) {
queryText = '</ent_type>';
} else {
queryText = '</ent>';
}
this.buttonfactory('end-entity', 'Entity End', queryText);
this.elements.entity.innerHTML = 'Entity';
} else {
this.hideEverything();
this.elements.entityBuilder.classList.remove("hide");
window.location.href = "#entity-builder";
}
}
englishEntTypeHandler() {
this.buttonfactory('start-entity', 'Entity Type=' + this.elements.englishEntType.value, '<ent_type="' + this.elements.englishEntType.value + '">');
this.elements.entity.innerHTML = 'End Entity';
this.hideEverything();
this.elements.entityAnyType = false;
// Resets materialize select dropdown
let SelectInstance = M.FormSelect.getInstance(this.elements.englishEntType);
SelectInstance.input.value = "English ent_type";
this.elements.englishEntType.value = "default";
}
germanEntTypeHandler() {
this.buttonfactory('start-entity', 'Entity Type=' + this.elements.germanEntType.value, '<ent_type="' + this.elements.germanEntType.value + '">');
this.elements.entity.innerHTML = 'End Entity';
this.hideEverything();
this.elements.entityAnyType = false;
// Resets materialize select dropdown
let SelectInstance = M.FormSelect.getInstance(this.elements.germanEntType);
SelectInstance.input.value = "German ent_type";
this.elements.germanEntType.value = "default";
}
emptyEntityButton() {
this.buttonfactory('start-empty-entity', 'Entity Start', '<ent>');
this.elements.entity.innerHTML = 'End Entity';
this.hideEverything();
this.elements.entityAnyType = true;
}
addTextAnnotation() {
this.hideEverything();
this.elements.textAnnotationBuilder.classList.remove("hide");
window.location.href = "#text-annotation-builder";
// Resets materialize select dropdown
let SelectInstance = M.FormSelect.getInstance(this.elements.textAnnotationOptions);
SelectInstance.input.value = "address";
this.elements.textAnnotationOptions.value = "address";
this.elements.textAnnotationInput.value= "";
}
textAnnotationSubmitHandler() {
if (this.elements.textAnnotationInput.value === '') {
this.elements.textAnnotationSubmit.classList.add('red');
this.elements.noValueMetadataMessage.classList.remove('hide');
setTimeout(() => {
this.elements.textAnnotationSubmit.classList.remove('red');
}, 500);
setTimeout(() => {
this.elements.noValueMetadataMessage.classList.add('hide');
}, 3000);
} else {
let queryText = `:: match.text_${this.elements.textAnnotationOptions.value}="${this.elements.textAnnotationInput.value}"`;
this.buttonfactory('text-annotation', `${this.elements.textAnnotationOptions.value}=${this.elements.textAnnotationInput.value}`, queryText);
this.hideEverything();
}
}
//#endregion Structural Attribute Builder Functions
2022-08-01 10:00:12 +02:00
2022-07-13 14:06:22 +02:00
}