acumatica - PXDBScalar SOOrderKvExt 属性 bool
问题描述
我正在尝试使用 PXDBScalar 将布尔属性从销售订单用户定义字段选项卡引入到发货屏幕。
我发现另一个堆栈溢出帖子有助于创建 SOOrderKvExt DAC,并且我能够通过我的 PXDBScalar 属性检索 valueNumeric(十进制)字段的值,但是我找不到将值转换为布尔值的方法,所以它在屏幕上正确显示为复选框。我尝试将未绑定字段的数据类型设置为 bool,但出现数据类型转换错误。我还尝试将字段保留为小数并仅更改屏幕上的控件类型,但无论值如何,它始终显示为已选中。知道如何将十进制值转换为 PXDBScalar 属性或其他解决方案中的布尔值吗?
下面提供的代码片段。
SOOrderKvExt
[PXCacheName("SO Order Attributes")]
[Serializable]
public class SOOrderKvExt : IBqlTable
{
public abstract class recordID : BqlGuid.Field<recordID> { }
[PXDBGuid(IsKey = true)]
public Guid? RecordID { get; set; }
public abstract class fieldName : BqlString.Field<fieldName> { }
[PXDBString(50,IsKey = true)]
[PXUIField(DisplayName ="Name")]
public string FieldName { get; set; }
public abstract class valueNumeric : BqlDecimal.Field<valueNumeric> { }
[PXDBDecimal(8)]
[PXUIField(DisplayName = "Value Numeric")]
public decimal? ValueNumeric { get; set; }
public abstract class valueDate : BqlDateTime.Field<valueDate> { }
[PXDBDate]
[PXUIField(DisplayName = "Value Date")]
public DateTime? ValueDate { get; set; }
public abstract class valueString : BqlString.Field<valueString> { }
[PXDBString(256)]
[PXUIField(DisplayName = "Value String")]
public string ValueString { get; set; }
public abstract class valueText : BqlString.Field<valueText> { }
[PXDBString]
[PXUIField(DisplayName = "Value Text")]
public string ValueText { get; set; }
}
}
PXDB标量
#region UsrSOBlindShip
[PXDecimal(8)]
[PXUIField(DisplayName="SO Blind Ship", IsReadOnly=true)]
[PXDBScalar(typeof(Search2<SOOrderKvExt.valueNumeric,
LeftJoin<SOOrder, On<SOOrder.noteID, Equal<SOOrderKvExt.recordID>>,
LeftJoin<SOShipLine, On<SOShipLine.origOrderNbr, Equal<SOOrder.orderNbr>>>>,
Where<SOShipLine.shipmentNbr, Equal<SOShipment.shipmentNbr>>>))]
public virtual decimal? UsrSOBlindShip{ get; set; }
public abstract class usrSOBlindShip: PX.Data.BQL.BqlDecimal.Field<usrSOBlindShip> { }
#endregion
谢谢斯科特
解决方案
我会添加一个布尔计算字段。与此类似:
public class SOLineExt : PXCacheExtension<PX.Objects.SO.SOLine>
{
#region UsrIsZero
[PXBool]
[PXUIField(DisplayName="Is Zero")]
[PXFormula(typeof(Switch< Case<Where<SOLine.orderQty, Greater<decimal0>>, False>, True >))]
public virtual bool? UsrIsZero { get; set; }
public abstract class usrIsZero : PX.Data.BQL.BqlBool.Field<usrIsZero> { }
#endregion
}
推荐阅读
- firebase - 如何修复 RenderPointerListener 对象在布局期间被赋予无限大小?
- html - 固定位置导航栏覆盖标题
- java - 我的 MainActivity 在使用 android 旧版本(例如 oreo)时滞后,但在最新版本中运行良好,如何解决?
- javascript - 遍历从 ajax / json 接收到的数据
- python - 在 fastai/pytorch 中获取学习者的预测
- android - Kotlin 协程:androidx.lifecycle.MutableLiveData 对象上的 NullPointerException
- firebase - 导航器推送替换错误
- arrays - 从类 String 的函数返回一个指针
- c# - 如何检测键盘上最后按下的箭头键
- python - NoneType' 对象没有属性 'find_all' 错误来了