Controllo AutoCompleteList

Il controllo AutoCompleteList permette di cercare e selezionare uno o più valori a partire da una sorgente dati. I valori selezionati devono essere presenti nella sorgente dati. Utile quando la sorgente dati contiene molti elementi che renderebbero il form troppo lungo o lento se visualizzati contemporaneamente.
 
Personalizzazione
Possiamo impostare una sorgente dati personalizzata specificando il valore ControlClass per DataSourceMode e inserendo namespace e nome classe nella proprietà del controllo CustomControlClass.
 
Nel metodo GetListValuesAsync dobbiamo gestire sia la fase di recupero dei suggerimento (parametro Title) sia quella di recupero, validazione e salvataggio dei relativi valori (parametro Text).
 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.Extensions.DependencyInjection;
using DataWeb.Data;
using DataWeb.Data.Controls;
using DataWeb.Identity;
using DataWeb.Structure;
using MyApp.Infrastructure;

namespace MyApp.DataWeb.Data.Controls
{
    public class News_UserIdMasters : AutoCompleteList
    {
        private readonly UserProfileStore userProfileStore;

        public News_UserIdMasters(Form form, IServiceProvider serviceProvider) : base(form, serviceProvider)
        {
            userProfileStore = serviceProvider.GetService<UserProfileStore>();
        }

        public override async Task<IEnumerable<List.ListItem>> GetListValuesAsync(Dictionary<string, object> parameters, IUser user, string itemId = null, NavigationContext navigationContext = null, CancellationToken cancellationToken = default)
        {
            var userProfiles = Enumerable.Empty<UserProfile>();

            if (parameters.ContainsKey("Title"))
            {
                userProfiles = await userProfileStore.GetUserProfilesAsync(new UserProfileStore.Filter { SuggestionText = Convert.ToString(parameters["Title"]), IsPrivateAreaAccess = true });
            }
            else
            {
                // Value filter

                if (!string.IsNullOrEmpty(Convert.ToString(parameters["Value"])))
                {
                    var values = Convert.ToString(parameters["Value"]).Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
                    if (values.Length != 0)
                    {
                        userProfiles = await userProfileStore.GetUserProfilesAsync(new UserProfileStore.Filter { IdMasters = values.ToList(), IsPrivateAreaAccess = true });
                    }
                }
            }

            return userProfiles.Select(x => new List.ListItem { Title = x.UserName, Value = x.IdMaster });
        }

        public override async Task<object> ProcessOnSaveDataAsync(object value, List<Form.ProvidedValue> providedValues, Dictionary<string, object> sectionData, IUser user, string itemId = null, NavigationContext navigationContext = null)
        {
            var listValues = await GetListValuesAsync(new Dictionary<string, object> { ["Value"] = value }, user, itemId, navigationContext);

            // Set additional data
            sectionData["UserDescriptions"] = string.Join(", ", listValues.Select(x => x.Title));

            return value;
        }
    }
}
 
In questo esempio deriviamo anche il metodo ProcessOnSaveDataAsync per salvare nella base dati anche le descrizioni dei valori selezionati.