From 2fef02484695efa77963de2cbff3a9b4a16c22da Mon Sep 17 00:00:00 2001 From: Olli Mannevaara Date: Mon, 11 Mar 2024 13:51:35 +0200 Subject: [PATCH] Adjust highlight generation to include more of the original data --- .../publications2/publications2.component.ts | 1 - .../portal/services/publication2.service.ts | 23 ++++++++----------- 2 files changed, 9 insertions(+), 15 deletions(-) diff --git a/src/app/portal/components/results/publications2/publications2.component.ts b/src/app/portal/components/results/publications2/publications2.component.ts index 5c4c30774..409964423 100644 --- a/src/app/portal/components/results/publications2/publications2.component.ts +++ b/src/app/portal/components/results/publications2/publications2.component.ts @@ -423,7 +423,6 @@ export class Publications2Component implements OnDestroy { selfArchivedCodeNames$ = this.publications2Service.getSelfArchivedCodeNames(); selfArchivedCodeFilters$ = combineLatest([this.additionsFromSelfArchivedCode$, this.selfArchivedCodeNames$, this.searchParams$.pipe(map(params => params.selfArchivedCode ?? []))]).pipe( - tap((values) => console.log(values)), map(([additionsFromSelfArchivedCode, selfArchivedCodeNames, enabledFilters]) => additionsFromSelfArchivedCode.map(additionFromSelfArchivedCode => ({ id: additionFromSelfArchivedCode.id, count: additionFromSelfArchivedCode.count, diff --git a/src/app/portal/services/publication2.service.ts b/src/app/portal/services/publication2.service.ts index 2c36f64e3..f9b721026 100644 --- a/src/app/portal/services/publication2.service.ts +++ b/src/app/portal/services/publication2.service.ts @@ -28,7 +28,6 @@ export type HighlightedPublication = { id: string; publicationName: SafeHtml; authorsText: SafeHtml; - authorsTextSplitted: SafeHtml; publisherName: SafeHtml; publicationYear: SafeHtml; @@ -128,15 +127,14 @@ export class Publication2Service { const size = parseInt(searchParams.size?.[0] ?? "10"); const from = (page - 1) * size; - // searchParams = searchParams as SearchParams; // TODO no effect? + // Settings for highlighting in ElasticSearch + const largeHighlight = { fragment_size: 200, number_of_fragments: 15 }; return this.http.post(this.searchUrl, { from: from, size: size, track_total_hits: true, sort: [ - // "_score", - // { "publicationYear": { "order": "desc" } } ...sortingTerms(searchParams) ], query: { @@ -155,10 +153,9 @@ export class Publication2Service { }, highlight: { fields: { - publicationName: {}, - authorsText: {}, - authorsTextSplitted: {}, - publisherName: {} + publicationName: { ...largeHighlight }, + authorsText: { ...largeHighlight, type: "plain" }, + publisherName: { ...largeHighlight } }, pre_tags: [""], post_tags: [""] @@ -199,17 +196,15 @@ export class Publication2Service { badges.openAccess = source.doiHandle; badges.peerReviewed = source.peerReviewed[0].id === "1"; - const publicationName = highlight?.publicationName?.[0] ?? source.publicationName ?? ''; - const authorsText = highlight?.authorsText?.[0] ?? source.authorsText ?? ''; - const authorsTextSplitted = highlight?.authorsText?.[0] ?? source.authorsText ?? ''; - const publisherName = highlight?.publisherName?.[0] ?? source.publisherName ?? ''; - const publicationYear = highlight?.publicationYear?.[0] ?? source.publicationYear ?? ''; + const publicationName = highlight?.publicationName?.join() ?? source.publicationName ?? ''; + const authorsText = highlight?.authorsText?.join() ?? source.authorsText ?? ''; + const publisherName = highlight?.publisherName?.join() ?? source.publisherName ?? ''; + const publicationYear = highlight?.publicationYear?.join() ?? source.publicationYear ?? ''; return { id: searchData._id, publicationName: this.sanitizer.sanitize(SecurityContext.HTML, publicationName), authorsText: this.sanitizer.sanitize(SecurityContext.HTML, authorsText), - authorsTextSplitted: this.sanitizer.sanitize(SecurityContext.HTML, authorsTextSplitted), publisherName: this.sanitizer.sanitize(SecurityContext.HTML, publisherName), publicationYear: this.sanitizer.sanitize(SecurityContext.HTML, publicationYear),