From b7ac5407386f4ce4e612c891fc97bf2333089bdf Mon Sep 17 00:00:00 2001 From: Hendy Racher Date: Sun, 7 Apr 2019 16:58:08 +0100 Subject: [PATCH] now indexes additional field for flag to indicate if the match has any tag in a given group --- src/Our.Umbraco.Look/LookConstants.cs | 5 +++++ .../Services/LookService_IndexTags.cs | 12 ++++++++++++ 2 files changed, 17 insertions(+) diff --git a/src/Our.Umbraco.Look/LookConstants.cs b/src/Our.Umbraco.Look/LookConstants.cs index a5febe3..003a8b8 100644 --- a/src/Our.Umbraco.Look/LookConstants.cs +++ b/src/Our.Umbraco.Look/LookConstants.cs @@ -82,6 +82,11 @@ internal static class LookConstants /// internal static string AllTagsField => "Look_AllTags"; + /// + /// Prefix to fields for the tag group flag + /// + internal static string TagGroupField => "Look_TagGroup_"; + /// /// Gets the field name to use for the tags - this field will contain space delimited non-tokenizable strings /// diff --git a/src/Our.Umbraco.Look/Services/LookService_IndexTags.cs b/src/Our.Umbraco.Look/Services/LookService_IndexTags.cs index f4290dd..ea26759 100644 --- a/src/Our.Umbraco.Look/Services/LookService_IndexTags.cs +++ b/src/Our.Umbraco.Look/Services/LookService_IndexTags.cs @@ -1,5 +1,6 @@ using Lucene.Net.Documents; using System; +using System.Linq; using Umbraco.Core.Logging; namespace Our.Umbraco.Look.Services @@ -51,6 +52,17 @@ private static void IndexTags(IndexingContext indexingContext, Document document document.Add(allTagsField); document.Add(tagField); } + + var tagGroups = tags.Select(x => x.Group).Distinct(); + + foreach (var tagGroup in tagGroups) + { + var tagGroupField = new Field( + LookConstants.TagGroupField + tagGroup, + "1", + Field.Store.NO, + Field.Index.NOT_ANALYZED); + } } } }