Acumatica动态MultiSelect下拉列表

时间:2016-05-16 08:42:12

标签: c# erp acumatica

我有一个用于存储交易数据的屏幕条目,我想使用带有多选组合框的动态来选择状态,并且状态数据来自,但有些时候选择了数据状态,存储的数据量不匹配已被选中,

Screen Entry Screenshoot

Database Screenshoot

我尝试过以下代码,但它对我没用。

 public class StatusMultiStringListAttribute : PXStringListAttribute
{
    public StatusMultiStringListAttribute() : base()
    {
        PXResultset<StatusTable> rslt = PXSelect<StatusTable>.Select(new PXGraph());
        List<string> values = new List<string>();
        List<string> labels = new List<string>();
        foreach (PXResult<StatusTable> item in rslt)
        {
            BSMTStatus e = (StatusTable)item;
            values.Add(e.StatusID);
            labels.Add(e.Description);
        }

        this._AllowedValues = values.ToArray();
        this._AllowedLabels = labels.ToArray();
        MultiSelect = true;
    }
}

有没有其他解决方案,抱歉我的英语不好,谢谢。

1 个答案:

答案 0 :(得分:2)

我注意到您对http://asiablog.acumatica.com/2016/03/multiselect-combo-box.html的评论,并看到您发布了一些额外的代码。根据您的示例代码,我发现了两个问题:

首先,您从StatusTable DAC加载的值包含未剪裁的尾随空格。您尚未提供StatusTable DAC的声明,但可以安全地从屏幕截图中假设此字段的IsFixed属性设置为true。使用这些设置,系统将在值的末尾添加空格。为了节省目标字段中的空间,我建议在构造函数代码中添加一个Trim():

foreach (PXResult<StatusTable> item in rslt)
{
    BSMTStatus e = (StatusTable)item;
    values.Add(e.StatusID.Trim()); //Remove any white-space
    labels.Add(e.Description);
}

其次,您存储所选值的状态字段不够长,无法容纳多个选择。它目前定义为20个字符([PXDBString(20, IsFixed=true)]),即使假设您删除了空格,您仍然只能选择4个选项。我建议您将其更改为255,并删除IsFixed=true,因为此字段不需要它:

[PXDBString(255)]
[PXDefault]
[PXUIField(DisplayName = "Status")]
[StatusStringList]
public virtual string Status