USiteSearch 0.641.0
See the version list below for details.
dotnet add package USiteSearch --version 0.641.0
NuGet\Install-Package USiteSearch -Version 0.641.0
<PackageReference Include="USiteSearch" Version="0.641.0" />
paket add USiteSearch --version 0.641.0
#r "nuget: USiteSearch, 0.641.0"
// Install USiteSearch as a Cake Addin #addin nuget:?package=USiteSearch&version=0.641.0 // Install USiteSearch as a Cake Tool #tool nuget:?package=USiteSearch&version=0.641.0
Warning
This repo is coming soon. There is no functional code as yet. Peace.
Why Create USiteSearch?
I build websites using the Umbraco content management system, and one feature that is often necessary is a site search. While you can use Examine for this purpose, my sites often require a Google-like search rather than a search specific to the site's content. Additionally, I need a user-friendly interface for the search and syntax highlighting to make the results more readable.
In the past, I have copied and pasted my site search code between projects, but this has not been efficient and has resulted in bugs and other issues. To improve the quality of my code and make it easier to use, I have decided to add tests and turn it into a system that can be easily installed in just 15 minutes. This system is called USiteSearch.
Earlier 0.65-alphas of USiteSearch can be seen in action on the Energy Council and Mysterious Universe (20,000 blog posts), which have a total of 20,000 blog posts.
If you need help on this system or find bugs I respond to queries fairly quickly at petras @ yart dot com dot au
Installation
Let's get USiteSearch working in a sample Umbraco website so you can see exactly how it works. Installing on the sample site will teach you how to install it in your own site. Set up should take no longer than 15 minutes.
Note: This help can also be viewed as a YouTube tutorial if you prefer seeing a video. The video should solve most installation problems.
Installation steps
Clone this basic Umbraco 10 website. The website comes with an embedded database so it should run without further modifications. The back office login for the website is:
Username: admin@admin.com
Password: admin12345Alternatively clone the same website in Umbraco 11 if you are using Umbraco 11.
Check the website runs and you can log in to the backoffice.Install the nuget package USiteSearch via the NuGet package manager:
dotnet add package USiteSearch --version 0.651.0-alpha or update-package USiteSearch -0.651-alpha (if replacing an older version)
Install https://github.com/petrassurna/usitesearch/raw/main/nuget/USiteSearchProjectFiles-0.65-alpha.zip
This installs some css, images, javascript and a partial view
Run the project to view the sample website. Open startup.cs and uncomment these four using statements:
using Umbraco.Cms.Core.Notifications; using UmbracoExtensions; //uncomment the below using LuceneSearch; using Searchable; using Umbraco.Cms.Core.Notifications; using USiteSearch.Notifications;
and also the two lines in ConfigureServices:
public void ConfigureServices(IServiceCollection services) { services.AddUmbraco(_env, _config) .AddBackOffice() .AddWebsite() .AddComposers() //.AddUSiteSearch() .AddNotificationHandler<UmbracoApplicationStartingNotification, Bundling>() .Build(); //uncomment the below services.AddSingleton(typeof(ISearchProvider), new LuceneProvider("app_data/USiteSearch", 10)); }
Note this line:
services.AddSingleton(typeof(ISearchProvider), new LuceneProvider("app_data/USiteSearch", 10));
This configures the USiteSearch to a LuceneProvider search provider
app_data/USiteSearch - is the relative path where Lucene will store data.
10 - When displaying search results, the number of words to display each side of a word match.
Next we need to enable the css and javascript used by USiteSearch. Uncomment these lines in views/master.cshtml:
<link rel="stylesheet" href="usitesearch-css-bundle" /> <script src="usitesearch-js-bundle"></script>
This references:
~/USiteSearch/css/usitesearch.min.css and
~/USiteSearch/scripts/usitesearch.jswhich are included by bundling in Bundling.cs. Read more about Umbraco Bundling
Uncomment these lines in Views/master.cshtml so the html for USiteSearch is engaged:
@* <section id="dns-search-bar" class="dns-search-bar" usitesearch-exclude="true" zzz> <div id="dns-search-fields" class="dns-search-fields"> <input id="dns-search-input" type="text" placeholder="search"> <img id="dns-search-loader" src="/usitesearch/images/spinner.gif" width="50" height="50"> <a href="#" id="dns-search-close" title="Close"><img src="/usitesearch/images/icon-close.svg"></a> </div> <div id="dns-search-results" class="dns-search-results"> </div> </section> <div id="dns-search-overlay"></div> *@
Next we need to index the site, to do this, log into the backoffice and save and publish each of the pages.
This will create the lucene index under the app_data folder as specified in startup.cs:This folder can be deleted to reset the search.
In order to engage the search, we need to give a front end element the attribute id="site-search"
This has been done for you in master.cshtml<li> <a href="#" id="site-search" title="Search the site">Site search</a> </li>
Click on the element and you should see the search bar, enter the term animals. After typing a few characters you should see these results:
Refine the search, search for animals lions. Note the results reduce and each search term is highlighted with 10 words either side of the word match. This is the variable we set earlier in startup.cs.
Search for the term play close and notice it matches all pages:
This is because this text is in the margin. In order to remove this text from the search, add this tag to html elements you want excluded from the site search:
Typically you would exclude the navigation, footer and common margins. You will need to resave each page to reindex these pages.
If you want to remove whole pages from the site search, add the property blockFromSearch to document types:
This is already present in the sample project and when you check it on, pages will be removed from the search.
Learn more about Target Frameworks and .NET Standard.
-
- Newtonsoft.Json (>= 9.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated | |
---|---|---|---|
0.6675.0 | 235 | 10/16/2023 | |
0.6674.0 | 171 | 7/29/2023 | |
0.6673.0 | 148 | 7/29/2023 | |
0.6672.0 | 152 | 7/28/2023 | |
0.667.0 | 177 | 7/28/2023 | |
0.666.0 | 184 | 7/28/2023 | |
0.665.0 | 178 | 7/28/2023 | |
0.664.0 | 177 | 7/28/2023 | |
0.662.0 | 229 | 6/17/2023 | |
0.652.0 | 348 | 1/12/2023 | |
0.651.0 | 303 | 1/11/2023 | |
0.650.0 | 313 | 1/10/2023 | |
0.650.0-alpha | 153 | 1/10/2023 | |
0.641.0 | 305 | 12/21/2022 | |
0.66.1 | 157 | 6/17/2023 | |
0.66.0 | 168 | 6/17/2023 | |
0.66.0-alpha | 124 | 1/10/2023 | |
0.65.0-alpha | 141 | 1/10/2023 |
Pre release - for testing only