LoreSoft.Blazor.Controls 10.1.1

dotnet add package LoreSoft.Blazor.Controls --version 10.1.1                
NuGet\Install-Package LoreSoft.Blazor.Controls -Version 10.1.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="LoreSoft.Blazor.Controls" Version="10.1.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add LoreSoft.Blazor.Controls --version 10.1.1                
#r "nuget: LoreSoft.Blazor.Controls, 10.1.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install LoreSoft.Blazor.Controls as a Cake Addin
#addin nuget:?package=LoreSoft.Blazor.Controls&version=10.1.1

// Install LoreSoft.Blazor.Controls as a Cake Tool
#tool nuget:?package=LoreSoft.Blazor.Controls&version=10.1.1                

Overview

The LoreSoft Blazor Controls project contains a collection of Blazor user controls.

Installing

The LoreSoft.Blazor.Controls library is available on nuget.org via package name LoreSoft.Blazor.Controls.

To install LoreSoft.Blazor.Controls, run the following command in the Package Manager Console

Install-Package LoreSoft.Blazor.Controls

Setup

To use, you need to include the following CSS and JS files in your index.html (Blazor WebAssembly) or _Host.cshtml (Blazor Server).

In the head tag add the following CSS.

<link rel="stylesheet" href="_content/LoreSoft.Blazor.Controls/BlazorControls.css" />

Typeahead Features

  • Searching data by supplying a search function
  • Template for search result, selected value, and footer
  • Debounce support for smoother search
  • Character limit before searching
  • Multiselect support
  • Built in form validation support

Typeahead Properties

Required

  • Value - Bind to Value in single selection mode. Mutually exclusive to Values property.
  • Values - Bind to Values in multiple selection mode. Mutually exclusive to Value property.
  • SearchMethod - The method used to return search result

Optional

  • AllowClear - Allow the selected value to be cleared
  • ConvertMethod - The method used to convert search result type to the value type
  • Debounce - Time to wait, in milliseconds, after last key press before starting a search
  • Items - The initial list of items to show when there isn't any search text
  • MinimumLength - Minimum number of characters before starting a search
  • Placeholder - The placeholder text to show when nothing is selected

Templates

  • ResultTemplate - User defined template for displaying a result in the results list
  • SelectedTemplate - User defined template for displaying the selected item(s)
  • NoRecordsTemplate - Template for when no items are found
  • FooterTemplate - Template displayed at the end of the results list
  • LoadingTemplate - Template displayed while searching

Typeahead Examples

Basic Example

State selection dropdown. Bind to Value property for single selection mode.

<Typeahead SearchMethod="@SearchState"
           Items="Data.StateList"
           @bind-Value="@SelectedState"
           Placeholder="State">
    <SelectedTemplate Context="state">
        @state.Name
    </SelectedTemplate>
    <ResultTemplate Context="state">
        @state.Name
    </ResultTemplate>
</Typeahead>
@code {
    public StateLocation SelectedState { get; set; }

    public Task<IEnumerable<StateLocation>> SearchState(string searchText)
    {
        var result = Data.StateList
            .Where(x => x.Name.ToLower().Contains(searchText.ToLower()))
            .ToList();

        return Task.FromResult<IEnumerable<StateLocation>>(result);
    }
}

Multiselect Example

When you want to be able to select multiple results. Bind to the Values property. The target property must be type IList<T>.

<Typeahead SearchMethod="@SearchPeople"
           Items="Data.PersonList"
           @bind-Values="@SelectedPeople"
           Placeholder="Owners">
    <SelectedTemplate Context="person">
        @person.FullName
    </SelectedTemplate>
    <ResultTemplate Context="person">
        @person.FullName
    </ResultTemplate>
</Typeahead>
@code {
    public IList<Person> SelectedPeople;

    public Task<IEnumerable<Person>> SearchPeople(string searchText)
    {
        var result = Data.PersonList
            .Where(x => x.FullName.ToLower().Contains(searchText.ToLower()))
            .ToList();

        return Task.FromResult<IEnumerable<Person>>(result);
    }
 }

Use Octokit to search for a GitHub repository.

<Typeahead SearchMethod="@SearchGithub"
           @bind-Value="@SelectedRepository"
           Placeholder="Repository"
           MinimumLength="3">
    <SelectedTemplate Context="repo">
        @repo.FullName
    </SelectedTemplate>
    <ResultTemplate Context="repo">
        <div class="github-repository clearfix">
            <div class="github-avatar"><img src="@repo.Owner.AvatarUrl"></div>
            <div class="github-meta">
                <div class="github-title">@repo.FullName</div>
                <div class="github-description">@repo.Description</div>
                <div class="github-statistics">
                    <div class="github-forks"><i class="fa fa-flash"></i> @repo.ForksCount Forks</div>
                    <div class="github-stargazers"><i class="fa fa-star"></i> @repo.StargazersCount Stars</div>
                    <div class="github-watchers"><i class="fa fa-eye"></i> @repo.SubscribersCount Watchers</div>
                </div>
            </div>
        </div>
    </ResultTemplate>
</Typeahead>
@inject IGitHubClient GitHubClient;

@code {
    public Repository SelectedRepository { get; set; }

    public async Task<IEnumerable<Repository>> SearchGithub(string searchText)
    {
        var request = new SearchRepositoriesRequest(searchText);
        var result = await GitHubClient.Search.SearchRepo(request);

        return result.Items;
    }
}
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
10.1.1 628 11/18/2024
10.1.0 92 11/18/2024
10.0.0 150 11/13/2024
9.9.0 291 10/27/2024
9.8.8 1,363 8/28/2024
9.8.7 162 8/20/2024
9.8.6 304 8/19/2024
9.8.5 126 8/19/2024
9.8.4 124 8/18/2024
9.8.3 123 8/18/2024
9.8.2 131 8/18/2024
9.8.1 136 8/16/2024
9.8.0 121 8/16/2024
9.7.9 117 8/15/2024
9.7.8 169 8/14/2024
9.7.7 141 8/13/2024
9.7.6 81 8/2/2024
9.7.5 87 8/1/2024
9.7.4 156 7/30/2024
9.7.3 816 6/10/2024
9.7.2 152 6/1/2024
9.7.1 113 6/1/2024
9.7.0 117 5/31/2024
9.6.1 125 5/25/2024
9.6.0 122 5/25/2024
9.5.0 303 4/26/2024
9.4.1 1,661 4/12/2024
9.4.0 125 4/12/2024
9.3.0 119 4/12/2024
9.2.0 695 3/2/2024
9.1.0 576 1/14/2024
9.0.2 1,070 12/4/2023
9.0.1 162 12/4/2023
9.0.0 128 12/4/2023
8.0.0 6,090 12/28/2022
7.0.0 10,372 11/10/2021
6.7.0 4,003 10/23/2021
6.6.3 339 10/21/2021
6.6.2 1,460 7/28/2021
6.6.1 1,056 5/15/2021
6.6.0 422 5/15/2021
6.5.0.156 987 4/9/2021
6.2.0.139 1,188 3/24/2021
6.1.0.137 415 3/24/2021
6.0.0.128 538 3/14/2021
5.0.0.116 500 2/25/2021
4.1.0.114 6,996 2/15/2021
4.0.0.84 9,348 11/16/2020
3.5.0.27 10,448 6/4/2020
3.0.0.61 5,659 1/24/2020
3.0.0.52 867 1/2/2020
3.0.0.51 526 1/2/2020
3.0.0.49 505 1/2/2020
2.1.0.40 629 12/20/2019
2.1.0.39 708 12/18/2019
2.1.0.38 3,371 12/5/2019
2.1.0.29 1,180 10/3/2019
2.0.0.28 538 9/23/2019
2.0.0.27 324 9/19/2019
2.0.0.21 313 9/17/2019
2.0.0.20 317 9/6/2019
2.0.0.14 342 8/23/2019
2.0.0.13 319 8/19/2019
2.0.0.9 327 8/16/2019
1.0.0.8 330 8/14/2019
1.0.0.6 324 8/7/2019
1.0.0.5 323 8/7/2019
1.0.0.4 348 8/6/2019