35 lines
1.6 KiB
C#
35 lines
1.6 KiB
C#
using System.Threading.Tasks;
|
|
using AyaNova.Biz;
|
|
namespace AyaNova.Models
|
|
{
|
|
//Used to drive processes that rely on selections made at client from a datalist
|
|
//either a preselected list of id's or a datalist key and listview filter object that can
|
|
//be used to rehydrate a list of id's
|
|
public class DataListSelectedProcessingOptions : DataListProcessingBase
|
|
{
|
|
public AyaType ObjectType { get; set; }
|
|
public long[] SelectedRowIds { get; set; }
|
|
// public string DataListKey { get; set; }
|
|
// public string ListView { get; set; }//optional, if null or empty will use default list view built into DataList
|
|
// public string MetaView { get; set; }//optional meta list view to integrate into the standard list view. Used by client to add "meta" filter conditions above the user's choices e.g. customer notes customer id
|
|
|
|
|
|
public bool IsEmpty
|
|
{
|
|
get
|
|
{
|
|
return SelectedRowIds.LongLength == 0 && string.IsNullOrWhiteSpace(DataListKey);
|
|
}
|
|
}
|
|
|
|
TODO: recode this to fulfil requirements of datalistfetcher in the same way as
|
|
//DataListTableProcessingOptions constructor
|
|
//clean out datalistfetcher comments and similar afterwards
|
|
public async Task RehydrateIdList(AyContext ct, AuthorizationRoles userRoles, Microsoft.Extensions.Logging.ILogger log, long userId)
|
|
{
|
|
if (SelectedRowIds.Length == 0)
|
|
SelectedRowIds = await AyaNova.DataList.DataListFetcher.GetIdListResponseAsync(ct, this, userRoles, log, userId);
|
|
}
|
|
}
|
|
}
|