1

客户希望使用通用搜索框来搜索自定义字段中的值。如何才能做到这一点?

在本例中,我为 InventoryItem 创建了一个简单的自定义文本字段。目前,它在 UI 中不可见。

4

1 回答 1

2

让我们参考在此示例中创建的自定义 UsrAlternateIDs 字段,并将其包含到 Acumatica 的全文实体索引中。

将 UsrAlternateIDs 字段包含到全文实体索引中所需的唯一修改是替换InventoryItem DAC中NoteID字段上使用的PXSearchableAttribute的原始声明。如下面的代码片段所示,UsrAlternateIDs现在包含在作为第三个参数传递给新PXSearchableAttribute构造函数的字段类型数组中:

[PXNonInstantiatedExtension]
public class InventoryItemExt : PXCacheExtension<PX.Objects.IN.InventoryItem>
{
    [PXMergeAttributes(Method = MergeMethod.Append)]
    [PXRemoveBaseAttribute(typeof(PXSearchableAttribute))]
    [PXSearchable(SM.SearchCategory.IN, "{0}: {1}", 
        new Type[] {
            typeof(InventoryItem.itemType),
            typeof(InventoryItem.inventoryCD) },
        new Type[] {
            typeof(InventoryItem.descr),
            typeof(InventoryItemExt.usrAlternateIDs) },
        NumberFields = new Type[] {
            typeof(InventoryItem.inventoryCD),
            typeof(InventoryItemExt.usrAlternateIDs) },
        Line1Format = "{0}{1}{2}", 
        Line1Fields = new Type[] {
            typeof(INItemClass.itemClassCD),
            typeof(INItemClass.descr),
            typeof(InventoryItem.baseUnit) },
        Line2Format = "{0}", 
        Line2Fields = new Type[] {
            typeof(InventoryItem.descr) },
        WhereConstraint = typeof(Where<Current<InventoryItem.itemStatus>, 
            NotEqual<InventoryItemStatus.unknown>>)
     )]
     public Guid? NoteID { get; set; }
}

在按照上述示例实施InventoryItem扩展并在 Acumatica ERP 实例上重建全文实体索引后,应该可以根据其备用 ID 搜索库存项目。

于 2018-02-13T05:55:01.647 回答