Add new feature on results preview
This commit is contained in:
parent
a871e67caf
commit
99c443a32f
|
@ -4,4 +4,5 @@ export class Match {
|
||||||
context: string;
|
context: string;
|
||||||
extraprev: string;
|
extraprev: string;
|
||||||
extranext: string;
|
extranext: string;
|
||||||
|
occurences: string;
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,8 +46,8 @@
|
||||||
<div id="cm-run-test-section">
|
<div id="cm-run-test-section">
|
||||||
<div class="uk-display-inline">
|
<div class="uk-display-inline">
|
||||||
<button id="run-mining-btn" class="uk-button cm-run-test-button" [disabled]="documentsLoaded<1" (click)="runMining()">Run rules test</button>
|
<button id="run-mining-btn" class="uk-button cm-run-test-button" [disabled]="documentsLoaded<1" (click)="runMining()">Run rules test</button>
|
||||||
<span *ngIf="matches_number !== ''" id="results-number" class="cm-coloured-text uk-margin-left uk-text-bottom">{{matches_number}} matche{{matches_number == '1'?'':'s'}} found</span>
|
<span *ngIf="matches_number !== ''" id="results-number" class="cm-coloured-text uk-margin-left uk-text-bottom">{{matches_number}} match{{matches_number == '1'?'':'es'}} found</span>
|
||||||
<span *ngIf="prev_matches_number !== ''" id="results-number-previous" class="cm-text-muted uk-text-bottom">, {{prev_matches_number}} matche{{prev_matches_number == '1'?'':'s'}} found previously</span>
|
<span *ngIf="prev_matches_number !== ''" id="results-number-previous" class="cm-text-muted uk-text-bottom">, {{prev_matches_number}} match{{prev_matches_number == '1'?'':'es'}} found previously</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div id="results-section" class="cm-results-rows">
|
<div id="results-section" class="cm-results-rows">
|
||||||
|
@ -55,8 +55,16 @@
|
||||||
<li *ngFor="let result of resultsArray;" class="uk-card uk-card-default uk-card-small uk-card-body uk-open">
|
<li *ngFor="let result of resultsArray;" class="uk-card uk-card-default uk-card-small uk-card-body uk-open">
|
||||||
<h3 class="uk-accordion-title"><span class="uk-text-meta">document:</span> {{result.docTitle}}</h3>
|
<h3 class="uk-accordion-title"><span class="uk-text-meta">document:</span> {{result.docTitle}}</h3>
|
||||||
<div class="uk-accordion-content" aria-hidden="false">
|
<div class="uk-accordion-content" aria-hidden="false">
|
||||||
|
</div>
|
||||||
|
<div class="uk-accordion-content" aria-hidden="false">
|
||||||
<div *ngFor="let match of result.matches">
|
<div *ngFor="let match of result.matches">
|
||||||
<div class="match"><span class="uk-text-meta">match #{{match.matchcounter}}:</span> {{match.match}}</div>
|
<div class="match"><span class="uk-text-meta">match #{{match.matchcounter}}:</span> {{match.match}}</div>
|
||||||
|
<p class="cm-document-result" style="color:brown">
|
||||||
|
<b>All possible occurences in original text:</b> </p>
|
||||||
|
<p [innerHTML]="match.occurences" ></p>
|
||||||
|
<p class="cm-document-result" style="color:green">
|
||||||
|
<b>High confidence match after applying the mining rules: </b></p>
|
||||||
|
|
||||||
<p class="cm-document-result">
|
<p class="cm-document-result">
|
||||||
{{match.extraprev}} <span class="textwindow" [innerHTML]="match.context"></span> {{match.extranext}}
|
{{match.extraprev}} <span class="textwindow" [innerHTML]="match.context"></span> {{match.extranext}}
|
||||||
</p>
|
</p>
|
||||||
|
|
|
@ -98,13 +98,13 @@ export class ResultspreviewComponent implements OnInit {
|
||||||
}
|
}
|
||||||
|
|
||||||
highlightInElement(element: string, text: string): string {
|
highlightInElement(element: string, text: string): string {
|
||||||
let elementHtml = element;
|
var elementHtml = element;
|
||||||
const tags = [];
|
var tags = [];
|
||||||
const tagLocations = [];
|
var tagLocations = [];
|
||||||
const htmlTagRegEx = /<{1}\/{0,1}\w+>{1}/;
|
var htmlTagRegEx = /<{1}\/{0,1}\w+>{1}/;
|
||||||
|
|
||||||
// Strip the tags from the elementHtml and keep track of them
|
// Strip the tags from the elementHtml and keep track of them
|
||||||
let htmlTag;
|
var htmlTag;
|
||||||
while (htmlTag = elementHtml.match(htmlTagRegEx)) {
|
while (htmlTag = elementHtml.match(htmlTagRegEx)) {
|
||||||
tagLocations[tagLocations.length] = elementHtml.search(htmlTagRegEx);
|
tagLocations[tagLocations.length] = elementHtml.search(htmlTagRegEx);
|
||||||
tags[tags.length] = htmlTag;
|
tags[tags.length] = htmlTag;
|
||||||
|
@ -112,7 +112,7 @@ export class ResultspreviewComponent implements OnInit {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Search for the text in the stripped html
|
// Search for the text in the stripped html
|
||||||
const textLocation = elementHtml.search(text);
|
var textLocation = elementHtml.search(text);
|
||||||
if (textLocation) {
|
if (textLocation) {
|
||||||
// Add the highlight
|
// Add the highlight
|
||||||
const highlightHTMLStart = '<span class="highlight">';
|
const highlightHTMLStart = '<span class="highlight">';
|
||||||
|
@ -120,9 +120,9 @@ export class ResultspreviewComponent implements OnInit {
|
||||||
elementHtml = elementHtml.replace(text, highlightHTMLStart + text + highlightHTMLEnd);
|
elementHtml = elementHtml.replace(text, highlightHTMLStart + text + highlightHTMLEnd);
|
||||||
|
|
||||||
// Plug back in the HTML tags
|
// Plug back in the HTML tags
|
||||||
const textEndLocation = textLocation + text.length;
|
var textEndLocation = textLocation + text.length;
|
||||||
for (let i = tagLocations.length - 1; i >= 0; i--) {
|
for (let i = tagLocations.length - 1; i >= 0; i--) {
|
||||||
let location = tagLocations[i];
|
var location = tagLocations[i];
|
||||||
if (location > textEndLocation) {
|
if (location > textEndLocation) {
|
||||||
location += highlightHTMLStart.length + highlightHTMLEnd.length;
|
location += highlightHTMLStart.length + highlightHTMLEnd.length;
|
||||||
} else if (location > textLocation) {
|
} else if (location > textLocation) {
|
||||||
|
@ -168,6 +168,9 @@ export class ResultspreviewComponent implements OnInit {
|
||||||
match.match = values.match;
|
match.match = values.match;
|
||||||
match.extraprev = values.extraprev;
|
match.extraprev = values.extraprev;
|
||||||
match.extranext = values.extranext;
|
match.extranext = values.extranext;
|
||||||
|
match.occurences = values.occurences;
|
||||||
|
|
||||||
|
|
||||||
let context = values.prev + ' ' + values.middle + ' ' + values.next;
|
let context = values.prev + ' ' + values.middle + ' ' + values.next;
|
||||||
// hightlight positive words
|
// hightlight positive words
|
||||||
for (const posword in JSON.parse(localStorage.getItem('poswords'))) {
|
for (const posword in JSON.parse(localStorage.getItem('poswords'))) {
|
||||||
|
@ -188,6 +191,7 @@ export class ResultspreviewComponent implements OnInit {
|
||||||
return '<span class="negative">' + x + '</span>';
|
return '<span class="negative">' + x + '</span>';
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
context = this.highlightInElement(context, values.match);
|
context = this.highlightInElement(context, values.match);
|
||||||
match.context = context;
|
match.context = context;
|
||||||
match.matchcounter = ++matchcounter;
|
match.matchcounter = ++matchcounter;
|
||||||
|
|
Loading…
Reference in New Issue