From 5351d7a62188025caa003a8cb214cdf71c58e872 Mon Sep 17 00:00:00 2001 From: BusterIT Date: Mon, 9 May 2022 19:27:08 +0200 Subject: [PATCH 1/2] Optional parameter added to prevent clearing the search text after value has been selected or input focus lost --- .../BlazoredTypeahead.razor.cs | 21 +++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/src/Blazored.Typeahead/BlazoredTypeahead.razor.cs b/src/Blazored.Typeahead/BlazoredTypeahead.razor.cs index 623aaf6..0d6f5f8 100644 --- a/src/Blazored.Typeahead/BlazoredTypeahead.razor.cs +++ b/src/Blazored.Typeahead/BlazoredTypeahead.razor.cs @@ -18,6 +18,7 @@ public partial class BlazoredTypeahead : ComponentBase, IDisposab private Timer _debounceTimer; private string _searchText = string.Empty; private bool _eventsHookedUp = false; + private bool _initialized = false; private ElementReference _searchInput; private ElementReference _mask; @@ -52,6 +53,7 @@ public partial class BlazoredTypeahead : ComponentBase, IDisposab [Parameter] public bool EnableDropDown { get; set; } = false; [Parameter] public bool ShowDropDownOnFocus { get; set; } = false; [Parameter] public bool DisableClear { get; set; } = false; + [Parameter] public bool DisableClearSearchText { get; set; } = false; [Parameter] public bool StopPropagation { get; set; } = false; [Parameter] public bool PreventDefault { get; set; } = false; @@ -121,6 +123,7 @@ protected override void OnInitialized() _fieldIdentifier = IsMultiselect ? FieldIdentifier.Create(ValuesExpression) : FieldIdentifier.Create(ValueExpression); Initialize(); + _initialized = true; } protected override async Task OnAfterRenderAsync(bool firstRender) @@ -134,7 +137,10 @@ protected override async Task OnAfterRenderAsync(bool firstRender) private void Initialize() { - SearchText = ""; + if (!DisableClearSearchText || !_initialized || IsMultiselect) + { + SearchText = ""; + } IsShowingSuggestions = false; IsShowingMask = Value != null; } @@ -173,9 +179,12 @@ private async Task HandleClear() private async Task HandleClickOnMask() { - SearchText = ""; - IsShowingMask = false; + if (!DisableClearSearchText) + { + SearchText = ""; + } + IsShowingMask = false; await Task.Delay(250); // Possible race condition here. await Interop.Focus(JSRuntime, _searchInput); await HookOutsideClick(); @@ -240,7 +249,7 @@ private async Task HandleKeydown(KeyboardEventArgs args) { await ResetControl(); } - + } private async Task HandleKeyup(KeyboardEventArgs args) @@ -403,7 +412,7 @@ private async Task HookOutsideClick() private async Task SelectResult(TItem item) { var value = ConvertMethod(item); - + if (IsMultiselect) { var valueList = Values ?? new List(); @@ -417,7 +426,7 @@ private async Task SelectResult(TItem item) } else { - if (Value != null && Value.Equals(value)) return; + if (Value != null && Value.Equals(value) && !DisableClearSearchText) return; Value = value; await ValueChanged.InvokeAsync(value); } From cfe24cbb252c0da3b2a7ce637d3206ba1af0ea39 Mon Sep 17 00:00:00 2001 From: BusterIT Date: Sat, 28 May 2022 18:42:50 +0200 Subject: [PATCH 2/2] SelectResult from private to public task to set value from code behind. Just change the @bind-Value does not update the component behaviour that the assigned value is displayed correctly in UI. --- src/Blazored.Typeahead/BlazoredTypeahead.razor.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Blazored.Typeahead/BlazoredTypeahead.razor.cs b/src/Blazored.Typeahead/BlazoredTypeahead.razor.cs index 0d6f5f8..9032889 100644 --- a/src/Blazored.Typeahead/BlazoredTypeahead.razor.cs +++ b/src/Blazored.Typeahead/BlazoredTypeahead.razor.cs @@ -409,7 +409,7 @@ private async Task HookOutsideClick() await JSRuntime.OnOutsideClick(_searchInput, this, "ResetControlBlur", true); } - private async Task SelectResult(TItem item) + public async Task SelectResult(TItem item) { var value = ConvertMethod(item);