金蝶云星空字段之间连续触发值更新

 

场景说明
字段A配置了字段B的计算公式,字段B配置了自动C的计算公式,修改A的时候,触发了B的重算,但是C触发不到。


具体需求:
配置值更新事件:料本,料本系数, PCBA加工费,整机装配费,税率%【字段A】
公式:供应链含税报价 = ( 料本 * 料本系数 + PCBA加工费 + 整机装配费 ) * ( 1 + 税率% / 100 )


配置值更新:供应链含税报价
含税时,供应链报价 = 供应链含税报价 / ( 1 + 税率% / 100)【字段B】
含税时,销售含税结算价 = 供应链含税报价 + ( 销售含税指导价 - 供应链含税报价 ) * ( 毛利分成比例 / 100 )

 

配置值更新:销售含税结算价 【字段C】
含税时,销售结算价 = 销售含税结算价 / ( 1 + 税率% / 100)

 

 

 

 

 

 

 解决方案:新增表单插件,在DataChange事件,触发B的值更改时,强行触发B的值更新事件

 public override void DataChanged(DataChangedEventArgs e)
{
    base.DataChanged(e);

    switch (e.Field.Key.ToUpperInvariant())
    {
        case "FTAXPRICE"://供应链含税报价
            int entryCurrentRowIndex = this.Model.GetEntryCurrentRowIndex(entityKey);//获取当前父单据体选中行
            this.View.InvokeFieldUpdateService("FTaxPrice", entryCurrentRowIndex);
            break;
        case "FSALETAXSETTLEPRICE"://销售含税结算价
            int ecir2 = this.Model.GetEntryCurrentRowIndex(entityKey);//获取当前父单据体选中行
            this.View.InvokeFieldUpdateService("FSaleTaxsettlePrice", ecir2);//触发销售含税结算价的值更新事件
            break;
    }
}
View Code

 

posted @ 2024-07-02 17:07  lanrenka  阅读(63)  评论(0编辑  收藏  举报