Merge remote-tracking branch 'origin/dev' into dev

This commit is contained in:
owan 2025-06-12 16:16:54 +08:00
commit 5e462e8b94
9 changed files with 429 additions and 21 deletions

View File

@ -2,6 +2,8 @@ package zcgj.zcdev.zcdev.fs.plugin.form;
import com.alibaba.druid.util.StringUtils;
import kd.bos.bill.AbstractBillPlugIn;
import kd.bos.bill.BillShowParameter;
import kd.bos.bill.OperationStatus;
import kd.bos.context.RequestContext;
import kd.bos.dataentity.entity.DynamicObject;
import kd.bos.dataentity.entity.DynamicObjectCollection;
@ -27,20 +29,24 @@ public class TriprAutoCalWorkingDaysPlugin extends AbstractBillPlugIn implements
@Override
public void afterBindData(EventObject e) {
super.afterBindData(e);
//当前切换选择的组织
Object company = this.getModel().getValue("costcompany");//核算组织(费用承担公司)
Long currentOrgId = RequestContext.get().getOrgId();
if(company!=null){
DynamicObject companyObj = (DynamicObject)company;
Long companyId = companyObj.getLong("id");
if(OrgCheckUtils.isKS(companyId)){
Set<LocalDate> allSet = new HashSet<>();
Set<LocalDate> localDates1 = calHomeentityDay();
Set<LocalDate> localDates2 = calTripentryDay();
allSet.addAll(localDates1);
allSet.addAll(localDates2);
this.getModel().setValue("zcgj_kccbdays",allSet.size());
//如果是新增时
BillShowParameter bsp=(BillShowParameter)this.getView().getFormShowParameter();
if(bsp.getStatus()== OperationStatus.ADDNEW ){
//当前切换选择的组织
Object company = this.getModel().getValue("costcompany");//核算组织(费用承担公司)
Long currentOrgId = RequestContext.get().getOrgId();
if(company!=null){
DynamicObject companyObj = (DynamicObject)company;
Long companyId = companyObj.getLong("id");
if(OrgCheckUtils.isKS(companyId)){
Set<LocalDate> allSet = new HashSet<>();
Set<LocalDate> localDates1 = calHomeentityDay();
Set<LocalDate> localDates2 = calTripentryDay();
allSet.addAll(localDates1);
allSet.addAll(localDates2);
this.getModel().setValue("zcgj_kccbdays",allSet.size());
}
}
}
}

View File

@ -23,7 +23,7 @@ import java.util.*;
import java.util.stream.Collectors;
/**
* 职务消费休假台账
* 职务消费台账
* 报表取数插件
*/
public class PositionFeesRptQueryPlugin extends AbstractReportListDataPlugin {
@ -118,13 +118,21 @@ public class PositionFeesRptQueryPlugin extends AbstractReportListDataPlugin {
//通过查询用户过滤组织下的人
allUsersOfOrg = allUsersOfOrg.stream().filter(applierId::contains).collect(Collectors.toList());
}
//从配置表中获取需要纳入统计的人员
DynamicObject[] positionfeesstaffing = BusinessDataServiceHelper.load("zcgj_positionfeesstaffing", "zcgj_user",
new QFilter[]{new QFilter("zcgj_is_involvement",QCP.equals,true)});
Set<Long> positionfeesstaffingList = null;
if(positionfeesstaffing!=null && positionfeesstaffing.length>0){
positionfeesstaffingList = Arrays.stream(positionfeesstaffing).map(e -> (Long) e.getDynamicObject("zcgj_user").getLong("id"))
.collect(Collectors.toSet());
}
LocalDate localDate = dateToLocalDate(queryYear);
int year = localDate.getYear();
Set<Long> userSet = new HashSet<>();
// Map 来按照报销人单据编号费用发生日期分组
Map<String, ExpenseReport> reportMap = new LinkedHashMap<>();
for (Long userId : allUsersOfOrg) {
//费用报销单数据
//费用报销单数据-费用归属领导数据
DynamicObject[] dailyreimbursebillDataSet = getDailyreimbursebillDataSet(userId, year);
for (DynamicObject dynamicObject : dailyreimbursebillDataSet) {
String billno = dynamicObject.getString("billno");//单据编号
@ -133,6 +141,10 @@ public class PositionFeesRptQueryPlugin extends AbstractReportListDataPlugin {
DynamicObjectCollection entrys = dynamicObject.getDynamicObjectCollection("expenseentryentity");
for (DynamicObject entry : entrys) {
DynamicObject zcgjCostmangerEntity = entry.getDynamicObject("zcgj_costmanger_entity");
if(zcgjCostmangerEntity == null){
continue;
}
DynamicObject expenseitemObj = entry.getDynamicObject("expenseitem"); //费用项目
if(expenseitemObj == null){
continue;
@ -207,6 +219,95 @@ public class PositionFeesRptQueryPlugin extends AbstractReportListDataPlugin {
}
}
}
//申请人查询
if(positionfeesstaffingList != null && positionfeesstaffingList.contains(userId)){
DynamicObject[] dailyreimbursebillDataSetByApplier = getDailyreimbursebillDataSetByApplier(userId, year);
for (DynamicObject dynamicObject : dailyreimbursebillDataSetByApplier) {
String billno = dynamicObject.getString("billno");//单据编号
//判罚是否因公出国
Boolean isBusinessForeign = dynamicObject.getBoolean(DEV_KEY+"_is_business_foreign");//单据编号
DynamicObjectCollection entrys = dynamicObject.getDynamicObjectCollection("expenseentryentity");
for (DynamicObject entry : entrys) {
DynamicObject zcgjCostmangerEntity = entry.getDynamicObject("zcgj_costmanger_entity");
if(zcgjCostmangerEntity != null){ //过滤掉费用归属领导的
continue;
}
DynamicObject expenseitemObj = entry.getDynamicObject("expenseitem"); //费用项目
if(expenseitemObj == null){
continue;
}
Date happendate = entry.getDate("happendate");//费用发生日期
String itemNumber = expenseitemObj.getString("number");//费用项目编码
if(!itemSet.contains(itemNumber)){
continue;
}
String happendateStr = dateFormat.format(happendate);//费用发生日期str
BigDecimal expenseamount = BigDecimal.ZERO;
if(istax){
expenseamount = entry.getBigDecimal("expenseamount");//报销金额
}else{
expenseamount = entry.getBigDecimal("orientryamount");//不含税金额
}
// 生成唯一的键报销人 + 单据编号 + 费用发生日期
String key = userId + "-" + billno + "-" + happendateStr;
userSet.add(userId);
// 根据键获取报表对象
ExpenseReport report = reportMap.get(key);
if (report == null) {
report = new ExpenseReport(userId, billno, happendateStr);
reportMap.put(key, report);
}
if(!isBusinessForeign){
// 为该行添加费用
//report.addExpense(expenseType, amount);
if(itemNumber.startsWith(FYF)){//防疫费
BigDecimal health = report.getHealth().add(expenseamount);
report.setHealth(health);
}else if(itemNumber.startsWith(TXF)){//日常费用-通信费用
BigDecimal correspondence = report.getCorrespondence().add(expenseamount);
report.setCorrespondence(correspondence);
}else if(itemNumber.startsWith(PXF)){//日常费用-培训费用
BigDecimal training = report.getTraining().add(expenseamount);
report.setTraining(training);
}else if(itemNumber.startsWith(YWZD_SWZD)){//日常费用-业务招待费-商务招待
//businessEntertainment
BigDecimal businessEntertainment = report.getBusinessEntertainment().add(expenseamount);
report.setBusinessEntertainment(businessEntertainment);
}else if(itemNumber.startsWith(YWZD_WSZD)){//日常费用-业务招待费-外事招待
//foreignEntertainment
BigDecimal foreignEntertainment = report.getForeignEntertainment().add(expenseamount);
report.setForeignEntertainment(foreignEntertainment);
}
else if(itemNumber.startsWith(YWZD_ZYGW)){//日常费用-业务招待费-重要公务
//importantOfficial
BigDecimal importantOfficial = report.getImportantOfficial().add(expenseamount);
report.setImportantOfficial(importantOfficial);
}
else if(itemNumber.startsWith(YWZD_ZS)){//日常费用-业务招待费-住宿
//accommodation
BigDecimal accommodation = report.getAccommodation().add(expenseamount);
report.setAccommodation(accommodation);
}
else if(itemNumber.startsWith(YWZD_JNP)){//日常费用-业务招待费-纪念品
//souvenirs
BigDecimal souvenirs = report.getSouvenirs().add(expenseamount);
report.setSouvenirs(souvenirs);
}else if(itemNumber.startsWith(YWZD_QT)){//日常费用-业务招待费-其他
//other
BigDecimal other = report.getOther().add(expenseamount);
report.setOther(other);
}
}else{
//费用明细中的所有金额因公临时出国费用
BigDecimal abroadTravel = report.getAbroadTravel().add(expenseamount);
report.setAbroadTravel(abroadTravel);
}
}
}
}
//差旅报销单数据
DynamicObject[] tripreimburseDataSet = getTripreimburseDataSet(userId, year);
@ -387,7 +488,7 @@ public class PositionFeesRptQueryPlugin extends AbstractReportListDataPlugin {
/**
* 获取费用报销单数据
* 获取费用报销单数据-费用归属领导
* @param userId 用户id
* @param year 统计年份
* @return 数据集
@ -412,7 +513,44 @@ public class PositionFeesRptQueryPlugin extends AbstractReportListDataPlugin {
searchFilterList.add(new QFilter("expenseentryentity.happendate", QCP.less_equals, lastDay));
searchFilterList.add(new QFilter("billstatus", QCP.in, billStatuslist));//增加过滤
DynamicObject[] load = BusinessDataServiceHelper.load("er_dailyreimbursebill",
"id,description,billno,expenseentryentity," +
"id,description,billno,expenseentryentity,zcgj_costmanger_entity," +
DEV_KEY+"_is_business_foreign,"+
"expenseentryentity.happendate," + //费用发生日期
"expenseentryentity.expenseitem," + //费用项目
"expenseentryentity.expenseamount, "+//报销金额(含税)
"expenseentryentity.orientryamount " //不含税金额
, searchFilterList.toArray(new QFilter [] {}));
return load;
}
/**
* 获取费用报销单数据-费用归属领导
* @param userId 用户id
* @param year 统计年份
* @return 数据集
*/
public DynamicObject[] getDailyreimbursebillDataSetByApplier(Long userId, Integer year){
LocalDate firstDay = getFirstDayOfYear(year);
LocalDate lastDay = getLastDayOfYear(year);
List<String> billStatuslist = new ArrayList<>();
//billStatuslist.add("A"); //暂存
//billStatuslist.add("B"); //已提交
//billStatuslist.add("C"); //审核中
//billStatuslist.add("D"); //审核未通过
billStatuslist.add("E"); //审核通过
billStatuslist.add("F"); //等待付款
billStatuslist.add("G"); //已付款
//billStatuslist.add("H"); //废弃
billStatuslist.add("I"); //关闭
List<QFilter> searchFilterList = new ArrayList<>();
searchFilterList.add(new QFilter("applier", QCP.equals, userId));
//searchFilterList.add(new QFilter("expenseentryentity.zcgj_costmanger_entity", QCP.equals, userId));//根据费用归属领导查询
searchFilterList.add(new QFilter("expenseentryentity.happendate", QCP.large_equals, firstDay));
searchFilterList.add(new QFilter("expenseentryentity.happendate", QCP.less_equals, lastDay));
searchFilterList.add(new QFilter("billstatus", QCP.in, billStatuslist));//增加过滤
DynamicObject[] load = BusinessDataServiceHelper.load("er_dailyreimbursebill",
"id,description,billno,expenseentryentity,zcgj_costmanger_entity," +
DEV_KEY+"_is_business_foreign,"+
"expenseentryentity.happendate," + //费用发生日期
"expenseentryentity.expenseitem," + //费用项目

View File

@ -9,7 +9,7 @@ import kd.bos.entity.validate.AbstractValidator;
import kd.bos.orm.query.QFilter;
import kd.bos.servicehelper.BusinessDataServiceHelper;
//工序成本预算单提交操作插件验证项目和年份的组合是否已经存在
//工序成本预算单保存提交操作插件验证项目和年份的组合是否已经存在且只有一个
public class AimcostcbsBllSubmitOp extends AbstractOperationServicePlugIn {
@Override
@ -37,6 +37,9 @@ public class AimcostcbsBllSubmitOp extends AbstractOperationServicePlugIn {
filter.and(new QFilter("project", "=", project.getPkValue()));
DynamicObject ecco_aimcostbillcbs = BusinessDataServiceHelper.loadSingle("ecco_aimcostbillcbs", "id", new QFilter[]{filter});
if (ecco_aimcostbillcbs != null) {
if (dataEntity.getPkValue().equals(ecco_aimcostbillcbs.getPkValue())){
continue;
}
this.addFatalErrorMessage(extendedDataEntity, "该年份的项目已编制预算,请勿重复创建!");
}
}

View File

@ -0,0 +1,61 @@
package zcgj.zcdev.zcdev.pr.plugin.form;
import kd.bos.dataentity.entity.DynamicObject;
import kd.bos.form.FormShowParameter;
import kd.bos.form.plugin.AbstractFormPlugin;
import kd.bos.logging.Log;
import kd.bos.logging.LogFactory;
import kd.bos.orm.query.QFilter;
import kd.bos.servicehelper.BusinessDataServiceHelper;
import java.util.EventObject;
import java.util.Map;
/**
* 表单插件公共方法<br>
* 1.获取菜单参数配置的单据类型编码菜单参数:<br>
* key=billType,value=单据类型编码 <br>
* key=filedMark,value=单据类型字段标识 <br>
* 2.将单据类型编码转换为编辑界面单据类型字段的值
*/
public class CommonFormPlugin extends AbstractFormPlugin {
private final static Log logger = LogFactory.getLog(CommonFormPlugin.class);
/**
* 初始化时从获取参数类型设置单据类型值
* @param e
*/
@Override
public void afterCreateNewData(EventObject e) {
FormShowParameter formShowParameter = this.getView().getFormShowParameter();
if(null!=formShowParameter){
Map<String, Object> customParams = formShowParameter.getCustomParams();
if(null!=customParams){
//获取列表界面配置的参数billType=单据类型编码
Object billType = customParams.get("billType");
//获取列表界面配置的参数filedMark=单据类型字段标识
Object filedMark = customParams.get("filedMark");
if(null!=billType&&null!=filedMark){
DynamicObject billTypeObj = (DynamicObject)this.getModel().getValue(filedMark.toString());
if(null==billTypeObj){
//单据类型为空赋值
QFilter q1 = new QFilter("number", "=", billType.toString());
DynamicObject billTypeObject = BusinessDataServiceHelper.loadSingle("bos_billtype", new QFilter[]{q1});
this.getModel().setValue(filedMark.toString(), billTypeObject);
}else if(!billTypeObj.getString("number").equals(billType.toString())){
//单据类型和列表菜单参数一致不再赋值
QFilter q1 = new QFilter("number", "=", billType.toString());
DynamicObject billTypeObject = BusinessDataServiceHelper.loadSingle("bos_billtype", new QFilter[]{q1});
this.getModel().setValue(filedMark.toString(), billTypeObject);
}
}
}
}
super.afterCreateNewData(e);
}
}

View File

@ -0,0 +1,32 @@
package zcgj.zcdev.zcdev.pr.plugin.form;
import kd.bos.form.FormShowParameter;
import kd.bos.list.events.BeforeShowBillFormEvent;
import kd.bos.list.plugin.AbstractListPlugin;
import java.util.Map;
public class CommonListPlugin extends AbstractListPlugin {
@Override
public void beforeShowBill(BeforeShowBillFormEvent e) {
FormShowParameter formShowParameter = this.getView().getFormShowParameter();
if(null!=formShowParameter){
Map<String, Object> customParams =formShowParameter.getCustomParams();
if(null!=customParams){
Object billtype = customParams.get("billType");
Object filedMark = customParams.get("filedMark");
if(null!=billtype&&null!=filedMark){
customParams.putAll(e.getParameter().getCustomParams());
customParams.put("billtype",billtype.toString());
customParams.put("filedMark",filedMark.toString());
customParams.put("formId","zcgj_zckstopublicbill");
e.getParameter().setCustomParams(customParams);
}
}
}
super.beforeShowBill(e);
}
}

View File

@ -0,0 +1,96 @@
package zcgj.zcdev.zcdev.pr.plugin.form;
import com.greenpineyu.fel.common.NumberUtil;
import kd.bos.dataentity.entity.DynamicObject;
import kd.bos.entity.datamodel.ListSelectedRow;
import kd.bos.entity.datamodel.ListSelectedRowCollection;
import kd.bos.form.control.events.BeforeItemClickEvent;
import kd.bos.form.control.events.ItemClickEvent;
import kd.bos.form.events.BeforeDoOperationEventArgs;
import kd.bos.form.operate.FormOperate;
import kd.bos.list.plugin.AbstractListPlugin;
import kd.bos.orm.query.QCP;
import kd.bos.orm.query.QFilter;
import kd.bos.servicehelper.BusinessDataServiceHelper;
import kd.bos.servicehelper.operation.SaveServiceHelper;
import kd.sdk.plugin.Plugin;
import org.jetbrains.annotations.NotNull;
import java.util.EventObject;
import java.util.HashSet;
import java.util.Set;
public class EquipmentCardListPlugin extends AbstractListPlugin implements Plugin {
@Override
public void registerListener(EventObject e) {
super.registerListener(e);
this.addItemClickListeners("tbmain");//监听按钮
}
@Override
public void itemClick(ItemClickEvent evt) {
super.itemClick(evt);
String itemKey = evt.getItemKey();
if (itemKey.equals("zcgj_idle")){
Set<Long> setIds = getSelectOrderIds(this.getSelectedRows());
DynamicObject[] equipments = BusinessDataServiceHelper.load("eceq_equipment_card", "billno,billname,equipstatus", new QFilter[]{new QFilter("id", "in", setIds)});
for (DynamicObject equipment : equipments) {
equipment.set("equipstatus","FREE");
}
Object[] save = SaveServiceHelper.save(equipments);
System.out.println();
this.getView().showMessage("闲置成功!");
}
}
@Override
public void beforeDoOperation(BeforeDoOperationEventArgs args) {
super.beforeDoOperation(args);
// FormOperate operate = (FormOperate) args.getSource();
// String operateNo = operate.getOperateKey();
// if(operateNo.equalsIgnoreCase("zcgj_idle")){
// ListSelectedRowCollection listSelectedData = args.getListSelectedData();
// for (ListSelectedRow listSelectedDatum : listSelectedData) {
// String billNo = listSelectedDatum.getBillNo();
// QFilter qf = new QFilter("billno", QCP.equals,billNo);
// DynamicObject equipment = BusinessDataServiceHelper.loadSingle("eceq_equipment_card", new QFilter[]{qf});
// String equipstatus = equipment.getString("equipstatus");
// if (!equipstatus.equals("USED")){
// this.getView().showErrorNotification("只有在用状态下的设备才可置为闲置");
// args.setCancel(true);
// return;
// }
// }
//
// }
}
@Override
public void beforeItemClick(BeforeItemClickEvent evt) {
super.beforeItemClick(evt);
String itemKey = evt.getItemKey();
if(itemKey.equals("zcgj_idle")){
Set<Long> setIds = getSelectOrderIds(this.getSelectedRows());
DynamicObject[] equipments = BusinessDataServiceHelper.load("eceq_equipment_card", "billno,billname,equipstatus", new QFilter[]{new QFilter("id", "in", setIds)});
for (DynamicObject equipment : equipments) {
String equipstatus = equipment.getString("equipstatus");
if (!equipstatus.equals("USED")){
this.getView().showErrorNotification("只有在用状态下的设备才可置为闲置");
evt.setCancel(true);
return;
}
}
}
}
@NotNull
private Set<Long> getSelectOrderIds(@NotNull ListSelectedRowCollection selectedRows) {
Set<Long> setIds = new HashSet<>();
for (ListSelectedRow selectedRow : selectedRows) {
setIds.add(NumberUtil.toLong(selectedRow.getPrimaryKeyValue()));
}
return setIds;
}
}

View File

@ -40,11 +40,40 @@ import java.util.*;
import java.util.stream.Collectors;
/**
* 入库单发票导入插件
* 入库单发票导入插件+事物类型默认为空+是否主材隐显
*/
public class MaterialInbFinaceConfirmeInvoicePlugin extends AbstractBillPlugIn implements Plugin {
private static final Log log = LogFactory.getLog(MaterialInbFinaceConfirmeInvoicePlugin.class);
@Override
public void afterCreateNewData(EventObject e) {
super.afterCreateNewData(e);
this.getModel().setValue("transtype", null);//事务类型默认为空
}
@Override
public void propertyChanged(PropertyChangedArgs e) {
super.propertyChanged(e);
String key = e.getProperty().getName();
if (key.equals("transtype")) {
//事务类型
ChangeData[] changeSet = e.getChangeSet();
ChangeData changeData = changeSet[0];
DynamicObject transtype = (DynamicObject) changeData.getNewValue();//新值
if (transtype != null) {
String number = transtype.getString("number");
if (number.equals("jrjc")) {
//事务类型为即入即出时隐藏是否主材
this.getView().setVisible(false, "ismainmaterial");//是否主材
} else {
this.getView().setVisible(true, "ismainmaterial");//是否主材
}
} else {
this.getView().setVisible(true, "ismainmaterial");//是否主材
}
}
}
@Override
public void beforeDoOperation(BeforeDoOperationEventArgs args) {
super.beforeDoOperation(args);

View File

@ -163,6 +163,24 @@ public class PaymentApplySupplierPlugin extends AbstractBillPlugIn implements Pl
// for (int i = 0; i < itementry.size(); i++) {
// this.getModel().setValue("zcgj_supplier1", supplier, i);
// }
}else if (propName.equals("zcgj_maintenance")) {
//关联设备维修
Object value = this.getModel().getValue("zcgj_maintenance");
if (value!=null){
DynamicObject maintenance = (DynamicObject) value;
QFilter qf = new QFilter("id", QCP.equals, maintenance.getLong("id"));
DynamicObject maintenancebill = BusinessDataServiceHelper.loadSingle("zcgj_maintenanceackbill", new QFilter[]{qf});
this.getModel().setValue("totalshouldpay",maintenancebill.getBigDecimal("zcgj_toactualamount"));
this.getModel().setValue("project",maintenancebill.getDynamicObject("zcgj_project"));
this.getModel().setValue("fiaccountorg",maintenancebill.getDynamicObject("zcgj_accountorg"));
DynamicObjectCollection maintenanceentry = maintenancebill.getDynamicObjectCollection("entryentity");
for (int i = 0; i < maintenanceentry.size(); i++) {
DynamicObject object = maintenanceentry.get(i);
i = this.getModel().createNewEntryRow("itementry");
this.getModel().setValue("zcgj_supplier1", object.getDynamicObject("zcgj_supplier"), i);
this.getModel().setValue("zcgj_requestedamount", object.getBigDecimal("zcgj_actualamount"), i);
}
}
}
}

View File

@ -2,6 +2,7 @@ package zcgj.zcdev.zcdev.pr.plugin.form;
import kd.bos.bill.AbstractBillPlugIn;
import kd.bos.dataentity.entity.DynamicObject;
import kd.bos.dataentity.entity.DynamicObjectCollection;
import kd.bos.form.field.BasedataEdit;
import kd.bos.form.field.events.BeforeF7SelectEvent;
import kd.bos.form.field.events.BeforeF7SelectListener;
@ -36,8 +37,32 @@ public class RecAndPayInitPlugin extends AbstractBillPlugIn implements Plugin, B
if(name.equals("zcgj_in_contract") || name.equals("zcgj_out_contract")){
DynamicObject project = (DynamicObject)this.getModel().getValue("zcgj_project");
List<QFilter> qFilterList = new ArrayList<QFilter>();
qFilterList.add(new QFilter("project", QCP.equals,project.getLong("id")));
arg0.setCustomQFilters(qFilterList);
if(project == null){
this.getView().showErrorNotification("请选择项目!");
arg0.setCancel(true);
}else{
qFilterList.add(new QFilter("project", QCP.equals,project.getLong("id")));
String entryKey = "zcgj_payable";
String contractKey = "zcgj_out_contract";
if(name.equals("zcgj_in_contract")){
entryKey="zcgj_receivable";
contractKey="zcgj_in_contract";
}
DynamicObjectCollection dynamicObjectCollection = this.getModel().getDataEntity(true).getDynamicObjectCollection(entryKey);
if(dynamicObjectCollection != null){
List<Long> ids = new ArrayList<>();
for (DynamicObject dynamicObject : dynamicObjectCollection) {
DynamicObject contract = dynamicObject.getDynamicObject(contractKey);
if(contract != null){
long inContractId = contract.getLong("id");
ids.add(inContractId);
}
}
qFilterList.add(new QFilter("id", QCP.not_in,ids));
}
arg0.setCustomQFilters(qFilterList);
}
}
}
}