要向Acumatica的InvoiceSplits选择器中添加新列,需要进行以下步骤:
创建一个新的自定义字段: 在Acumatica的客户定制化界面中,找到InvoiceSplits的画面,点击“自定义字段”选项卡。 点击“新增字段”按钮,在弹出的对话框中输入字段的名称、数据类型和长度,并点击“确定”按钮。
修改选择器的查询命令: 找到InvoiceSplits选择器对应的图标方法,一般以“_Selector”结尾,比如“InvoiceNbr_SplitsSelector”。 在图标方法中,找到选择器的查询命令(一般以“CommandSelect”结尾),比如“InvoiceNbr_SplitsSelector_CommandSelect”。 在查询命令中添加新的字段,并将其关联到InvoiceSplits表。
以下是一个示例代码,演示如何添加一个名为“CustomField”的自定义列:
public PXAction InvoiceNbr_SplitsSelector;
[PXUIField(DisplayName = "Invoice Splits")]
[PXButton(ImageKey = PX.Web.UI.Sprite.Main.DataEntryF)]
protected virtual IEnumerable invoiceNbr_SplitsSelector(PXAdapter adapter)
{
ARInvoice doc = Base.Document.Current;
if (doc != null)
{
var graph = PXGraph.CreateInstance();
graph.Document.Current = doc;
var splitsView = graph.Transactions.Cache
.Extension()
.Splits.View;
PXView view = new PXView(graph, true, splitsView.BqlSelect);
var startRow = PXView.StartRow;
int totalRows = 0;
var list = view.Select(
PXView.Currents,
PXView.Parameters,
PXView.Searches,
PXView.SortColumns,
PXView.Descendings,
PXView.Filters,
ref startRow,
PXView.MaximumRows,
ref totalRows);
PXView.StartRow = 0;
PXSelectorAttribute.SelectorMode = PXSelectorMode.DisplayMode;
Dictionary columns = PXFieldState.GetFieldState(graph.Transactions.Cache, null)
.Where(state => state.Visibility == PXUIVisibility.Visible && state.Visible)
.ToDictionary(state => state.Name, state => state.DisplayName);
columns.Add("CustomField", "Custom Field"); // 添加一个名为“CustomField”的列
PXView.StartRow = 0;
var result = new List
请根据实际业务需求修改代码,确保字段名称、数据类型和长度与自定义字段的定义相匹配。